بسم الله الرحمن الرحيم

Latar Belakang Masalah

Saya membuat sebuah Ruby script untuk shell wraper dalam memudahkan proses copy paste asset modifikasi dari user direktori ke root direktori.

Misal, saya memiliki sebuah asset meta_01.svg yang berada di home user
$HOME/theme/keymon/oblivion/meta_01.svg

Ingin saya copy ke direktori asset dari keymon yang berada di
/usr/lib/python3.8/site-packages/keymon/themes/oblivion/meta.svg

Jika menggunakan command cp akan seperti ini kira-kira.

$ sudo cp -vf $HOME/theme/keymon/oblivion/meta_01.svg \
              /usr/lib/python3.8/site-packages/keymon/themes/oblivion/meta.svg

Karena path yang dituju sangat dalam, maka timbul rasa malas apabila pekerjaan modifikasi ini dialkukan berulang kali untuk tujuan pengujian.

Maka dari itu, saya berinisiatif untuk membuatkan Ruby installation script agar dapat menangani masalah ini dengan memberikan instruksi secara interaktif.

Selain itu juga karena saya mengharapkan apabila saya menambahkan direktori theme lain, dan juga style yang lain, saya tidak perlu mengubah-ubah script untk memberikan option atau pilihan lagi. Karena pilihan-pilihan theme dan style sudah ditangani oleh script.

Mantaaaaaap memang!

Pemecahan Masalah

Secara sederhana, algoritma dari script ini adalah:

  1. Membuat list semua direktori theme yang ada
  2. Menampilkan semua direktori theme sebagai pilihan (option)
  3. User: Memilih theme yang tersedia
    Nama theme diambil dari nama direktori dari masing-masing theme.
  4. Masuk ke dalam direktori theme
  5. Membuat list semua style yang ada di dalam direktori theme
  6. Menampilkan semua style sebagai pilihan (option)
  7. User: Memilih style yang ada di dalam theme
  8. User: Konfirmasi untuk melakukan proses instalasi
  9. Melakukan proses $ sudo cp


Selanjutnya, saya membuat sebuah file install.rb.

Kemudian mulai menulis prosedur dari algoritma di atas dengan bahasa Ruby.

Saya akan menjelaskan perbagian kecil, agar teman-teman yang teratarik dengan bahasa Ruby dapat lebih mudah memahami.

  1. Mendefinisikan lokasi dari keymon installation direktori.
    Setiap sistem kemungkinan akan berbeda berdasarkan distro yang digunakan dan versi Python yang digunakan.
    Pada langkah ini, mau tidak mau saya harus meminta akses administrator dengan sudo.
    python_lib_path = `sudo python -c "import sys; print(sys.path[4])"`
    keymon_dir = python_lib_path.strip << '/keymon/themes'
    puts "\nYour Key-Mon installation directory is on:
    #{keymon_dir.sub('/themes', '')}"
    
  2. Membuat daftar semua theme yang ada di dalam project.
    list_theme = `ls -1d */`.gsub("\/", '').split("\n")
    
  3. Mengecualikan direktori tertentu dari daftar direktori theme.
    Dalam kasus ini, direktori sample.
    ['sample'].each do |exclude|
      list_theme.delete(exclude)
    end
    
  4. Menampilkan option (pilihan) berupa daftar theme yang ada.
    puts 'Select your Key-mon theme!'
    list_theme.each_with_index do |theme, index|
      puts " (#{index + 1}) #{theme.capitalize}"
    end
    

    Output:

     Select your Key-mon theme!
     (1) Oblivion
    
  5. Meminta inputan ke user dari pertanyaan di atas.
    puts "\nEnter theme number:"
    print '=> '
    selected_theme = gets.chomp
    

    Output:

    Enter theme number:
    => _
    
  6. Mendefinisikan nama theme berdasarkan jawaban yang diberikan user.
    Dari jawaban berupa string angka ke theme name dari list_theme.
    selected_theme_name = list_theme[selected_theme.to_i - 1]
    
  7. Berpindah direktori ke dalam direktori theme yang dipilih user.
    Dir.chdir(selected_theme_name)
    puts "\nYou are in #{selected_theme_name.capitalize} directory"
    

    Output:

    You are in ... directory
    
  8. Membuat kondisi, apabila direktori terdapat style, maka masukkan ke dalam variable list_style array.
    Apabila di dalam direktori kosong, maka exit program.
    unless `ls -p | grep -v /`.empty?
      list_style = `ls -p | grep -v /`.split("\n")
    else
      puts "\nThere are no style in this directory"
      exit
    end
    
  9. Menampilkan option (pilihan) berupa style-style yang terdapat di dalam direktori theme.
    puts "\nSelect you modification style:"
    list_style.each_with_index do |style, index|
      puts " (#{index + 1}) #{style}"
    end
    

    Output:

    Select you modification style:
      (1) meta_01.svg
      (2) meta_02.svg
      (3) meta_03.svg
      (4) meta_04.svg
    
  10. Meminta inputan berupa nomor style ke user.
    puts "\nEnter style number"
    print '=> '
    selected_style = gets.chomp
    

    Output:

    Enter style number
    => _
    
  11. Mendefinisikan nama style berdasarkan jawaban yang diberikan user.
    Dari jawaban berupa string angka ke nama style.
    selected_style_name = list_style[selected_style.to_i - 1]
    
  12. Menampilkan pilihan style yang dipilih user.
    puts "\nYou choose: #{selected_style_name}"
    

    Output:

    You choose: ...
    
  13. Menanyakan persetujuan kepada user, apakah ingin melakukan instalasi atau tidak.
    puts "\nAre you sure want to change the style? [y/n]"
    print '=> '
    agreement = gets.chomp
    

    Output:

    Are you sure want to change the style? [y/n]
    => _
    
  14. Mengolah jawaban user.
    if %w[y Y].include? agreement
      puts "\nLet's party!"
      puts
      system "sudo cp -vf #{selected_style_name} \
                      #{keymon_dir}/#{selected_theme_name}/meta.svg"
      puts "\nInstallation COMPLETED!"
    elsif %w[n N].include? agreement
      puts "\nAh, Maybe later"
    else
      puts "\nYou are not enter the correct answer"
    end
    

    Output:
    Apabila y

    Let's party!
    [sudo] password for user:
    'meta_01.svg' -> '/usr/lib/python3.8/site-packages/keymon/themes/oblivion/meta.svg'
    Installation COMPLETED!

    Apabila n

    Ah, Maybe later
    

    Selain y & n

    You are not enter the correct answer
    
  15. Selesai

