blob: bc66e176dcd74fa0c4b6a9fbd234f28fd12bf4b4 (
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
59
60
61
62
63
64
65
66
67
68
69
70
71
|
# NEXT_ROOT is defined by _PEERDIR_TS_RESOURCE(next)
NEXT_ROOT=
TS_NEXT_OUTPUT_DIR=.next
TS_NEXT_CONFIG_PATH=next.config.js
TS_NEXT_CMD=$TOUCH_UNIT \
&& $_TS_FILES_COPY_CMD \
&& $ADD_VCS_INFO_FILE_CMD \
&& ${cwd:BINDIR} $NOTS_TOOL build-nextjs $NOTS_TOOL_BASE_ARGS \
--moddir $MODDIR \
--ts-config ${input:TS_CONFIG_PATH} \
--node-modules-bundle $NOTS_TOOL_NODE_MODULES_BUNDLE $NODE_MODULES_BUNDLE_AS_OUTPUT ${hide:PEERS} \
--nextjs-resource $NEXT_ROOT \
--nextjs-config ${input:TS_NEXT_CONFIG_PATH} \
--vcs-info "${VCS_INFO_FILE}" \
--output-dir ${TS_NEXT_OUTPUT_DIR} \
${input;hide:"package.json"} ${TS_CONFIG_FILES} $_TS_GLOB_AS_INPUTS(IN $TS_GLOB_FILES) \
${output;hide:"output.tar"} ${output;hide:"package.json"} \
${kv;hide:"p TSNEXT"} ${kv;hide:"pc magenta"}
### @usage: TS_NEXT()
###
### NextJS app, built with `next build`. Requires sources to be under /src folder.
### /pages and /app on the root level ar not supported.
### Build results are output.tar.
###
### @example
###
### TS_NEXT()
### END()
###
multimodule TS_NEXT {
module BUILD: _TS_BASE_UNIT {
.CMD=TS_NEXT_CMD
.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(next)
SET_APPEND(_MAKEFILE_INCLUDE_LIKE_DEPS ${CURDIR}/${TS_CONFIG_PATH} ${CURDIR}/package.json)
SET(TS_CONFIG_DEDUCE_OUT no)
_TS_GLOB()
_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 {
}
}
macro TS_NEXT_CONFIG(Path) {
SET(TS_NEXT_CONFIG_PATH $Path)
}
### @usage: TS_NEXT_OUTPUT(DirName)
###
### Macro sets the output directory name for TS_NEXT module.
###
### - DirName - output directory name ("bundle" by default).
macro TS_NEXT_OUTPUT(DirName) {
SET(TS_NEXT_OUTPUT_DIR $DirName)
}
|