aboutsummaryrefslogtreecommitdiffstats
path: root/build/conf/ts/ts_bundle.conf
diff options
context:
space:
mode:
authoralexv-smirnov <alex@ydb.tech>2023-06-13 11:05:01 +0300
committeralexv-smirnov <alex@ydb.tech>2023-06-13 11:05:01 +0300
commitbf0f13dd39ee3e65092ba3572bb5b1fcd125dcd0 (patch)
tree1d1df72c0541a59a81439842f46d95396d3e7189 /build/conf/ts/ts_bundle.conf
parent8bfdfa9a9bd19bddbc58d888e180fbd1218681be (diff)
downloadydb-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.conf46
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 {
+ }
+}