diff options
author | alexv-smirnov <alex@ydb.tech> | 2023-06-13 11:05:01 +0300 |
---|---|---|
committer | alexv-smirnov <alex@ydb.tech> | 2023-06-13 11:05:01 +0300 |
commit | bf0f13dd39ee3e65092ba3572bb5b1fcd125dcd0 (patch) | |
tree | 1d1df72c0541a59a81439842f46d95396d3e7189 /build/conf/ts/ts_bundle.conf | |
parent | 8bfdfa9a9bd19bddbc58d888e180fbd1218681be (diff) | |
download | ydb-bf0f13dd39ee3e65092ba3572bb5b1fcd125dcd0.tar.gz |
add ymake export to ydb
Diffstat (limited to 'build/conf/ts/ts_bundle.conf')
-rw-r--r-- | build/conf/ts/ts_bundle.conf | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/build/conf/ts/ts_bundle.conf b/build/conf/ts/ts_bundle.conf new file mode 100644 index 0000000000..973b9ae40f --- /dev/null +++ b/build/conf/ts/ts_bundle.conf @@ -0,0 +1,46 @@ +# WEBPACK_ROOT is redefined in /build/plugins/nots.py _set_resource_vars() +WEBPACK_ROOT= +WEBPACK_CONFIG_PATH=webpack.config.js +TS_BUNDLE_WEBPACK=$TOUCH_UNIT \ + && ${cwd:BINDIR} $NOTS_TOOL bundle-webpack $NOTS_TOOL_BASE_ARGS --webpack-resource $WEBPACK_ROOT \ + --webpack-config ${input:WEBPACK_CONFIG_PATH} --ts-config ${input:TS_CONFIG_PATH} \ + --node-modules-bundle $NOTS_TOOL_NODE_MODULES_BUNDLE $NODE_MODULES_BUNDLE_AS_OUTPUT ${hide:PEERS} \ + ${input;hide:"./package.json"} ${TS_CONFIG_FILES} ${output;hide:"bundle.tar"} \ + ${output;hide:"package.json"} ${kv;hide:"p TSWP"} ${kv;hide:"pc magenta"} + +### @usage: TS_BUNDLE([name]) +### +### The Webpack bundle, bundles JavaScript code. +### Build results are bundle.tar (depending on local tsconfig.json settings). +### +### @example +### +### TS_BUNDLE() +### SRCS(src/index.ts) +### END() +### +multimodule TS_BUNDLE { + module BUILD: _TS_BASE_UNIT { + .CMD=TS_BUNDLE_WEBPACK + .PEERDIRSELF=NODE_MODULES + # epilogue is not inherited from TS_LIBRARY + .EPILOGUE=_TS_CONFIG_EPILOGUE + + # by default multimodule overrides inherited MODULE_TAG to submodule name (BUILD in this case) + # but we have to set it to TS for include processor to work + SET(MODULE_TAG TS) + + _PEERDIR_TS_RESOURCE(webpack) + SET_APPEND(_MAKEFILE_INCLUDE_LIKE_DEPS ${CURDIR}/${TS_CONFIG_PATH} ${CURDIR}/package.json) + SET(TS_CONFIG_DEDUCE_OUT no) + + _TS_CONFIGURE($TS_CONFIG_PATH) + + # we should set NODE_MODULES_BUNDLE_AS_OUTPUT conditionally, + # based on whether module has deps or doesn't have + _SET_NODE_MODULES_BUNDLE_AS_OUTPUT() + } + + module NODE_MODULES: _NODE_MODULES_BASE { + } +} |