*Do not edit, this file is generated from comments to macros definitions using `ya dump conf-docs`.* # ya.make commands General info: [How to write ya.make files](https://wiki.yandex-team.ru/yatool/HowToWriteYaMakeFiles) ## Table of contents * [Multimodules](#multimodules) - Multimodule [DLL_JAVA](#multimodule_DLL_JAVA) - Multimodule [DOCS](#multimodule_DOCS) - Multimodule [FBS_LIBRARY](#multimodule_FBS_LIBRARY) - Multimodule [JAR_PROGRAM](#multimodule_JAR_PROGRAM) - Multimodule [JAVA_CONTRIB_PROGRAM](#multimodule_JAVA_CONTRIB_PROGRAM) - Multimodule [JAVA_PROGRAM](#multimodule_JAVA_PROGRAM) - Multimodule [JTEST](#multimodule_JTEST) - Multimodule [JTEST_FOR](#multimodule_JTEST_FOR) - Multimodule [JTEST_YMAKE](#multimodule_JTEST_YMAKE) - Multimodule [JUNIT5](#multimodule_JUNIT5) - Multimodule [JUNIT5_YMAKE](#multimodule_JUNIT5_YMAKE) - Multimodule [MAPS_IDL_LIBRARY](#multimodule_MAPS_IDL_LIBRARY) - Multimodule [MKDOCS](#multimodule_MKDOCS) - Multimodule [PROTO_LIBRARY](#multimodule_PROTO_LIBRARY) - Multimodule [PY23_LIBRARY](#multimodule_PY23_LIBRARY) - Multimodule [PY23_NATIVE_LIBRARY](#multimodule_PY23_NATIVE_LIBRARY) - Multimodule [PY23_TEST](#multimodule_PY23_TEST) - Multimodule [PY3TEST](#multimodule_PY3TEST) - Multimodule [PY3_PROGRAM](#multimodule_PY3_PROGRAM) - Multimodule [SANDBOX_PY23_TASK](#multimodule_SANDBOX_PY23_TASK) - Multimodule [SANDBOX_PY3_TASK](#multimodule_SANDBOX_PY3_TASK) - Multimodule [SANDBOX_TASK](#multimodule_SANDBOX_TASK) - Multimodule [SSQLS_LIBRARY](#multimodule_SSQLS_LIBRARY) - Multimodule [YQL_UDF](#multimodule_YQL_UDF) * [Modules](#modules) - Module [BOOSTTEST](#module_BOOSTTEST) - Module [BOOSTTEST_WITH_MAIN](#module_BOOSTTEST_WITH_MAIN) - Module [CI_GROUP](#module_CI_GROUP) - Module [CONTAINER](#module_CONTAINER) - Module [CONTAINER_LAYER](#module_CONTAINER_LAYER) - Module [CPP_STYLE_TEST](#module_CPP_STYLE_TEST) - Module [CUSTOM_BUILD_LIBRARY](#module_CUSTOM_BUILD_LIBRARY) - Module [DEFAULT_IOS_INTERFACE](#module_DEFAULT_IOS_INTERFACE) - Module [DLL](#module_DLL) - Module [DLL_TOOL](#module_DLL_TOOL) - Module [DOCS_LIBRARY](#module_DOCS_LIBRARY) - Module [EXECTEST](#module_EXECTEST) - Module [FAT_OBJECT](#module_FAT_OBJECT) - Module [FUZZ](#module_FUZZ) - Module [GO_DLL](#module_GO_DLL) - Module [GO_LIBRARY](#module_GO_LIBRARY) - Module [GO_PROGRAM](#module_GO_PROGRAM) - Module [GO_TEST](#module_GO_TEST) - Module [GTEST](#module_GTEST) - Module [GTEST_UGLY](#module_GTEST_UGLY) - Module [G_BENCHMARK](#module_G_BENCHMARK) - Module [IOS_INTERFACE](#module_IOS_INTERFACE) - Module [JAVA_CONTRIB](#module_JAVA_CONTRIB) - Module [JAVA_CONTRIB_PROXY](#module_JAVA_CONTRIB_PROXY) - Module [JAVA_LIBRARY](#module_JAVA_LIBRARY) - Module [LIBRARY](#module_LIBRARY) - Module [MCU_PROGRAM](#module_MCU_PROGRAM) - Module [PACKAGE](#module_PACKAGE) - Module [PROGRAM](#module_PROGRAM) - Module [PROTO_DESCRIPTIONS](#module_PROTO_DESCRIPTIONS) - Module [PROTO_REGISTRY](#module_PROTO_REGISTRY) - Module [PY2MODULE](#module_PY2MODULE) - Module [PY2TEST](#module_PY2TEST) - Module [PY2_LIBRARY](#module_PY2_LIBRARY) - Module [PY2_PROGRAM](#module_PY2_PROGRAM) - Module [PY3MODULE](#module_PY3MODULE) - Module [PY3TEST_BIN](#module_PY3TEST_BIN) - Module [PY3_LIBRARY](#module_PY3_LIBRARY) - Module [PY3_PROGRAM_BIN](#module_PY3_PROGRAM_BIN) - Module [PYCR_PROGRAM](#module_PYCR_PROGRAM) - Module [PYTEST_BIN](#module_PYTEST_BIN) - Module [PY_ANY_MODULE](#module_PY_ANY_MODULE) - Module [RECURSIVE_LIBRARY](#module_RECURSIVE_LIBRARY) - Module [RESOURCES_LIBRARY](#module_RESOURCES_LIBRARY) - Module [R_MODULE](#module_R_MODULE) - Module [SO_PROGRAM](#module_SO_PROGRAM) - Module [TS_BUNDLE](#module_TS_BUNDLE) - Module [TS_LIBRARY](#module_TS_LIBRARY) - Module [UDF](#module_UDF) - Module [UDF_LIB](#module_UDF_LIB) - Module [UNION](#module_UNION) - Module [UNITTEST](#module_UNITTEST) - Module [UNITTEST_FOR](#module_UNITTEST_FOR) - Module [UNITTEST_WITH_CUSTOM_ENTRY_POINT](#module_UNITTEST_WITH_CUSTOM_ENTRY_POINT) - Module [YCR_PROGRAM](#module_YCR_PROGRAM) - Module [YQL_PYTHON3_UDF](#module_YQL_PYTHON3_UDF) - Module [YQL_PYTHON3_UDF_TEST](#module_YQL_PYTHON3_UDF_TEST) - Module [YQL_PYTHON_UDF](#module_YQL_PYTHON_UDF) - Module [YQL_PYTHON_UDF_PROGRAM](#module_YQL_PYTHON_UDF_PROGRAM) - Module [YQL_PYTHON_UDF_TEST](#module_YQL_PYTHON_UDF_TEST) - Module [YQL_UDF_MODULE](#module_YQL_UDF_MODULE) - Module [YQL_UDF_TEST](#module_YQL_UDF_TEST) - Module [YT_UNITTEST](#module_YT_UNITTEST) - Module [Y_BENCHMARK](#module_Y_BENCHMARK) * [Macros](#macros) - Macros [AARS](#macro_AARS) .. [ADD_COMPILABLE_TRANSLATE](#macro_ADD_COMPILABLE_TRANSLATE) - Macros [ADD_COMPILABLE_TRANSLIT](#macro_ADD_COMPILABLE_TRANSLIT) .. [ALL_RESOURCE_FILES](#macro_ALL_RESOURCE_FILES) - Macros [ALL_SRCS](#macro_ALL_SRCS) .. [BPF](#macro_BPF) - Macros [BPF_STATIC](#macro_BPF_STATIC) .. [BUNDLE](#macro_BUNDLE) - Macros [CFLAGS](#macro_CFLAGS) .. [COLLECT_FRONTEND_FILES](#macro_COLLECT_FRONTEND_FILES) - Macros [COLLECT_JINJA_TEMPLATES](#macro_COLLECT_JINJA_TEMPLATES) .. [CONLYFLAGS](#macro_CONLYFLAGS) - Macros [COPY](#macro_COPY) .. [CREATE_INIT_PY_STRUCTURE](#macro_CREATE_INIT_PY_STRUCTURE) - Macros [CREDITS_DISCLAIMER](#macro_CREDITS_DISCLAIMER) .. [DECIMAL_MD5_LOWER_32_BITS](#macro_DECIMAL_MD5_LOWER_32_BITS) - Macros [DECLARE_EXTERNAL_HOST_RESOURCES_BUNDLE](#macro_DECLARE_EXTERNAL_HOST_RESOURCES_BUNDLE) .. [DLL_FOR](#macro_DLL_FOR) - Macros [DOCS_BUILDER](#macro_DOCS_BUILDER) .. [ELSEIF](#macro_ELSEIF) - Macros [EMBED_JAVA_VCS_INFO](#macro_EMBED_JAVA_VCS_INFO) .. [EXPORT_ALL_DYNAMIC_SYMBOLS](#macro_EXPORT_ALL_DYNAMIC_SYMBOLS) - Macros [EXPORT_YMAPS_PROTO](#macro_EXPORT_YMAPS_PROTO) .. [FILES](#macro_FILES) - Macros [FLATC_FLAGS](#macro_FLATC_FLAGS) .. [FUZZ_DICTS](#macro_FUZZ_DICTS) - Macros [FUZZ_OPTS](#macro_FUZZ_OPTS) .. [GO_BENCH_TIMEOUT](#macro_GO_BENCH_TIMEOUT) - Macros [GO_CGO1_FLAGS](#macro_GO_CGO1_FLAGS) .. [GO_GRPC_GATEWAY_SWAGGER_SRCS](#macro_GO_GRPC_GATEWAY_SWAGGER_SRCS) - Macros [GO_LDFLAGS](#macro_GO_LDFLAGS) .. [GO_TEST_EMBED_PATTERN](#macro_GO_TEST_EMBED_PATTERN) - Macros [GO_TEST_FOR](#macro_GO_TEST_FOR) .. [IF](#macro_IF) - Macros [INCLUDE](#macro_INCLUDE) .. [JAR_INCLUDE](#macro_JAR_INCLUDE) - Macros [JAR_RESOURCE](#macro_JAR_RESOURCE) .. [JAVA_TEST](#macro_JAVA_TEST) - Macros [JAVA_TEST_DEPS](#macro_JAVA_TEST_DEPS) .. [LICENSE_TEXTS](#macro_LICENSE_TEXTS) - Macros [LINKER_SCRIPT](#macro_LINKER_SCRIPT) .. [LLVM_COMPILE_LL](#macro_LLVM_COMPILE_LL) - Macros [LLVM_LINK](#macro_LLVM_LINK) .. [MAVEN_GROUP_ID](#macro_MAVEN_GROUP_ID) - Macros [MESSAGE](#macro_MESSAGE) .. [NO_CHECK_IMPORTS](#macro_NO_CHECK_IMPORTS) - Macros [NO_CLANG_COVERAGE](#macro_NO_CLANG_COVERAGE) .. [NO_JOIN_SRC](#macro_NO_JOIN_SRC) - Macros [NO_LIBC](#macro_NO_LIBC) .. [NO_RUNTIME](#macro_NO_RUNTIME) - Macros [NO_SANITIZE](#macro_NO_SANITIZE) .. [ORIGINAL_SOURCE](#macro_ORIGINAL_SOURCE) - Macros [OWNER](#macro_OWNER) .. [PIRE_INLINE_CMD](#macro_PIRE_INLINE_CMD) - Macros [PREPARE_INDUCED_DEPS](#macro_PREPARE_INDUCED_DEPS) .. [PYTHON](#macro_PYTHON) - Macros [PYTHON2_ADDINCL](#macro_PYTHON2_ADDINCL) .. [PY_MAIN](#macro_PY_MAIN) - Macros [PY_NAMESPACE](#macro_PY_NAMESPACE) .. [REAL_LINK_EXE_IMPL](#macro_REAL_LINK_EXE_IMPL) - Macros [RECURSE](#macro_RECURSE) .. [RESOURCE_FILES](#macro_RESOURCE_FILES) - Macros [RESTRICT_LICENSES](#macro_RESTRICT_LICENSES) .. [RUN_PROGRAM](#macro_RUN_PROGRAM) - Macros [RUN_PYTHON](#macro_RUN_PYTHON) .. [SET_APPEND_WITH_GLOBAL](#macro_SET_APPEND_WITH_GLOBAL) - Macros [SET_COMPILE_OUTPUTS_MODIFIERS](#macro_SET_COMPILE_OUTPUTS_MODIFIERS) .. [SRCS](#macro_SRCS) - Macros [SRC_C_AVX](#macro_SRC_C_AVX) .. [SRC_C_SSE41](#macro_SRC_C_SSE41) - Macros [SRC_C_SSSE3](#macro_SRC_C_SSSE3) .. [SYMLINK](#macro_SYMLINK) - Macros [SYSTEM_PROPERTIES](#macro_SYSTEM_PROPERTIES) .. [TIMEOUT](#macro_TIMEOUT) - Macros [UBERJAR](#macro_UBERJAR) .. [UPDATE_VCS_JAVA_INFO_NODEP](#macro_UPDATE_VCS_JAVA_INFO_NODEP) - Macros [USE_COMMON_GOOGLE_APIS](#macro_USE_COMMON_GOOGLE_APIS) .. [USE_PLANTUML](#macro_USE_PLANTUML) - Macros [USE_PYTHON2](#macro_USE_PYTHON2) .. [WINDOWS_MANIFEST](#macro_WINDOWS_MANIFEST) - Macros [WITHOUT_LICENSE_TEXTS](#macro_WITHOUT_LICENSE_TEXTS) .. [YABS_GENERATE_PHANTOM_CONF_PATCH](#macro_YABS_GENERATE_PHANTOM_CONF_PATCH) - Macros [YABS_GENERATE_PHANTOM_CONF_TEST_CHECK](#macro_YABS_GENERATE_PHANTOM_CONF_TEST_CHECK) .. [YT_SPEC](#macro_YT_SPEC) ## Multimodules ###### Multimodule [DLL\_JAVA][]() DLL built using swig for Java. Produces dynamic library and a .jar. Dynamic library is treated the same as in the case of PEERDIR from Java to DLL. .jar goes on the classpath. Documentation: https://wiki.yandex-team.ru/yatool/java/#integracijascpp/pythonsborkojj ###### Multimodule [DOCS][]() Documentation project multimodule. When built directly, via RECURSE, DEPENDS or BUNDLE the output artifact is docs.tar.gz with statically generated site. When PEERDIRed from other DOCS() module behaves like a UNION (supplying own content and dependencies to build target). Peerdirs from modules other than DOCS are not accepted. Most usual macros are not accepted, only used with the macros DOCS\_DIR(), DOCS\_CONFIG(), DOCS\_VARS(). @see: [DOCS\_DIR()](#macro\_DOCS\_DIR), [DOCS\_CONFIG()](#macro\_DOCS\_CONFIG), [DOCS\_VARS()](#macro\_DOCS\_VARS). ###### Multimodule [FBS\_LIBRARY][]() Build some variant of Flatbuffers library. The particular variant is selected based on where PEERDIR to FBS\_LIBRARY comes from. Now supported 5 variants: C++, Java, Python 2.x, Python 3.x and Go. When PEERDIR comes from module for particular language appropriate variant is selected. Notes: FBS\_NAMESPACE must be specified in all dependent FBS\_LIBRARY modules if build of Go code is requested. ###### Multimodule [JAR\_PROGRAM][] Not documented yet. ###### Multimodule [JAVA\_CONTRIB\_PROGRAM][] Not documented yet. ###### Multimodule [JAVA\_PROGRAM][]() The module describing java programs build. Output artifacts: .jar and directory with all the jar to the classpath of the formation. Documentation: https://wiki.yandex-team.ru/yatool/java/ ###### Multimodule [JTEST][] Not documented yet. ###### Multimodule [JTEST\_FOR][] Not documented yet. ###### Multimodule [JTEST\_YMAKE][] Not documented yet. ###### Multimodule [JUNIT5][] Not documented yet. ###### Multimodule [JUNIT5\_YMAKE][] Not documented yet. ###### Multimodule [MAPS\_IDL\_LIBRARY][]() Definition of multimodule that builds various variants of libraries. The particular variant is selected based on where PEERDIR to IDL\_LIBRARY comes from. Now supported 2 variants: C++, Java Java version is not really a library but an archive of generated Java sources ###### Multimodule [MKDOCS][]() Documentation project multimodule. When built directly, via RECURSE, DEPENDS or BUNDLE the output artifact is docs.tar.gz with statically generated site (using mkdocs as builder). When PEERDIRed from other MKDOCS() module behaves like a UNION (supplying own content and dependencies to build target). Peerdirs from modules other than MKDOCS are not accepted. Most usual macros are not accepted, only used with the macros DOCS\_DIR(), DOCS\_CONFIG(), DOCS\_VARS(). @see: [DOCS\_DIR()](#macro\_DOCS\_DIR), [DOCS\_CONFIG()](#macro\_DOCS\_CONFIG), [DOCS\_VARS()](#macro\_DOCS\_VARS). ###### Multimodule [PROTO\_LIBRARY][]() Build some varian of protocol buffers library. The particular variant is selected based on where PEERDIR to PROTO\_LIBRARY comes from. Now supported 5 variants: C++, Java, Python 2.x, Python 3.x and Go. When PEERDIR comes from module for particular language appropriate variant is selected. PROTO\_LIBRARY also supports emission of GRPC code if GRPC() macro is specified. Notes: - Python versions emit C++ code in addition to Python as optimization. - In some PROTO\_LIBRARY-es Java or Python versions are excluded via EXCLUDE\_TAGS macros due to incompatibilities. - Use from DEPENDS or BUNDLE is not allowed Documentation: https://wiki.yandex-team.ru/yatool/proto\_library/ See: [GRPC()](#macro\_GRPC), [OPTIMIZE\_PY\_PROTOS()](#macro\_OPTIMIZE\_PY\_PROTOS), [INCLUDE\_TAGS()](#macro\_INCLUDE\_TAGS), [EXCLUDE\_TAGS()](#macro\_EXCLUDE\_TAGS) ###### Multimodule [PY23\_LIBRARY][]([name]) Build PY2\_LIBRARY or PY3\_LIBRARY depending on incoming PEERDIR. Direct build or build by RECURSE creates both variants. This multimodule doesn't define any final targets, so use from DEPENDS or BUNDLE is not allowed. Documentation: https://wiki.yandex-team.ru/arcadia/python/pysrcs ###### Multimodule [PY23\_NATIVE\_LIBRARY][]([name]) Build LIBRARY compatible with either Python 2.x or Python 3.x depending on incoming PEERDIR. This multimodule doesn't depend on Arcadia Python binary build. It is intended only for C++ code and cannot contain PY\_SRCS and USE\_PYTHON2 macros. Use these multimodule instead of PY23\_LIBRARY if the C++ extension defined in it will be used in PY2MODULE. While it doesn't bring Arcadia Python dependency itself, it is still compatible with Arcadia Python build and can be PEERDIR-ed from PY2\_LIBRARY and alikes. Proper version will be selected according to Python version of the module PEERDIR comes from. This mulrtimodule doesn't define any final targets so cannot be used from DEPENDS or BUNDLE macros. For more information read https://wiki.yandex-team.ru/arcadia/python/pysrcs/#pysrcssrcsipy23nativelibrary @see [LIBRARY()](#module\_LIBRARY), [PY2MODULE()](#module\_PY2MODULE) ###### Multimodule [PY23\_TEST][] Not documented yet. ###### Multimodule [PY3TEST][]([name]) The test module for Python 3.x based on py.test This module is compatible only with PYTHON3-tagged modules and selects peers from multimodules accordingly. This module is only compatible with Arcadia Python build (to avoid tests duplication from Python2/3-tests). For non-Arcadia python use PYTEST. Documentation: https://wiki.yandex-team.ru/yatool/test/#testynapytest Documentation about the Arcadia test system: https://wiki.yandex-team.ru/yatool/test/ ###### Multimodule [PY3\_PROGRAM][]([progname]) Python 3.x binary program. Links all Python 3.x libraries and Python 3.x interpreter into itself to form regular executable. If name is not specified it will be generated from the name of the containing project directory. This only compatible with PYTHON3-tagged modules and selects those from multimodules. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs/ ###### Multimodule [SANDBOX\_PY23\_TASK][] Not documented yet. ###### Multimodule [SANDBOX\_PY3\_TASK][]([Name]) Multimodule describing Sandbox task (Python3 code that can be executed by Sandbox system). When being a final target, this multimodule builds Sandbox binary task. It may PEERDIR other SANDBOX\_PY3\_TASKs as libraries. The final artifact is provided when SANDBOX\_PY3\_TASK is referred to by DEPENDS and BUNDLE macros. As PEERDIR target, it works like regular PY3\_LIBRARY with predefined dependencies on Sandbox SDK to allow code reuse among SANDBOX\_PY3\_TASKs. Currently Sandbox supports Python 3.x only in binary tasks, both variants will be compatible only with Python 3.x and py23 libraries and will select multimodule variants accordingly. Documentation: https://wiki.yandex-team.ru/sandbox/tasks/binary ###### Multimodule [SANDBOX\_TASK][]([Name]) Multimodule describing Sandbox task (Python code that can be executed by Sandbox system). When being a final target, this multimodule builds Sandbox binary task. It may PEERDIR other SANDBOX\_TASKs as libraries. The final artifact is provided when SANDBOX\_TASK is referred to by DEPENDS and BUNDLE macros. As PEERDIR target, it works like regular PY2\_LIBRARY with predefined dependencies on Sandbox SDK to allow code reuse among SANDBOX\_TASKs. Currently Sandbox supports only Python 2.x, so both variants will be compatible only with Python 2.x modules and will select multimodule variants accordingly. Documentation: https://wiki.yandex-team.ru/sandbox/tasks/binary ###### Multimodule [SSQLS\_LIBRARY][] Not documented yet. ###### Multimodule [YQL\_UDF][](name) User-defined function for YQL Multimodule which is YQL\_UDF\_MODULE when built directly or referred by BUNDLE and DEPENDS macros. If used by PEERDIRs it is usual static LIBRARY with default YQL dependencies, allowing code reuse between UDFs. @see: [YQL\_UDF\_MODULE()](#module\_YQL\_UDF\_MODULE) ## Modules ###### Module [BOOSTTEST][]([name]) _#deprecated_ Test module based on boost/test/unit\_test.hpp. As with entire boost library usage of this technology is deprecated in Arcadia and restricted with configuration error in most of projects. No new module of this type should be introduced unless it is explicitly approved by C++ committee. ###### Module [BOOSTTEST\_WITH\_MAIN][]([name]) _#deprecated_ Same as BOOSTTEST (see above), but comes with builtin int main(argc, argv) implementation ###### Module [CI\_GROUP][]() Module collects what is described directly inside it transitively by PEERDIRs. No particular layout of built artifacts is implied. This module is needed primarily for CI dependency analysis and may not trigger builds at all. Is only used together with the macro PEERDIR() and FILES(). Don't use SRCS inside CI\_GROUP(). ###### Module [CONTAINER][]: \_BARE\_UNIT Not documented yet. ###### Module [CONTAINER\_LAYER][]: \_BARE\_UNIT Not documented yet. ###### Module [CPP\_STYLE\_TEST][]: PY3TEST\_BIN Not documented yet. ###### Module [CUSTOM\_BUILD\_LIBRARY][]: LIBRARY Not documented yet. ###### Module [DEFAULT\_IOS\_INTERFACE][]: IOS\_INTERFACE Not documented yet. ###### Module [DLL][](name major\_ver [minor\_ver] [EXPORTS symlist\_file] [PREFIX prefix]) Dynamic library module definition. 1. major\_ver and minor\_ver must be integers. 2. EXPORTS allows you to explicitly specify the list of exported functions. This accepts 2 kind of files: .exports with pairs and JSON-line .symlist files 3. PREFIX allows you to change the prefix of the output file (default DLL has the prefix "lib"). DLL cannot participate in linking to programs but can be used from Java or as final artifact (packaged and deployed). ###### Module [DLL\_TOOL][] DLL\_TOOL is a DLL that can be used as a LD\_PRELOAD tool. ###### Module [DOCS\_LIBRARY][]: \_DOCS\_BARE\_UNIT Not documented yet. ###### Module [EXECTEST][]() Module definition of generic test that executes a binary. Use macro RUN to specify binary to run. @example: EXECTEST() OWNER(g:yatool) RUN( cat input.txt ) DATA( arcadia/devtools/ya/test/tests/exectest/data ) DEPENDS( devtools/dummy_arcadia/cat ) TEST_CWD(devtools/ya/test/tests/exectest/data) END() More examples: https://wiki.yandex-team.ru/yatool/test/#exec-testy @see: [RUN()](#macro\_RUN) ###### Module [FAT\_OBJECT][]() The "fat" object module. It will contain all its transitive dependencies reachable by PEERDIRs: static libraries, local (from own SRCS) and global (from peers') object files. Designed for use in XCode projects for iOS. ###### Module [FUZZ][]() In order to start using Fuzzing in Arcadia, you need to create a FUZZ module with the implementation of the function LLVMFuzzerTestOneInput(). This module should be reachable by RECURSE from /autocheck project in order for the corpus to be regularly updated. AFL and Libfuzzer are supported in Arcadia via a single interface, but the automatic fuzzing still works only through Libfuzzer. Example: https://a.yandex-team.ru/arc/trunk/arcadia/contrib/libs/re2/re2/fuzzing/re2\_fuzzer.cc?rev=2919463#L58 Documentation: https://wiki.yandex-team.ru/yatool/fuzzing/ ###### Module [GO\_DLL][](name major\_ver [minor\_ver] [PREFIX prefix]) Go ishared object module definition. Compile and link Go module to a shared object. Will select Go implementation on PEERDIR to PROTO\_LIBRARY. ###### Module [GO\_LIBRARY][]([name]) Go library module definition. Compile Go module as a library suitable for PEERDIR from other Go modules. Will select Go implementation on PEERDIR to PROTO\_LIBRARY. ###### Module [GO\_PROGRAM][]([name]) Go program module definition. Compile and link Go module to an executable program. Will select Go implementation on PEERDIR to PROTO\_LIBRARY. ###### Module [GO\_TEST][]([name]) Go test module definition. Compile and link Go module as a test suitable for running with Arcadia testing support. All usual testing support macros like DATA, DEPENDS, SIZE, REQUIREMENTS etc. are supported. Will select Go implementation on PEERDIR to PROTO\_LIBRARY. ###### Module [GTEST][]([name]) Unit test module based on library/cpp/testing/gtest. It is recommended not to specify the name. Documentation: https://docs.yandex-team.ru/arcadia-cpp/cpp\_test ###### Module [GTEST\_UGLY][]([name]) Deprecated, do not use in new projects. Use GTEST instead. The test module based on gtest (contrib/libs/gtest contrib/libs/gmock). Use public documentation on gtest for details. Documentation about the Arcadia test system: https://wiki.yandex-team.ru/yatool/test/ ###### Module [G\_BENCHMARK][]([benchmarkname]) Benchmark test based on the google benchmark. For more details see: https://a.yandex-team.ru/arc/trunk/arcadia/contrib/libs/benchmark/README.md ###### Module [IOS\_INTERFACE][]() iOS GUI module definition ###### Module [JAVA\_CONTRIB][]: \_JAR\_BASE Not documented yet. ###### Module [JAVA\_CONTRIB\_PROXY][]: \_JAR\_BASE Not documented yet. ###### Module [JAVA\_LIBRARY][]() The module describing java library build. Documentation: https://wiki.yandex-team.ru/yatool/java/ ###### Module [LIBRARY][]() The regular static library module. The LIBRARY() is intermediate module, so when built directly it won't build its dependencies. It transitively provides its PEERDIRs to ultimate final target, where all LIBRARY() modules are built and linked together. This is C++ library, and it selects peers from multimodules accordingly. It makes little sense to mention LIBRARY in DEPENDS or BUNDLE, package and deploy it since it is not a standalone entity. In order to use library in tests PEERDIR it to link into tests. If you think you need to distribute static library please contact devtools@ for assistance. ###### Module [MCU\_PROGRAM][]([progname]) Program module for microcontrollers. Converts ELF to Intel HEX, Motorola S-record and raw binary file formats. If name is not specified it will be generated from the name of the containing project directory. ###### Module [PACKAGE][](name) Module collects what is described directly inside it, builds and collects all its transitively available PEERDIRs. As a result, build directory of the project gets the structure of the accessible part of Arcadia, where the build result of each PEERDIR is placed to relevant Arcadia subpath. The data can be optionally packed if macro PACK() is used. Is only used together with the macros FILES(), PEERDIR(), COPY(), FROM\_SANDBOX(), RUN\_PROGRAM or BUNDLE(). Don't use SRCS inside a PACKAGE. Documentation: https://wiki.yandex-team.ru/yatool/large-data/ @see: [PACK()](#macro\_PACK) ###### Module [PROGRAM][]([progname]) Regular program module. If name is not specified it will be generated from the name of the containing project directory. ###### Module [PROTO\_DESCRIPTIONS][]: \_BARE\_UNIT Not documented yet. ###### Module [PROTO\_REGISTRY][]: PROTO\_DESCRIPTIONS Not documented yet. ###### Module [PY2MODULE][](name major\_ver [minor\_ver] [EXPORTS symlist\_file] [PREFIX prefix]) The Python external module for Python2 and any system Python 1. major\_ver and minor\_ver must be integers. 2. The resulting .so will have the prefix "lib". 3. Processing EXPORTS and PREFIX is the same as for DLL module This is native DLL, so it will select C++ version from PROTO\_LIBRARY. Note: this module will always PEERDIR Python2 version of PY23\_NATIVE\_LIBRARY. Do not PEERDIR PY2\_LIBRARY or PY23\_LIBRARY: this will link Python in and render artifact unusable as Python module. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs/ ###### Module [PY2TEST][]([name]) The test module for Python 2.x based on py.test This module is compatible only with PYTHON2-tagged modules and selects peers from multimodules accordingly. This module is compatible with non-Arcadia Python builds. Documentation: https://wiki.yandex-team.ru/yatool/test/#python Documentation about the Arcadia test system: https://wiki.yandex-team.ru/yatool/test/ ###### Module [PY2\_LIBRARY][]() _# deprecated_ Deprecated. Use PY23\_LIBRARY or PY3\_LIBRARY instead. Python 2.x binary built library. Builds sources from PY\_SRCS to data suitable for PY2\_PROGRAM. Adds dependencies to Python 2.x runtime library from Arcadia. This module is only compatible with PYTHON2-tagged modules and selects those from multimodules. This module is only compatible with Arcadia Python build. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs/ ###### Module [PY2\_PROGRAM][]([progname]) _# deprecated_ Deprecated. Use PY3\_PROGRAM instead. Python 2.x binary program. Links all Python 2.x libraries and Python 2.x interpreter into itself to form regular executable. If name is not specified it will be generated from the name of the containing project directory. This only compatible with PYTHON2-tagged modules and selects those from multimodules. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs/ ###### Module [PY3MODULE][](name major\_ver [minor\_ver] [EXPORTS symlist\_file] [PREFIX prefix]) The Python external module for Python3 and any system Python 1. major\_ver and minor\_ver must be integers. 2. The resulting .so will have the prefix "lib". 3. Processing EXPORTS and PREFIX is the same as for DLL module This is native DLL, so it will select C++ version from PROTO\_LIBRARY. Note: this module will always PEERDIR Python3 version of PY23\_NATIVE\_LIBRARY. Do not PEERDIR PY3\_LIBRARY or PY23\_LIBRARY: this will link Python in and render artifact unusable as Python module. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs/ ###### Module [PY3TEST\_BIN][]() _#deprecated_ Same as PY3TEST. Don't use this, use PY3TEST instead. ###### Module [PY3\_LIBRARY][]() Python 3.x binary library. Builds sources from PY\_SRCS to data suitable for PY2\_PROGRAM Adds dependencies to Python 2.x runtime library from Arcadia. This module is only compatible with PYTHON3-tagged modules and selects those from multimodules. This module is only compatible with Arcadia Python build. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs/ ###### Module [PY3\_PROGRAM\_BIN][]([progname]) Use instead of PY3\_PROGRAM only if ya.make with PY3\_PROGRAM() included in another ya.make In all other cases use PY3\_PROGRAM ###### Module [PYCR\_PROGRAM][]([progname]) pycare-specific program module. Generates pycare configs in addition to producing the program. If name is not specified it will be generated from the name of the containing project directory. ###### Module [PYTEST\_BIN][]() _#deprecated_ Same as PY2TEST. Don't use this, use PY2TEST instead. ###### Module [PY\_ANY\_MODULE][](name major\_ver [minor\_ver] [EXPORTS symlist\_file] [PREFIX prefix]) The Python external module for any versio of Arcadia or system Python. 1. major\_ver and minor\_ver must be integers. 2. The resulting .so will have the prefix "lib". 3. Processing EXPORTS and PREFIX is the same as for DLL module This is native DLL, so it will select C++ version from PROTO\_LIBRARY. Note: Use PYTHON2\_MODULE()/PYTHON3\_MODULE() in order to PEERDIR proper version of PY23\_NATIVE\_LIBRARY. Do not PEERDIR any PY\*\_LIBRARY: this will link Python in and render artifact unusable as Python module. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs/ ###### Module [RECURSIVE\_LIBRARY][]() The recursive ("fat") library module. It will contain all its transitive dependencies reachable by PEERDIRs: from static libraries, local (from own SRCS) and global (from peers') object files. Designed for use in XCode projects for iOS. ###### Module [RESOURCES\_LIBRARY][]() Definition of a module that brings its content from external source (Sandbox) via DECLARE\_EXTERNAL\_RESOURCE macro. This can participate in PEERDIRs of others as library but it cannot have own sources and PEERDIRs. @see: [DECLARE\_EXTERNAL\_RESOURCE()](#macro\_DECLARE\_EXTERNAL\_RESOURCE) ###### Module [R\_MODULE][](name major\_ver [minor\_ver] [EXPORTS symlist\_file] [PREFIX prefix]) The external module for R language. 1. major\_ver and minor\_ver must be integers. 2. The resulting .so will have the prefix "lib". 3. Processing EXPORTS and PREFIX is the same as for DLL module This is native DLL, so it will select C++ version from PROTO\_LIBRARY. ###### Module [SO\_PROGRAM][](name major\_ver [minor\_ver] [EXPORTS symlist\_file] [PREFIX prefix]) Executable dynamic library module definition. 1. major\_ver and minor\_ver must be integers. 2. EXPORTS allows you to explicitly specify the list of exported functions. This accepts 2 kind of files: .exports with pairs and JSON-line .symlist files 3. PREFIX allows you to change the prefix of the output file. ###### Module [TS\_BUNDLE][]([name]) The Webpack bundle, bundles JavaScript code. Build results are bundle.tar, typings and source mappings (depending on local tsconfig.json settings). @see [NODE\_MODULES()](#macro\_NODE\_MODULES) @example TS_BUNDLE() SRCS(src/index.ts) NODE_MODULES() END() ###### Module [TS\_LIBRARY][]([name]) The TypeScript/JavaScript library module, compiles TypeScript sources to JavaScript. Build results are JavaScript files, typings and source mappings (depending on local tsconfig.json settings). @see [NODE\_MODULES()](#macro\_NODE\_MODULES) @example TS_LIBRARY() SRCS(src/index.ts) NODE_MODULES() END() ###### Module [UDF][](name [EXPORTS symlist\_file] [PREFIX prefix]) _# deprecated_ The KiWi UDF module. Processing EXPORTS and PREFIX is the same as for DLL. https://wiki.yandex-team.ru/robot/manual/kiwi/userguide/#polzovatelskiefunkciiudftriggerykwcalc ###### Module [UDF\_LIB][]([name]) _# deprecated_ The LIBRARY module for KiWi UDF, so has default PEERDIR to yweb/robot/kiwi/kwcalc/udflib. ###### Module [UNION][](name) Collection of PEERDIR dependencies, files and artifacts. UNION doesn't build its peers, just provides those to modules depending on it. When specified in DEPENDS() macro the UNION is transitively closed, building all its peers and providing those by own paths (without adding this module path like PACKAGE does). Is only used together with the macros like FILES(), PEERDIR(), COPY(), FROM\_SANDBOX(), RUN\_PROGRAM or BUNDLE(). Don't use SRCS inside a UNION. Documentation: https://wiki.yandex-team.ru/yatool/large-data/ ###### Module [UNITTEST][]([name]) Unit test module based on library/cpp/testing/unittest. It is recommended not to specify the name. Documentation: https://wiki.yandex-team.ru/yatool/test/#opisanievya.make1 ###### Module [UNITTEST\_FOR][](path/to/lib) Convenience extension of UNITTEST module. The UNINTTEST module with additional SRCDIR + ADDINCL + PEERDIR on path/to/lib. path/to/lib is the path to the directory with the LIBRARY project. Documentation about the Arcadia test system: https://wiki.yandex-team.ru/yatool/test/ ###### Module [UNITTEST\_WITH\_CUSTOM\_ENTRY\_POINT][]([name]) Generic unit test module. ###### Module [YCR\_PROGRAM][]([progname]) yacare-specific program module. Generates yacare configs in addition to producing the program. If name is not specified it will be generated from the name of the containing project directory. ###### Module [YQL\_PYTHON3\_UDF][](name) The extension module for YQL with Python 3.x UDF (User Defined Function for YQL). Unlike YQL\_UDF this is plain DLL module, so PEERDIRs to it are not allowed. Documentation: https://yql.yandex-team.ru/docs/yt/udf/python/ ###### Module [YQL\_PYTHON3\_UDF\_TEST][](name) The Python test for Python 3.x YQL UDF (User Defined Function for YQL). The code should be a proper YQL\_PYTHON3\_UDF. This module will basically build itself as UDF and run as test using yql/tools/run\_python\_udf/run\_python\_udf tool. Documentation: https://yql.yandex-team.ru/docs/yt/udf/python/ @see: [YQL\_PYTHON3\_UDF()](#module\_YQL\_PYTHON3\_UDF) ###### Module [YQL\_PYTHON\_UDF][](name) Definition of the extension module for YQL with Python 2.x UDF (User Defined Function for YQL). Unlike YQL\_UDF this is plain DLL module, so PEERDIRs to it are not allowed. https://yql.yandex-team.ru/docs/yt/udf/python/ ###### Module [YQL\_PYTHON\_UDF\_PROGRAM][](name) Definition of the extension module for YQL with Python 2.x UDF (User Defined Function for YQL). Unlike YQL\_UDF this is plain DLL module, so PEERDIRs to it are not allowed. https://yql.yandex-team.ru/docs/yt/udf/python/ ###### Module [YQL\_PYTHON\_UDF\_TEST][](name) The Python test for Python YQL UDF (Python User Defined Function for YQL). The code should be a proper YQL\_PYTHON\_UDF. This module will basically build itself as UDF and run as test using yql/tools/run\_python\_udf/run\_python\_udf tool. Documentation: https://yql.yandex-team.ru/docs/yt/udf/python/ @example: https://a.yandex-team.ru/arc/trunk/arcadia/yql/udfs/test/simple/ya.make @see: [YQL\_PYTHON\_UDF()](#module\_YQL\_PYTHON\_UDF) ###### Module [YQL\_UDF\_MODULE][](name) The extension module for YQL with C++ UDF (User Defined Function YQL) https://yql.yandex-team.ru/docs/yt/udf/cpp/ ###### Module [YQL\_UDF\_TEST][]([name]) The module to test YQL C++ UDF. Documentation: https://yql.yandex-team.ru/docs/yt/libraries/testing/ Documentation about the Arcadia test system: https://wiki.yandex-team.ru/yatool/test/ ###### Module [YT\_UNITTEST][]([name]) YT Unit test module based on mapreduce/yt/library/utlib ###### Module [Y\_BENCHMARK][]([benchmarkname]) Benchmark test based on the library/cpp/testing/benchmark. For more details see: https://wiki.yandex-team.ru/yatool/test/#zapuskbenchmark ## Macros ###### Macro [AARS][](Aars...) This macro is strictly prohibited to use outside of mapsmobi project ###### Macro [AAR\_GRADLE\_SCRIPT\_GENERATOR][](python\_script) Not documented yet. ###### Macro [AAR\_LOCAL\_MAVEN\_REPO][](repo...) Not documented yet. ###### Macro [ACCELEO][](XSD{input}[], MTL{input}[], MTL\_ROOT="${MODDIR}", LANG{input}[], OUT{output}[], OUT\_NOAUTO{output}[], OUTPUT\_INCLUDES[], DEBUG?"stdout2stderr":"stderr2stdout") Not documented yet. ###### Macro [ADDINCL][]([FOR ][GLOBAL dir]\* dirlist) _# builtin_ The macro adds the directories to include/import search path to compilation flags of the current project. By default settings apply to C/C++ compilation namely sets -I flag, use FOR argument to change target command. @params: `FOR ` - adds inclues/import serach path for othe language. E.g. `FOR proto` adds import search path for .proto files processing. `GLOBAL` - extends the search for headers (-I) on the dependent projects. ###### Macro [ADDINCLSELF][]() The macro adds the -I flag to the source compilation flags of the current project. ###### Macro [ADD\_CHECK][] Not documented yet. ###### Macro [ADD\_CHECK\_PY\_IMPORTS][] Not documented yet. ###### Macro [ADD\_CLANG\_TIDY][]() Not documented yet. ###### Macro [ADD\_COMPILABLE\_TRANSLATE][](Dict Name Options...) Generate translation dictionary code to transdict.LOWER(Name).cpp that will than be compiled into library ###### Macro [ADD\_COMPILABLE\_TRANSLIT][](TranslitTable NGrams Name Options...) Generate transliteration dictionary code This will emit both translit, untranslit and ngrams table codes those will be than further compiled into library ###### Macro [ADD\_DLLS\_TO\_JAR][]() Not documented yet. ###### Macro [ADD\_PERL\_MODULE][](Dir ModuleName) Add dependency on specified Perl module to the library ###### Macro [ADD\_PYTEST\_BIN][] Not documented yet. ###### Macro [ADD\_PYTEST\_SCRIPT][] Not documented yet. ###### Macro [ADD\_YTEST][] Not documented yet. ###### Macro [ALLOCATOR][](Alloc) _# Default: LF_ Set memory allocator implementation for the PROGRAM()/DLL() module. This may only be specified for programs and dlls, use in other modules leads to configuration errors. Available allocators are: "LF", "LF\_YT", "LF\_DBG", "YT", "J", "B", "BM", "C", "TCMALLOC", "GOOGLE", "LOCKLESS", "SYSTEM", "FAKE", "MIM", "HU". - LF - lfalloc (https://a.yandex-team.ru/arc/trunk/arcadia/library/cpp/lfalloc) - LF\_YT - Allocator selection for YT (https://a.yandex-team.ru/arc/trunk/arcadia/library/cpp/lfalloc/yt/ya.make) - LF\_DBG - Debug allocator selection (https://a.yandex-team.ru/arc/trunk/arcadia/library/cpp/lfalloc/dbg/ya.make) - YT - The YTAlloc allocator (https://a.yandex-team.ru/arc/trunk/arcadia/library/cpp/ytalloc/impl/ya.make) - J - The JEMalloc allocator (https://a.yandex-team.ru/arc/trunk/arcadia/library/malloc/jemalloc) - B - The balloc allocator named Pyotr Popov and Anton Samokhvalov - Discussion: https://ironpeter.at.yandex-team.ru/replies.xml?item\_no=126 - Code: https://a.yandex-team.ru/arc/trunk/arcadia/library/cpp/balloc - BM - The balloc for market (agri@ commits from july 2018 till November 2018 saved) - C - Like B, but can be disabled for each thread to LF or SYSTEM one (B can be disabled only to SYSTEM) - MIM - Microsoft's mimalloc (actual version) (https://a.yandex-team.ru/arc/trunk/arcadia/library/malloc/mimalloc) - TCMALLOC - Google TCMalloc (actual version) (https://a.yandex-team.ru/arc/trunk/arcadia/library/malloc/tcmalloc) - GOOGLE - Google TCMalloc (https://a.yandex-team.ru/arc/trunk/arcadia/library/malloc/galloc) - LOCKLESS - Allocator based upon lockless queues (https://a.yandex-team.ru/arc/trunk/arcadia/library/malloc/lockless) - SYSTEM - Use target system allocator - FAKE - Don't link with any allocator More about allocators in Arcadia: https://wiki.yandex-team.ru/arcadia/allocators/ ###### Macro [ALL\_PYTEST\_SRCS][]([RECURSIVE] [Dirs...]) Puts all .py-files from given Dirs (relative to projects') into TEST\_SRCS of the current module. If Dirs is omitted project directory is used `RECURSIVE` makes lookup recursive with respect to Dirs Note: Only one such macro per module is allowed Note: Macro is designed to reject any ya.make files in Dirs except current one @see [TEST\_SRCS()](#macro\_TEST\_SRCS) ###### Macro [ALL\_PY\_SRCS][]([RECURSIVE] { | TOP\_LEVEL | NAMESPACE ns} [Dirs...]) Puts all .py-files from given Dirs (relative to projects') into PY\_SRCS of the current module. If Dirs is ommitted project directory is used `RECURSIVE` makes lookup recursive with resprect to Dirs `TOP\_LEVEL` and `NAMESPACE` are forwarded to `PY\_SRCS` Note: Only one such macro per module is allowed Note: Macro is designed to reject any ya.make files in Dirs except current one @see [PY\_SRCS()](#macro\_PY\_SRCS) ###### Macro [ALL\_RESOURCE\_FILES][](Ext [PREFIX {prefix}] [STRIP {strip}] Dirs...) This macro collects all files with extension `Ext` and Passes them to `RESOURCE\_FILES` macro as relative to current directory `PREFIX` and `STRIP` have the same meaning as in `ROURCES\_FILES`, both are applied over moddir-relative paths Note: This macro can be used multiple times per ya.make, but only once for each Ext value Note: Wildcards are not allowed neither as Ext nor in Dirs ###### Macro [ALL\_SRCS][]([GLOBAL] filenames...) Make all source files listed as GLOBAL or not depending on the keyword GLOBAL Call to ALL\_SRCS macro is equivalent to call to GLOBAL\_SRCS macro when GLOBAL keyword is specified as the first argument and is equivalent to call to SRCS macro otherwise. @example: LIBRARY() SET(MAKE_IT_GLOBAL GLOBAL) ALL_SRCS(${MAKE_IT_GLOBAL} foo.cpp bar.cpp) END() @see: [GLOBAL\_SRCS()](#macro\_GLOBAL\_SRCS), [SRCS()](#macro\_SRCS) ###### Macro [ANNOTATION\_PROCESSOR][](processors...) The macro is in development. Used to specify annotation processors to build JAVA\_PROGRAM() and JAVA\_LIBRARY(). ###### Macro [APPHOST][]() Emit APPHOST service code for all .proto files in a PROTO\_LIBRARY. This works only for C++ and Java at the moment. ###### Macro [ARCHIVE][](archive\_name [DONT\_COMPRESS] files...) Add arbitrary data to a modules. Unlike RESOURCE macro the result should be futher processed by othet macros in the module. Example: https://wiki.yandex-team.ru/yatool/howtowriteyamakefiles/#a1ispolzujjtekomanduarchive ###### Macro [ARCHIVE\_ASM][](NAME archive\_name files...) Similar to the macro ARCHIVE, but: 1. works faster and it is better to use for large files. 2. Different syntax (see examples in codesearch or users/pg/tests/archive\_test) ###### Macro [ARCHIVE\_BY\_KEYS][](archive\_name key [DONT\_COMPRESS] files...) Add arbitrary data to a module be accessible by specified key. Unlike RESOURCE macro the result should be futher processed by othet macros in the module. Example: https://wiki.yandex-team.ru/yatool/howtowriteyamakefiles/#a1ispolzujjtekomanduarchive ###### Macro [ASM\_PREINCLUDE][](AsmFiles...) Supply additional .asm files to all assembler calls within a module ###### Macro [ASSERT][] Not documented yet. ###### Macro [BASE\_CODEGEN][](tool\_path prefix) Generator ${prefix}.cpp + ${prefix}.h files based on ${prefix}.in. ###### Macro [BPF][](Input Output Opts...) Emit eBPF bytecode from .c file. Note: Output name is used as is, no extension added. ###### Macro [BPF\_STATIC][](Input Output Opts...) Emit eBPF bytecode from .c file. Note: Output name is used as is, no extension added. ###### Macro [BUILDWITH\_CYTHON\_C][](Src Options...) Generates .c file from .pyx. ###### Macro [BUILDWITH\_CYTHON\_CPP][](Src Options...) Generates .cpp file from .pyx. ###### Macro [BUILDWITH\_RAGEL6][](Src Options...) Compile .rl file using Ragel6. ###### Macro [BUILD\_CATBOOST][](cbmodel cbname) Generate catboost model and access code. cbmodel - CatBoost model file name (\*.cmb). cbname - name for a variable (of NCatboostCalcer::TCatboostCalcer type) to be available in CPP code. CatBoost specific macro. ###### Macro [BUILD\_MN][]([CHECK] [PTR] [MULTI] mninfo mnname) _# matrixnet_ Generate MatrixNet data and access code using single command. Alternative macro BUILD\_MNS() works faster and better for large files. ###### Macro [BUILD\_MNS][]([CHECK] NAME listname mninfos...) _# matrixnet_ Generate MatrixNet data and access code using separate commands for support code, interface and data. Faster version of BUILD\_MN() macro for large files. ###### Macro [BUILD\_ONLY\_IF][](variables) _# builtin_ Print warning if all variables are false. For example, BUILD\_ONLY\_IF(LINUX WIN32) ###### Macro [BUILD\_YDL\_DESC][](Input Symbol Output) Generate a descriptor for a Symbol located in a ydl module Input, and put it to the file Output. @example: PACKAGE() BUILD_YDL_DESC(../types.ydl Event Event.ydld) END() This will parse file ../types.ydl, generate a descriptor for a symbol Event defined in the said file, and put the descriptor to the Event.ydld. ###### Macro [BUNDLE][](...) Brings build artefact from module Dir under optional Name to the current module (e.g. UNION) If NAME is not specified, the name of the Dir's build artefact will be preserved It makes little sense to specify BUNDLE on non-final targets and so this may stop working without prior notice. Bundle on multimodule will select final target among multimodule variants and will fail if there are none or more than one. ###### Macro [CFLAGS][]([GLOBAL compiler\_flag]\* compiler\_flags) Add the specified flags to the compilation command of C and C++ files. @params: GLOBAL - Propagates these flags to dependent projects Note: remember about the incompatibility flags for clang and cl (to set flags specifically for cl.exe use MSVC\_FLAGS). ###### Macro [CGO\_CFLAGS][](Flags...) Compiler flags specific to CGO compilation ###### Macro [CGO\_LDFLAGS][](Files...) Linker flags specific to CGO linking ###### Macro [CGO\_SRCS][](Files...) .go sources to be built with CGO ###### Macro [CHECK\_CONTRIB\_CREDITS][] Not documented yet. ###### Macro [CHECK\_DEPENDENT\_DIRS][](DENY|ALLOW\_ONLY ([ALL|PEERDIRS|GLOB] dir)...) Specify project transitive dependencies constraints. @params: 1. DENY: current module can not depend on module from any specified directory neither directly nor transitively. 2. ALLOW\_ONLY: current module can not depend on module from a dir not specified in the directory list neither directly nor transitively. 3. ALL: directory constraints following after this modifier are applied to both transitive PEERDIR dependencies and tool dependencies. 4. PEERDIRS: directory constraints following after this modifier are applied to transitive PEERDIR dependencies only. 5. GLOB: next directory constraint is an ANT glob pattern. 6. EXCEPT: next constraint is an exception for the rest of other rules. Directory constraints added before either ALL or PEERDIRS modifier is used are treated as ALL directory constraints. Note: Can be used multiple times on the same module all specified constraints will be checked. All macro invocation for the same module must use same constraints type (DENY or ALLOW\_ONLY) ###### Macro [CHECK\_JAVA\_DEPS][]() Check for different classes with duplicate name in classpath. Documentation: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [CLANG\_EMIT\_AST\_CXX][](Input Output Opts...) Emit Clang AST from .cpp file. CXXFLAGS and LLVM\_OPTS are passed in, while CFLAGS and C\_FLAGS\_PLATFORM are not. Note: Output name is used as is, no extension added. ###### Macro [CMAKE\_EXPORTED\_TARGET\_NAME][](Name) Forces to use the name given as cmake target name without changing the name of output artefact. This macro should be used to resolve target name conflicts in exported cmake project when changing module name is not applicable. For example both CUDA and non-CUDA py modules for catboost should have same name lib\_catboost.so and both of them are defined as PY\_ANY\_MODULE(\_catboost). adding CMAKE\_EXPORTED\_TARGET\_NAME(\_catboost\_non\_cuda) to the non CUDA module ya.make file changes exported cmake target name but preserve generated artefact file name. ###### Macro [COLLECT\_FRONTEND\_FILES][](Varname, Dir) Recursively collect files with typical frontend extensions from Dir and save the result into variable Varname ###### Macro [COLLECT\_JINJA\_TEMPLATES][](varname path) This macro collects all jinja and yaml files in the directory specified by second argument and stores result in the variable with mane specified by first parameter. ###### Macro [COLLECT\_YDB\_API\_SPECS\_LEGACY][](VarName Paths...) _#deprecated_ This macro is ugly hack for legacy YDB go API codegen, any other uses are prohibited ###### Macro [COMPILE\_C\_AS\_CXX][]() Compile .c files as .cpp ones within a module. ###### Macro [COMPILE\_LUA][](Src, [NAME ]) Compile LUA source file to object code using LUA 2.0 Optionally override import name which is by default reflects Src name ###### Macro [COMPILE\_LUA\_21][](Src, [NAME ]) Compile LUA source file to object code using LUA 2.1 Optionally override import name which is by default reflects Src name ###### Macro [COMPILE\_NLG][](Src...) Generate and compile .nlg templates (Jinja2-based) and interface for megamind runtime. Alice-specific macro ###### Macro [COMPILE\_SWIFT\_MODULE][](SRCS{input}[], BRIDGE\_HEADER{input}="", Flags...) Not documented yet. ###### Macro [CONFIGURE\_FILE][](from to) Copy file with the replacement of configuration variables in form of @ANY\_CONF\_VAR@ with their values. The values are collected during configure stage, while replacement itself happens during build stage. Used implicitly for .in-files processing. ###### Macro [CONFTEST\_LOAD\_POLICY\_LOCAL][]() Loads conftest.py files in a way that pytest does it ###### Macro [CONLYFLAGS][]([GLOBAL compiler\_flag]\* compiler\_flags) Add the specified flags to the compilation command of .c (but not .cpp) files. @params: GLOBAL - Distributes these flags on dependent projects ###### Macro [COPY][] Not documented yet. ###### Macro [COPY\_FILE][](File Destination [AUTO] [OUTPUT\_INCLUDES Deps...]) Copy file to build root. It is possible to change both location and the name. Parameters: - File - Source file name. - Destination - Output file name. - AUTO - Consider copied file for further processing automatically. - OUTPUT\_INCLUDES output\_includes... - Output file dependencies. - INDUCED\_DEPS $VARs... - Dependencies for generated files. Unlike `OUTPUT\_INCLUDES` these may target files further in processing chain. In order to do so VAR should be filled by PREPARE\_INDUCED\_DEPS macro, stating target files (by type) and set of dependencies The file will be just copied if AUTO boolean parameter is not specified. You should explicitly mention it in SRCS under new name (or specify AUTO boolean parameter) for further processing. ###### Macro [COPY\_FILE\_WITH\_CONTEXT][](FILE DEST [AUTO] [OUTPUT\_INCLUDES DEPS...]) Copy file to build root the same way as it is done for COPY\_FILE, but also propagates the context of the source file. ###### Macro [CPP\_ADDINCL][](Dirs...) Not documented yet. ###### Macro [CPP\_ENUMS\_SERIALIZATION][] Not documented yet. ###### Macro [CPP\_PROTO\_PLUGIN][](Name Tool Suf DEPS ) Define protoc plugin for C++ with given Name that emits code into 1 extra output using Tool. Extra dependencies are passed via DEPS. ###### Macro [CPP\_PROTO\_PLUGIN0][](Name Tool DEPS ) Define protoc plugin for C++ with given Name that emits code into regular outputs using Tool. Extra dependencies are passed via DEPS. ###### Macro [CPP\_PROTO\_PLUGIN2][](Name Tool Suf1 Suf2 DEPS ) Define protoc plugin for C++ with given Name that emits code into 2 extra outputs using Tool. Extra dependencies are passed via DEPS. ###### Macro [CREATE\_BUILDINFO\_FOR][](GenHdr) Creates header file to access some information about build specified via configuration variables. Unlike CREATE\_SVNVERSION\_FOR() it doesn't take revion information from VCS, it uses revision and SandboxTaskId passed via -D options to ya make ###### Macro [CREATE\_INIT\_PY\_STRUCTURE][] Not documented yet. ###### Macro [CREDITS\_DISCLAIMER][] Not documented yet. ###### Macro [CTEMPLATE\_VARNAMES][](File) Generate File.varnames.h using contrib/libs/ctemplate/make\_tpl\_varnames\_h Documentation: https://a.yandex-team.ru/arc/trunk/arcadia/contrib/libs/ctemplate/README.md ###### Macro [CUDA\_NVCC\_FLAGS][](compiler flags) Add the specified flags to the compile line .cu-files. ###### Macro [CUSTOM\_LINK\_STEP\_SCRIPT][](name) Specifies name of a script for custom link step. The scripts should be placed in the build/scripts directory and are subject to review by devtools@. ###### Macro [CXXFLAGS][](compiler\_flags) Add the specified flags to the compilation command of .cpp (but not .c) files. ###### Macro [DARWIN\_SIGNED\_RESOURCE][](Resource, Relpath) Not documented yet. ###### Macro [DARWIN\_STRINGS\_RESOURCE][](Resource, Relpath) Not documented yet. ###### Macro [DATA][]([path...]) Specifies the path to the data necessary test. Valid values are: arcadia/ , arcadia\_tests\_data/ and sbr://. In the latter case resource will be brought to the working directory of the test before it is started Used only inside TEST modules. Documentation: https://wiki.yandex-team.ru/yatool/test/#dannyeizrepozitorija ###### Macro [DEB\_VERSION][](File) Creates a header file DebianVersion.h define the DEBIAN\_VERSION taken from the File. ###### Macro [DECIMAL\_MD5\_LOWER\_32\_BITS][]( [FUNCNAME funcName] [inputs...]) Generates .cpp file with one defined function 'const char\* () { return ""; }'. will be md5 hash for all inputs passed to this macro. ###### Macro [DECLARE\_EXTERNAL\_HOST\_RESOURCES\_BUNDLE][](name sbr:id FOR platform1 sbr:id FOR platform2...) _#builtin_ Associate name with sbr-id on platform. Ask devtools@yandex-team.ru if you need more information ###### Macro [DECLARE\_EXTERNAL\_HOST\_RESOURCES\_PACK][](RESOURCE\_NAME name sbr:id FOR platform1 sbr:id FOR platform2... RESOURCE\_NAME name1 sbr:id1 FOR platform1...) _#builtin_ Associate name with sbr-id on platform. Ask devtools@yandex-team.ru if you need more information ###### Macro [DECLARE\_EXTERNAL\_RESOURCE][](name sbr:id name1 sbr:id1...) _#builtin_ Associate name with sbr-id. Ask devtools@yandex-team.ru if you need more information ###### Macro [DEFAULT][](varname value) _#builtin_ Sets varname to value if value is not set yet ###### Macro [DEPENDENCY\_MANAGEMENT][](path/to/lib1 path/to/lib2 ...) Lock version of the library from the contrib/java at some point, so that all unversioned PEERDIRs to this library refer to the specified version. For example, if the module has PEERDIR (contrib/java/junit/junit), and 1. specifies DEPENDENCY\_MANAGEMENT(contrib/java/junit/junit/4.12), the PEERDIR is automatically replaced by contrib/java/junit/junit/4.12; 2. doesn't specify DEPENDENCY\_MANAGEMENT, PEERDIR automatically replaced with the default from contrib/java/junit/junit/ya.make. These defaults are always there and are supported by maven-import, which puts there the maximum version available in contrib/java. The property is transitive. That is, if module A PEERDIRs module B, and B has PEERDIR(contrib/java/junit/junit), and this junit was replaced by junit-4.12, then junit-4.12 will come to A through B. If some module has both DEPENDENCY\_MANAGEMENT(contrib/java/junit/junit/4.12) and PERDIR(contrib/java/junit/junit/4.11), the PEERDIR wins. Documentation: https://wiki.yandex-team.ru/yatool/java/ ###### Macro [DEPENDS][](path1 [path2...]) _# builtin_ Buildable targets that should be brought to the test run. This dependency isonly used when tests run is requested. It will build the specified modules andbring them to the working directory of the test (in their Arcadia paths). Itis reasonable to specify only final targets her (like programs, DLLs orpackages). DEPENDS to UNION is the only exception: UNIONs aretransitively closed at DEPENDS bringing all dependencies to the test. DEPENDS on multimodule will select and bring single final target. If more noneor more than one final target available in multimodule DEPENDS to it willproduce configuration error. ###### Macro [DIRECT\_DEPS\_ONLY][] Add direct PEERDIR's only in java compile classpath ###### Macro [DISABLE][](varname) _#builtin_ Sets varname to 'no' ###### Macro [DISABLE\_DATA\_VALIDATION][]() Not documented yet. ###### Macro [DLL\_FOR][](path/to/lib [libname] [major\_ver [minor\_ver]] [EXPORTS symlist\_file]) _#builtin_ DLL module definition based on specified LIBRARY ###### Macro [DOCS\_BUILDER][](tool) _# deprecated_ Not documented yet. ###### Macro [DOCS\_CONFIG][](path) Specify path to config file for DOCS multimodule if it differs from default path. If used for [MKDOCS](#multimodule\_MKDOCS) multimodule the default path is "%%project\_directory%%/mkdocs.yml". If used for [DOCS](#multimodule\_DOCS) multimodule the default path is "%%project\_directory%%/.yfm". Path must be either Arcadia root relative. @see: [DOCS](#multimodule\_DOCS) ###### Macro DOCS\_COPY\_FILE(FROM src\_dir [NAMESPCE dst\_dir] files...) Copy files from src\_dir to $BINDIR/dst\_dir ###### Macro [DOCS\_DIR][](path) Specify directory with source .md files for DOCS multimodule if it differs from project directory. Path must be Arcadia root relative. @see: [DOCS](#multimodule\_DOCS) ###### Macro [DOCS\_INCLUDE\_SOURCES][](path...) Specify a list of paths to source code files which will be used as text includes in a documentation project. Paths must be Arcadia root relative. @see: [DOCS](#multimodule\_DOCS) ###### Macro [DOCS\_VARS][](variable1=value1 variable2=value2 ...) Specify a set of default values of template variables for DOCS multimodule. There must be no spaces around "=". Values will be treated as strings. @see: [DOCS](#multimodule\_DOCS) ###### Macro [DUMPERF\_CODEGEN][](Prefix) A special case BASE\_CODEGEN, in which the extsearch/images/robot/tools/dumperf/codegen tool is used ###### Macro [DYNAMIC\_LIBRARY\_FROM][](Paths) Use specified libraries as sources of DLL ###### Macro IF(condition) .. [ELSE][]IF(other\_condition) .. ELSE() .. ENDIF() _#builtin_ Apply macros if none of previous conditions hold ###### Macro IF(condition) .. [ELSEIF][](other\_condition) .. ELSE() .. ENDIF() _#builtin_ Apply macros if other\_condition holds while none of previous conditions hold ###### Macro [EMBED\_JAVA\_VCS\_INFO][]() Embed manifest with vcs info into `EXTERNAL\_JAVA\_LIBRARY` By default this is disabled. ###### Macro [ENABLE][](varname) _#builtin_ Sets varname to 'yes' ###### Macro [ENABLE\_PREVIEW][]() Enable java preview features. ###### Macro [END][]() _# builtin_ The end of the module ###### Macro IF(condition) .. ELSEIF(other\_condition) .. ELSE() .. [ENDIF][]() _#builtin_ End of conditional construct ###### Macro [ENV][](key[=value]) Sets env variable key to value (gets value from system env by default). ###### Macro [EXCLUDE][] EXCLUDE(prefixes) The macro is in development. Specifies which libraries should be excluded from the classpath. ###### Macro [EXCLUDE\_TAGS][](tags...) _# builtin_ Instantiate from multimodule all variants except ones with tags listed ###### Macro [EXPORTS\_SCRIPT][](exports\_file) Specify exports script within PROGRAM, DLL and DLL-derived modules. This accepts 2 kind of files: .exports with pairs and JSON-line .symlist files. The other option use EXPORTS parameter of the DLL module itself. @see: [DLL](#module\_DLL) ###### Macro [EXPORT\_ALL\_DYNAMIC\_SYMBOLS][]() Export all non-hidden symbols as dynamic when linking a PROGRAM. ###### Macro [EXPORT\_YMAPS\_PROTO][]() _# maps-specific_ Maps-specific .proto handling: IMPORT\_YMAPS\_PROTO() + maps protobuf namespace. ###### Macro [EXPOSE][](OutputsToExport...) Allows to mark outputs of macro command as unused in the current module but intended to be used in modules consuming current via PEERDIR. TODO(DEVTOOLS-9000) proper implementation needed ###### Macro [EXTERNAL\_JAR][] Not documented yet. ###### Macro [EXTERNAL\_RESOURCE][](...) _#builtin, deprecated_ Don't use this. Use RESOURCE\_LIBRARY or FROM\_SANDBOX instead ###### Macro [EXTRADIR][](...) _#builtin, deprecated_ Ignored ###### Macro [EXTRALIBS][](liblist) _# builtin_ Add external dynamic libraries during program linkage stage ###### Macro [EXTRALIBS\_STATIC][](Libs...) Add the specified external static libraries to the program link ###### Macro [FAT\_RESOURCE][] Not documented yet. ###### Macro [FBS\_NAMESPACE][](NAMESPACE, PATH...) Not documented yet. ###### Macro [FILES][] Not documented yet. ###### Macro [FLATC\_FLAGS][](flags...) Add flags to flatc command line ###### Macro [FLAT\_JOIN\_SRCS\_GLOBAL][](Out Src...) Join set of sources into single file named Out and send it for further processing as if it were listed as SRCS(GLOBAL Out). This macro places all files into single file, so will work with any sources. You should specify file name with the extension as Out. Further processing will be done according to this extension. ###### Macro [FORK\_SUBTESTS][]() Splits the test run in chunks on subtests. The number of chunks can be overridden using the macro SPLIT\_FACTOR. Allows to run tests in parallel. Supported in UNITTEST, JTEST/JUNIT5 and PY2TEST/PY3TEST modules. Documentation about the system test: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [FORK\_TESTS][]() Splits a test run on chunks by test classes. The number of chunks can be overridden using the macro SPLIT\_FACTOR. Allows to run tests in parallel. Supported in UNITTEST, JTEST/JUNIT5 and PY2TEST/PY3TEST modules. Documentation about the system test: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [FORK\_TEST\_FILES][]() Only for PY2TEST and PY3TEST: splits a file executable with the tests on chunks in the files listed in TEST\_SRCS Compatible with FORK\_(SUB)TESTS. Documentation about the system test: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [FROM\_ARCHIVE][](Src [RENAME ] OUT\_[NOAUTO] [EXECUTABLE] [OUTPUT\_INCLUDES ] [INDUCED\_DEPS $VARs...]) Process file archive as [FROM\_SANDBOX()](#macro\_FROM\_SANDBOX). ###### Macro [FROM\_MDS][]([FILE] key [RENAME ] OUT\_[NOAUTO] [EXECUTABLE] [OUTPUT\_INCLUDES ] [INDUCED\_DEPS $VARs...]) Download resource from MDS with the specified key and process like [FROM\_SANDBOX()](#macro\_FROM\_SANDBOX). ###### Macro [FROM\_NPM][](NAME VERSION SKY\_ID INTEGRITY INTEGRITY\_ALGO TARBALL\_PATH) Not documented yet. ###### Macro [FROM\_SANDBOX][]([FILE] resource\_id [AUTOUPDATED script] [RENAME ] OUT\_[NOAUTO] [EXECUTABLE] [OUTPUT\_INCLUDES ] [INDUCED\_DEPS $VARs...]) Download the resource from the Sandbox, unpack (if not explicitly specified word FILE) and add OUT files to the build. EXECUTABLE makes them executable. You may specify extra dependencies that output files bring using OUTPUT\_INCLUDES or INDUCED\_DEPS. The change of these may e.g. lead to recompilation of .cpp files extracted from resource. If there is no default processing for OUT files or you need process them specially use OUT\_NOAUTO instead of OUT. It is disallowed to specify directory as OUT/OUT\_NOAUTO since all outputs of commands shall be known to build system. RENAME renames files to the corresponding OUT and OUT\_NOAUTO outputs: FROM\_SANDBOX(resource\_id RENAME in\_file1 in\_file2 OUT out\_file1 out\_file2 out\_file3) FROM\_SANDBOX(resource\_id RENAME in\_file1 OUT out\_file1 RENAME in\_file2 OUT out\_file2) FROM\_SANDBOX(FILE resource\_id RENAME resource\_file OUT out\_name) RENAME RESOURCE allows to rename the resource without specifying its file name. OUTPUT\_INCLUDES output\_includes... - Includes of the output files that are needed to build them. INDUCED\_DEPS $VARs... - Dependencies for generated files. Unlike `OUTPUT\_INCLUDES` these may target files further in processing chain. In order to do so VAR should be filled by PREPARE\_INDUCED\_DEPS macro, stating target files (by type) and set of dependencies If AUTOUPDATED is specified than macro will be regularly updated according to autoupdate script. The dedicated Sandbox task scans the arcadia and changes resource\_ids in such macros if newer resource of specified type is available. Note that the task seeks AUTOUPDATED in specific position, so you shall place it immediately after resource\_id. ###### Macro [FUZZ\_DICTS][](path1 [path2...]) Allows you to specify dictionaries, relative to the root of Arcadia, which will be used in Fuzzing. Libfuzzer and AFL use a single syntax for dictionary descriptions. Should only be used in FUZZ modules. Documentation: https://wiki.yandex-team.ru/yatool/fuzzing/ ###### Macro [FUZZ\_OPTS][](opt1 [Opt2...]) Overrides or adds options to the corpus mining and fuzzer run. Currently supported only Libfuzzer, so you should use the options for it. Should only be used in FUZZ modules. @example: FUZZ_OPTS ( -max_len=1024 -rss_limit_mb=8192 ) Documentation: https://wiki.yandex-team.ru/yatool/fuzzing/ ###### Macro [GENERATED\_SRCS][](srcs... PARSE\_META\_FROM cpp\_srcs... [OUTPUT\_INCLUDES output\_includes...] [OPTIONS]) Generate sources using Jinja 2 template engine. srcs... - list of text files which will be generated during build time by templates. Each template must be placed to the place in source tree where corresponding source file should be generated. Name of template must be ".markettemplate". For example if you want to generate file "example.cpp" then template should be named "example.cpp.markettemplate". PARSE\_META\_FROM cpp\_srcs... - list of C++ source files (.cpp, .h) which will be parsed using clang library and metainformation extracted from the files will be made available for templates. Example of template code fragment using metainformation: {{ meta.objects["@N@std@S@string"].name }} OUTPUT\_INCLUDES output\_includes... - in cases when build system parser fails to determine all headers which generated files include, you can specify additional headers here. In a normal situation this should not be needed and this feature could be removed in the future. OPTIONS - additional options for code\_generator utility Examples of templates can be found in directory market/tools/code\_generator/templates. Metainformation does not contain entries for every object declared in C++ files specified in PARSE\_META\_FROM parameter. To include some object into consideration you need to mark it by attribute. Attributes can automatically add more attributes to dependent objects. This behavior depends on attribute definition. More information will be available (eventually:) here: https://wiki.yandex-team.ru/Users/denisk/codegenerator/ ###### Macro [GENERATE\_ENUM\_SERIALIZATION][](File.h) Create serialization support for enumeration members defined in the header (String <-> Enum conversions) and compile it into the module. Documentation: https://wiki.yandex-team.ru/yatool/HowToWriteYaMakeFiles/ ###### Macro [GENERATE\_ENUM\_SERIALIZATION\_WITH\_HEADER][](File.h) Create serialization support for enumeration members defined in the header (String <-> Enum conversions) and compile it into the module Provide access to serialization functions via generated header File\_serialized.h Documentation: https://wiki.yandex-team.ru/yatool/HowToWriteYaMakeFiles/ ###### Macro [GENERATE\_PY\_PROTOS][](ProtoFiles...) _# deprecated_ Generate python bindings for protobuf files. Macro is obsolete and not recommended for use! ###### Macro [GENERATE\_SCRIPT][] heretic@ promised to make tutorial here Don't forget Feel free to remind ###### Macro [GEN\_SCHEEME2][](scheeme\_name from\_file dependent\_files...) Generates a C++ description for structure(contains the field RecordSig) in the specified file (and connected). 1. ${scheeme\_name}.inc - the name of the generated file. 2. Use an environment variable - DATAWORK\_SCHEEME\_EXPORT\_FLAGS that allows to specify flags to tools/structparser @example: SET(DATAWORK_SCHEEME_EXPORT_FLAGS --final_only -m "::") all options are passed to structparser (in this example --final\_only - do not export heirs with public base that contains the required field,,- m "::" only from the root namespace) sets in extra option @example: SET(EXTRACT_STRUCT_INFO_FLAGS -f \"const static ui32 RecordSig\" -u \"RecordSig\" -n${scheeme_name}SchemeInfo ----gcc44_no_typename no_complex_overloaded_func_export ${DATAWORK_SCHEEME_EXPORT_FLAGS}) for compatibility with C++ compiler and the external environment. See tools/structparser for more details. ###### Macro [GLOBAL\_SRCS][](filenames...) Make all source files listed as GLOBAL. Call to GLOBAL\_SRCS macro is equivalent to call to SRCS macro when each source file is marked with GLOBAL keyword. Arcadia root relative or project dir relative paths are supported for filenames arguments. GLOBAL keyword is not recognized for GLOBAL\_SRCS in contrast to SRCS macro. @example: Consider the file to ya.make: LIBRARY() GLOBAL_SRCS(foo.cpp bar.cpp) END() @see: [SRCS()](#macro\_SRCS) ###### Macro [GO\_ASM\_FLAGS][](flags) Add the specified flags to the go asm compile command line. ###### Macro [GO\_BENCH\_TIMEOUT][](x) Sets timeout in seconds for 1 Benchmark in go benchmark suite Documentation about the system test: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [GO\_CGO1\_FLAGS][](flags) Add the specified flags to the go cgo compile command line. ###### Macro [GO\_CGO2\_FLAGS][](flags) Add the specified flags to the go cgo compile command line. ###### Macro [GO\_COMPILE\_FLAGS][](flags) Add the specified flags to the go compile command line. ###### Macro [GO\_EMBED\_DIR][](DIR) Define an embed directory DIR. ###### Macro [GO\_EMBED\_PATTERN][](PATTERN) Define an embed pattern. ###### Macro GO\_TEST\_EMBED\_DIR(DIR) Define an embed directory DIR for internal go tests. ###### Macro GO\_XTEST\_EMBED\_DIR(DIR) Define an embed directory DIR for external go tests. ###### Macro [GO\_FAKE\_OUTPUT][](go-src-files...) Not documented yet. ###### Macro [GO\_GRPC\_GATEWAY\_SRCS][]() Use of grpc-gateway plugin (Supported for Go only). ###### Macro [GO\_GRPC\_GATEWAY\_SWAGGER\_SRCS][]() Use of grpc-gateway plugin w/ swagger emission (Supported for Go only). ###### Macro [GO\_LDFLAGS][](Flags...) Link flags for GO\_PROGRAM linking from .go sources ###### Macro [GO\_LINK\_FLAGS][](flags) Add the specified flags to the go link command line. ###### Macro [GO\_MOCKGEN\_FROM][](Path) Not documented yet. ###### Macro [GO\_MOCKGEN\_MOCKS][]() Not documented yet. ###### Macro [GO\_MOCKGEN\_REFLECT][]() Not documented yet. ###### Macro [GO\_MOCKGEN\_TYPES][](First, Rest...) Not documented yet. ###### Macro [GO\_PACKAGE\_NAME][](Name) Override name of a Go package. ###### Macro [GO\_PROTO\_PLUGIN][](Name Ext Tool [DEPS dependencies...]) Define protoc plugin for GO with given Name that emits extra output with provided extension Ext using Tool. Extra dependencies are passed via DEPS. ###### Macro [GO\_SKIP\_TESTS][](TestNames...) Define a set of tests that should not be run. NB! Subtests are not taken into account! ###### Macro [GO\_TEST\_EMBED\_PATTERN][](PATTERN) Define an embed pattern for internal go tests. ###### Macro [GO\_TEST\_FOR][](path/to/module) _#builtin_ Produces go test for specified module ###### Macro [GO\_TEST\_SRCS][](Files...) .go sources for internal tests of a module ###### Macro [GO\_XTEST\_EMBED\_PATTERN][](PATTERN) Define an embed pattern for external go tests. ###### Macro [GO\_XTEST\_SRCS][](Files...) .go sources for external tests of a module ###### Macro [GRPC][]() Emit GRPC code for all .proto files in a PROTO\_LIBRARY. This works for all available PROTO\_LIBRARY versions (C++, Python 2.x, Pyton 3.x, Java and Go). ###### Macro [IDEA\_EXCLUDE\_DIRS][]() Exclude specified directories from an idea project generated by ya ide idea Have no effect on regular build. ###### Macro [IDEA\_JAR\_SRCS][](Args...) Not documented yet. ###### Macro [IDEA\_MODULE\_NAME][](module\_name) Set module name in an idea project generated by ya ide idea Have no effect on regular build. ###### Macro [IDEA\_RESOURCE\_DIRS][]() Set specified resource directories in an idea project generated by ya ide idea Have no effect on regular build. ###### Macro [IF][](condition) .. ELSEIF(other\_condition) .. ELSE() .. ENDIF() _#builtin_ Apply macros if condition holds ###### Macro [INCLUDE][](filename) _#builtin_ Include file textually and process it as a part of the ya.make ###### Macro [INCLUDE\_TAGS][](tags...) _# builtin_ Additionally instantiate from multimodule all variants with tags listed (overrides default) ###### Macro [INDUCED\_DEPS][](Extension Path...) _#builtin_ States that files wih the Extension generated by the PROGRAM will depend on files in Path. This only useful in PROGRAM and similar modules. It will be applied if the PROGRAM is used in RUN\_PROGRAM macro. All Paths specified must be absolute arcadia paths i.e. start with ${ARCADIA\_ROOT} ${ARCADIA\_BUILD\_ROOT}, ${CURDIR} or ${BINDIR}. ###### Macro [IOS\_APP\_ASSETS\_FLAGS][](Flags...) Not documented yet. ###### Macro [IOS\_APP\_COMMON\_FLAGS][](Flags...) Not documented yet. ###### Macro [IOS\_APP\_SETTINGS][] Not documented yet. ###### Macro [IOS\_ASSETS][] Not documented yet. ###### Macro [JAR\_ANNOTATION\_PROCESSOR][](Classes...) Not documented yet. ###### Macro [JAR\_EXCLUDE][](Filters...) Filter .jar file content: remove matched files \* and \*\* patterns are supported (like JAVA\_SRCS) ###### Macro [JAR\_INCLUDE][](Filters...) Filter .jar file content: keep only matched files \* and \*\* patterns are supported (like JAVA\_SRCS) ###### Macro [JAR\_RESOURCE][](Id) Not documented yet. ###### Macro [JAVAC\_FLAGS][](Args...) Set additional Java compilation flags. ###### Macro [JAVA\_DEPENDENCIES\_CONFIGURATION][](Vetos...) Validate contrib/java dependencies Valid arguments FORBID\_DIRECT\_PEERDIRS - fail when module have direct PEERDIR (with version) (non-transitive) FORBID\_DEFAULT\_VERSIONS - fail when module have PEERDIR to library with default (last) version (transitive) FORBID\_CONFLICT - fail when module have resolved without DEPENDENCY\_MANAGEMENT version conflict (transitive) FORBID\_CONFLICT\_DM - fail when module have resolved with DEPENDENCY\_MANAGEMENT version conflict (transitive) FORBID\_CONFLICT\_DM\_RECENT - like FORBID\_CONFLICT\_DM but fail only when dependency have more recent version than specified in DEPENDENCY\_MANAGEMENT REQUIRE\_DM - all dependencies must be specified in DEPENDENCY\_MANAGEMENT (transitive) ###### Macro [JAVA\_EXTERNAL\_DEPENDENCIES][](file1 file2 ...) Add non-source java external build dependency (like lombok config file) ###### Macro [JAVA\_IGNORE\_CLASSPATH\_CLASH\_FOR][]([classes]) Ignore classpath clash test fails for classes ###### Macro [JAVA\_MODULE][] Not documented yet. ###### Macro [JAVA\_PROTO\_PLUGIN][](Name Tool DEPS ) Define protoc plugin for Java with given Name that emits extra outputs using Tool. Extra dependencies are passed via DEPS ###### Macro [JAVA\_RESOURCE][](JAR, SOURCES="") Not documented yet. ###### Macro [JAVA\_SRCS][](srcs) Specify java source files and resources. A macro can be contained in any of four java modules. Keywords: 1. X SRCDIR - specify the directory x is performed relatively to search the source code for these patterns. If there is no SRCDIR, the source will be searched relative to the module directory. 2. PACKAGE\_PREFIX x - use if source paths relative to the SRCDIR does not coincide with the full class names. For example, if all sources of module are in the same package, you can create a directory package/name , and just put the source code in the SRCDIR and specify PACKAGE\_PREFIX package.name. @example: - example/ya.make JAVA_PROGRAM() JAVA_SRCS(SRCDIR src/main/java **/*) END() - example/src/main/java/ru/yandex/example/HelloWorld.java package ru.yandex.example; public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } } Documentation: https://wiki.yandex-team.ru/yatool/java/#javasrcs ###### Macro [JAVA\_TEST][] Not documented yet. ###### Macro [JAVA\_TEST\_DEPS][] Not documented yet. ###### Macro MODULE\_JDK(Version) Specify JDK version for module ###### Macro [JOIN\_SRCS][](Out Src...) Join set of sources into single file named Out and send it for further processing. This macro doesn't place all file into Out, it emits #include... Use the for C++ source files only. You should specify file name with the extension as Out. Further processing will be done according this extension. ###### Macro [JOIN\_SRCS\_GLOBAL][](Out Src...) Join set of sources into single file named Out and send it for further processing as if it were listed as SRCS(GLOBAL Out). This macro doesn't place all file into Out, it emits #include... Use the for C++ source files only. You should specify file name with the extension as Out. Further processing will be done according to this extension. ###### Macro [JVM\_ARGS][](Args...) Arguments to run Java programs in tests. Documentation: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [KOTLINC\_FLAGS][](-flags) Set additional Kotlin compilation flags. ###### Macro [LARGE\_FILES][]([AUTOUPDATED] Files...) Use large file ether from working copy or from remote storage via placeholder .external If is present locally (and not a symlink!) it will be copied to build directory. Otherwise macro will try to locate .external, parse it retrieve ot during build phase. ###### Macro [LDFLAGS][](LinkerFlags...) Add flags to the link command line of executable or shared library/dll. Note: LDFLAGS are always global. When set in the LIBRARY module they will affect all programs/dlls/tests the library is linked into. Note: remember about the incompatibility of flags for gcc and cl. ###### Macro [LICENSE][](licenses...) Specify the licenses of the module, separated by spaces. Specifying multiple licenses interpreted as permission to use this library satisfying all conditions of any of the listed licenses. A license must be prescribed for contribs ###### Macro [LICENSE\_TEXTS][](File) This macro specifies the filename with all library licenses texts ###### Macro [LINKER\_SCRIPT][](Files...) Specify files to be used as a linker script ###### Macro [LINK\_EXEC\_DYN\_LIB\_IMPL][] $usage: LINK\_EXEC\_DYN\_LIB\_IMPL(peers...) # internal ###### Macro [LINK\_EXE\_IMPL][] $usage: LINK\_EXE\_IMPL(peers...) # internal ###### Macro [LINT][]() Set linting levem for sources of the module ###### Macro [LJ\_21\_ARCHIVE][](NAME Name LuaFiles...) _# deprecated_ Precompile .lua files using LuaJIT 2.1 and archive both sources and results using sources names as keys ###### Macro [LJ\_ARCHIVE][](NAME Name LuaFiles...) Precompile .lua files using LuaJIT and archive both sources and results using sources names as keys ###### Macro [LLVM\_BC][] Not documented yet. ###### Macro [LLVM\_COMPILE\_C][](Input Output Opts...) Emit LLVM bytecode from .c file. BC\_CFLAGS, LLVM\_OPTS and C\_FLAGS\_PLATFORM are passed in, while CFLAGS are not. Note: Output name is used as is, no extension added. ###### Macro [LLVM\_COMPILE\_CXX][](Input Output Opts...) Emit LLVM bytecode from .cpp file. BC\_CXXFLAGS, LLVM\_OPTS and C\_FLAGS\_PLATFORM are passed in, while CFLAGS are not. Note: Output name is used as is, no extension added. ###### Macro [LLVM\_COMPILE\_LL][](Input Output Opts...) Compile LLVM bytecode to object representation. Note: Output name is used as is, no extension added. ###### Macro [LLVM\_LINK][](Output Inputs...) Call llvm-link on set of Inputs to produce Output. Note: Unlike many other macros output argument goes first. Output name is used as is, no extension added. ###### Macro [LLVM\_OPT][](Input Output Opts...) Call llvm-opt with set of Opts on Input to produce Output. Note: Output name is used as is, no extension added. ###### Macro [LOCAL\_JAR][](File) Not documented yet. ###### Macro [LOCAL\_SOURCES\_JAR][](File) Not documented yet. ###### Macro [MACROS\_WITH\_ERROR][] Not documented yet. ###### Macro [MANUAL\_GENERATION][](Outs...) Not documented yet. ###### Macro [MAPKITIDL][](idl-file-name... [OUT\_DIR output-dir] [IDL\_INCLUDES idl-dirs...] [FILTER filters...]) [FILTER\_OUT filters...]) [GLOBAL\_OUTPUTS] Generate bindings to target platform language. (Used for mobile MapKit project) 1. idl-file-name... - a list of \*.idl files to process 2. output-dir - a base root of output directory 3. idl-dirs - a list of directories where to search for imported \*.idl files 4. filters - a list of extensions used to filter outputs and output includes ###### Macro [MAPKIT\_ADDINCL][](Dirs...) Not documented yet. ###### Macro [MASMFLAGS][](compiler flags) Add the specified flags to the compilation command of .masm files. ###### Macro [MAVEN\_GROUP\_ID][](group\_id\_for\_maven\_export) Set maven export group id for JAVA\_PROGRAM() and JAVA\_LIBRARY(). Have no effect on regular build. ###### Macro [MESSAGE][]([severity] message) _# builtin_ Print message with given severity level (STATUS, FATAL\_ERROR) ###### Macro [METAQUERYFILES][](filenames...) _#deprecated_ This macro does nothing and will be removed ###### Macro [MSVC\_FLAGS][]([GLOBAL compiler\_flag]\* compiler\_flags) Add the specified flags to the compilation line of C/C++files. Flags apply only if the compiler used is MSVC (cl.exe) ###### Macro [MX\_FORMULAS][](BinFiles...) _# deprecated, matrixnet_ Create MatrixNet formulas archive ###### Macro [NEED\_CHECK][]() Commits to the project marked with this macro will be blocked by pre-commit check and then will be automatically merged to trunk only if there is no new broken build targets in check results. The use of this macro is disabled by default. ###### Macro [NEED\_REVIEW][]() _# deprecated_ Mark the project as needing review. Reviewers are listed in the macro OWNER. The use of this macro is disabled by default. Details can be found here: https://clubs.at.yandex-team.ru/arcadia/6104 ###### Macro [NGINX\_MODULES][](Modules...) Not documented yet. ###### Macro [NODE\_MODULES][]() Materializes `node\_modules.tar` bundle according to the module's lockfile. @see [NPM\_CONTRIBS()](#module\_NPM\_CONTRIBS) ###### Macro [NO\_BUILD\_IF][](variables) _# builtin_ Print warning if some variable is true ###### Macro [NO\_CHECK\_IMPORTS][]([patterns]) Do not run checks on imports of Python modules. Optional parameter mask patterns describes the names of the modules that do not need to check. ###### Macro [NO\_CLANG\_COVERAGE][]() Disable heavyweight clang coverage for the module ###### Macro [NO\_CLANG\_TIDY][]() Not documented yet. ###### Macro [NO\_COMPILER\_WARNINGS][]() Disable all compiler warnings in the module. Priorities: NO\_COMPILER\_WARNINGS > NO\_WERROR > WERROR\_MODE > WERROR. ###### Macro [NO\_CPU\_CHECK][]() Compile module without startup CPU features check ###### Macro [NO\_CYTHON\_COVERAGE][]() Disable cython and cythonized python coverage (CYTHONIZE\_PY) Implies NO\_CLANG\_COVERAGE() - right now, we can't disable instrumentation for .py.cpp files, but enable for .cpp ###### Macro [NO\_DEBUG\_INFO][]() Compile files without debug info collection. ###### Macro [NO\_DOCTESTS][]() Disable doctests in PY[|3|23\_]TEST ###### Macro [NO\_EXPORT\_DYNAMIC\_SYMBOLS][]() Disable exporting all non-hidden symbols as dynamic when linking a PROGRAM. ###### Macro [NO\_EXTENDED\_SOURCE\_SEARCH][]() Prevent module using in extended python source search. Use the macro if module contains python2-only files (or other python sources which shouldn't be imported by python3 interpreter) which resides in the same directories with python 3 useful code. contrib/python/future is a example. Anyway, preferred way is to move such files into separate dir and don't use this macro at all. Also see: https://docs.yandex-team.ru/ya-make/manual/python/vars#y\_python\_extended\_source\_search for details ###### Macro [NO\_JOIN\_SRC][]() _# deprecated, does-nothing_ This macro currently does nothing. This is default behavior which cannot be overridden at module level. ###### Macro [NO\_LIBC][]() Exclude dependencies on C++ and C runtimes (including util, musl and libeatmydata). Note: use this with care. libc most likely will be linked into executable anyway, so using libc headers/functions may not be detected at build time and may lead to unpredictable behavors at configure time. ###### Macro [NO\_LINT][]() Do not check for style files included in PY\_SRCS, TEST\_SRCS, JAVA\_SRCS. ###### Macro [NO\_LTO][]() Disable any lto (link-time optimizations) for the module. This will compile module source files as usual (without LTO) but will not prevent lto-enabled linking of entire program if global settings say so. ###### Macro [NO\_MYPY][]() Not documented yet. ###### Macro [NO\_NEED\_CHECK][]() Commits to the project marked with this macro will not be affected by higher-level NEED\_CHECK macro. ###### Macro [NO\_OPTIMIZE][]() Build code without any optimizations (-O0 mode). ###### Macro [NO\_OPTIMIZE\_PY\_PROTOS][]() Disable Python proto optimization using embedding corresponding C++ code into binary. Python protobuf runtime will use C++ implementation instead of Python one if former is available. This is default mode only for some system libraries. ###### Macro [NO\_PLATFORM][]() Exclude dependencies on C++ and C runtimes (including util, musl and libeatmydata) and set NO\_PLATFORM variable for special processing. Note: use this with care. libc most likely will be linked into executable anyway, so using libc headers/functions may not be detected at build time and may lead to unpredictable behavors at configure time. ###### Macro [NO\_PYTHON\_COVERAGE][]() Disable python coverage for module ###### Macro [NO\_RUNTIME][]() This macro: 1. Sets the ENABLE(NOUTIL) + DISABLE(USE\_INTERNAL\_STL); 2. If the project that contains the macro NO\_RUNTIME(), peerdir-it project does not contain NO\_RUNTIME() => Warning. Note: use this with care. Arcadia STL most likely will be linked into executable anyway, so using STL headers/functions/classes may not be detected at build time and may lead to unpredictable behavors at configure time. ###### Macro [NO\_SANITIZE][]() Disable all sanitizers for the module. ###### Macro [NO\_SANITIZE\_COVERAGE][]() Disable lightweight coverage (-fsanitize-coverage) for the module. ###### Macro [NO\_SSE4][]() Compile module without SSE4 ###### Macro [NO\_UTIL][]() Build module without dependency on util. Note: use this with care. Util most likely will be linked into executable anyway, so using util headers/functions/classes may not be detected at build time and may lead to unpredictable behavors at configure time. ###### Macro [NO\_WERROR][]() Override WERROR() behavior Priorities: NO\_COMPILER\_WARNINGS > NO\_WERROR > WERROR\_MODE > WERROR. ###### Macro [NO\_WSHADOW][]() Disable C++ shadowing warnings. ###### Macro [NVCC\_DEVICE\_LINK][](file.cu...) Run nvcc --device-link on objects compiled from srcs with --device-c. This generates a stub object devlink.o that supplies missing pieces for the host linker to link relocatable device objects into the final executable. ###### Macro [ONLY\_TAGS][](tags...) _# builtin_ Instantiate from multimodule only variants with tags listed ###### Macro [OPENSOURCE\_EXPORT\_REPLACEMENT][](CMAKE PkgName CMAKE\_TARGET PkgName::PkgTarget CONAN ConanRef CMAKE\_COMPONENT OptCmakePkgComponent) Use specified conan/system pacakcge when exporting cmake build scripts for arcadia C++ project for opensource publication. ###### Macro [ORIGINAL\_SOURCE][](Source) This macro specifies the source repository for contrib Does nothing now (just a placeholder for future functionality) See https://st.yandex-team.ru/DTCC-316 ###### Macro [OWNER][](owners...) _# builtin_ Add reviewers/responsibles of the code. In the OWNER macro you can use: 1. login-s from staff.yandex-team.ru 2. Review group (to specify the Code-review group need to use the prefix g:) Ask devtools@yandex-team.ru if you need more information ###### Macro [PACK][](archive\_type) When placed inside the PACKAGE module, packs the build results tree to the archive with specified extension. Currently supported extensions are `tar` and `tar.gz` Is not allowed other module types than PACKAGE(). @see: [PACKAGE()](#module\_PACKAGE) ###### Macro [PACKAGE\_STRICT][]() Not documented yet. ###### Macro [PACK\_GLOBALS\_IN\_LIBRARY][]() Not documented yet. ###### Macro [PARTITIONED\_RECURSE][]([BALANCING\_CONFIG config] [LOCAL] dirs...) _# builtin_ Add directories to the build All projects must be reachable from the root chain RECURSE() for monorepo continuous integration functionality. Arguments are processed in chunks ###### Macro [PARTITIONED\_RECURSE\_FOR\_TESTS][]([BALANCING\_CONFIG config] [LOCAL] dirs...) _# builtin_ Add directories to the build if tests are demanded. Arguments are processed in chunks ###### Macro [PARTITIONED\_RECURSE\_ROOT\_RELATIVE][]([BALANCING\_CONFIG config] dirlist) _# builtin_ In comparison with RECURSE(), in dirlist there must be a directory relative to the root (${ARCADIA\_ROOT}). Arguments are processed in chunks ###### Macro [PEERDIR][](dirs...) _# builtin_ Specify project dependencies Indicates that the project depends on all of the projects from the list of dirs. Libraries from these directories will be collected and linked to the current target if the target is executable or sharedlib/dll. If the current target is a static library, the specified directories will not be built, but they will be linked to any executable target that will link the current library. @params: 1. As arguments PEERDIR you can only use the LIBRARY directory (the directory with the PROGRAM/DLL and derived from them are prohibited to use as arguments PEERDIR). 2. ADDINCL Keyword ADDINCL (written before the specified directory), adds the flag -I the flags to compile the source code of the current project. Perhaps it may be removed in the future (in favor of a dedicated ADDINCL) ###### Macro [PIRE\_INLINE][](FILES...) Not documented yet. ###### Macro [PIRE\_INLINE\_CMD][](SRC) Not documented yet. ###### Macro [PREPARE\_INDUCED\_DEPS][](VAR Type Files...) Format value for `INDUCED\_DEPS` param in certain macros and assign to `VAR` This tells that files of Type resulted from code generation macros (not neccessarily directly, but in processing chain of generated files) should have extra dependencies from list of Files... Prominent example here is Cython: one can generate .pyx file that may depend on .pxd and have cimpot from certain .h. The former is dependency for .pyx itself, while the latter is dependency for .pyx.cpp resulted from Cython-processing of generated pyx. The code ganeration will look like: ``` PREPARE_INDUCED_DEPS(PYX_DEPS pyx imported.pxd) PREPARE_INDUCED_DEPS(CPP_DEPS cpp cdefed.h) RUN_PYTHON3(generate_pyx.py genereted.pyx OUT generated.pyx INDUCED_DEPS $PYX_DEPS $CPP_DEPS) ``` The VAR will basically contain pair of `Type:[Files...]` in a form suitable for passing as an element of array parameter. This is needed because language of ya.make doesn't support Dict params right now and so it is impossible to directly pass something like `{Type1:[Files2...], Type2:[Files2...]}` ###### Macro [PRINT\_MODULE\_TYPE][] Not documented yet. ###### Macro [PROCESS\_DOCS][] Not documented yet. ###### Macro [PROCESS\_MKDOCS][] Not documented yet. ###### Macro PROGURAD\_RULES(ProguardRuleFiles...) This macro is strictly prohibited to use outside of mapsmobi project ###### Macro [PROTO2FBS][](InputProto) Produce flatbuf schema out of protobuf description. ###### Macro [PROTO\_ADDINCL][]([GLOBAL] [WITH\_GEN] Path) This macro introduces proper ADDINCLs for .proto-files found in sources and .cpp/.h generated files, supplying them to appropriate commands and allowing proper dependency resolution at configure-time. Note: you normally shouldn't use this macro. ADDINCLs should be sent to user from dependency via PROTO\_NAMESPACE macro ###### Macro [PROTO\_NAMESPACE][]([GLOBAL] [WITH\_GEN] Namespace) Defines protobuf namespace (import/export path prefix) which should be used for imports and which defines output path for .proto generation. For proper importing and configure-time dependency management it sets ADDINCLs for both .cpp headers includes and .proto imports. If .proto expected to be used outside of the processing module use GLOBAL to send proper ADDINCLs to all (transitive) users. PEERDIR to PROTO\_LIBRARY with PROTO\_NAMESPACE(GLOBAL ) is enough at user side to correctly use the library. If generated .proto files are going to be used for building a module than use of WITH\_GEN parameter will add appropriate dir from the build root for .proto files search. ###### Macro [PROVIDES][](Name...) Specifies provided features. The names must be correct C identifiers. This prevents different libraries providing the same features to be linked into one program. ###### Macro [PYTHON][](script\_path args... [CWD dir] [ENV key=value...] [TOOL tools...] [IN[\_NOPARSE] inputs...] [OUT[\_NOAUTO] outputs...] [STDOUT[\_NOAUTO] output] [OUTPUT\_INCLUDES output\_includes...] [INDUCED\_DEPS $VARs...]) Run a python script with $(PYTHON)/python built from devtools/huge\_python. These macros are similar: RUN\_PROGRAM, RUN\_LUA, PYTHON. Parameters: - script\_path - Path to the script. - args... - Program arguments. Relative paths listed in TOOL, IN, OUT, STDOUT become absolute. - CWD dir - Absolute path of the working directory. - ENV key=value... - Environment variables. - TOOL tools... - Auxiliary tool directories. - IN[\_NOPARSE] inputs... - Input files. NOPARSE inputs are treated as textual and not parsed for dependencies regardless of file extensions. - OUT[\_NOAUTO] outputs... - Output files. NOAUTO outputs are not automatically added to the build process. - STDOUT[\_NOAUTO] output - Redirect the standard output to the output file. - OUTPUT\_INCLUDES output\_includes... - Includes of the output files that are needed to build them. - INDUCED\_DEPS $VARs... - Dependencies for generated files. Unlike `OUTPUT\_INCLUDES` these may target files further in processing chain. In order to do so VAR should be filled by PREPARE\_INDUCED\_DEPS macro, stating target files (by type) and set of dependencies For absolute paths use ${ARCADIA\_ROOT} and ${ARCADIA\_BUILD\_ROOT}, or ${CURDIR} and ${BINDIR} which are expanded where the outputs are used. ###### Macro [PYTHON2\_ADDINCL][]() This macro adds include path for Python headers (Python 2.x variant) without PEERDIR. This should be used in 2 cases only: - In PY2MODULE since it compiles into .so and uses external Python runtime; - In system Python libraries themselves since proper PEERDIR there may create a loop; In all other cases use USE\_PYTHON2 macro instead. Never use this macro in PY2\_PROGRAM, PY2\_LIBRARY and PY23\_LIBRARY: they have everything needed by default. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs ###### Macro [PYTHON2\_MODULE][]() Use in PY\_ANY\_MODULE to set it up for Python 2.x. ###### Macro [PYTHON3\_ADDINCL][]() This macro adds include path for Python headers (Python 3.x variant). This should be used in 2 cases only: - In PY2MODULE since it compiles into .so and uses external Python runtime; - In system Python libraries themselves since peerdir there may create a loop; In all other cases use USE\_PYTHON3() macro instead. Never use this macro in PY3\_PROGRAM and PY3\_LIBRARY and PY23\_LIBRARY: they have everything by default. Documentation: https://wiki.yandex-team.ru/devtools/commandsandvars/py\_srcs ###### Macro [PYTHON3\_MODULE][]() Use in PY\_ANY\_MODULE to set it up for Python 3.x. ###### Macro [PYTHON\_PATH][](Path) Set path to Python that will be used to runs scripts in tests ###### Macro [PY\_CONSTRUCTOR][](package.module[:func]) Specifies the module or function which will be started before python's main() init() is expected in the target module if no function is specified Can be considered as \_\_attribute\_\_((constructor)) for python ###### Macro PY\_DOCTEST(Packages...) Add to the test doctests for specified Python packages The packages should be part of a test (listed as sources of the test or its PEERDIRs). ###### Macro [PY\_ENUMS\_SERIALIZATION][] Not documented yet. ###### Macro [PY\_EXTRA\_LINT\_FILES][](files...) Add extra Python files for linting. This macro allows adding Python files which has no .py extension. ###### Macro [PY\_MAIN][](package.module[:func]) Specifies the module or function from which to start executing a python program Documentation: https://wiki.yandex-team.ru/arcadia/python/pysrcs/#modulipyprogrampy3programimakrospymain ###### Macro [PY\_NAMESPACE][](prefix) Sets default Python namespace for all python sources in the module. Especially suitable in PROTO\_LIBRARY where Python sources are generated and there is no PY\_SRCS to place NAMESPACE parameter. ###### Macro [PY\_PROTOS\_FOR][](path/to/module) _#builtin, deprecated_ Use PROTO\_LIBRARY() in order to have .proto compiled into Python. Generates pb2.py files out of .proto files and saves those into PACKAGE module ###### Macro [PY\_PROTO\_PLUGIN][](Name Ext Tool DEPS ) Define protoc plugin for python with given Name that emits extra output with provided Extension using Tool. Extra dependencies are passed via DEPS ###### Macro [PY\_PROTO\_PLUGIN2][](Name Ext1 Ext2 Tool DEPS ) Define protoc plugin for python with given Name that emits 2 extra outputs with provided Extensions using Tool. Extra dependencies are passed via DEPS ###### Macro [PY\_REGISTER][]([package.]module\_name) Python knows about which built-ins can be imported, due to their registration in the Assembly or at the start of the interpreter. All modules from the sources listed in PY\_SRCS() are registered automatically. To register the modules from the sources in the SRCS(), you need to use PY\_REGISTER(). PY\_REGISTER(module\_name) initializes module globally via call to initmodule\_name() PY\_REGISTER(package.module\_name) initializes module in the specified package It renames its init function with CFLAGS(-Dinitmodule\_name=init7package11module\_name) or CFLAGS(-DPyInit\_module\_name=PyInit\_7package11module\_name) Documentation: https://wiki.yandex-team.ru/arcadia/python/pysrcs/#makrospyregister ###### Macro [PY\_SRCS][]({| CYTHON\_C} { | TOP\_LEVEL | NAMESPACE ns} Files...) Build specified Python sources according to Arcadia binary Python build. Basically creates precompiled and source resources keyed with module paths. The resources eventually are linked into final program and can be accessed as regular Python modules. This custom loader linked into the program will add them to sys.meta\_path. PY\_SRCS also support .proto, .ev, .pyx and .swg files. The .proto and .ev are compiled to .py-code by protoc and than handled as usual .py files. .pyx and .swg lead to C/C++ Python extensions generation, that are automatically registered in Python as built-in modules. By default .pyx files are built as C++-extensions. Use CYTHON\_C to build them as C (similar to BUILDWITH\_CYTHON\_C, but with the ability to specify namespace). \_\_init\_\_.py never required, but if present (and specified in PY\_SRCS), it will be imported when you import package modules with \_\_init\_\_.py Oh. @example PY2_LIBRARY(mymodule) PY_SRCS(a.py sub/dir/b.py e.proto sub/dir/f.proto c.pyx sub/dir/d.pyx g.swg sub/dir/h.swg) END() PY\_SRCS honors Python2 and Python3 differences and adjusts itself to Python version of a current module. PY\_SRCS can be used in any Arcadia Python build modules like PY\*\_LIBRARY, PY\*\_PROGRAM, PY\*TEST. PY\_SRCS in LIBRARY or PROGRAM effectively converts these into PY2\_LIBRARY and PY2\_PROGRAM respectively. It is strongly advised to make this conversion explicit. Never use PY\_SRCS in a LIBRARY if you plan to use it from external Python extension module. Documentation: https://wiki.yandex-team.ru/arcadia/python/pysrcs/#modulipylibrarypy3libraryimakrospysrcs ###### Macro [PY\_SSQLS\_SRCS][](Srcs...) Not documented yet. ###### Macro [REAL\_LINK\_DYN\_LIB\_IMPL][] $usage: REAL\_LINK\_DYN\_LIB\_IMPL(peers...) # internal ###### Macro [REAL\_LINK\_EXEC\_DYN\_LIB\_IMPL][] $usage: REAL\_LINK\_EXEC\_DYN\_LIB\_IMPL(peers...) # internal ###### Macro [REAL\_LINK\_EXE\_IMPL][] $usage: REAL\_LINK\_EXE\_IMPL(peers...) # internal ###### Macro [RECURSE][]([LOCAL] dirs...) _# builtin_ Add directories to the build All projects must be reachable from the root chain RECURSE() for monorepo continuous integration functionality ###### Macro [RECURSE\_FOR\_TESTS][]([LOCAL] dirs...) _# builtin_ Add directories to the build if tests are demanded. Use --force-build-depends flag if you want to build testing modules without tests running ###### Macro [RECURSE\_ROOT\_RELATIVE][](dirlist) _# builtin_ In comparison with RECURSE(), in dirlist there must be a directory relative to the root (${ARCADIA\_ROOT}) ###### Macro [REGISTER\_SANDBOX\_IMPORT][] Not documented yet. ###### Macro [REGISTER\_YQL\_PYTHON\_UDF][] Not documented yet. ###### Macro [REQUIREMENTS][]([cpu:] [disk\_usage:] [ram:] [ram\_disk:] [container:] [network:] [dns:dns64]) Allows you to specify the requirements of the test. Documentation about the Arcadia test system: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [REQUIRES][](dirs...) Specify list of dirs which this module must depend on indirectly. This macro can be used if module depends on the directories specified but they can't be listed as direct PEERDIR dependencies (due to public include order or link order issues). ###### Macro [RESOLVE\_PROTO][]() Enable include resolving within UNIONs and let system .proto being resolved among .proto/.gztproto imports Note: it is currently impossible to enable resolving only for .proto, so resolving is enabled for all supported files also we only add ADDINCL for stock protobuf. So use this macro with care: it may cause resolving problems those are to be addressed by either ADDINCLs or marking them as TEXT. Please contact devtools for details. ###### Macro [RESOURCE][]([FORCE\_TEXT ][Src Key]\* [- Key=Value]\*) _# built-in_ Add data (resources, random files, strings) to the program) The common usage is to place Src file into binary. The Key is used to access it using library/cpp/resource or library/python/resource. Alternative syntax with '- Key=Value' allows placing Value string as resource data into binary and make it accessible by Key. This is a simpler but less flexible option than ARCHIVE(), because in the case of ARCHIVE(), you have to use the data explicitly, and in the case of RESOURCE(), the data will fall through SRCS() or SRCS(GLOBAL) to binary linking. Use the FORCE\_TEXT parameter to explicitly mark all Src files as text files: they will not be parsed unless used elsewhere. @example: https://wiki.yandex-team.ru/yatool/howtowriteyamakefiles/#a2ispolzujjtekomanduresource @example: LIBRARY() OWNER(user1) RESOURCE( path/to/file1 /key/in/program/1 path/to/file2 /key2 ) END() ###### Macro [RESOURCE\_FILES][]([DONT\_PARSE] [PREFIX {prefix}] [STRIP prefix\_to\_strip] {path}) This macro expands into RESOURCE([DONT\_PARSE] {path} resfs/file/{prefix}{path} - resfs/src/resfs/file/{prefix}{remove\_prefix(path, prefix\_to\_strip)}={rootrel\_arc\_src(path)} ) resfs/src/{key} stores a source root (or build root) relative path of the source of the value of the {key} resource. resfs/file/{key} stores any value whose source was a file on a filesystem. resfs/src/resfs/file/{key} must store its path. DONT\_PARSE disables parsing for source code files (determined by extension) Please don't abuse: use separate DONT\_PARSE macro call only for files subject to parsing This form is for use from other plugins: RESOURCE\_FILES([DEST {dest}] {path}) expands into RESOURCE({path} resfs/file/{dest}) @see: https://wiki.yandex-team.ru/devtools/commandsandvars/resourcefiles/ ###### Macro [RESTRICT\_LICENSES][](ALLOW\_ONLY|DENY LicenseProperty...) Restrict licenses of direct and indirect module dependencies. ALLOW\_ONLY restriction type requires dependent module to have at leas one license without propertis not listed in restrictions list. DENY restriction type forbids dependency on module with no license without any listed propery from the list. Note: Can be used multiple times on the same module all specified constraints will be checked. All macro invocation for the same module must use same constraints type (DENY or ALLOW\_ONLY) ###### Macro [RESTRICT\_PATH][] Not documented yet. ###### Macro [RUN][] Not documented yet. ###### Macro [RUN\_ANTLR][](Args...) Macro to invoke ANTLR3 generator (general case) ###### Macro [RUN\_ANTLR4][](Args...) Macro to invoke ANTLR4 generator (general case) ###### Macro [RUN\_ANTLR4\_CPP][](GRAMMAR, OUTPUT\_INCLUDES, LISTENER, VISITOR, Args...) Macro to invoke ANTLR4 generator (Cpp) ###### Macro [RUN\_ANTLR4\_GO][](GRAMMAR, OUTPUT\_INCLUDES, LISTENER, VISITOR, Args...) Macro to invoke ANTLR4 generator (Go) ###### Macro [RUN\_JAVA\_PROGRAM][](Args...) Not documented yet. ###### Macro [RUN\_LUA][](script\_path args... [CWD dir] [ENV key=value...] [TOOL tools...] [IN[\_NOPARSE] inputs...] [OUT[\_NOAUTO] outputs...] [STDOUT[\_NOAUTO] output] [OUTPUT\_INCLUDES output\_includes...] [INDUCED\_DEPS $VARs...]) Run a lua script. These macros are similar: RUN\_PROGRAM, RUN\_LUA, PYTHON. Parameters: - script\_path - Path to the script.3 - args... - Program arguments. Relative paths listed in TOOL, IN, OUT, STDOUT become absolute. - CWD dir - Absolute path of the working directory. - ENV key=value... - Environment variables. - TOOL tools... - Auxiliary tool directories. - IN[\_NOPARSE] inputs... - Input files. NOPARSE inputs are treated as textual and not parsed for dependencies regardless of file extensions. - OUT[\_NOAUTO] outputs... - Output files. NOAUTO outputs are not automatically added to the build process. - STDOUT[\_NOAUTO] output - Redirect the standard output to the output file. - OUTPUT\_INCLUDES output\_includes... - Includes of the output files that are needed to build them. - INDUCED\_DEPS $VARs... - Dependencies for generated files. Unlike `OUTPUT\_INCLUDES` these may target files further in processing chain. In order to do so VAR should be filled by PREPARE\_INDUCED\_DEPS macro, stating target files (by type) and set of dependencies For absolute paths use ${ARCADIA\_ROOT} and ${ARCADIA\_BUILD\_ROOT}, or ${CURDIR} and ${BINDIR} which are expanded where the outputs are used. ###### Macro [RUN\_PROGRAM][](tool\_path args... [CWD dir] [ENV key=value...] [TOOL tools...] [IN[\_NOPARSE] inputs...] [OUT[\_NOAUTO] outputs...] [STDOUT[\_NOAUTO] output] [OUTPUT\_INCLUDES output\_includes...] [INDUCED\_DEPS $VARs...]) Run a program from arcadia. These macros are similar: RUN\_PROGRAM, RUN\_LUA, PYTHON. Parameters: - tool\_path - Path to the directory of the tool. - args... - Program arguments. Relative paths listed in TOOL, IN, OUT, STDOUT become absolute. - CWD dir - Absolute path of the working directory. - ENV key=value... - Environment variables. - TOOL tools... - Auxiliary tool directories. - IN[\_NOPARSE] inputs... - Input files. NOPARSE inputs are treated as textual and not parsed for dependencies regardless of file extensions. - OUT[\_NOAUTO] outputs... - Output files. NOAUTO outputs are not automatically added to the build process. - STDOUT[\_NOAUTO] output - Redirect the standard output to the output file. - OUTPUT\_INCLUDES output\_includes... - Includes of the output files that are needed to build them. - INDUCED\_DEPS $VARs... - Dependencies for generated files. Unlike `OUTPUT\_INCLUDES` these may target files further in processing chain. In order to do so VAR should be filled by PREPARE\_INDUCED\_DEPS macro, stating target files (by type) and set of dependencies For absolute paths use ${ARCADIA\_ROOT} and ${ARCADIA\_BUILD\_ROOT}, or ${CURDIR} and ${BINDIR} which are expanded where the outputs are used. Note that Tool is always built for the host platform, so be careful to provide that tool can be built for all Arcadia major host platforms (Linux, MacOS and Windows). ###### Macro [RUN\_PYTHON][](Args...) Version of RUN() macro to invoke Python scripts @see: [RUN()](#macro\_RUN) ###### Macro [RUN\_PYTHON3][](script\_path args... [CWD dir] [ENV key=value...] [TOOL tools...] [IN[\_NOPARSE] inputs...] [OUT[\_NOAUTO] outputs...] [STDOUT[\_NOAUTO] output] [OUTPUT\_INCLUDES output\_includes...] [INDUCED\_DEPS $VARs...]) Run a python script with prebuilt python3 interpretor built from devtools/huge\_python3. These macros are similar: RUN\_PROGRAM, RUN\_LUA, PYTHON. Parameters: - script\_path - Path to the script. - args... - Program arguments. Relative paths listed in TOOL, IN, OUT, STDOUT become absolute. - CWD dir - Absolute path of the working directory. - ENV key=value... - Environment variables. - TOOL tools... - Auxiliary tool directories. - IN[\_NOPARSE] inputs... - Input files. NOPARSE inputs are treated as textual and not parsed for dependencies regardless of file extensions. - OUT[\_NOAUTO] outputs... - Output files. NOAUTO outputs are not automatically added to the build process. - STDOUT[\_NOAUTO] output - Redirect the standard output to the output file. - OUTPUT\_INCLUDES output\_includes... - Includes of the output files that are needed to build them. - INDUCED\_DEPS $VARs... - Dependencies for generated files. Unlike `OUTPUT\_INCLUDES` these may target files further in processing chain. In order to do so VAR should be filled by PREPARE\_INDUCED\_DEPS macro, stating target files (by type) and set of dependencies For absolute paths use ${ARCADIA\_ROOT} and ${ARCADIA\_BUILD\_ROOT}, or ${CURDIR} and ${BINDIR} which are expanded where the outputs are used. ###### Macro [SDBUS\_CPP\_ADAPTOR][](File) Not documented yet. ###### Macro [SDBUS\_CPP\_PROXY][](File) Not documented yet. ###### Macro [SET][](varname value) _#builtin_ Sets varname to value ###### Macro [SETUP\_EXECTEST][] Not documented yet. ###### Macro [SETUP\_PYTEST\_BIN][] Not documented yet. ###### Macro [SETUP\_RUN\_PYTHON][] Not documented yet. ###### Macro [SET\_APPEND][](varname appendvalue) _#builtin_ Appends appendvalue to varname's value using space as a separator ###### Macro [SET\_APPEND\_WITH\_GLOBAL][](varname appendvalue) _#builtin_ Appends appendvalue to varname's value using space as a separator. New value is propagated to dependants ###### Macro [SET\_COMPILE\_OUTPUTS\_MODIFIERS][](NOREL?";norel":"") Not documented yet. ###### Macro [SIZE][](SMALL/MEDIUM/LARGE) Set the 'size' for the test. Each 'size' has own set of resrtictions, SMALL bein the most restricted and LARGE being the list. See documentation on test system for more details. Documentation about the system test: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [SKIP\_TEST][](Reason) Skip the suite defined by test module. Provide a reason to be output in test execution report. ###### Macro [SOURCE\_GROUP][](...) _#builtin, deprecated_ Ignored ###### Macro [SPLIT\_CODEGEN][](tool prefix opts... [OUT\_NUM num] [OUTPUT\_INCLUDES output\_includes...]) Generator of a certain number of parts of the .cpp file + one header .h file from .in Supports keywords: 1. OUT\_NUM 2. OUTPUT\_INCLUDES ###### Macro [SPLIT\_DWARF][]() Emit debug info for the PROGRAM/DLL as a separate file .debug. NB: It does not help you to save process RSS but can add problems (see e.g. BEGEMOT-2147). ###### Macro [SPLIT\_FACTOR][](x) Sets the number of chunks for parallel run tests when used in test module with FORK\_TESTS() or FORK\_SUBTESTS(). If none of those is specified this macro implies FORK\_TESTS(). Supports C++ ut and PyTest. Documentation about the system test: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [SRC][](File Flags...) Compile single file with extra Flags. Compilation is driven by the last extension of the File and Flags are specific to corresponding compilation command ###### Macro [SRCDIR][](dirlist) _# builtin_ Add the specified directories to the list of those in which the source files will be searched Available only for arcadia/contrib ###### Macro [SRCS][](<[GLOBAL] File> ...) Source files of the project. Files are built according to their extension and put int module output or fed to ultimate PROGRAM/DLL depending on GLOBAL presence. Arcadia Paths from the root and is relative to the project's LIST are supported GLOBAL marks next file as direct input to link phase of the program/shared library project built into. This prevents symbols of the file to be excluded by linker as unused. The scope of the GLOBAL keyword is the following file (that is, in the case of SRCS(GLOBAL foo.cpp bar.cpp) global will be only foo.cpp) @example: LIBRARY(test_global) SRCS(GLOBAL foo.cpp) END() This will produce foo.o and feed it to any PROGRAM/DLL module transitively depending on test\_global library. The library itself will be empty and won't produce .a file. ###### Macro [SRC\_C\_AVX][] @uasge SRC\_C\_AVX(File Flags...) Compile a single C/C++ file with AVX and additional Flags ###### Macro [SRC\_C\_AVX2][] @uasge SRC\_C\_AVX2(File Flags...) Compile a single C/C++ file with AVX2 and additional Flags ###### Macro [SRC\_C\_AVX512][] @uasge SRC\_C\_AVX512(File Flags...) Compile a single C/C++ file with AVX512 and additional Flags ###### Macro [SRC\_C\_NO\_LTO][] @uasge SRC\_C\_NO\_LTO(File Flags...) Compile a single C/C++ file with link-time-optimization disabling and additional Flags ###### Macro [SRC\_C\_PCLMUL][] @uasge SRC\_C\_PCLMUL(File Flags...) Compile a single C/C++ file with PCLMUL and additional Flags ###### Macro [SRC\_C\_PIC][] @uasge SRC\_C\_PIC(File Flags...) Compile a single C/C++ file with -fPIC and additional Flags ###### Macro [SRC\_C\_SSE2][] @uasge SRC\_C\_SSE2(File Flags...) Compile a single C/C++ file with SSE2 and additional Flags ###### Macro [SRC\_C\_SSE3][] @uasge SRC\_C\_SSE3(File Flags...) Compile a single C/C++ file with SSE3 and additional Flags ###### Macro [SRC\_C\_SSE4][] @uasge SRC\_C\_SSE4(File Flags...) Compile a single C/C++ file with SSE4 and additional Flags ###### Macro [SRC\_C\_SSE41][] @uasge SRC\_C\_SSE41(File Flags...) Compile a single C/C++ file with SSE4.1 and additional Flags ###### Macro [SRC\_C\_SSSE3][] @uasge SRC\_C\_SSSE3(File Flags...) Compile a single C/C++ file with SSSE3 and additional Flags ###### Macro [SRC\_C\_XOP][] @uasge SRC\_C\_XOP(File Flags...) Compile a single C/C++ file with (an AMD-specific instruction set, see https://en.wikipedia.org/wiki/XOP\_instruction\_set) and additional Flags ###### Macro [SRC\_RESOURCE][](Id) Not documented yet. ###### Macro [STRIP][]() Strip debug info from a PROGRAM, DLL or TEST. This macro doesn't work in LIBRARY's, UNION's and PACKAGE's. ###### Macro [STRUCT\_CODEGEN][](Prefix) A special case BASE\_CODEGEN, in which the kernel/struct\_codegen/codegen\_tool tool is used. ###### Macro [STYLE][](Globs...) Not documented yet. ###### Macro [STYLE\_PYTHON][]() Check python3 sources for style issues using black. ###### Macro [SUBSCRIBER][](subscribers...) _# builtin_ Add observers of the code. In the SUBSCRIBER macro you can use: 1. login-s from staff.yandex-team.ru 2. Review group (to specify the Code-review group need to use the prefix g:) Note: current behavior of SUBSCRIBER is almost the same as OWNER. The are only 2 differences: SUBSCRIBER is not mandatory and it may be separately processed by external tools Ask devtools@yandex-team.ru if you need more information ###### Macro [SUPPRESSIONS][] SUPPRESSIONS() - allows to specify files with suppression notation which will be used by address, leak or thread sanitizer runtime by default. Use asan.supp filename for address sanitizer, lsan.supp for leak sanitizer and tsan.supp for thread sanitizer suppressions respectively. See https://clang.llvm.org/docs/AddressSanitizer.html#suppressing-memory-leaks for details. ###### Macro [SYMLINK][](from to) Add symlink ###### Macro [SYSTEM\_PROPERTIES][]([...] [...]) List of Key,Value pairs that will be available to test via System.getProperty(). FILE means that parst should be read from file specifies as Path. Documentation: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [TAG][] ([tag...]) Each test can have one or more tags used to filter tests list for running. There are also special tags affecting test behaviour, for example ya:external, sb:ssd. Documentation: https://wiki.yandex-team.ru/yatool/test/#obshhieponjatija ###### Macro [TASKLET][]() Not documented yet. ###### Macro [TASKLET\_REG][](Name, Lang, Impl, Includes...) Not documented yet. ###### Macro [TASKLET\_REG\_EXT][](Name, Lang, Impl, Wrapper, Includes...) Not documented yet. ###### Macro [TEST\_CWD][](path) Defines working directory for test runs. Often used in conjunction with DATA() macro. Is only used inside of the TEST modules. Documentation: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [TEST\_DATA][] Not documented yet. ###### Macro [TEST\_JAVA\_CLASSPATH\_CMD\_TYPE][](Type) Available types: MANIFEST(default), COMMAND\_FILE, LIST Method for passing a classpath value to a java command line MANIFEST via empty jar file with manifest that contains Class-Path attribute COMMAND\_FILE via @command\_file LIST via flat args ###### Macro [TEST\_SRCS][](Files...) In PY2TEST, PY3TEST and PY\*\_LIBRARY modules used as PY\_SRCS macro and additionally used to mine test cases to be executed by testing framework. Documentation: https://wiki.yandex-team.ru/yatool/test/#testynapytest ###### Macro [TIMEOUT][](TIMEOUT) Sets a timeout on test execution Documentation about the system test: https://wiki.yandex-team.ru/yatool/test/ ###### Macro [UBERJAR][]() UBERJAR is a single all-in-one jar-archive that includes all its Java dependencies (reachable PEERDIR). It also supports shading classes inside the archive by moving them to a different package (similar to the maven-shade-plugin). Use UBERJAR inside JAVA\_PROGRAM module. You can use the following macros to configure the archive: 1. UBERJAR\_HIDING\_PREFIX prefix for classes to shade (classes remain in their packages by default) 2. UBERJAR\_HIDE\_EXCLUDE\_PATTERN exclude classes matching this patterns from shading (if enabled). 3. UBERJAR\_PATH\_EXCLUDE\_PREFIX the prefix for classes that should not get into the jar archive (all classes are placed into the archive by default) 4. UBERJAR\_MANIFEST\_TRANSFORMER\_MAIN add ManifestResourceTransformer class to uberjar processing and specify main-class 5. UBERJAR\_MANIFEST\_TRANSFORMER\_ATTRIBUTE add ManifestResourceTransformer class to uberjar processing and specify some attribute 6. UBERJAR\_APPENDING\_TRANSFORMER add AppendingTransformer class to uberjar processing 7. UBERJAR\_SERVICES\_RESOURCE\_TRANSFORMER add ServicesResourceTransformer class to uberjar processing Documentation: https://wiki.yandex-team.ru/yatool/java/ @see: [JAVA\_PROGRAM](#module\_JAVA\_PROGRAM), [UBERJAR\_HIDING\_PREFIX](#macro\_UBERJAR\_HIDING\_PREFIX), [UBERJAR\_HIDE\_EXCLUDE\_PATTERN](#macro\_UBERJAR\_HIDE\_EXCLUDE\_PATTERN), [UBERJAR\_PATH\_EXCLUDE\_PREFIX](#macro\_UBERJAR\_PATH\_EXCLUDE\_PREFIX) ###### Macro [UBERJAR\_APPENDING\_TRANSFORMER][](Resource) Add AppendingTransformer for UBERJAR() java programs Parameters: - Resource - Resource name @see: [UBERJAR](#macro\_UBERJAR) ###### Macro [UBERJAR\_HIDE\_EXCLUDE\_PATTERN][](Args...) Exclude classes matching this patterns from shading (if enabled). Pattern may contain '\*' and '\*\*' globs. Shading is enabled for UBERJAR program using UBERJAR\_HIDING\_PREFIX macro. If this macro is not specified all classes are shaded. @see: [UBERJAR](#macro\_UBERJAR), [UBERJAR\_HIDING\_PREFIX](#macro\_UBERJAR\_HIDING\_PREFIX) ###### Macro [UBERJAR\_HIDING\_PREFIX][](Arg) Set prefix for classes to shade. All classes in UBERJAR will be moved into package prefixed with Arg. Classes remain in their packages by default. @see: [UBERJAR](#macro\_UBERJAR) ###### Macro [UBERJAR\_MANIFEST\_TRANSFORMER\_ATTRIBUTE][](Key, Value) Transform manifest.mf for UBERJAR() java programs, set attribute @see: [UBERJAR](#macro\_UBERJAR) ###### Macro [UBERJAR\_MANIFEST\_TRANSFORMER\_MAIN][](Main) Transform manifest.mf for UBERJAR() java programs, set main-class attribute @see: [UBERJAR](#macro\_UBERJAR) ###### Macro [UBERJAR\_PATH\_EXCLUDE\_PREFIX][](Args...) Exclude classes matching this patterns from UBERJAR. By default all dependencies of UBERJAR program will lend in a .jar archive. @see: [UBERJAR](#macro\_UBERJAR) ###### Macro [UBERJAR\_SERVICES\_RESOURCE\_TRANSFORMER][]() Add ServicesResourceTransformer for UBERJAR() java programs @see: [UBERJAR](#macro\_UBERJAR) ###### Macro [UDF\_NO\_PROBE][]() Disable UDF import check at build stage ###### Macro [UPDATE\_VCS\_JAVA\_INFO\_NODEP][](Jar) Not documented yet. ###### Macro [USE\_COMMON\_GOOGLE\_APIS][](APIS...) Not documented yet. ###### Macro [USE\_CXX][]() Add dependency on C++ runtime Note: This macro is inteneded for use in \_GO\_BASE\_UNIT like module when the module is built without C++ runtime by default ###### Macro [USE\_DYNAMIC\_CUDA][]() Enable linking of PROGRAM with dynamic CUDA. By default CUDA uses static linking ###### Macro [USE\_ERROR\_PRONE][]() Use errorprone instead of javac for .java compilation. ###### Macro [USE\_EXT\_PROTO][](peerdir\_tag...) Configure module to use proto files from existing PROTO\_LIBRARY module. Additional PEERDIR tags required to build a module can be passed through EXTRA\_TAGS vararg parameter. ###### Macro [USE\_JAVALITE][]() Use protobuf-javalite for Java ###### Macro [USE\_LINKER\_GOLD][]() Use gold linker for a program. This doesn't work in libraries ###### Macro [USE\_PERL\_514\_LIB][]() Add dependency on Perl 5.14 to your LIBRARY ###### Macro [USE\_PERL\_LIB][]() Add dependency on Perl to your LIBRARY ###### Macro [USE\_PLANTUML][]() Use PlantUML plug-in for yfm builder to render UML diagrams into documentation ###### Macro [USE\_PYTHON2][]() This adds Python 2.x runtime library to your LIBRARY and makes it Python2-compatible. Compatibility means proper PEERDIRs, ADDINCLs and variant selection on PEERDIRs to multimodules. If you'd like to use #include with Python2 specify USE\_PYTHON2 or better make it PY2\_LIBRARY. If you'd like to use #include with Python3 specify USE\_PYTHON3 or better make it PY3\_LIBRARY. If you'd like to use #include with both Python2 and Python3 convert your LIBRARY to PY23\_LIBRARY. @see: [PY2\_LIBRARY](#module\_PY2\_LIBRARY), [PY3\_LIBRARY](#module\_PY3\_LIBRARY), [PY23\_LIBRARY](#multimodule\_PY23\_LIBRARY) ###### Macro [USE\_PYTHON3][]() This adds Python3 library to your LIBRARY and makes it Python3-compatible. Compatibility means proper PEERDIRs, ADDINCLs and variant selection on PEERDIRs to multimodules. If you'd like to use #include with Python3 specify USE\_PYTHON3 or better make it PY3\_LIBRARY. If you'd like to use #include with Python2 specify USE\_PYTHON2 or better make it PY2\_LIBRARY. If you'd like to use #include with both Python2 and Python3 convert your LIBRARY to PY23\_LIBRARY. @see: [PY2\_LIBRARY](#module\_PY2\_LIBRARY), [PY3\_LIBRARY](#module\_PY3\_LIBRARY), [PY23\_LIBRARY](#multimodule\_PY23\_LIBRARY) ###### Macro [USE\_RECIPE][](path [arg1 arg2...]) Provides prepared environment via recipe for test. Documentation: https://wiki.yandex-team.ru/yatool/test/recipes ###### Macro [USE\_SKIFF][]() _#wip, do not use_ Use mapreduce/yt/skiff\_proto/plugin for C++ ###### Macro [USE\_UTIL][]() Add dependency on util and C++ runtime Note: This macro is intended for use in \_GO\_BASE\_UNIT like module when the module is build without util by default ###### Macro [VALIDATE\_DATA\_RESTART][](ext) Change uid for resource validation tests. May be useful when sandbox resource ttl is changed, but test status is cached in CI. You can change ext to change test's uid. For example VALIDATE\_DATA\_RESTART(X), where is X is current revision. ###### Macro [VERSION][](Args...) Specify version of a module. Currently unused by build system, only informative. ###### Macro [VISIBILITY][](level) This macro sets visibility level for symbols compiled for the current module. 'level' may take only one of the following values: DEFAULT, HIDDEN. ###### Macro [WERROR][]() Consider warnings as errors in the current module. In the bright future will be removed, since WERROR is the default. Priorities: NO\_COMPILER\_WARNINGS > NO\_WERROR > WERROR\_MODE > WERROR. ###### Macro [WINDOWS\_MANIFEST][](Manifest) Not documented yet. ###### Macro [WITHOUT\_LICENSE\_TEXTS][]() This macro indicates that the module has no license text ###### Macro [WITH\_DYNAMIC\_LIBS][] $usage: WITH\_DYNAMIC\_LIBS() # restricted Include dynamic libraries as extra PROGRAM/DLL outputs ###### Macro [WITH\_GROOVY][]() Compile groovy source code in this java module ###### Macro [WITH\_JDK][]() Add directory with JDK to JAVA\_PROGRAM output ###### Macro [WITH\_KOTLIN][]() Compile kotlin source code in this java module ###### Macro [WITH\_KOTLINC\_ALLOPEN][](-flags) Enable allopen kotlin compiler plugin https://kotlinlang.org/docs/all-open-plugin.html ###### Macro [WITH\_KOTLINC\_NOARG][](-flags) Enable noarg kotlin compiler plugin https://kotlinlang.org/docs/no-arg-plugin.html ###### Macro [XS\_PROTO][](InputProto Dir Outputs...) _# deprecated_ Generate Perl code from protobuf. In order to use this macro one should predict all outputs protoc will emit from input\_proto file and enlist those as outputs. ###### Macro [YABS\_GENERATE\_CONF][] Not documented yet. ###### Macro [YABS\_GENERATE\_PHANTOM\_CONF\_PATCH][] Not documented yet. ###### Macro [YABS\_GENERATE\_PHANTOM\_CONF\_TEST\_CHECK][] Not documented yet. ###### Macro [YDL\_DESC\_USE\_BINARY][]() Used in conjunction with BUILD\_YDL\_DESC. When enabled, all generated descriptors are binary. @example: PACKAGE() YDL_DESC_USE_BINARY() BUILD_YDL_DESC(../types.ydl Event Event.ydld) END() This will generate descriptor Event.ydld in a binary format. ###### Macro [YMAPS\_SPROTO][](ProtoFiles...) _# maps-specific_ Maps-specific .proto handling: generate .sproto.h files using maps/libs/sproto/sprotoc. ###### Macro [YP\_PROTO\_YSON][](Files... OUT\_OPTS Opts...) Generate .yson.go from .proto using yp/go/yson/internal/proto-yson-gen/cmd/proto-yson-gen ###### Macro [YQL\_ABI\_VERSION][](major minor release)) Specifying the supported ABI for YQL\_UDF. @see: [YQL\_UDF()](#multimodule\_YQL\_UDF) ###### Macro [YQL\_LAST\_ABI\_VERSION][]() Use the last ABI for YQL\_UDF ###### Macro [YT\_SPEC][](path1 [path2...]) Allows you to specify json-files with YT task and operation specs, which will be used to run test node in the YT. Test must be marked with ya:yt tag. Files must be relative to the root of Arcadia. Documentation: https://wiki.yandex-team.ru/yatool/test/ [DLL\_JAVA]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L190 [DOCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L147 [FBS\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7936 [JAR\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3864 [JAVA\_CONTRIB\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L144 [JAVA\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L31 [JTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L84 [JTEST\_FOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L114 [JTEST\_YMAKE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3915 [JUNIT5]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L55 [JUNIT5\_YMAKE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3896 [MAPS\_IDL\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/mapkit.conf?rev=9582506#L86 [MKDOCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L271 [PROTO\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7686 [PY23\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9385 [PY23\_NATIVE\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9419 [PY23\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9616 [PY3TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2345 [PY3\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1826 [SANDBOX\_PY23\_TASK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4970 [SANDBOX\_PY3\_TASK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5015 [SANDBOX\_TASK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4945 [SSQLS\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9725 [YQL\_UDF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L120 [BOOSTTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2054 [BOOSTTEST\_WITH\_MAIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2074 [CI\_GROUP]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3201 [CONTAINER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9757 [CONTAINER\_LAYER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9750 [CPP\_STYLE\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2357 [CUSTOM\_BUILD\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9769 [DEFAULT\_IOS\_INTERFACE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9495 [DLL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2965 [DLL\_TOOL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2983 [DOCS\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L81 [EXECTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2410 [FAT\_OBJECT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2691 [FUZZ]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2010 [GO\_DLL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8849 [GO\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8750 [GO\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8767 [GO\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8869 [GTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1989 [GTEST\_UGLY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2376 [G\_BENCHMARK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2440 [IOS\_INTERFACE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9484 [JAVA\_CONTRIB]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3499 [JAVA\_CONTRIB\_PROXY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3460 [JAVA\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L22 [LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2563 [MCU\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9827 [PACKAGE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3177 [PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1768 [PROTO\_DESCRIPTIONS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7893 [PROTO\_REGISTRY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7905 [PY2MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2877 [PY2TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2298 [PY2\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3946 [PY2\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1794 [PY3MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2896 [PY3TEST\_BIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2316 [PY3\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3982 [PY3\_PROGRAM\_BIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4129 [PYCR\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1888 [PYTEST\_BIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2281 [PY\_ANY\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2824 [RECURSIVE\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2725 [RESOURCES\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2640 [R\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2934 [SO\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2995 [TS\_BUNDLE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/ts.conf?rev=9582506#L127 [TS\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/ts.conf?rev=9582506#L99 [UDF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L30 [UDF\_LIB]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L37 [UNION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3237 [UNITTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1956 [UNITTEST\_FOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2468 [UNITTEST\_WITH\_CUSTOM\_ENTRY\_POINT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1978 [YCR\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1866 [YQL\_PYTHON3\_UDF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L215 [YQL\_PYTHON3\_UDF\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L263 [YQL\_PYTHON\_UDF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L164 [YQL\_PYTHON\_UDF\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L190 [YQL\_PYTHON\_UDF\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L249 [YQL\_UDF\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L99 [YQL\_UDF\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L55 [YT\_UNITTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1969 [Y\_BENCHMARK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2428 [AARS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/aar.conf?rev=9582506#L20 [AAR\_GRADLE\_SCRIPT\_GENERATOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/aar.conf?rev=9582506#L255 [AAR\_LOCAL\_MAVEN\_REPO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/aar.conf?rev=9582506#L249 [ACCELEO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/java.ymake.conf?rev=9582506#L12 [ADDINCL]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [ADDINCLSELF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5647 [ADD\_CHECK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L546 [ADD\_CHECK\_PY\_IMPORTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L658 [ADD\_CLANG\_TIDY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1682 [ADD\_COMPILABLE\_TRANSLATE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5313 [ADD\_COMPILABLE\_TRANSLIT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5323 [ADD\_DLLS\_TO\_JAR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4685 [ADD\_PERL\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5202 [ADD\_PYTEST\_BIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L731 [ADD\_PYTEST\_SCRIPT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L702 [ADD\_YTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L416 [ALLOCATOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5232 [ALL\_PYTEST\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9362 [ALL\_PY\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9345 [ALL\_RESOURCE\_FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5408 [ALL\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3129 [ANNOTATION\_PROCESSOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4640 [APPHOST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9869 [ARCHIVE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6529 [ARCHIVE\_ASM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6507 [ARCHIVE\_BY\_KEYS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6540 [ASM\_PREINCLUDE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7524 [ASSERT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/macros_with_error.py?rev=9582506#L25 [BASE\_CODEGEN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6614 [BPF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7402 [BPF\_STATIC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7411 [BUILDWITH\_CYTHON\_C]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6394 [BUILDWITH\_CYTHON\_CPP]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6373 [BUILDWITH\_RAGEL6]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6451 [BUILD\_CATBOOST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/other.conf?rev=9582506#L9 [BUILD\_MN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6944 [BUILD\_MNS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6969 [BUILD\_ONLY\_IF]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [BUILD\_YDL\_DESC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6171 [BUNDLE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/bundle.py?rev=9582506#L4 [CFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6664 [CGO\_CFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8377 [CGO\_LDFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8386 [CGO\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8360 [CHECK\_CONTRIB\_CREDITS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/credits.py?rev=9582506#L8 [CHECK\_DEPENDENT\_DIRS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L521 [CHECK\_JAVA\_DEPS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4417 [CLANG\_EMIT\_AST\_CXX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7374 [CMAKE\_EXPORTED\_TARGET\_NAME]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/opensource.conf?rev=9582506#L51 [COLLECT\_FRONTEND\_FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9564 [COLLECT\_JINJA\_TEMPLATES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8074 [COLLECT\_YDB\_API\_SPECS\_LEGACY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9859 [COMPILE\_C\_AS\_CXX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7307 [COMPILE\_LUA]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6113 [COMPILE\_LUA\_21]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6131 [COMPILE\_NLG]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6980 [COMPILE\_SWIFT\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9578 [CONFIGURE\_FILE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6606 [CONFTEST\_LOAD\_POLICY\_LOCAL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2189 [CONLYFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6679 [COPY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/cp.py?rev=9582506#L6 [COPY\_FILE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5381 [COPY\_FILE\_WITH\_CONTEXT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5390 [CPP\_ADDINCL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7577 [CPP\_ENUMS\_SERIALIZATION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/pybuild.py?rev=9582506#L661 [CPP\_PROTO\_PLUGIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L739 [CPP\_PROTO\_PLUGIN0]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L725 [CPP\_PROTO\_PLUGIN2]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L750 [CREATE\_BUILDINFO\_FOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6577 [CREATE\_INIT\_PY\_STRUCTURE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/create_init_py.py?rev=9582506#L6 [CREDITS\_DISCLAIMER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/credits.py?rev=9582506#L4 [CTEMPLATE\_VARNAMES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7323 [CUDA\_NVCC\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6693 [CUSTOM\_LINK\_STEP\_SCRIPT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1931 [CXXFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6686 [DARWIN\_SIGNED\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9475 [DARWIN\_STRINGS\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9471 [DATA]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2149 [DEB\_VERSION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6933 [DECIMAL\_MD5\_LOWER\_32\_BITS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6589 [DECLARE\_EXTERNAL\_HOST\_RESOURCES\_BUNDLE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [DECLARE\_EXTERNAL\_HOST\_RESOURCES\_PACK]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [DECLARE\_EXTERNAL\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [DEFAULT]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [DEPENDENCY\_MANAGEMENT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4723 [DEPENDS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [DIRECT\_DEPS\_ONLY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4794 [DISABLE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [DISABLE\_DATA\_VALIDATION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2134 [DLL\_FOR]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [DOCS\_BUILDER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L319 [DOCS\_CONFIG]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L383 [DOCS\_COPY\_FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L13 [DOCS\_DIR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L332 [DOCS\_INCLUDE\_SOURCES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L407 [DOCS\_VARS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L395 [DUMPERF\_CODEGEN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6644 [DYNAMIC\_LIBRARY\_FROM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2951 [ELSE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [ELSEIF]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [EMBED\_JAVA\_VCS\_INFO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3312 [ENABLE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [ENABLE\_PREVIEW]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4607 [END]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [ENDIF]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [ENV]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2182 [EXCLUDE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4649 [EXCLUDE\_TAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [EXPORTS\_SCRIPT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1899 [EXPORT\_ALL\_DYNAMIC\_SYMBOLS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1913 [EXPORT\_YMAPS\_PROTO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/sproto.conf?rev=9582506#L4 [EXPOSE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7651 [EXTERNAL\_JAR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/java.py?rev=9582506#L243 [EXTERNAL\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [EXTRADIR]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [EXTRALIBS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [EXTRALIBS\_STATIC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5306 [FAT\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/res.py?rev=9582506#L38 [FBS\_NAMESPACE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7918 [FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/files.py?rev=9582506#L1 [FLATC\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1093 [FLAT\_JOIN\_SRCS\_GLOBAL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5532 [FORK\_SUBTESTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5464 [FORK\_TESTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5450 [FORK\_TEST\_FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5490 [FROM\_ARCHIVE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7292 [FROM\_MDS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7262 [FROM\_NPM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/ts.conf?rev=9582506#L47 [FROM\_SANDBOX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7254 [FUZZ\_DICTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2086 [FUZZ\_OPTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2105 [GENERATED\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7365 [GENERATE\_ENUM\_SERIALIZATION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6912 [GENERATE\_ENUM\_SERIALIZATION\_WITH\_HEADER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6924 [GENERATE\_PY\_PROTOS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5341 [GENERATE\_SCRIPT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/java.py?rev=9582506#L60 [GEN\_SCHEEME2]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7054 [GLOBAL\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3111 [GO\_ASM\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8198 [GO\_BENCH\_TIMEOUT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8858 [GO\_CGO1\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8206 [GO\_CGO2\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8214 [GO\_COMPILE\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8222 [GO\_EMBED\_DIR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8459 [GO\_EMBED\_PATTERN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8423 [GO\_EMBED\_TEST\_DIR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8467 [GO\_EMBED\_XTEST\_DIR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8475 [GO\_FAKE\_OUTPUT]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/plugins/plugin_go_fake_output_handler.cpp?rev=9582506#L110 [GO\_GRPC\_GATEWAY\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8522 [GO\_GRPC\_GATEWAY\_SWAGGER\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8530 [GO\_LDFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8369 [GO\_LINK\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8230 [GO\_MOCKGEN\_FROM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8893 [GO\_MOCKGEN\_MOCKS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8918 [GO\_MOCKGEN\_REFLECT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8904 [GO\_MOCKGEN\_TYPES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8898 [GO\_PACKAGE\_NAME]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8315 [GO\_PROTO\_PLUGIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L851 [GO\_SKIP\_TESTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8397 [GO\_TEST\_EMBED\_PATTERN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8431 [GO\_TEST\_FOR]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [GO\_TEST\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8334 [GO\_XTEST\_EMBED\_PATTERN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8439 [GO\_XTEST\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L8345 [GRPC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1077 [IDEA\_EXCLUDE\_DIRS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4568 [IDEA\_JAR\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3374 [IDEA\_MODULE\_NAME]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4588 [IDEA\_RESOURCE\_DIRS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4578 [IF]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [INCLUDE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [INCLUDE\_TAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [INDUCED\_DEPS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [IOS\_APP\_ASSETS\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9467 [IOS\_APP\_COMMON\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9461 [IOS\_APP\_SETTINGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ios_app_settings.py?rev=9582506#L5 [IOS\_ASSETS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ios_assets.py?rev=9582506#L6 [JAR\_ANNOTATION\_PROCESSOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3417 [JAR\_EXCLUDE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4928 [JAR\_INCLUDE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4920 [JAR\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3479 [JAVAC\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4597 [JAVA\_DEPENDENCIES\_CONFIGURATION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4904 [JAVA\_EXTERNAL\_DEPENDENCIES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4803 [JAVA\_IGNORE\_CLASSPATH\_CLASH\_FOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9288 [JAVA\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/java.py?rev=9582506#L77 [JAVA\_PROTO\_PLUGIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L701 [JAVA\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3641 [JAVA\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4679 [JAVA\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L799 [JAVA\_TEST\_DEPS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L891 [JDK\_VERSION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9532 [JOIN\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5511 [JOIN\_SRCS\_GLOBAL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5522 [JVM\_ARGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4406 [KOTLINC\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4760 [LARGE\_FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7283 [LDFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6654 [LICENSE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/license.conf?rev=9582506#L375 [LICENSE\_TEXTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9795 [LINKER\_SCRIPT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/linker_script.py?rev=9582506#L1 [LINK\_EXEC\_DYN\_LIB\_IMPL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1646 [LINK\_EXE\_IMPL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1640 [LINT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2237 [LJ\_21\_ARCHIVE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/lj_archive.py?rev=9582506#L23 [LJ\_ARCHIVE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/lj_archive.py?rev=9582506#L1 [LLVM\_BC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/llvm_bc.py?rev=9582506#L6 [LLVM\_COMPILE\_C]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7393 [LLVM\_COMPILE\_CXX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7383 [LLVM\_COMPILE\_LL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7420 [LLVM\_LINK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7429 [LLVM\_OPT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7439 [LOCAL\_JAR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3489 [LOCAL\_SOURCES\_JAR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3494 [MACROS\_WITH\_ERROR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/macros_with_error.py?rev=9582506#L8 [MANUAL\_GENERATION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5902 [MAPKITIDL]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/plugins/plugin_mapkitidl_handler.cpp?rev=9582506#L409 [MAPKIT\_ADDINCL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/mapkit.conf?rev=9582506#L2 [MASMFLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6671 [MAVEN\_GROUP\_ID]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4630 [MESSAGE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [METAQUERYFILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9835 [MSVC\_FLAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9852 [MX\_FORMULAS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/mx_archive.py?rev=9582506#L1 [NEED\_CHECK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6991 [NEED\_REVIEW]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7009 [NGINX\_MODULES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9738 [NODE\_MODULES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/ts.conf?rev=9582506#L56 [NO\_BUILD\_IF]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [NO\_CHECK\_IMPORTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7473 [NO\_CLANG\_COVERAGE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6849 [NO\_CLANG\_TIDY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6853 [NO\_COMPILER\_WARNINGS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6722 [NO\_CPU\_CHECK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5640 [NO\_CYTHON\_COVERAGE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6870 [NO\_DEBUG\_INFO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7314 [NO\_DOCTESTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2254 [NO\_EXPORT\_DYNAMIC\_SYMBOLS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1906 [NO\_EXTENDED\_SOURCE\_SEARCH]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1814 [NO\_JOIN\_SRC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6825 [NO\_LIBC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6789 [NO\_LINT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2230 [NO\_LTO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L434 [NO\_MYPY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L946 [NO\_NEED\_CHECK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6999 [NO\_OPTIMIZE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6715 [NO\_OPTIMIZE\_PY\_PROTOS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L651 [NO\_PLATFORM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6799 [NO\_PYTHON\_COVERAGE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6861 [NO\_RUNTIME]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6778 [NO\_SANITIZE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6833 [NO\_SANITIZE\_COVERAGE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6841 [NO\_SSE4]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5632 [NO\_UTIL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6767 [NO\_WERROR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6737 [NO\_WSHADOW]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6743 [NVCC\_DEVICE\_LINK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6702 [ONLY\_TAGS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [OPENSOURCE\_EXPORT\_REPLACEMENT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/opensource.conf?rev=9582506#L33 [ORIGINAL\_SOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9782 [OWNER]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [PACK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3157 [PACKAGE\_STRICT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3162 [PACK\_GLOBALS\_IN\_LIBRARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2662 [PARTITIONED\_RECURSE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [PARTITIONED\_RECURSE\_FOR\_TESTS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [PARTITIONED\_RECURSE\_ROOT\_RELATIVE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [PEERDIR]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [PIRE\_INLINE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6518 [PIRE\_INLINE\_CMD]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6513 [PREPARE\_INDUCED\_DEPS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7118 [PRINT\_MODULE\_TYPE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/print_module_type.py?rev=9582506#L1 [PROCESS\_DOCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/docs.py?rev=9582506#L31 [PROCESS\_MKDOCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/docs.py?rev=9582506#L43 [PROGUARD\_RULES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/aar.conf?rev=9582506#L13 [PROTO2FBS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1012 [PROTO\_ADDINCL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L613 [PROTO\_NAMESPACE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L630 [PROVIDES]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [PYTHON]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7194 [PYTHON2\_ADDINCL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5053 [PYTHON2\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2906 [PYTHON3\_ADDINCL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5100 [PYTHON3\_MODULE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2918 [PYTHON\_PATH]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2212 [PY\_CONSTRUCTOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/pybuild.py?rev=9582506#L629 [PY\_DOCTESTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/pybuild.py?rev=9582506#L556 [PY\_ENUMS\_SERIALIZATION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/pybuild.py?rev=9582506#L644 [PY\_EXTRA\_LINT\_FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9373 [PY\_MAIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/pybuild.py?rev=9582506#L612 [PY\_NAMESPACE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3282 [PY\_PROTOS\_FOR]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [PY\_PROTO\_PLUGIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L674 [PY\_PROTO\_PLUGIN2]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L686 [PY\_REGISTER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/pybuild.py?rev=9582506#L574 [PY\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9318 [PY\_SSQLS\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9709 [REAL\_LINK\_DYN\_LIB\_IMPL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1634 [REAL\_LINK\_EXEC\_DYN\_LIB\_IMPL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1628 [REAL\_LINK\_EXE\_IMPL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1622 [RECURSE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [RECURSE\_FOR\_TESTS]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [RECURSE\_ROOT\_RELATIVE]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [REGISTER\_SANDBOX\_IMPORT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/sandbox_registry.py?rev=9582506#L6 [REGISTER\_YQL\_PYTHON\_UDF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/yql_python_udf.py?rev=9582506#L10 [REQUIREMENTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2173 [REQUIRES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L499 [RESOLVE\_PROTO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3223 [RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L592 [RESOURCE\_FILES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/res.py?rev=9582506#L54 [RESTRICT\_LICENSES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/license.conf?rev=9582506#L391 [RESTRICT\_PATH]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/macros_with_error.py?rev=9582506#L13 [RUN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L1030 [RUN\_ANTLR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7541 [RUN\_ANTLR4]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7550 [RUN\_ANTLR4\_CPP]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7563 [RUN\_ANTLR4\_GO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7571 [RUN\_JAVA\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3410 [RUN\_LUA]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7169 [RUN\_PROGRAM]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7143 [RUN\_PYTHON]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7533 [RUN\_PYTHON3]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7220 [SDBUS\_CPP\_ADAPTOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9679 [SDBUS\_CPP\_PROXY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9685 [SET]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [SETUP\_EXECTEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L1036 [SETUP\_PYTEST\_BIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L1020 [SETUP\_RUN\_PYTHON]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L1048 [SET\_APPEND]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [SET\_APPEND\_WITH\_GLOBAL]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [SET\_COMPILE\_OUTPUTS\_MODIFIERS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5660 [SIZE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5502 [SKIP\_TEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2221 [SOURCE\_GROUP]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [SPLIT\_CODEGEN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/split_codegen.py?rev=9582506#L9 [SPLIT\_DWARF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5290 [SPLIT\_FACTOR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5478 [SRC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6197 [SRCDIR]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6216 [SRC\_C\_AVX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6315 [SRC\_C\_AVX2]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6323 [SRC\_C\_AVX512]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6331 [SRC\_C\_NO\_LTO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6364 [SRC\_C\_PCLMUL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6348 [SRC\_C\_PIC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6356 [SRC\_C\_SSE2]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6275 [SRC\_C\_SSE3]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6283 [SRC\_C\_SSE4]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6299 [SRC\_C\_SSE41]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6307 [SRC\_C\_SSSE3]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6291 [SRC\_C\_XOP]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6340 [SRC\_RESOURCE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L3484 [STRIP]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6709 [STRUCT\_CODEGEN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6637 [STYLE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2362 [STYLE\_PYTHON]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2246 [SUBSCRIBER]: https://a.yandex-team.ru/arc/trunk/arcadia/devtools/ymake/yndex/builtin.cpp?rev=9582506#L14 [SUPPRESSIONS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/suppressions.py?rev=9582506#L1 [SYMLINK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7060 [SYSTEM\_PROPERTIES]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4395 [TAG]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2162 [TASKLET]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7591 [TASKLET\_REG]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7611 [TASKLET\_REG\_EXT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7626 [TEST\_CWD]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4436 [TEST\_DATA]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/ytest.py?rev=9582506#L41 [TEST\_JAVA\_CLASSPATH\_CMD\_TYPE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4886 [TEST\_SRCS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2130 [TIMEOUT]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5423 [UBERJAR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4460 [UBERJAR\_APPENDING\_TRANSFORMER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4544 [UBERJAR\_HIDE\_EXCLUDE\_PATTERN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4488 [UBERJAR\_HIDING\_PREFIX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4473 [UBERJAR\_MANIFEST\_TRANSFORMER\_ATTRIBUTE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4528 [UBERJAR\_MANIFEST\_TRANSFORMER\_MAIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4515 [UBERJAR\_PATH\_EXCLUDE\_PREFIX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4502 [UBERJAR\_SERVICES\_RESOURCE\_TRANSFORMER]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4557 [UDF\_NO\_PROBE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L45 [UPDATE\_VCS\_JAVA\_INFO\_NODEP]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6569 [USE\_COMMON\_GOOGLE\_APIS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L810 [USE\_CXX]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6809 [USE\_DYNAMIC\_CUDA]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1921 [USE\_ERROR\_PRONE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4425 [USE\_EXT\_PROTO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7874 [USE\_JAVALITE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L971 [USE\_LINKER\_GOLD]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1457 [USE\_PERL\_514\_LIB]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5193 [USE\_PERL\_LIB]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5186 [USE\_PLANTUML]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/docs.conf?rev=9582506#L313 [USE\_PYTHON2]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5149 [USE\_PYTHON3]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5166 [USE\_RECIPE]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2200 [USE\_SKIFF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L761 [USE\_UTIL]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6817 [VALIDATE\_DATA\_RESTART]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L5433 [VERSION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L7017 [VISIBILITY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9657 [WERROR]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6730 [WINDOWS\_MANIFEST]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9642 [WITHOUT\_LICENSE\_TEXTS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L9803 [WITH\_DYNAMIC\_LIBS]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1616 [WITH\_GROOVY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4751 [WITH\_JDK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4733 [WITH\_KOTLIN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4742 [WITH\_KOTLINC\_ALLOPEN]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4769 [WITH\_KOTLINC\_NOARG]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L4779 [XS\_PROTO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L1002 [YABS\_GENERATE\_CONF]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/yabs_generate_conf.py?rev=9582506#L10 [YABS\_GENERATE\_PHANTOM\_CONF\_PATCH]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/yabs_generate_conf.py?rev=9582506#L35 [YABS\_GENERATE\_PHANTOM\_CONF\_TEST\_CHECK]: https://a.yandex-team.ru/arc/trunk/arcadia/build/plugins/yabs_generate_conf.py?rev=9582506#L53 [YDL\_DESC\_USE\_BINARY]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L6188 [YMAPS\_SPROTO]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/maps/sproto.conf?rev=9582506#L16 [YP\_PROTO\_YSON]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L891 [YQL\_ABI\_VERSION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L144 [YQL\_LAST\_ABI\_VERSION]: https://a.yandex-team.ru/arc/trunk/arcadia/build/conf/project_specific/yql_udf.conf?rev=9582506#L153 [YT\_SPEC]: https://a.yandex-team.ru/arc/trunk/arcadia/build/ymake.core.conf?rev=9582506#L2119