नियम
proto_lang_toolchain
proto_lang_toolchain(name, blacklisted_protos, command_line, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, licenses, mnemonic, output_files, plugin, plugin_format_flag, progress_message, proto_compiler, restricted_to, runtime, tags, target_compatible_with, testonly, visibility)
समर्थन नहीं होना या रुकना. इसके बजाय, कृपया https://github.com/bazelbuild/rules_proto.
यह बताता है कि lang_proto_library नियम (उदाहरण के लिए, java_proto_library
) प्रोटो-कंपाइलर
को शुरू करना चाहिए.
कुछ lang_proto_library नियम यह तय करने की अनुमति देते हैं कि कमांड-लाइन फ़्लैग का इस्तेमाल करके, किस टूलचेन का इस्तेमाल करना है;
उनके दस्तावेज़ देखें.
आम तौर पर, आपको इस तरह के नियम तब तक नहीं लिखने चाहिए, जब तक कि आप अपने Java कंपाइलर को ट्यून न करना चाहें.
कोई कंपाइलर नहीं है. प्रोटो-कंपाइलर को उस Proto_library नियम से लिया जाता है जिससे हम जुड़े होते हैं. इसे Blaze को
कमांड-लाइन फ़्लैग के रूप में पास किया गया है.
कुछ सुविधाओं के लिए, Proto_library नियम पर ही प्रोटो-कंपाइलर शुरू करना ज़रूरी होता है.
lang_proto_library जिस कंपाइलर का इस्तेमाल करता है, बेहतर वही होता है
proto_library
.
उदाहरण
इसका एक आसान उदाहरण यह होगा:
proto_lang_toolchain( name = "javalite_toolchain", command_line = "--javalite_out=shared,immutable:$(OUT)", plugin = ":javalite_plugin", runtime = ":protobuf_lite", )
तर्क
एट्रिब्यूट | |
---|---|
name |
इस टारगेट के लिए एक खास नाम. |
blacklisted_protos
|
blacklisted_protos के srcs एट्रिब्यूट में मौजूद फ़ाइलों के लिए,
कोई कोड जनरेट नहीं किया जाएगा.
इसका इस्तेमाल .proto फ़ाइलों के लिए किया जाता है, जो पहले से ही प्रोटो रनटाइम से लिंक हैं, जैसे कि
any.proto .
|
command_line
|
|
mnemonic
|
|
output_files
|
command_line में $(OUT) को कैसे फ़ॉर्मैट किया जाए. इसके लिए, एक फ़ाइल के पाथ या कई फ़ाइलें होने पर आउटपुट डायरेक्ट्री इस्तेमाल की जा सकती है.
संभावित वैल्यू ये हैं: "एक", "एक से ज़्यादा".
|
plugin
|
--plugin=protoc-gen-PLUGIN=
|
plugin_format_flag
|
--plugin=protoc-gen-PLUGIN=
|
progress_message
|
|
proto_compiler
|
|
runtime
|
|
proto_library
proto_library(name, deps, srcs, data, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, exports, features, import_prefix, licenses, restricted_to, strip_import_prefix, tags, target_compatible_with, testonly, visibility)
समर्थन नहीं होना या रुकना. इसके बजाय, कृपया https://github.com/bazelbuild/rules_proto का इस्तेमाल करें.
proto_library
का इस्तेमाल करके, प्रोटोकॉल बफ़र की लाइब्रेरी तय करें, जिन्हें कई भाषाओं में इस्तेमाल किया जा सकता है. proto_library
को इस्तेमाल किए जा सकने वाले नियमों के deps
क्लॉज़ में शामिल किया जा सकता है, जैसे कि java_proto_library
.
कमांड लाइन से इकट्ठा किए जाने पर proto_library
, foo-descriptor-set.proto.bin
नाम की फ़ाइल बनाता है. यह फ़ाइल उन मैसेज के लिए डिस्क्रिप्टर सेट होती है जो नियम srcs से भेजे जाते हैं. फ़ाइल क्रम से दी गई FileDescriptorSet
है, जिसकी जानकारी
https://developers.google.com/protocol-buffers/docs/techniques#self-description में दी गई है.
इस फ़ाइल में सिर्फ़ उन .proto
फ़ाइलों के बारे में जानकारी है जिनके बारे में proto_library
नियम के तहत सीधे तौर पर बताया गया है. ट्रांज़िटिव डिस्क्रिप्टर के सेट, [ProtoInfo].transitive_descriptor_sets
Starlark की सेवा देने वाली कंपनी की मदद से उपलब्ध होती है.
ProtoInfo.java
में दस्तावेज़ देखें.
सुझाया गया कोड संगठन:
- हर
.proto
फ़ाइल के लिए एकproto_library
नियम. -
foo.proto
नाम की फ़ाइलfoo_proto
नाम के नियम में होगी और उसी पैकेज में मौजूद होगी. -
foo_proto
नाम केproto_library
को रैप करने वाला[language]_proto_library
,foo_[language]_proto
नाम का होना चाहिए. साथ ही, यह उसी पैकेज में मौजूद होना चाहिए.
तर्क
एट्रिब्यूट | |
---|---|
name |
इस टारगेट के लिए एक खास नाम. |
deps
|
proto_library नियमों की सूची, जिस पर टारगेट निर्भर करता है.
proto_library सिर्फ़ अन्य
proto_library टारगेट पर निर्भर हो सकता है.
यह मुमकिन है कि यह किसी भाषा की लाइब्रेरी पर निर्भर न हो.
|
srcs
|
.proto और .protodevel फ़ाइलों की सूची, जिन्हें टारगेट बनाने के लिए
प्रोसेस किया गया है. आम तौर पर, यह एक खाली सूची होती है. alias-लाइब्रेरी, एक ऐसे मामले में
इस्तेमाल का एक उदाहरण है जिसमें srcs खाली हो सकता है. यह
एक Proto_library नियम है, जिसमें deps में एक या एक से ज़्यादा अन्य proto_library होने चाहिए.
इस पैटर्न का इस्तेमाल, किसी स्थायी नाम के तहत सार्वजनिक एपीआई एक्सपोर्ट करने के लिए किया जा सकता है.
|
exports
|
|
import_prefix
|
सेट किए जाने पर, इस नियम के इस प्रीफ़िक्स को जोड़ने से पहले, |
strip_import_prefix
|
सेट किए जाने पर, इस नियम के अगर यह रिलेटिव पाथ है (स्लैश से शुरू नहीं होता), तो इसे पैकेज-रिलेटिव के तौर पर लिया जाता है. अगर यह पूरा है, तो इसे रिपॉज़िटरी-रिलेटिव पाथ के तौर पर माना जाता है. इस प्रीफ़िक्स को हटाने के बाद, |