serenity/Meta/gn/build/embed_as_string.gni
Sam Atkins 5d86305596 Meta: Make embed_as_string_view.py produce Strings instead
This is only used for CSS style sheets. One case wants it as a String,
and the others don't care, but will in future also want to have the
source as a String.

(cherry picked from commit 8cbc2116162764479edeec78e4b2b7c41447b643;
amended to fix conflicts in two cmake files, due to serenity
still having more code_generators, and still buildling
OutOfProcessWebView.cpp. Also kept embed_as_string_view because
it's used by stringify_gml. Did this by giving embed_as_string.py
a --type= argument that defaults to string but can also be set
to string-view.)
2024-11-15 23:10:03 -05:00

64 lines
1.8 KiB
Text

# This file introduces a template for calling embed_as_string.py.
#
# embed_as_string behaves like C++23 #embed, converting an input file into
# an AK::StringView literal rather than a C-string literal. The literal will
# be placed into a global variable, optionally with a namespace wrapping it.
#
# Note that the file must not contain any tokens that need to be escaped
# in C++, or the script will fail to produce a valid C++ translation unit.
#
# Parameters:
#
# input (required) [string]
#
# output (required) [string]
#
# variable_name (required) [string]
#
# namespace (optional) [string]
#
# Example use:
#
# embed_as_string("embed_my_file") {
# input = "MyFile.txt"
# output = "$root_gen_dir/MyDirectory/MyFile.cpp"
# variable_name = "my_file_contents"
# namespace = "My::NS"
# }
template("embed_as_string") {
assert(defined(invoker.input), "must set 'input' in $target_name")
assert(defined(invoker.output), "must set 'output' in $target_name")
assert(defined(invoker.variable_name),
"must set 'variable_name' in $target_name")
action(target_name) {
script = "//Meta/embed_as_string.py"
sources = [ invoker.input ]
outputs = [ invoker.output ]
args = [
"-o",
rebase_path(outputs[0], root_build_dir),
"-n",
invoker.variable_name,
]
if (defined(invoker.namespace)) {
args += [
"-s",
invoker.namespace,
]
}
args += [ rebase_path(sources[0], root_build_dir) ]
forward_variables_from(invoker,
[
"configs",
"deps",
"public_configs",
"public_deps",
"testonly",
"visibility",
])
}
}