Latar Belakang Masalah
Sejak 2019 saya memulai memprogram menggunakan bahasa Ruby, baru sekarang saya merasa perlu untuk menerapkan code formater. Tujuannya agar code yang kita tulis minim dari kesalahan akibat dari kesalahan penulisan stuktur dari sintaks sekaligus untuk menyeragamkan format code yang ditulis oleh tim member yang lain yang juga menggunakan code formater.
Code formater biasanya dalam text editor akan di-bundle bersama code analyzer yang biasa disebut dengan linter. Pengalaman saya berinteraksi dengan linter adalah saat belajar menggunakan bahasa Python dengan vim plugin python-mode. Saat itu, saya mendapat pengalaman dan kesan yang sangat bagus. Karena saya dipaksa untuk menulis sintaks kode berdasarkan format yang sudah disepakati. Kalau tidak, maka akan terdapat beberapa warning yang menandakan bahwa baris kode yang kita tulis tidak mengikuti kaidah atau format yang sesuai.
Dalam bahasa Python, saya mengenal beberapa linter diantaranya: pylint, pylama, pycodestyle, pyflake, flake8, pep8, dll. Dalam bahasa Ruby, saya mengenal beberapa linter diantaranya: Rubocop –mungkin masih banyak lagi, namun hanya satu itu saja yang sering saya dengar.
Maka, pada kesempatan kali ini, saya merasa sudah waktunya untuk menulis kode Ruby menggunakan code formater agar format penulisan kode lebih rapi. Code formater yang akan saya pergunakan adalah Rubocop.
Apa itu Rubocop?
Secara sederhana, Rubocop adalah static code analyzer (linter) dan juga code formater untuk bahasa pemrograman Ruby. Apabila kita menggunakan Rubocop, secara otomatis, Rubocop akan memaksa kita untuk menulis sintaks Ruby dengan mengikuti kaidah-kaidah penulisan Ruby code yang ada di dalam Ruby Style Guide.
Instalasi
Tanpa berlama-lama, saya akan langsung saya to the point pada hal-hal teknik yang perlu dilakukan.
Pasang Rubocop Gem
Sebelum memasang Rubocop pada Vim, kita perlu memasang Rubocop pada Ruby environment kita. Kenapa saya katakan Ruby environment? Karena biasanya sebagai programmer Ruby, kita sangat direkomendasikan untuk menggunakan Ruby environment seperti RVM atau Rbenv. Saya sendiri menggunakan Rbenv.
Terlebih dahulu saya melakukan pengecekan versi Ruby yang saat ini sedang saya pergunakan. Tujuannya agar saya mengetahui bahwa saya pernah memasang Rubocop pada Ruby versi tertentu.
$ ruby -v
ruby 2.7.1p83 (2020-03-31 revision a0c7c23c9c) [x86_64-linux]
Setelah itu pasang Rubocop gem terbaru.
$ gem install rubocop
Tunggu proses instalasinya hingga selesai.
Apabila telah selesai, artinya kita telah berhasil memasang Rubocop pada versi Ruby 2.7.1. Jika kita memiliki project dengan versi Ruby yang berbeda, kita perlu memasang Rubocop kembali pada versi Ruby tersebut.
ALE
Saya juga menggunakan ALE (Asynchronous Lint Engine) adalah Vim plugin yang menyediakan linting (syntax checking dan semantic errors) untuk NeoVim 0.2.0+ dan Vim 8 saat kita mengedit text dan berperilaku seperti Vim Language Server Protocol client.
ALE mendukung cukup banyak language dan linter. Nantinya, kita akan mengkonfigurasi ALE agar menggunakan Rubocop sebagai linter saat kita mengerjakan file Ruby.
Pasang vim-rubocop & ALE
Saya menggunakan vim-plug sebagai plugin manager.
Untuk memasang Rubocop, kita akan menggunakan bantuan plugin yang bernama ngmy/vim-rubocop.
Dan juga, untuk Asynchronous Lint Engine, kita akan menggunakan ALE
Tambahkan pada .vimrc
.
1
2
3
4
5
" A The Vim RuboCop plugin runs RuboCop and displays the results in Vim
Plug 'ngmy/vim-rubocop'
" A Check syntax in Vim asynchronously and fix files, with Language Server Protocol (LSP) support
Plug 'dense-analysis/ale'
Kemudian refresh dulu vimrc dengan melakukan source ke vimrc agar plugin yang baru saja kita tambahkan dapat dikenali.
:source $MYVIMRC
Lalu instal vim-rubocop yang baru saja kita tambahkan, dengan menggunakan perintah.
:PlugInstall
Tunggu proses instalasinya sampai selesai.
Konfigurasi vim-rubocop
Untuk mengkonfigurasi vim-rubocop, yang paling penting adalah kita perlu mendefinisikan dimana letak file rubocop.yml
berada.
File rubocop.yml ini berisi aturan-aturan yang akan digunkan oleh Rubocop untuk menilai kode yang kita tulis.
Kita dapat meng-enable atau men-disable sesuai dengan keperluan kita.
Letak dari file rubocop.yml ini dapat kita letakkan secara global atau project root direktori (local).
Secara urutan, proses pembacaan file rubocop.yml akan seperti di bawah ini.
[1] /path/to/project/lib/utils/.rubocop.yml
[2] /path/to/project/lib/.rubocop.yml
[3] /path/to/project/.rubocop.yml
[4] /.rubocop.yml
[5] ~/.rubocop.yml
[6] ~/.config/rubocop/config.yml
[7] RuboCop’s default configuration
Pada konfigurasi kali ini saya akan menggunakan yang global karena saya tidak selalu mendifinisikan file rubocop.yml untuk project yang sedang saya kerjakan.
Saya menggunakan nomor 6 dan akan membuat symbolic link untuk nomor 5. 😁
Pembuatan File rubocop.yml
Pertama buat dahulu direktori config untuk Rubocop dan masuk ke dalam direktori tersebut.
$ mkdir -p $HOME/.config/rubocop
$ cd $HOME/.config/rubocop
Kemudian download dulu aturan-aturan Rubocop yang default dari alamat di bawah ini.
RuboCop’s default configuration
Ganti nama filenya menjadi rubocop.yml.example
.
$ mv default.yml rubocop.yml.example
Selanjutnya, saya akan membuat file config.yml yang berisi aturan-aturan yang akan meng-override aturan default untuk saya disable.
Jadi fungsi dari file config.yml ini saya pergunakan hanya untuk men-disable aturan yang saya tidak inginkan.
$ touch $HOME/.config/rubocop/config.yml
Apabila saya melakukan list direktori akan seperti ini hasilnya
$ ls
config.yml rubocop.yml.example
Buka file config.yml dengan text editor dan tambahkan beberapa aturan yang ingin di-disable.
Contoh beberapa aturan yang saya disable.
Saya mendisable:
- Style/Documentation, untuk Class documentation yang biasanya ada di bagian atas dari Class.
- Metrics/MethodLength, untuk membatasi jumlah baris pada method yang tidak lebih dari 10 baris.
- Style/GlobalVars, untuk menghindari menggunakan global variabel.
- Style/FrozenStringLiteralComment, untuk mewajibkan menulis magic string.
- Metrics/PerceivedComplexity & Metrics/CyclomaticComplexity, untuk mengatur penulisan method yang mudah dipahami, dan tidak berbelit-belit.
Kemudian, saya akan membuat symbolic link file config.yml untuk saya letakkan di $HOME direktori secara hidden.
$ ln -sf $HOME/.config/rubocop/config.yml $HOME/.rubocop.yml
Dengan begini, saya memiliki file ~/.rubocop.yml
yang isinya akan sama dengan file ~/.config/rubocop/config.yml
.
Kenapa saya buat menjadi symbolic seperti ini?
Agar path yang digunakan lebih pendek. 😁
Definisikan File rubocop.yml yang Digunakan
Setelah kita mendifinikan aturan-aturan apa saja, kita perlu mendifinisikan file aturan mana yang akan kita pergunakan.
Tambahkan pada .vimrc
.
Saya mendefinisikan file ~/.rubocop.yml
yang merupakan symbolic link dari file ~/.config/rubocop/config.yml
.
Konfigurasi ALE
Setelah kita mengkonfigurasi vim-rubocop, kita juga perlu mengkonfigurasi ALE untuk mendifinisikan linter apa yang akan kita gunakan.
Kemudian, definisikan juga fixer yang akan digunakan.
Untuk mengaktifkan ALE fixer kita dapat menggunakan perintah.
:ALEFix
Selain menggunakan Rubocop sebagai fixer, kita dapat mengecek saran penggunaan fixer yang lain dengan menggunakan perintah.
:ALEFixSuggest
Try the following fixers appropriate for the filetype:
'rubocop' - Fix ruby files with rubocop --auto-correct.
'rufo' - Fix ruby files with rufo
'sorbet' - Fix ruby files with srb tc --autocorrect.
'standardrb' - Fix ruby files with standardrb --fix
Try the following generic fixers:
'remove_trailing_lines' - Remove all blank lines at the end of a file.
'trim_whitespace' - Remove all trailing whitespace characters at the end of every line.
See :help ale-fix-configuration
Press q to close this window
Tambahkan juga beberapa dekorasi.
Saya tidak mengaktifkan fix pada saat save.
Untuk melihat Linter Variable gunakan perintah:
:ALEInfo
Current Filetype: ruby
Available Linters: ['brakeman', 'debride', 'rails_best_practices', 'reek', 'rubocop', 'ruby', 'solargraph', 'sorbet', 'standardrb']
Linter Aliases:
'sorbet' -> ['srb']
Enabled Linters: ['rubocop']
Suggested Fixers:
'remove_trailing_lines' - Remove all blank lines at the end of a file.
'rubocop' - Fix ruby files with rubocop --auto-correct.
'rufo' - Fix ruby files with rufo
'sorbet' - Fix ruby files with srb tc --autocorrect.
'standardrb' - Fix ruby files with standardrb --fix
'trim_whitespace' - Remove all trailing whitespace characters at the end of every line.
Linter Variables:
let g:ale_ruby_rails_best_practices_executable = 'rails_best_practices'
let g:ale_ruby_rails_best_practices_options = ''
let g:ale_ruby_rubocop_executable = 'rubocop'
let g:ale_ruby_rubocop_options = ''
Global Variables:
let g:ale_cache_executable_check_failures = v:null
let g:ale_change_sign_column_color = 0
let g:ale_command_wrapper = ''
...
...
Pada saat ini, saya hanya mendifinisikan untuk bahasa Ruby, namun sebenarnya, saya juga mendifinisikan untuk bahasa yang lain seperi JavaScript dan Python.
Meskipun saat ini, saya hanya berhasil menjalankan fixer untuk remove_trailing_lines
.
Saya masih akan terus mencoba-coba agar fungsi fixer secara otomatis benar-benar dapat digunakan.
Pesan Penulis
Sepertinya, segini dulu yang saya tuliskan.
Mudah-mudahan dapat bermanfaat.
Terima kasih.
(^_^)
Referensi
-
github.com/rubocop-hq/rubocop
Diakses tanggal: 2020/08/25 -
github.com/ngmy/vim-rubocop
Diakses tanggal: 2020/08/25 -
Vim for Ruby and Rails in 2019
Diakses tanggal: 2020/08/25 -
github.com/dense-analysis/ale
Diakses tanggal: 2020/08/25
Lisensi
Atribusi-NonKomersial-BerbagiSerupa 4.0 Internasional (CC BY-NC-SA 4.0)
Penulis
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