-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathcado
executable file
·185 lines (163 loc) · 7.92 KB
/
cado
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
#!/bin/bash
#
# Explanation that this is not part of the CMake workflow but is just a helper
# to save some typing.
#
# Basically there are two commands to know:
#
# 1. Configure a build directory. Generate makefiles
#
# cmake -S SOURCE_DIR -B BUILD_DIR [-DOPTION=VALUE ...]
#
# The options are provided by the project maintainers to enable the users
# to change aspects of the build process without needing to understand cmake.
#
# This is also equivalent to doing
#
# mkdir BUILD_DIR
# cd BUILD_DIR
# cmake SOURCE_DIR
#
# 2. Building the entire project or single targets
#
# cmake --build BUILD_DIR [--target TARGET] [-- -j [N]]
#
# this is exactly equivalent to CD'ing into BUILD_DIR and doing
#
# make [-j N] [TARGET]
#
this_project=`cat MANIFEST | sed -n '/NAME/s/.*: //p'`
cmake_command='cmake -S . -B ${build_dir} "$@"'
cmake_static_command='cmake -S . -B ${build_dir} -DSTATIC_INTEL=ON "$@"'
cmake_all_command='WITH_SYSTEM_RPN=FALSE cmake -S . -B ${build_dir} "$@"'
cmake_debug_command='cmake -S . -B ${build_dir} -DCMAKE_BUILD_TYPE=Debug "$@"'
cmake_debug_extra_command='cmake -S . -B ${build_dir} -DCMAKE_BUILD_TYPE=Debug -DEXTRA_CHECKS=ON "$@"'
cmake_mach_command='cmake -S . -B ${build_dir} -DWITH_MACH=TRUE "$@"'
cmake_mach_static_command='cmake -S . -B ${build_dir} -DWITH_MACH=TRUE -DSTATIC_INTEL=ON "$@"'
cmake_all_mach_command='WITH_SYSTEM_RPN=FALSE cmake -S . -B ${build_dir} -DWITH_MACH=TRUE "$@"'
cmake_mach_debug_command='cmake -S . -B ${build_dir} -DWITH_MACH=TRUE -DCMAKE_BUILD_TYPE=Debug "$@"'
build_command='cmake --build ${build_dir} -- "$@"'
work_command='cmake --build ${build_dir} --target work -- "$@"'
install_command='cmake --build ${build_dir} --target install -- "$@"'
package_command='cmake --build ${build_dir} --target package -- "$@"'
clean_command='cmake --build ${build_dir} --target clean -- "$@"'
print_cado_help(){
printf "Usage: cado COMMAND ..
Shortcuts for configuring and building ${this_project}.
\033[1mDESCRIPTION\033[0m:
This project is configured using CMake. To get started, you must first run
one of the \`cado cmake*\` commands which will configure the project to be
built following certain options described below.
Once this is done, one of the other commands (build, work, package, clean)
may be used build the project and possibly install it to the working
directory
\033[1mCOMMANDS\033[0m:
\033[4mconfiguration\033[0m:
\033[1mcmake\033[0m:
Generate Makefiles for building the project with installed RPN
dependencies when at CMC, or with their sources outside CMC.
\033[1mcmake-static\033[0m:
Generate Makefiles for building the project with static Intel libraries.
\033[1mcmake-all\033[0m:
Generate Makefiles for building the project with the RPN libraries
included as submodules instead of the system-installed ones. This
allows the developer to be exactly sure what they are using at the cost
of longer build time.
\033[1mcmake-debug\033[0m:
Generate Makefiles for compiling with debug flags.
\033[1mcmake-debug-extra\033[0m:
Generate Makefiles for compiling with debug flags and extra checks.
\033[4mbuilding\033[0m:
Additional arguments will be passed to the build tool (make). For example
\`cado build -j\`
\033[1mbuild\033[0m:
Build the entire project
\033[1mwork\033[0m:
Build the entire project and install it in the working directory
\033[1mpackage\033[0m:
Build the entire project and create an SSM package.
\033[1mclean\033[0m:
Clean all build artifacts (.o, .a, .so, and executables)
NOTE:
- Because CMake supports and encourages out-of-tree builds, the equivalent of
distclean target from the GNU standard is simply removing the build directory.
- Running one of the cmake commands after another can change some build options
for example, running \`cado cmake-all\` will cause the project to be built
with the RPN libraries included as submodules. It is possible to switch to
building with the system RPN libraries by running \`cado cmake\` without
needing to delete the build directory and start over.
"
}
print_cado_short_help(){
printf "cado COMMAND [...]
COMMANDS:
configuration: (additional arguments forwarded to CMake)
cmake: configure using installed RPN libraries at CMC (and sources outside CMC)
cmake-static: configure using installed RPN libraries and static Intel libraries (-DSTATIC_INTEL=ON)
cmake-all: configure using sources of RPN libraries (WITH_SYSTEM_RPN is set to FALSE)
cmake-debug: configure with debug flags (-DCMAKE_BUILD_TYPE=Debug)
cmake-debug-extra: configure with debug flags and extra compile-time checks (-DCMAKE_BUILD_TYPE=Debug -DEXTRA_CHECKS=ON)
cmake-mach: configure using installed RPN libraries (-DWITH_MACH=TRUE)
cmake-mach-static: configure using installed RPN libraries and static Intel libraries (-DSTATIC_INTEL=ON -DWITH_MACH=TRUE)
cmake-all-mach: configure using sources of RPN libraries (WITH_SYSTEM_RPN is set to FALSE -DWITH_MACH=TRUE)
cmake-mach-debug: configure with debug flags (-DCMAKE_BUILD_TYPE=Debug -DWITH_MACH=TRUE)
building: (Additional arguments forwarded to make (like -j))
build: Build entire project
work: Build entire project, install to working directory
package: Build entire project, create SSM package
clean: Delete build artifacts
See \`cado --help\` for more detailed info
"
}
this_project_upper=$(echo ${this_project} | tr '[:lower:]' '[:upper:]')
if [[ -z $(eval echo \${${this_project_upper}_ARCH}) ]] ; then
echo "$0: This convenience helper uses \${${this_project_upper}_ARCH} to set the cmake build"
echo "and install directories as build-\${${this_project_upper}_ARCH} and work-\${${this_project_upper}_ARCH}"
echo "but the variable is not set. This indicates that the environment"
echo "setup 'source .common_setup <compiler>' has not been done. This"
echo "is necessary for the build with or without this helper."
exit 1
fi
this_project_lower=$(echo ${this_project} | tr '[:upper:]' '[:lower:]')
if [[ $(realpath $PWD) != $(realpath $(eval echo \${${this_project_lower}_DIR})) ]] ; then
printf "$0: \033[1;31mERROR\033[0m: This command must be run from the top of the source code repository\n"
exit 1
fi
if ! build_dir=$(realpath build-$(eval echo \${${this_project_upper}_ARCH})) ; then
echo "ERROR running true_path on 'build-\${this_project_upper}_ARCH}'."
fi
echo "Using build directory '${build_dir}'"
name=$1
shift
cmd=""
case "${name}" in
cmake) cmd=${cmake_command} ;;
cmake-static) cmd=${cmake_static_command} ;;
cmake-all) cmd=${cmake_all_command} ;;
cmake-debug) cmd=${cmake_debug_command} ;;
cmake-debug-extra) cmd=${cmake_debug_extra_command} ;;
cmake-mach) cmd=${cmake_mach_command} ;;
cmake-mach-static) cmd=${cmake_mach_static_command} ;;
cmake-all-mach) cmd=${cmake_all_mach_command} ;;
cmake-mach-debug) cmd=${cmake_mach_debug_command} ;;
build) cmd=${build_command} ;;
work) cmd=${work_command} ;;
install) cmd=${install_command} ;;
package) cmd=${package_command} ;;
clean) cmd=${clean_command} ;;
help|--help) print_cado_help ; exit 0 ;;
-h) print_cado_short_help ; exit 0 ;;
'') printf "\033[1;31mERROR\033[0m: A command is required\n"; print_cado_short_help ; exit 1 ;;
*) printf "\033[1;31mERROR\033[0m: Unknown command '${name}', see \`cado help\`\n"; exit 1 ;;
esac
printf "$0: running '${name}' command:\n"
eval echo ${cmd}
eval ${cmd}
cmd_exit_code=$?
if [[ ${cmd_exit_code} == 0 ]] ; then
printf "$0: Command '${name}' completed successfully:\n"
else
printf "$0: Command '${name}' completed failed with code ${cmd_exit_code}:\n"
fi
eval echo ${cmd}
exit ${cmd_exit_code}