Aturan
- java_binary
- java_import
- java_library
- java_lite_proto_library
- java_proto_library
- java_test
- java_package_configuration
- java_plugin
- java_runtime
- java_toolchain
java_binary
Lihat sumber aturanjava_binary(name, deps, srcs, data, resources, args, classpath_resources, compatible_with, create_executable, deploy_env, deploy_manifest_lines, deprecation, distribs, env, exec_compatible_with, exec_properties, features, javacopts, jvm_flags, launcher, licenses, main_class, output_licenses, plugins, resource_jars, resource_strip_prefix, restricted_to, runtime_deps, stamp, tags, target_compatible_with, testonly, toolchains, use_launcher, use_testrunner, visibility)
Membangun arsip Java ("file jar"), plus skrip shell wrapper dengan nama yang sama seperti aturan.
Skrip shell wrapper menggunakan classpath yang menyertakan, antara lain, file jar untuk setiap library tempat biner bergantung. Saat menjalankan skrip shell wrapper, variabel lingkungan JAVABIN
yang tidak kosong akan lebih diutamakan daripada versi yang ditentukan melalui flag --java_runtime_version
Bazel.
Skrip wrapper menerima beberapa flag unik. Lihat //src/main/java/com/google/devtools/build/lib/bazel/rules/java/java_stub_template.txt
untuk mengetahui daftar variabel lingkungan dan flag yang dapat dikonfigurasi yang diterima oleh wrapper.
Target output implisit
name.jar
: Arsip Java, yang berisi file class dan resource lain yang terkait dengan dependensi langsung biner.name-src.jar
: Arsip yang berisi sumber ("jar sumber").name_deploy.jar
: Arsip Java yang cocok untuk deployment (hanya dibangun jika diminta secara eksplisit).Membuat target
<name>_deploy.jar
untuk aturan Anda akan membuat file jar mandiri dengan manifes yang memungkinkannya dijalankan dengan perintahjava -jar
atau dengan opsi--singlejar
skrip wrapper. Penggunaan skrip wrapper lebih disukai daripadajava -jar
karena juga meneruskan flag JVM dan opsi untuk memuat library native.Jar deploy berisi semua class yang akan ditemukan oleh classloader yang menelusuri classpath dari skrip wrapper biner dari awal hingga akhir. Library ini juga berisi library native yang diperlukan untuk dependensi. Link ini akan otomatis dimuat ke JVM saat runtime.
Jika target Anda menentukan atribut peluncur, _deploy.jar akan menjadi biner native, bukan file JAR normal. Objek ini akan berisi peluncur dan dependensi native (C++) dari aturan Anda, yang semuanya ditautkan ke biner statis. Byte file jar yang sebenarnya akan ditambahkan ke biner native tersebut, sehingga menghasilkan satu blob biner yang berisi kode yang dapat dieksekusi dan kode Java. Anda dapat langsung mengeksekusi file jar yang dihasilkan seperti mengeksekusi biner native.
name_deploy-src.jar
: Arsip yang berisi sumber yang dikumpulkan dari penutupan transitif target. Ini akan cocok dengan class dideploy.jar
kecuali jika jar tidak memiliki jar sumber yang cocok.
Atribut deps
tidak diizinkan dalam aturan java_binary
tanpa
srcs
; aturan seperti itu memerlukan
main_class
yang disediakan oleh
runtime_deps
.
Cuplikan kode berikut mengilustrasikan kesalahan umum:
java_binary( name = "DontDoThis", srcs = [ ..., "GeneratedJavaFile.java", # a generated .java file ], deps = [":generating_rule"], # rule that generates that file )
Lakukan hal berikut:
java_binary( name = "DoThisInstead", srcs = [ ..., ":generating_rule", ], )
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. Sebaiknya gunakan nama file sumber yang merupakan titik entri utama aplikasi (tanpa ekstensi). Misalnya, jika titik entri Anda diberi nama Main.java , nama Anda dapat berupa Main .
|
deps
|
Daftar label; default-nya adalah deps di bagian Atribut umum yang ditentukan oleh sebagian besar aturan build.
|
srcs
|
Daftar label; default-nya adalah
File sumber jenis
File sumber jenis
Aturan: jika aturan (biasanya
Argumen ini hampir selalu diperlukan, kecuali jika atribut
|
resources
|
Daftar label; default-nya adalah
Jika ditentukan, resource akan dipaketkan dalam jar bersama dengan file
Resource dapat berupa file sumber atau file buatan. |
classpath_resources
|
Daftar label; default-nya adalah
Daftar resource yang harus ditempatkan di root pohon java. Tujuan satu-satunya atribut ini adalah untuk mendukung library pihak ketiga yang mengharuskan agar resource-nya ditemukan di classpath sama persis dengan |
create_executable
|
Boolean; tidak dapat dikonfigurasi; defaultnya adalah java_single_jar .
|
deploy_env
|
Daftar label; default-nya adalah java_binary lain yang mewakili lingkungan deployment untuk biner ini.
Tetapkan atribut ini saat mem-build plugin yang akan dimuat oleh java_binary lain.Menetapkan atribut ini akan mengecualikan semua dependensi dari classpath runtime (dan jar deploy) biner ini yang digunakan bersama biner ini dan target yang ditentukan dalam deploy_env .
|
deploy_manifest_lines
|
Daftar string; default-nya adalah META-INF/manifest.mf yang dihasilkan untuk target *_deploy.jar . Konten atribut ini tidak tunduk pada
substitusi "Buat variabel".
|
javacopts
|
Daftar string; default-nya adalah Opsi compiler ini diteruskan ke javac setelah opsi compiler global. |
jvm_flags
|
Daftar string; default-nya adalah Skrip wrapper untuk biner Java menyertakan definisi CLASSPATH (untuk menemukan semua jar dependen) dan memanggil penafsir Java yang tepat.
Command line yang dihasilkan oleh skrip wrapper menyertakan nama class utama, diikuti dengan Perhatikan bahwa atribut ini tidak berpengaruh pada output |
launcher
|
Label; default-nya adalah bin/java normal yang disertakan dengan JDK.
Target harus berupa cc_binary . Setiap cc_binary yang
mengimplementasikan
Java Invocation API dapat ditentukan sebagai nilai untuk atribut ini.
Secara default, Bazel akan menggunakan peluncur JDK normal (bin/java atau java.exe). Flag Perlu diperhatikan bahwa dependensi native (C++, SWIG, JNI) akan dibuat secara berbeda bergantung pada apakah Anda menggunakan peluncur JDK atau peluncur lain:
Saat menggunakan peluncur selain peluncur JDK default, format
output |
main_class
|
String; defaultnya adalah main() untuk digunakan sebagai titik entri.
Aturan tidak memerlukan daftar srcs=[...] jika menggunakan opsi ini.
Jadi, dengan atribut ini, seseorang dapat membuat file yang dapat dieksekusi dari library Java yang sudah
berisi satu atau beberapa metode main() .
Nilai atribut ini adalah nama class, bukan file sumber. Class harus
tersedia saat runtime: class dapat dikompilasi oleh aturan ini (dari |
plugins
|
Daftar label; default-nya adalah java_plugin yang ditentukan dalam atribut ini akan dijalankan setiap kali aturan ini dibuat. Library juga dapat mewarisi plugin dari dependensi yang menggunakan
exported_plugins . Resource yang dihasilkan oleh plugin akan disertakan dalam jar yang dihasilkan aturan ini.
|
resource_jars
|
Daftar label; default-nya adalah |
resource_strip_prefix
|
String; defaultnya adalah
Jika ditentukan, awalan jalur ini akan dihilangkan dari setiap file dalam atribut |
runtime_deps
|
Daftar label; default-nya adalah deps biasa, library ini akan muncul di classpath runtime, tetapi tidak seperti
class tersebut, bukan pada classpath waktu kompilasi. Dependensi yang hanya diperlukan saat runtime harus tercantum di sini. Alat analisis dependensi harus mengabaikan target yang muncul di
runtime_deps dan deps .
|
stamp
|
Bilangan bulat; defaultnya adalah
Biner berstempel tidak dibangun ulang kecuali jika dependensinya berubah. |
use_launcher
|
Boolean; defaultnya adalah Jika atribut ini ditetapkan ke false, atribut
launcher dan flag
|
use_testrunner
|
Boolean; defaultnya adalah com.google.testing.junit.runner.BazelTestRunner ) sebagai titik entri utama untuk program Java, dan berikan class pengujian tersebut kepada runner pengujian sebagai nilai properti sistem bazel.test_suite .
Anda dapat menggunakannya untuk mengganti perilaku default, yaitu menggunakan runner pengujian untuk aturan java_test , dan tidak menggunakannya untuk aturan java_binary . Anda tidak mungkin
ingin melakukan hal ini. Salah satunya adalah untuk aturan AllTest yang dipanggil oleh aturan lain (misalnya untuk menyiapkan database sebelum menjalankan pengujian). Aturan AllTest harus dideklarasikan sebagai java_binary , tetapi tetap harus menggunakan runner pengujian sebagai titik entri utamanya.
Nama class runner pengujian dapat diganti dengan atribut main_class .
|
java_import
Lihat sumber aturanjava_import(name, deps, data, add_exports, add_opens, compatible_with, constraints, deprecation, distribs, exec_compatible_with, exec_properties, exports, features, jars, licenses, neverlink, proguard_specs, restricted_to, runtime_deps, srcjar, tags, target_compatible_with, testonly, toolchains, visibility)
Aturan ini mengizinkan penggunaan file .jar
yang telah dikompilasi sebagai
library untuk aturan java_library
dan
java_binary
.
Contoh
java_import(
name = "maven_model",
jars = [
"maven_model/maven-aether-provider-3.2.3.jar",
"maven_model/maven-model-3.2.3.jar",
"maven_model/maven-model-builder-3.2.3.jar",
],
)
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
deps
|
Daftar label; default-nya adalah |
data
|
Daftar label; default-nya adalah |
add_exports
|
Daftar string; default-nya adalah module atau package yang ditentukan.
Ini sesuai dengan flag --add-exports= javac dan JVM. |
add_opens
|
Daftar string; default-nya adalah module atau
package yang diberikan secara reflektif.
Ini berkaitan dengan flag --add-opens= javac dan JVM. |
constraints
|
Daftar string; default-nya adalah |
exports
|
Daftar label; default-nya adalah |
jars
|
Daftar label; wajib diisi Daftar file JAR yang diberikan ke target Java yang bergantung pada target ini. |
neverlink
|
Boolean; defaultnya adalah tools.jar untuk apa pun yang berjalan di
JDK standar.
|
proguard_specs
|
Daftar label; default-nya adalah android_binary apa pun bergantung pada library ini.
File yang disertakan di sini hanya boleh memiliki aturan idempoten, yaitu -dontnote, -dontwarning, assumenosideimpact, dan aturan yang dimulai dengan -keep. Opsi lain hanya dapat muncul di
proguard_specs android_binary , untuk memastikan penggabungan non-tautological.
|
runtime_deps
|
Daftar label; default-nya adalah |
srcjar
|
Label; default-nya adalah |
java_library
Lihat sumber aturanjava_library(name, deps, srcs, data, resources, add_exports, add_opens, bootclasspath, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, exported_plugins, exports, features, javabuilder_jvm_flags, javacopts, licenses, neverlink, plugins, proguard_specs, resource_strip_prefix, restricted_to, runtime_deps, tags, target_compatible_with, testonly, toolchains, visibility)
Aturan ini mengompilasi dan menautkan sumber ke dalam file .jar
.
Output implisit
libname.jar
: Arsip Java yang berisi file class.libname-src.jar
: Arsip yang berisi sumber ("jar sumber").
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
deps
|
Daftar label; default-nya adalah deps di bagian Atribut umum yang ditentukan oleh sebagian besar aturan build.
Jar yang dibuat oleh aturan
Sebaliknya, target dalam atribut |
srcs
|
Daftar label; default-nya adalah
File sumber jenis
File sumber jenis
Aturan: jika aturan (biasanya
File sumber jenis Semua file lain akan diabaikan, selama ada setidaknya satu file dari jenis file yang dijelaskan di atas. Jika tidak, error akan muncul.
Argumen ini hampir selalu diperlukan, kecuali jika Anda menentukan argumen |
data
|
Daftar label; default-nya adalah data di bagian Atribut umum yang ditentukan oleh sebagian besar aturan build.
Saat mem-build |
resources
|
Daftar label; default-nya adalah Resource dapat berupa file sumber atau file buatan.
Jika ditentukan, resource akan dipaketkan dalam jar bersama dengan file
|
add_exports
|
Daftar string; default-nya adalah module atau package yang ditentukan.
Ini sesuai dengan flag --add-exports= javac dan JVM. |
add_opens
|
Daftar string; default-nya adalah module atau
package yang diberikan secara reflektif.
Ini berkaitan dengan flag --add-opens= javac dan JVM. |
bootclasspath
|
Label; default-nya adalah |
exported_plugins
|
Daftar label; default-nya adalah java_plugin (mis. pemroses
anotasi) yang akan diekspor ke library yang secara langsung bergantung pada library ini.
Daftar |
exports
|
Daftar label; default-nya adalah
Mencantumkan aturan di sini akan membuatnya tersedia untuk aturan induk, seolah-olah induk secara eksplisit bergantung pada aturan ini. Hal ini tidak berlaku untuk
Ringkasan: aturan X dapat mengakses kode dalam Y jika ada jalur dependensi di antaranya yang dimulai dengan edge
Asumsikan A bergantung pada B dan B bergantung pada C. Dalam hal ini, C adalah dependensi transitif dari A. Oleh karena itu, mengubah sumber C dan mem-build ulang A akan membangun ulang semuanya dengan benar. Namun, A tidak akan dapat menggunakan class di C. Untuk mengizinkannya, A harus mendeklarasikan C dalam Penutupan library yang diekspor tersedia untuk semua aturan induk langsung. Ambil contoh yang sedikit berbeda: A bergantung pada B, B bergantung pada C dan D, serta mengekspor C tetapi tidak D. Sekarang A memiliki akses ke C tetapi tidak ke D. Sekarang, jika C dan D mengekspor beberapa library, C' dan D', A hanya dapat mengakses C', tetapi tidak dapat mengakses D'.
Penting: aturan yang diekspor bukan dependensi reguler. Tetap berpegang pada contoh sebelumnya, jika B mengekspor C dan ingin menggunakan C juga, B harus mencantumkannya dalam |
javabuilder_jvm_flags
|
Daftar string; default-nya adalah |
javacopts
|
Daftar string; default-nya adalah Opsi compiler ini diteruskan ke javac setelah opsi compiler global. |
neverlink
|
Boolean; defaultnya adalah tools.jar untuk apa pun
yang berjalan di JDK standar.
Perlu diperhatikan bahwa Jika library runtime berbeda dengan library kompilasi, Anda harus memastikan bahwa library tersebut hanya berbeda di tempat-tempat yang dilarang oleh JLS untuk compiler inline (dan yang harus berlaku untuk semua versi JLS di masa mendatang). |
plugins
|
Daftar label; default-nya adalah java_plugin yang ditentukan dalam atribut ini akan dijalankan setiap kali aturan ini dibuat. Library juga dapat mewarisi plugin dari dependensi yang menggunakan
exported_plugins . Resource
yang dihasilkan oleh plugin akan disertakan dalam jar yang dihasilkan aturan ini.
|
proguard_specs
|
Daftar label; default-nya adalah android_binary apa pun bergantung pada library ini.
File yang disertakan di sini hanya boleh memiliki aturan idempoten, yaitu -dontnote, -dontwarning, assumenosideimpact, dan aturan yang dimulai dengan -keep. Opsi lain hanya dapat muncul di
proguard_specs android_binary , untuk memastikan penggabungan non-tautological.
|
resource_strip_prefix
|
String; defaultnya adalah
Jika ditentukan, awalan jalur ini akan dihilangkan dari setiap file dalam atribut |
runtime_deps
|
Daftar label; default-nya adalah deps biasa, library ini akan muncul di classpath runtime, tetapi tidak seperti
classpath tersebut, bukan pada classpath waktu kompilasi. Dependensi yang hanya diperlukan saat runtime harus
tercantum di sini. Alat analisis dependensi harus mengabaikan target yang muncul di runtime_deps dan deps .
|
java_lite_proto_library
Lihat sumber aturanjava_lite_proto_library(name, deps, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
java_lite_proto_library
menghasilkan kode Java dari file .proto
.
deps
harus mengarah ke aturan proto_library
.
Contoh:
java_library(
name = "lib",
runtime_deps = [":foo"],
)
java_lite_proto_library(
name = "foo",
deps = [":bar"],
)
proto_library(
name = "bar",
)
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
deps
|
Daftar label; default-nya adalah proto_library
yang digunakan untuk membuat kode Java.
|
java_proto_library
Lihat sumber aturanjava_proto_library(name, deps, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, licenses, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
java_proto_library
menghasilkan kode Java dari file .proto
.
deps
harus mengarah ke aturan proto_library
.
Contoh:
java_library(
name = "lib",
runtime_deps = [":foo_java_proto"],
)
java_proto_library(
name = "foo_java_proto",
deps = [":foo_proto"],
)
proto_library(
name = "foo_proto",
)
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
deps
|
Daftar label; default-nya adalah proto_library
yang digunakan untuk membuat kode Java.
|
java_test
Lihat sumber aturanjava_test(name, deps, srcs, data, resources, add_exports, add_opens, args, bootclasspath, classpath_resources, compatible_with, create_executable, deploy_manifest_lines, deprecation, distribs, env, env_inherit, exec_compatible_with, exec_properties, features, flaky, javacopts, jvm_flags, launcher, licenses, local, main_class, neverlink, plugins, resource_strip_prefix, restricted_to, runtime_deps, shard_count, size, stamp, tags, target_compatible_with, test_class, testonly, timeout, toolchains, use_launcher, use_testrunner, visibility)
Aturan java_test()
mengompilasi pengujian Java. Pengujian adalah wrapper biner di sekitar kode pengujian Anda. Metode utama runner pengujian dipanggil, bukan class utama yang dikompilasi.
Target output implisit
name.jar
: Arsip Java.name_deploy.jar
: Arsip Java yang cocok untuk deployment. (Hanya dibuat jika diminta secara eksplisit.) Lihat deskripsi outputname_deploy.jar
dari java_binary untuk detail selengkapnya.
Lihat bagian argumen java_binary()
. Aturan ini juga mendukung semua atribut umum untuk semua aturan pengujian (*_test).
Contoh
java_library(
name = "tests",
srcs = glob(["*.java"]),
deps = [
"//java/com/foo/base:testResources",
"//java/com/foo/testing/util",
],
)
java_test(
name = "AllTests",
size = "small",
runtime_deps = [
":tests",
"//util/mysql",
],
)
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
deps
|
Daftar label; default-nya adalah deps di bagian Atribut umum yang ditentukan oleh sebagian besar aturan build.
|
srcs
|
Daftar label; default-nya adalah
File sumber jenis
File sumber jenis
Aturan: jika aturan (biasanya
Argumen ini hampir selalu diperlukan, kecuali jika atribut
|
data
|
Daftar label; default-nya adalah data
di Atribut umum yang ditentukan oleh
sebagian besar aturan build.
|
resources
|
Daftar label; default-nya adalah Resource dapat berupa file sumber atau file buatan.
Jika ditentukan, resource akan dipaketkan dalam jar bersama dengan file
|
add_exports
|
Daftar string; default-nya adalah module atau package yang ditentukan.
Ini sesuai dengan flag --add-exports= javac dan JVM. |
add_opens
|
Daftar string; default-nya adalah module atau
package yang diberikan secara reflektif.
Ini berkaitan dengan flag --add-opens= javac dan JVM. |
bootclasspath
|
Label; default-nya adalah |
classpath_resources
|
Daftar label; default-nya adalah
Daftar resource yang harus ditempatkan di root pohon java. Tujuan satu-satunya
atribut ini adalah untuk mendukung library pihak ketiga yang mengharuskan resource-nya
ditemukan di classpath sama persis dengan |
create_executable
|
Boolean; defaultnya adalah java_single_jar .
|
deploy_manifest_lines
|
Daftar string; default-nya adalah META-INF/manifest.mf yang dihasilkan untuk
target *_deploy.jar . Konten atribut ini tidak dapat
substitusi "Buat variabel".
|
javacopts
|
Daftar string; default-nya adalah Opsi compiler ini diteruskan ke javac setelah opsi compiler global. |
jvm_flags
|
Daftar string; default-nya adalah Skrip wrapper untuk biner Java menyertakan definisi CLASSPATH (untuk menemukan semua jar dependen) dan memanggil penafsir Java yang tepat.
Command line yang dihasilkan oleh skrip wrapper menyertakan nama
class utama, diikuti dengan Perhatikan bahwa atribut ini tidak berpengaruh pada output
|
launcher
|
Label; default-nya adalah bin/java normal yang disertakan dengan JDK.
Target harus berupa cc_binary . Setiap cc_binary yang
mengimplementasikan
Java Invocation API dapat ditentukan sebagai nilai untuk atribut ini.
Secara default, Bazel akan menggunakan peluncur JDK normal (bin/java atau java.exe). Flag Perlu diperhatikan bahwa dependensi native (C++, SWIG, JNI) akan dibuat secara berbeda bergantung pada apakah Anda menggunakan peluncur JDK atau peluncur lain:
Saat menggunakan peluncur selain peluncur JDK default, format
output |
main_class
|
String; defaultnya adalah main() untuk digunakan sebagai titik entri.
Aturan tidak memerlukan daftar srcs=[...] jika menggunakan opsi ini.
Jadi, dengan atribut ini, seseorang dapat membuat file yang dapat dieksekusi dari library Java yang sudah
berisi satu atau beberapa metode main() .
Nilai atribut ini adalah nama class, bukan file sumber. Class harus
tersedia saat runtime: class dapat dikompilasi oleh aturan ini (dari |
neverlink
|
Boolean; defaultnya adalah |
plugins
|
Daftar label; default-nya adalah java_plugin yang ditentukan dalam atribut ini akan dijalankan setiap kali aturan ini dibuat. Library juga dapat mewarisi plugin dari dependensi yang menggunakan
exported_plugins . Resource
yang dihasilkan oleh plugin akan disertakan dalam jar yang dihasilkan aturan ini.
|
resource_strip_prefix
|
String; defaultnya adalah
Jika ditentukan, awalan jalur ini akan dihilangkan dari setiap file dalam atribut |
runtime_deps
|
Daftar label; default-nya adalah deps biasa, library ini akan muncul di classpath runtime, tetapi tidak seperti
classpath tersebut, bukan pada classpath waktu kompilasi. Dependensi yang hanya diperlukan saat runtime harus
tercantum di sini. Alat analisis dependensi harus mengabaikan target yang muncul di runtime_deps dan deps .
|
stamp
|
Bilangan bulat; defaultnya adalah
Biner berstempel tidak dibangun ulang kecuali jika dependensinya berubah. |
test_class
|
String; defaultnya adalah
Secara default, jika argumen ini tidak ditentukan, mode lama akan digunakan dan
argumen pengujian akan digunakan. Tetapkan flag
Atribut ini menentukan nama class Java yang akan dijalankan
oleh pengujian ini. Pengaturan ini jarang dilakukan. Jika dihilangkan, argumen ini akan disimpulkan menggunakan
Untuk JUnit3, class pengujian harus berupa subclass
Atribut ini memungkinkan beberapa aturan |
use_launcher
|
Boolean; defaultnya adalah Jika atribut ini ditetapkan ke false, atribut
peluncur dan tanda
|
use_testrunner
|
Boolean; defaultnya adalah com.google.testing.junit.runner.BazelTestRunner ) sebagai
titik entri utama untuk program Java, dan berikan class pengujian
kepada runner pengujian sebagai nilai properti sistem
bazel.test_suite .
Anda dapat menggunakan ini untuk mengganti perilaku default, yaitu menggunakan runner pengujian untuk aturan java_test ,
dan tidak menggunakannya untuk aturan java_binary . Anda tidak mungkin
ingin melakukan ini. Salah satu kegunaannya adalah untuk aturan AllTest yang dipanggil oleh aturan lain (misalnya untuk menyiapkan database sebelum menjalankan pengujian). Aturan AllTest
harus dideklarasikan sebagai java_binary , tetapi tetap
harus menggunakan runner pengujian sebagai titik entri utamanya.
Nama class runner pengujian dapat diganti dengan atribut main_class .
|
java_package_configuration
Lihat sumber aturanjava_package_configuration(name, data, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, javacopts, output_licenses, packages, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
Konfigurasi yang akan diterapkan ke kumpulan paket.
Konfigurasi dapat ditambahkan ke
java_toolchain.javacopts
.
Contoh:
java_package_configuration(
name = "my_configuration",
packages = [":my_packages"],
javacopts = ["-Werror"],
)
package_group(
name = "my_packages",
packages = [
"//com/my/project/...",
"-//com/my/project/testing/...",
],
)
java_toolchain(
...,
package_configuration = [
":my_configuration",
]
)
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
data
|
Daftar label; default-nya adalah |
javacopts
|
Daftar string; default-nya adalah |
output_licenses
|
Daftar string; default-nya adalah |
packages
|
Daftar label; default-nya adalah package_group
tempat konfigurasi akan diterapkan.
|
java_plugin
Lihat sumber aturanjava_plugin(name, deps, srcs, data, resources, add_exports, add_opens, bootclasspath, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, generates_api, javabuilder_jvm_flags, javacopts, licenses, neverlink, output_licenses, plugins, processor_class, proguard_specs, resource_strip_prefix, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
java_plugin
menentukan plugin untuk compiler Java yang dijalankan oleh Bazel. Saat ini, satu-satunya jenis plugin yang didukung adalah pemroses anotasi. Aturan java_library
atau
java_binary
dapat menjalankan plugin dengan bergantung padanya melalui atribut
plugins
. java_library
juga dapat otomatis mengekspor plugin ke library yang
bergantung langsung padanya menggunakan
exported_plugins
.
Target output implisit
libname.jar
: Arsip Java.
Argumen identik dengan java_library
, kecuali untuk penambahan argumen processor_class
.
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
deps
|
Daftar label; default-nya adalah deps di bagian Atribut umum yang ditentukan oleh sebagian besar aturan build.
Jar yang dibuat oleh aturan
Sebaliknya, target dalam atribut |
srcs
|
Daftar label; default-nya adalah
File sumber jenis
File sumber jenis
Aturan: jika aturan (biasanya
File sumber jenis Semua file lain akan diabaikan, selama ada setidaknya satu file dari jenis file yang dijelaskan di atas. Jika tidak, error akan muncul.
Argumen ini hampir selalu diperlukan, kecuali jika Anda menentukan argumen |
data
|
Daftar label; default-nya adalah data di bagian Atribut umum yang ditentukan oleh sebagian besar aturan build.
Saat mem-build |
resources
|
Daftar label; default-nya adalah Resource dapat berupa file sumber atau file buatan.
Jika ditentukan, resource akan dipaketkan dalam jar bersama dengan file
|
add_exports
|
Daftar string; default-nya adalah module atau package yang ditentukan.
Ini sesuai dengan flag --add-exports= javac dan JVM. |
add_opens
|
Daftar string; default-nya adalah module atau
package yang diberikan secara reflektif.
Ini berkaitan dengan flag --add-opens= javac dan JVM. |
bootclasspath
|
Label; default-nya adalah |
generates_api
|
Boolean; defaultnya adalah Jika aturan menggunakan pemroses anotasi yang membuat API, aturan lain yang bergantung pada aturan tersebut dapat merujuk ke kode yang dihasilkan hanya jika tindakan kompilasinya dijadwalkan setelah aturan yang dibuat. Atribut ini menginstruksikan Bazel untuk menerapkan batasan penjadwalan saat --java_header_compilation diaktifkan. PERINGATAN: Atribut ini memengaruhi performa build. Gunakan atribut ini hanya jika diperlukan. |
javabuilder_jvm_flags
|
Daftar string; default-nya adalah |
javacopts
|
Daftar string; default-nya adalah Opsi compiler ini diteruskan ke javac setelah opsi compiler global. |
neverlink
|
Boolean; defaultnya adalah tools.jar untuk apa pun
yang berjalan di JDK standar.
Perlu diperhatikan bahwa Jika library runtime berbeda dengan library kompilasi, Anda harus memastikan bahwa library tersebut hanya berbeda di tempat-tempat yang dilarang oleh JLS untuk compiler inline (dan yang harus berlaku untuk semua versi JLS di masa mendatang). |
output_licenses
|
Daftar string; default-nya adalah |
plugins
|
Daftar label; default-nya adalah java_plugin yang ditentukan dalam atribut ini akan dijalankan setiap kali aturan ini dibuat. Library juga dapat mewarisi plugin dari dependensi yang menggunakan
exported_plugins . Resource
yang dihasilkan oleh plugin akan disertakan dalam jar yang dihasilkan aturan ini.
|
processor_class
|
String; defaultnya adalah |
proguard_specs
|
Daftar label; default-nya adalah android_binary apa pun bergantung pada library ini.
File yang disertakan di sini hanya boleh memiliki aturan idempoten, yaitu -dontnote, -dontwarning, assumenosideimpact, dan aturan yang dimulai dengan -keep. Opsi lain hanya dapat muncul di
proguard_specs android_binary , untuk memastikan penggabungan non-tautological.
|
resource_strip_prefix
|
String; defaultnya adalah
Jika ditentukan, awalan jalur ini akan dihilangkan dari setiap file dalam atribut |
java_runtime
Lihat sumber aturanjava_runtime(name, srcs, compatible_with, default_cds, deprecation, distribs, exec_compatible_with, exec_properties, features, hermetic_srcs, hermetic_static_libs, java, java_home, lib_ct_sym, lib_modules, output_licenses, restricted_to, tags, target_compatible_with, testonly, toolchains, version, visibility)
Menentukan konfigurasi untuk runtime Java.
Contoh:
java_runtime(
name = "jdk-9-ea+153",
srcs = glob(["jdk9-ea+153/**"]),
java_home = "jdk9-ea+153",
)
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
srcs
|
Daftar label; default-nya adalah |
default_cds
|
Label; default-nya adalah java_runtime hermetic. Saat hermetic
diaktifkan untuk target java_binary dan jika target tidak
menyediakan arsip CDS-nya sendiri dengan menentukan
atribut classlist ,
CDS default java_runtime akan dikemas dalam JAR deploy hermetis.
|
hermetic_srcs
|
Daftar label; default-nya adalah |
hermetic_static_libs
|
Daftar label; default-nya adalah |
java
|
Label; default-nya adalah |
java_home
|
String; defaultnya adalah srcs dan java harus kosong.
|
lib_ct_sym
|
Label; default-nya adalah --release . Jika tidak ditentukan dan
tepat ada satu file di srcs yang jalurnya diakhiri dengan
/lib/ct.sym , file tersebut akan digunakan.
|
lib_modules
|
Label; default-nya adalah |
output_licenses
|
Daftar string; default-nya adalah |
version
|
Bilangan bulat; defaultnya adalah Runtime.version().feature() .
|
java_toolchain
Lihat sumber aturanjava_toolchain(name, android_lint_data, android_lint_jvm_opts, android_lint_opts, android_lint_package_configuration, android_lint_runner, bootclasspath, compatible_javacopts, compatible_with, deprecation, deps_checker, distribs, exec_compatible_with, exec_properties, features, forcibly_disable_header_compilation, genclass, header_compiler, header_compiler_builtin_processors, header_compiler_direct, ijar, jacocorunner, java_runtime, javabuilder, javabuilder_data, javabuilder_jvm_opts, javac_supports_multiplex_workers, javac_supports_worker_cancellation, javac_supports_worker_multiplex_sandboxing, javac_supports_workers, javacopts, jspecify_implicit_deps, jspecify_javacopts, jspecify_packages, jspecify_processor, jspecify_processor_class, jspecify_stubs, jvm_opts, licenses, misc, oneversion, oneversion_allowlist_for_tests, oneversion_whitelist, package_configuration, proguard_allowlister, reduced_classpath_incompatible_processors, restricted_to, singlejar, source_version, tags, target_compatible_with, target_version, testonly, timezone_data, toolchains, tools, turbine_data, turbine_jvm_opts, visibility, xlint)
Menentukan konfigurasi untuk compiler Java. Toolchain yang akan digunakan dapat diubah melalui argumen --java_ toolchain. Biasanya, Anda tidak perlu menulis aturan semacam itu kecuali jika Anda ingin men-tuning compiler Java.
Contoh
Contoh sederhananya adalah:
java_toolchain(
name = "toolchain",
source_version = "7",
target_version = "7",
bootclasspath = ["//tools/jdk:bootclasspath"],
xlint = [ "classfile", "divzero", "empty", "options", "path" ],
javacopts = [ "-g" ],
javabuilder = ":JavaBuilder_deploy.jar",
)
Argumen
Atribut | |
---|---|
name |
Nama; wajib diisi Nama unik untuk target ini. |
android_lint_data
|
Daftar label; default-nya adalah |
android_lint_jvm_opts
|
Daftar string; default-nya adalah |
android_lint_opts
|
Daftar string; default-nya adalah |
android_lint_package_configuration
|
Daftar label; default-nya adalah |
android_lint_runner
|
Label; default-nya adalah |
bootclasspath
|
Daftar label; default-nya adalah |
compatible_javacopts
|
null; default is |
deps_checker
|
Label; default-nya adalah |
forcibly_disable_header_compilation
|
Boolean; defaultnya adalah |
genclass
|
Label; default-nya adalah |
header_compiler
|
Label; default-nya adalah |
header_compiler_builtin_processors
|
Daftar string; default-nya adalah |
header_compiler_direct
|
Label; default-nya adalah Alat ini tidak mendukung pemrosesan anotasi. |
ijar
|
Label; default-nya adalah |
jacocorunner
|
Label; default-nya adalah |
java_runtime
|
Label; default-nya adalah |
javabuilder
|
Label; default-nya adalah |
javabuilder_data
|
Daftar label; default-nya adalah |
javabuilder_jvm_opts
|
Daftar string; default-nya adalah |
javac_supports_multiplex_workers
|
Boolean; defaultnya adalah |
javac_supports_worker_cancellation
|
Boolean; defaultnya adalah |
javac_supports_worker_multiplex_sandboxing
|
Boolean; defaultnya adalah |
javac_supports_workers
|
Boolean; defaultnya adalah |
javacopts
|
Daftar string; default-nya adalah |
jspecify_implicit_deps
|
Label; default-nya adalah |
jspecify_javacopts
|
Daftar string; default-nya adalah |
jspecify_packages
|
Daftar label; default-nya adalah |
jspecify_processor
|
Label; default-nya adalah |
jspecify_processor_class
|
String; defaultnya adalah |
jspecify_stubs
|
Daftar label; default-nya adalah |
jvm_opts
|
Daftar string; default-nya adalah |
misc
|
Daftar string; default-nya adalah |
oneversion
|
Label; default-nya adalah |
oneversion_allowlist_for_tests
|
Label; default-nya adalah |
oneversion_whitelist
|
Label; default-nya adalah |
package_configuration
|
Daftar label; default-nya adalah |
proguard_allowlister
|
Label; default-nya adalah |
reduced_classpath_incompatible_processors
|
Daftar string; default-nya adalah |
singlejar
|
Label; default-nya adalah |
source_version
|
String; defaultnya adalah |
target_version
|
String; defaultnya adalah |
timezone_data
|
Label; default-nya adalah |
tools
|
Daftar label; default-nya adalah |
turbine_data
|
Daftar label; default-nya adalah |
turbine_jvm_opts
|
Daftar string; default-nya adalah |
xlint
|
Daftar string; default-nya adalah |