Bazel 2.0 बिल्ड सिस्टमचे प्रकाशन

उपलब्ध खुल्या असेंब्ली टूल्सचे प्रकाशन बॅझेल 2.0, развиваемого инженерами из Google и используемого для сборки большинства внутренних проектов данной компании. Bazel обеспечивает сборку проекта, запуская необходимые компиляторы и тесты. Поддерживается сборка и тестирование кода на Java, C++, Objective-C, Python, Rust, Go и многих других языках, а также сборка мобильных приложений для Android и iOS. Код проекта द्वारा वितरित Apache 2.0 अंतर्गत परवानाकृत.

Значительное изменение версии связано с добавлением изменений, нарушающих обратную совместимость. Начиная с Bazel 2.0 включены по умолчанию режимы «—incompatible_remap_main_repo» (ссылки по имени и через @ теперь ссылаются на один репозиторий), «—incompatible_disallow_dict_lookup»_(применение нехешируемых ключей),
«—incompatible_remove_native_maven_jar» и «—incompatible_prohibit_aapt1». Среди других изменений:

  • В команде aquery появилась экспериментальная поддержка новой редауции формата вывода «proto» (—output=proto), которая пока отключена по умолчанию (—incompatible_proto_output_v2) и обеспечивает более компактное представление данных;
  • Добавлен флаг «—incompatible_remove_enabled_toolchain_types», позволяющий удалить поле PlatformConfiguration.enabled_toolchain_types;
  • Добавлена защита от загрузки пакетов, при загрузке которых при раскрытии путей используются цикличные символические ссылки;
  • Реализована возможность использования флага «—disk_cache» с внешними кэшами gRPC;
  • В пакет для Debian и бинарный инсталлятор включена улучшенная прослойка, обрабатывающая файлы ~/.bazelversion и переменную окружения $USE_BAZEL_VERSION;
  • В рамках подготовки к переводу файлов с манифестом runfiles в категорию устаревших возможностей добавлен флаг «—experimental_skip_runfiles_manifests».

Bazel च्या विशिष्ट वैशिष्ट्यांपैकी उच्च गती, विश्वसनीयता आणि असेंबली प्रक्रियेची पुनरावृत्ती क्षमता आहे. उच्च बिल्ड गती प्राप्त करण्यासाठी, बॅझेल बिल्ड प्रक्रियेसाठी कॅशिंग आणि समांतरीकरण तंत्र सक्रियपणे वापरते. BUILD फायलींनी सर्व अवलंबित्व पूर्णपणे परिभाषित केले पाहिजेत, ज्याच्या आधारावर बदल केल्यानंतर घटकांची पुनर्बांधणी करण्याचे निर्णय घेतले जातात (केवळ बदललेल्या फायली पुन्हा तयार केल्या जातात) आणि असेंबली प्रक्रियेला समांतर केले जाते. टूलिंग देखील पुनरावृत्ती करण्यायोग्य असेंब्ली सुनिश्चित करते, म्हणजे. डेव्हलपरच्या मशीनवर प्रोजेक्ट बनवण्याचा परिणाम थर्ड-पार्टी सिस्टीमवरील बिल्ड सारखाच असेल, जसे की सतत इंटिग्रेशन सर्व्हर.

मेक आणि निन्जाच्या विपरीत, बॅझेल असेंब्ली नियम तयार करण्यासाठी उच्च-स्तरीय दृष्टीकोन वापरते, ज्यामध्ये, तयार केल्या जात असलेल्या फाइल्ससाठी कमांडचे बंधन परिभाषित करण्याऐवजी, अधिक अमूर्त रेडीमेड ब्लॉक्स वापरले जातात, जसे की “एक्झिक्युटेबल फाइल तयार करणे C++", "C++ मध्ये लायब्ररी तयार करणे" किंवा "C++ साठी चाचणी चालवणे", तसेच लक्ष्य ओळखणे आणि प्लॅटफॉर्म तयार करणे. BUILD मजकूर फाईलमध्ये, प्रकल्प घटकांचे वर्णन वैयक्तिक फाइल्स आणि कंपाइलर कॉल कमांड्सच्या स्तरावर तपशील न करता, लायब्ररी, एक्झिक्युटेबल फाइल्स आणि चाचण्यांचा समूह म्हणून केले जाते. एक्स्टेंशन कनेक्ट करण्याच्या यंत्रणेद्वारे अतिरिक्त कार्यक्षमता लागू केली जाते.

Поддерживается использование единых сборочных файлов для разных платформ и архитектур, например, один файл сборки без изменений может применяться как для серверной системы, так и для мобильного устройства. Сборочная система изначально спроектирована для оптимальной сборки проектов Google, в том числе сборки очень больших проектов и проектов, содержащих код на нескольких языках программирования, требующих расширенного тестирования и собираемых для нескольких платформ.

स्त्रोत: opennet.ru

एक टिप्पणी जोडा