forked from semver/semver.org
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update Indonesian translations (semver#409)
- Loading branch information
Showing
10 changed files
with
1,026 additions
and
183 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
--- | ||
title: Pemversian Semantik 0.1.0 | ||
language: id | ||
--- | ||
|
||
Pemversian Semantik 0.1.0 | ||
========================= | ||
|
||
Dalam pengembangan perangkat lunak, sering terjadi permasalahan *dependency hell*. Semakin besar sistem yang dibuat dan semakin banyak modul yang digunakan sistem kita, semakin sering permasalahan ini akan terjadi. | ||
|
||
Dalam sistem yang saling terkait, merilis versi baru bisa menjadi mimpi buruk. Jika spesifikasi dependensi sistem terlalu ketat, bisa jadi sistem kita tidak bisa dikembangkan lagi. Jika spesifikasi dependensi sistem terlalu bebas, semakin sulit untuk berasumsi versi mana yang bisa digunakan dengan versi yang lain. *Dependency hell* adalah saat Anda berada pada satu atau dua masalah ini, yang menahan Anda untuk bergerak maju dengan aman dan mudah. | ||
|
||
Sebagai solusi permasalahan ini, saya mengusulkan seperangkat aturan dan persayaratan sederhana yang menentukan bagaimana nomor versi diberikan dan bertambah. Agar sistem ini dapat bekerja, Anda harus mengumumkan API publik terlebih dahulu. Ini dapat terdiri dari dokumentasi atau diberlakukan oleh kode itu sendiri. Apapun itu, API ini harus jelas dan tepat. Setelah Anda mengidentifikasi API publik Anda, Anda mengomunikasikan perubahan pada API tersebut dengan penambahan spesifik pada nomor versi Anda. Pertimbangkan format versi X.Y.Z (Major.Minor.Patch). Perbaikan bug yang tidak memengaruhi API tersebut akan menambah versi *patch*, penambahan/perubahan API yang kompatibel dengan versi sebelumnya akan menambah versi *minor*, dan perubahan API yang tidak kompatibel dengan versi sebelumnya akan menambah versi major. | ||
|
||
Standar ini bernama "Pemversian Semantik". Dengan skema ini, setiap orang yang melihat angka versi bisa tahu secara umum apa yang berubah dengan sistem tersebut. | ||
|
||
Spesifikasi Pemversian Semantik | ||
------------------------------- | ||
|
||
1. Perangkat lunak dengan Pemversian Semantik HARUS menentukan API public. Bisa dijelaskan dengan kode, atau ditulis di dokumentasi saja. Apapun itu harus ditulis dengan jelas dan akurat. | ||
|
||
1. Sebuah versi memiliki bentuk X.Y.Z, dengan X, Y, dan Z adalah bilangan bulat. X adalah versi *major*, Y adalah *minor*, dan Z adalah *patch*. Setiap elemen bertambah secara numerik seperti versi 1.0.10 muncul setelah 1.0.9 | ||
|
||
1. Saat menandai rilis dalam sistem kontrol versi, *tag* untuk sebuah versi HARUS "vX.Y.Z", seperti "v3.1.0". | ||
|
||
1. Setelah sebuah paket berversi dirilis, isi dari versi tersebut TIDAK BOLEH diubah. Setiap perubahan harus dirilis sebagai versi baru. | ||
|
||
1. Versi *major* 0 (0.y.z) adalah untuk pengembangan awal. Apapun bisa bisa berubah kapanpun. API publik sebaiknya dianggap tidak stabil di versi ini. | ||
|
||
1. Versi 1.0.0 adalah titik awal API publik. Cara nomor versi ini sekarang tergantung dengan API publik ini dan bagaimana ia berubah. | ||
|
||
1. Versi *patch* Z (x.y.Z \| x > 0) HARUS dinaikkan jika ada perbaikan bug yang kompatibel dengan versi lama. Sebuah perbaikan bug didefinisikan sebagai perubahan internal yang memperbaiki perilaku yang salah. | ||
|
||
1. Versi *minor* Y (x.Y.z \| x > 0) HARUS dinaikkan jika ada fitur baru yang kompatibel dengan versi lama dalam API publik. Ini BISA dinaikkan jika ada tambahan fungsionalitas substansial atau terjadi peningkatan di dalam kode privat. Ini BISA diubah bersama dengan perubahan tingkat *patch*. | ||
|
||
1. Versi *major* X (X.y.z \| X > 0) HARUS dinaikkan jika ada perubahan yang membuat versi baru tidak kompatibel dengan versi lama pada API publik. Ini BISA diubah bersama dengan perubahan tingkat *patch* dan *minor*. | ||
|
||
Kenapa Menggunakan Pemversian Semantik? | ||
--------------------------------------- | ||
|
||
Ini bukanlah ide baru yang revolusioner. Faktanya, kalian mungkin sudah menggunakan standar ini, hanya saja tidak terlalu ketat. Masalahnya, "tidak teralu ketat" saja tidak cukup bagus. Tanpa kepatuhan terhadap beberapa jenis spesifikasi formal, nomor versi adalah pada dasarnya tidak berguna untuk manajemen dependensi. Dengan memberikan nama dan definisi yang jelas definisi yang jelas untuk ide-ide tersebut, mengkomunikasikan maksud Anda kepada pengguna perangkat lunak Anda menjadi lebih mudah. Setelah maksud ini jelas, spesifikasi ketergantungan yang fleksibel (tetapi tidak terlalu fleksibel) akhirnya dapat dibuat. | ||
|
||
Contoh sederhana ini menunjukkan manfaat Pemversian Semantik untuk menghilangkan "*dependency hell*." Misalkan ada sebuah modul bernama "MobilPemadamKebakaran". Modul "MobilPemadamKebakaran" membutuhkan modul lain bernama "Tangga". Pada waktu "MobilPemadamKebakaran" dibuat, "Tangga" memiliki versi 3.1.0. Dengan menggunakan Pemversian Semantik, "MobilPemadamKebakaran" bisa dengan yakin menggunakan modul "Tangga" selama modul tersebut mempunyai versi antara 3.1.0 sampai dengan sebelum versi 4.0.0. | ||
|
||
Sebagai pengembang yang bertanggung jawab, tentu saja Anda ingin memverifikasi bahwa peningkatan paket berfungsi seperti yang diiklankan. Dunia nyata tidaklah pasti; tidak ada yang bisa kita lakukan selain waspada. Yang bisa Anda lakukan adalah membiarkan Pemversian Semantik memberi Anda cara yang masuk akal untuk merilis dan memutakhirkan paket tanpa harus menggulirkan versi baru dari paket dependen, membuat Anda menghemat waktu dan kerumitan. | ||
|
||
Jika menurut kalian aturan ini bagus, cara untuk memulai menggunakan pemversian semantik adalah dengan menautkan situs ini dalam README kalian supaya orang lain bisa tahu mengenai aturan ini dan mulai menggunakannya juga. | ||
|
||
Pertanyaan Yang Sering Diajukan | ||
------------------------------- | ||
|
||
### Bagaimana saya tahu kapan merilis 1.0.0? | ||
|
||
Jika perangkat lunak Anda digunakan dalam produksi, mungkin perangkat lunak Anda sudah versi 1.0.0. Jika Anda memiliki API yang stabil yang menjadi andalan pengguna, Anda harusnya sudah pada 1.0.0. Jika Anda sangat mengkhawatirkan kompatibilitas versi lama, Anda mungkin sudah pada 1.0.0. | ||
|
||
### Bukankah standar ini mencegah perkembangan yang cepat? | ||
|
||
Versi *major* nol adalah tentang pengembangan yang cepat. Jika Anda mengubah API setiap hari, Anda harus tetap berada di versi 0.x.x atau di pengembangan terpisah yang bekerja pada versi *major* berikutnya. | ||
|
||
### Jika perubahan terkecil yang tidak kompatibel dengan API publik memerlukan kenaikkan versi *major*, bukankah saya akan berakhir di versi 42.0.0 dengan sangat cepat? | ||
|
||
Ini adalah pertanyaan tentang pengembangan yang bertanggung jawab dan pandangan ke depan. Perubahan yang tidak kompatibel tidak boleh diperkenalkan dengan mudah ke perangkat lunak yang memiliki banyak kode dependen. Biaya yang harus dikeluarkan untuk meng-upgrade bisa sangat besar. Kewajiban mengganti versi *major* untuk merilis perubahan yang tidak kompatibel seharusnya membuat Anda memikirkan dampak dari perubahan Anda, dan mengevaluasi perbandingan biaya dan manfaat yang terkait. | ||
|
||
### Mendokumentasikan seluruh API publik sangatlah merepotkan! | ||
|
||
Sudah tanggung jawab Anda sebagai pengembang profesional untuk mendokumentasikan perangkat lunak untuk digunakan oleh orang lain dengan benar. Mengelola kompleksitas perangkat lunak adalah bagian yang sangat penting dalam menjaga proyek tetap efisien, dan itu sulit dilakukan jika tidak ada yang tahu cara menggunakan perangkat lunak Anda, atau metode apa yang aman untuk dihubungi. Dalam jangka panjang, Pemversian Semantik, dan desakan pada API publik yang terdefinisi dengan baik dapat membuat semua orang dan segala sesuatu berjalan dengan lancar. | ||
|
||
### Bagaimana jika secara tidak sengaja membuat perubahan yang menjadikan versi lama tidak bisa dipakai? | ||
|
||
Setelah Anda menyadari bahwa Anda telah melanggar spesifikasi Pemversian Semantik, perbaiki dan rilis versi *minor* baru yang memperbaiki masalah dan mengembalikan kompatibilitas versi lama. Ingat, memodifikasi rilis yang telah diberi versi adalah dilarang, bahkan dalam kondisi ini. Jika mau, dokumentasikan versi yang bermasalah dan memberi tahu pengguna Anda tentang masalah tersebut sehingga mereka mengetahui versi yang bermasalah. | ||
|
||
### Apa yang harus saya lakukan jika saya memperbarui dependensi saya sendiri tanpa mengubah API publik? | ||
|
||
Hal tersebut dianggap kompatibel karena tidak mempengaruhi API publik. Perangkat lunak yang secara eksplisit bergantung pada dependensi yang sama dengan paket Anda harus memiliki spesifikasi dependensi mereka sendiri dan pembuatnya akan memberi tahu konflik yang ada. Menentukan apakah perubahan tersebut merupakan tingkat *patch* atau tingkat *minor* tergantung pada apakah Anda memperbarui dependensi untuk memperbaiki *bug* atau memperkenalkan fungsionalitas baru. Saya biasanya mengharapkan kode tambahan untuk contoh yang kedua, yang dalam hal ini jelas merupakan kenaikan tingkat *minor*. | ||
|
||
Tentang | ||
------- | ||
|
||
Spesifikasi Pemversian Semantik dibuat oleh [Tom Preston-Werner](http://tom.preston-werner.com), pembuat Gravatars dan *cofounder* dari GitHub. | ||
|
||
Terjemahan Bahasa Indonesia ditulis oleh [Aditya Purwa](https://adityamyria.wordpress.com), [Christian B. Wibowo](https://github.com/cwibowo), dan [Hans5958](https://github.com/Hans5958). | ||
|
||
Untuk saran dan kritik, silahkan [buka issue di GitHub](https://github.com/mojombo/semver/issues). |
Oops, something went wrong.