blob: 6e9e0571cf336767b6ca11b27793af0bf872bbd0 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
WEBPACK_OUTPUT_DIR=bundle
WEBPACK_CONFIG_PATH=webpack.config.js
TS_WEBPACK_CMD=$TOUCH_UNIT \
&& $_TS_FILES_COPY_CMD \
&& $ADD_VCS_INFO_FILE_CMD \
&& $NOTS_TOOL $NOTS_TOOL_BASE_ARGS build-webpack $NOTS_TOOL_COMMON_BUILDER_ARGS \
--bundler-config-path ${input:WEBPACK_CONFIG_PATH} \
--output-dir ${WEBPACK_OUTPUT_DIR} \
$_NODE_MODULES_INOUTS ${hide:PEERS} \
${input;hide:"package.json"} ${TS_CONFIG_FILES} $_AS_HIDDEN_INPUTS(IN $TS_INPUT_FILES) \
${output;hide:"package.json"} \
${kv;hide:"pc magenta"} ${kv;hide:"p TS_WPK"}
### @usage: WEBPACK_OUTPUT(DirName)
###
### Macro sets the output directory name for TS_WEBPACK module.
###
### - DirName - output directory name ("bundle" by default).
macro WEBPACK_OUTPUT(DirName) {
SET(WEBPACK_OUTPUT_DIR $DirName)
}
### @usage: TS_WEBPACK([name])
###
### The Webpack bundle, bundles JavaScript code.
### Build results are packed as `output.tar`.
###
### @example
###
### TS_WEBPACK()
### END()
###
multimodule TS_WEBPACK {
module BUILD: _TS_BASE_UNIT {
.CMD=TS_WEBPACK_CMD
.EPILOGUE=_TS_CONFIG_EPILOGUE
.PEERDIRSELF=TS_PREPARE_DEPS
# 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 webpack-cli)
DISABLE(TS_CONFIG_DEDUCE_OUT)
DISABLE(TS_CONFIG_USE_OUTDIR)
_TS_CONFIGURE($TS_CONFIG_PATH)
SET_APPEND(_MAKEFILE_INCLUDE_LIKE_DEPS ${CURDIR}/package.json ${CURDIR}/pnpm-lock.yaml ${CURDIR}/${TS_CONFIG_PATH})
_TS_ADD_NODE_MODULES_FOR_BUILDER()
}
module TS_PREPARE_DEPS: _PREPARE_DEPS_BASE {
}
}
|