Giriş
Bazel'i kullanmaya yeni mi başladınız? Doğru yerdesiniz. Bazel'in kullanımına basitleştirilmiş bir giriş için bu İlk Derleme eğitimini izleyin. Bu eğitimde, temel terimler Bazel bağlamında kullanıldığı şekilde tanımlanmakta ve Bazel iş akışının temelleri açıklanmaktadır. İhtiyacınız olan araçlardan başlayarak karmaşıklığı artan üç proje oluşturup çalıştıracak ve bu projelerin nasıl ve neden daha karmaşık hale geldiğini öğreneceksiniz.
Bazel, çok dilli derlemeleri destekleyen bir derleme sistemi olsa da bu eğitimde örnek olarak bir C++ projesi kullanılmakta ve çoğu dil için geçerli olan genel yönergeler ve akış sağlanmaktadır.
Tahmini tamamlama süresi: 30 dakika.
Ön koşullar
Henüz yapmadıysanız Bazel'i yükleyerek başlayın. Bu eğitimde kaynak kontrolü için Git kullanılır. En iyi sonuçları elde etmek istiyorsanız Git'i de yükleyin.
Ardından, tercih ettiğiniz komut satırı aracında aşağıdakileri çalıştırarak örnek projeyi Bazel'in GitHub deposundan alın:
git clone https://github.com/bazelbuild/examples
Bu eğitim için örnek proje examples/cpp-tutorial
dizinindedir.
Nasıl yapılandırıldığına aşağıda göz atabilirsiniz:
examples
└── cpp-tutorial
├──stage1
│ ├── main
│ │ ├── BUILD
│ │ └── hello-world.cc
│ └── WORKSPACE
├──stage2
│ ├── main
│ │ ├── BUILD
│ │ ├── hello-world.cc
│ │ ├── hello-greet.cc
│ │ └── hello-greet.h
│ └── WORKSPACE
└──stage3
├── main
│ ├── BUILD
│ ├── hello-world.cc
│ ├── hello-greet.cc
│ └── hello-greet.h
├── lib
│ ├── BUILD
│ ├── hello-time.cc
│ └── hello-time.h
└── WORKSPACE
Her biri bu eğitimdeki bir aşamayı temsil eden üç dosya grubu vardır. İlk aşamada, tek bir paket içinde yer alan tek bir hedef oluşturacaksınız. İkinci aşamada, tek bir paketten hem ikili program hem de kitaplık oluşturacaksınız. Üçüncü ve son aşamada, birden fazla paket içeren bir proje oluşturacak ve bu projeyi birden fazla hedef için derleyeceksiniz.
Özet: Giriş
Bu eğitim için Bazel'ı (ve Git) yükleyip depoyu klonlayarak Bazel ile ilk derlemenizin temelini atmış oldunuz. Bazı terimleri tanımlamak ve çalışma alanınızı ayarlamak için sonraki bölüme geçin.
Başlarken
Çalışma alanını ayarlama
Proje oluşturmadan önce projenin çalışma alanını ayarlamanız gerekir. Çalışma alanı, projenizin kaynak dosyalarını ve Bazel'in derleme çıkışlarını içeren bir dizindir. Ayrıca şu önemli dosyaları da içerir:
- Dizini ve içeriğini Bazel çalışma alanı olarak tanımlayan ve projenin dizin yapısının kökünde bulunan
.WORKSPACE
file - Bazel'e projenin farklı bölümlerinin nasıl derleneceğini söyleyen bir veya daha fazla
. Çalışma alanındakiBUILD
filesBUILD
dosyası içeren bir dizin paket olarak adlandırılır. (Paketler hakkında daha fazla bilgiyi bu eğitimde daha sonra bulabilirsiniz.)
Gelecekteki projelerde bir dizini Bazel çalışma alanı olarak belirlemek için söz konusu dizinde WORKSPACE
adlı boş bir dosya oluşturun. Bu eğitim kapsamında, her aşamada bir WORKSPACE
dosyası zaten mevcuttur.
NOT: Bazel projeyi oluşturduğunda tüm girişlerin aynı çalışma alanında olması gerekir. Farklı çalışma alanlarında bulunan dosyalar, bağlanmadıkları sürece birbirinden bağımsızdır. Çalışma alanı kuralları hakkında daha ayrıntılı bilgiyi bu kılavuzda bulabilirsiniz.
BUILD dosyasını anlama
BUILD
dosyası, Bazel için farklı türde talimatları içerir. Her BUILD
dosyasında, Bazel'e istenen çıkışları (ör. yürütülebilir ikili dosyalar veya kitaplıklar) nasıl oluşturacağını söyleyen bir talimat grubu olarak en az bir kural gerekir. BUILD
dosyasındaki her derleme kuralının örneğine hedef adı verilir ve bunlar belirli bir kaynak dosyaları ile bağımlılıkları işaret eder.
Hedefler diğer hedefleri de gösterebilir.
cpp-tutorial/stage1/main
dizinindeki BUILD
dosyasına göz atın:
cc_binary(
name = "hello-world",
srcs = ["hello-world.cc"],
)
Örneğimizde hello-world
hedefi, Bazel'in yerleşik cc_binary rule
özelliğini örneklendirir.
Kural, Bazel'a hello-world.cc
kaynak dosyasından bağımlılık olmadan bağımsız yürütülebilir bir ikili program oluşturmasını söyler.
Özet: Başlarken
Artık bazı anahtar terimleri ve bunların bu proje ve genel olarak Bazel bağlamında ne anlama geldiğini biliyorsunuz. Bir sonraki bölümde, projenin 1. aşamasını oluşturup test edeceksiniz.
1. Aşama: tek hedef, tek paket
Projenin ilk bölümünü oluşturmanın zamanı geldi. Görsel bir referans olması açısından, projenin 1. Aşama bölümünün yapısı şöyledir:
examples
└── cpp-tutorial
└──stage1
├── main
│ ├── BUILD
│ └── hello-world.cc
└── WORKSPACE
cpp-tutorial/stage1
dizinine taşımak için aşağıdaki komutu çalıştırın:
cd cpp-tutorial/stage1
Ardından şu komutu çalıştırın:
bazel build //main:hello-world
Hedef etikette //main:
bölümü, çalışma alanının köküne göre BUILD
dosyasının konumu, hello-world
ise BUILD
dosyasındaki hedef addır.
Bazel aşağıdaki gibi bir sonuç oluşturur:
INFO: Found 1 target...
Target //main:hello-world up-to-date:
bazel-bin/main/hello-world
INFO: Elapsed time: 2.267s, Critical Path: 0.25s
İlk Bazel hedefinizi oluşturdunuz. Bazel, derleme çıkışlarını çalışma alanının kökündeki bazel-bin
dizinine yerleştirir.
Artık yeni oluşturulan ikili programınızı test edin. Bu program:
bazel-bin/main/hello-world
Bu işlem, "Hello world
" mesajının yazdırılmasına neden olur.
1. Aşama'nın bağımlılık grafiği aşağıda verilmiştir:
Özet: 1. aşama
İlk derlemenizi tamamladığınıza göre, artık bir derlemenin nasıl yapılandırıldığına dair temel bir fikriniz var. Sonraki aşamada, başka bir hedef ekleyerek karmaşıklığı artıracaksınız.
2. Aşama: Birden fazla derleme hedefi
Küçük projeler için tek bir hedef yeterli olsa da büyük projeleri birden fazla hedefe ve pakete bölmek isteyebilirsiniz. Bu sayede, Bazel yalnızca değişenleri yeniden derleyerek hızlı artımlı derlemeler yapabilir ve bir projenin birden fazla bölümünü aynı anda derleyerek derlemelerinizi hızlandırabilir. Eğitimin bu aşamasında bir hedef, sonraki aşamada ise bir paket eklenir.
2. Aşama için kullandığınız dizin budur:
├──stage2
│ ├── main
│ │ ├── BUILD
│ │ ├── hello-world.cc
│ │ ├── hello-greet.cc
│ │ └── hello-greet.h
│ └── WORKSPACE
Aşağıda, cpp-tutorial/stage2/main
dizinindeki BUILD
dosyasına göz atın:
cc_library(
name = "hello-greet",
srcs = ["hello-greet.cc"],
hdrs = ["hello-greet.h"],
)
cc_binary(
name = "hello-world",
srcs = ["hello-world.cc"],
deps = [
":hello-greet",
],
)
Bazel, bu BUILD
dosyasıyla önce hello-greet
kitaplığını (Bazel'in yerleşik cc_library rule
kitaplığını kullanarak) ve ardından hello-world
ikili programını oluşturur. hello-world
hedefindeki deps
özelliği, Bazel'a hello-world
ikili programını derlemek için hello-greet
kitaplığının gerekli olduğunu bildirir.
Projenin bu yeni sürümünü oluşturabilmek için önce dizinleri değiştirmeniz ve aşağıdaki komutu çalıştırarak cpp-tutorial/stage2
dizinine geçmeniz gerekir:
cd ../stage2
Artık aşağıdaki tanıdık komutu kullanarak yeni ikili dosyayı derleyebilirsiniz:
bazel build //main:hello-world
Bazel yine şuna benzer bir şey oluşturur:
INFO: Found 1 target...
Target //main:hello-world up-to-date:
bazel-bin/main/hello-world
INFO: Elapsed time: 2.399s, Critical Path: 0.30s
Artık yeni oluşturulan ikili dosyanızı test edebilirsiniz. Bu dosya başka bir "Hello world
" döndürür:
bazel-bin/main/hello-world
Artık hello-greet.cc
dosyasını değiştirip projeyi yeniden oluşturursanız Bazel yalnızca bu dosyayı yeniden derleyecektir.
Bağımlılık grafiğine baktığınızda hello-world'un öncekiyle aynı girişlere bağlı olduğunu ancak derlemenin yapısının farklı olduğunu görebilirsiniz:
Özet: 2. aşama
Projeyi iki hedefle oluşturmuş oldunuz. hello-world
hedefi bir kaynak dosya oluşturur ve iki ek kaynak dosyası oluşturan başka bir hedefe (//main:hello-greet
) bağlıdır. Bir sonraki bölümde, bunu bir adım öteye
getirip başka bir paket ekleyin.
3. Aşama: Birden fazla paket
Bu sonraki aşamada, karmaşıklık bir kat daha artar ve birden fazla paket içeren bir proje oluşturulur. cpp-tutorial/stage3
dizininin yapısına ve içeriğine aşağıdan göz atın:
└──stage3
├── main
│ ├── BUILD
│ ├── hello-world.cc
│ ├── hello-greet.cc
│ └── hello-greet.h
├── lib
│ ├── BUILD
│ ├── hello-time.cc
│ └── hello-time.h
└── WORKSPACE
Artık iki alt dizin olduğunu ve her birinin bir BUILD
dosyası içerdiğini görebilirsiniz. Bu nedenle, Bazel'e göre çalışma alanı artık iki paket içeriyor: lib
ve
main
.
lib/BUILD
dosyasına göz atın:
cc_library(
name = "hello-time",
srcs = ["hello-time.cc"],
hdrs = ["hello-time.h"],
visibility = ["//main:__pkg__"],
)
main/BUILD
dosyasında:
cc_library(
name = "hello-greet",
srcs = ["hello-greet.cc"],
hdrs = ["hello-greet.h"],
)
cc_binary(
name = "hello-world",
srcs = ["hello-world.cc"],
deps = [
":hello-greet",
"//lib:hello-time",
],
)
Ana paketteki hello-world
hedefi, lib
paketindeki hello-time
hedefine (dolayısıyla hedef etiketi //lib:hello-time
) bağlıdır. Bazel bunu deps
özelliği aracılığıyla bilir. Bu durumu bağımlılık grafiğinde görebilirsiniz:
Derlemenin başarılı olması için görünürlük özelliğini kullanarak lib/BUILD
içindeki //lib:hello-time
hedefini main/BUILD
içindeki hedeflere açıkça görünür hale getirirsiniz.
Bunun nedeni, hedeflerin varsayılan olarak yalnızca aynı BUILD
dosyasındaki diğer hedefler tarafından görülebilmesidir. Bazel, herkese açık API'lere sızdırılan uygulama ayrıntılarını içeren kitaplıklar gibi sorunları önlemek için hedef görünürlük kullanır.
Şimdi projenin bu son sürümünü derleyin. Aşağıdaki komutu çalıştırarak cpp-tutorial/stage3
dizinine geçin:
cd ../stage3
Aşağıdaki komutu tekrar çalıştırın:
bazel build //main:hello-world
Bazel aşağıdaki gibi bir sonuç oluşturur:
INFO: Found 1 target...
Target //main:hello-world up-to-date:
bazel-bin/main/hello-world
INFO: Elapsed time: 0.167s, Critical Path: 0.00s
Şimdi son Hello world
mesajı için bu eğitimdeki son ikili dosyayı test edin:
bazel-bin/main/hello-world
Özet: 3. aşama
Artık projeyi üç hedefi olan iki paket olarak oluşturdunuz ve aralarındaki bağımlılıkları anladınız. Bu sayede, Bazel ile gelecekteki projeleri oluşturmaya hazırsınız. Bir sonraki bölümde, Basel yolculuğunuza nasıl devam edeceğiniz açıklanmaktadır.
Sonraki adımlar
Bazel ile ilk temel derlemenizi tamamladınız. Ancak bu sadece başlangıç. Bazel ile ilgili daha fazla bilgi edinmek için aşağıdaki kaynaklardan yararlanabilirsiniz:
- C++'ya odaklanmaya devam etmek için yaygın C++ derleme kullanım alanları hakkında bilgi edinin.
- Bazel ile başka uygulamalar oluşturmaya başlamak için Java, Android uygulaması veya iOS uygulaması ile ilgili eğitici içeriklere göz atın.
- Yerel ve uzak depolarla çalışma hakkında daha fazla bilgi edinmek için harici bağımlılıklar hakkındaki makaleyi inceleyin.
- Bazel'in diğer kuralları hakkında daha fazla bilgi edinmek için bu referans kılavuzunu inceleyin.
İyi çalışmalar.