Full Script

FILEinstall.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/usr/bin/env ruby

# This is a Ruby wraper script for change the Meta/Super key logo of your
# Key-mon. You can choose your Meta modification style with this installation
# script install.rb.
# source  : https://github.com/bandithijo/key-mon-meta-mod
# author  : bandithijo@gmail.com
# created : 2020/09/27

# Please take a look a installation path of your keymon.
# It probably difference with my own system.
python_lib_path = `sudo python -c "import sys; print(sys.path[4])"`
keymon_dir = python_lib_path.strip << '/keymon/themes'

puts "\nYour Key-Mon installation directory is on:
#{keymon_dir.sub('/themes', '')}"

list_theme = `ls -1d */`.gsub("\/", '').split("\n")

['sample'].each do |exclude|
  list_theme.delete(exclude)
end

puts 'Select your Key-mon theme!'
list_theme.each_with_index do |theme, index|
  puts " (#{index + 1}) #{theme.capitalize}"
end
puts "\nEnter theme number:"
print '=> '
selected_theme = gets.chomp
selected_theme_name = list_theme[selected_theme.to_i - 1]

Dir.chdir(selected_theme_name)
puts "\nYou are in #{selected_theme_name.capitalize} directory"

unless `ls -p | grep -v /`.empty?
  list_style = `ls -p | grep -v /`.split("\n")
else
  puts "\nThere are no style in this directory"
  exit
end

puts "\nSelect you modification style:"
list_style.each_with_index do |style, index|
  puts " (#{index + 1}) #{style}"
end

puts "\nEnter style number"
print '=> '
selected_style = gets.chomp
selected_style_name = list_style[selected_style.to_i - 1]

puts "\nYou choose: #{selected_style_name}"

puts "\nAre you sure want to change the style? [y/n]"
print '=> '
agreement = gets.chomp
if %w[y Y].include? agreement
  puts "\nLet's party!"
  puts
  system "sudo cp -vf #{selected_style_name} \
                      #{keymon_dir}/#{selected_theme_name}/meta.svg"
  puts "\nInstallation COMPLETED!"
elsif %w[n N].include? agreement
  puts "\nAh, Maybe later"
else
  puts "\nYou are not enter the correct answer"
end

Pesan Penulis

Untuk versi lebih update dapat dilihat pada repositori di sini

Sepertinya, segini dulu yang dapat saya tuliskan.

Mudah-mudahan dapat bermanfaat.

Terima kasih.

(^_^)


Penulis

bandithijo

My journey kicks off from reading textbooks as a former Medical Student to digging bugs as a Software Engineer – a delightful rollercoaster of career twists. Embracing failure with the grace of a Cat avoiding water, I've seamlessly transitioned from Stethoscope to Keyboard. Armed with ability for learning and adapting faster than a Heart Beat, I'm on a mission to turn Code into a Product.

- Rizqi Nur Assyaufi

4a4543305bf2acc6bc4e781491fc8b01888c5de8