Bazel membangun perangkat lunak dari kode sumber yang terorganisir dalam pohon direktori yang disebut
repositori tambahan. Satu set repositori yang ditentukan akan membentuk ruang kerja. Sumber
file di repositori diatur dalam
hierarki paket bertingkat, di mana
setiap paket adalah direktori yang berisi
kumpulan file sumber terkait dan satu
File BUILD
. File BUILD
menentukan output software yang dapat dibuat
sumbernya.
Repositori
File sumber yang digunakan dalam build Bazel diatur dalam repositori (sering kali
disingkat menjadi repos). Repo adalah pohon direktori dengan file penanda batas di
{i>root<i}; file penanda batas tersebut bisa berupa MODULE.bazel
, REPO.bazel
, atau
dalam konteks lama, WORKSPACE
atau WORKSPACE.bazel
.
Repo tempat perintah Bazel saat ini dijalankan disebut main repo Anda. Repositori (eksternal) lainnya ditentukan oleh aturan repo; lihat eksternal ringkasan dependensi untuk mengetahui informasi selengkapnya.
Workspace
Ruang kerja adalah lingkungan yang digunakan bersama oleh semua perintah Bazel yang dijalankan dari satu repo utama ini. Ini mencakup repo utama dan kumpulan semua resource repo.
Perhatikan bahwa secara historis konsep "repositori" dan "workspace" telah bercampur; istilah "ruang kerja" sering digunakan untuk mengacu pada repositori, dan kadang-kadang bahkan digunakan sebagai sinonim dari "repositori".
Paket
Unit utama organisasi kode dalam repositori adalah paket. J adalah kumpulan file terkait dan spesifikasi bagaimana mereka dapat yang digunakan untuk menghasilkan artefak {i>output<i}.
Paket didefinisikan sebagai direktori yang berisi sebuah
File BUILD
bernama BUILD
atau BUILD.bazel
. J
paket mencakup semua file dalam direktorinya, ditambah semua subdirektori di bawahnya,
kecuali yang berisi file BUILD
. Dari definisi ini, tidak
file atau direktori dapat menjadi bagian
dari dua paket yang berbeda.
Misalnya, dalam hierarki direktori berikut ada dua paket, my/app
,
dan sub-paket my/app/tests
. Perlu diketahui bahwa my/app/data
bukan paket, tetapi
direktori yang termasuk dalam paket my/app
.
src/my/app/BUILD
src/my/app/app.cc
src/my/app/data/input.txt
src/my/app/tests/BUILD
src/my/app/tests/test.cc
Target
Paket adalah container target, yang ditentukan dalam
File BUILD
. Sebagian besar target adalah salah satu dari dua jenis utama, yaitu file dan aturan.
File dibagi lagi menjadi dua jenis. File sumber biasanya ditulis oleh upaya orang-orang, dan memeriksa repositori. File yang dihasilkan, kadang-kadang disebut file turunan atau file {i>output<i}, tidak di-check in, tetapi yang dihasilkan dari {i>file<i} sumber.
Jenis target kedua dideklarasikan dengan aturan. Setiap instance aturan menentukan hubungan antara set input dan set file output. Tujuan input ke aturan dapat berupa file sumber, tetapi juga dapat berupa output aturan.
Apakah input ke aturan adalah file sumber atau file yang dihasilkan paling kasus tidak penting; yang penting hanyalah isi dari file tersebut. Fakta ini memudahkan penggantian file sumber yang kompleks dengan file yang dihasilkan oleh aturan, seperti yang terjadi ketika beban mengelola file terstruktur menjadi terlalu melelahkan, dan seseorang menulis program untuk mendapatkannya. Tidak ada perubahan yang diperlukan bagi pemakai file tersebut. Sebaliknya, respons yang dihasilkan file dapat dengan mudah digantikan oleh file sumber yang hanya berisi perubahan lokal.
Input ke aturan juga dapat mencakup aturan lainnya. Makna yang sebenarnya dari hubungannya sering kali cukup kompleks dan bergantung pada bahasa atau aturan, tetapi secara intuitif sederhana: aturan library C++ A mungkin memiliki library C++ lainnya aturan B untuk input. Efek dari dependensi ini adalah bahwa file {i>header<i} B tersedia untuk A selama kompilasi, simbol B tersedia untuk A selama dan data runtime B tersedia untuk A selama eksekusi.
Invarian dari semua aturan adalah bahwa file yang dihasilkan oleh aturan selalu menjadi milik paket yang sama dengan aturan itu sendiri; tidak mungkin membuat file ke paket lain. Tidak jarang input aturan berasal dari input lain paket data, tetapi
Grup paket adalah kumpulan paket yang tujuannya
untuk membatasi aksesibilitas
aturan tertentu. Grup paket ditentukan oleh fungsi package_group
. Mereka
memiliki tiga properti: daftar paket yang dikandung, namanya, dan
grup paket yang mereka sertakan. Satu-satunya cara yang diizinkan untuk merujuknya adalah dari
visibility
aturan atau dari atribut default_visibility
fungsi package
; tidak menghasilkan atau memakai file. Untuk selengkapnya
selengkapnya, lihat package_group
dokumentasi.