Use a shorter/simpler license convention, stops the header taking so much space. Follow the SPDX license specification: https://spdx.org/licenses - C/C++/objc/objc++ - Python - Shell Scripts - CMake, GNUmakefile While most of the source tree has been included - `./extern/` was left out. - `./intern/cycles` & `./intern/atomic` are also excluded because they use different header conventions. doc/license/SPDX-license-identifiers.txt has been added to list SPDX all used identifiers. See P2788 for the script that automated these edits. Reviewed By: brecht, mont29, sergey Ref D14069
42 lines
1.4 KiB
C++
42 lines
1.4 KiB
C++
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
|
|
#include "BLI_string_utf8.h"
|
|
|
|
#include "node_function_util.hh"
|
|
|
|
namespace blender::nodes::node_fn_slice_string_cc {
|
|
|
|
static void fn_node_slice_string_declare(NodeDeclarationBuilder &b)
|
|
{
|
|
b.add_input<decl::String>(N_("String"));
|
|
b.add_input<decl::Int>(N_("Position"));
|
|
b.add_input<decl::Int>(N_("Length")).min(0).default_value(10);
|
|
b.add_output<decl::String>(N_("String"));
|
|
}
|
|
|
|
static void fn_node_slice_string_build_multi_function(NodeMultiFunctionBuilder &builder)
|
|
{
|
|
static blender::fn::CustomMF_SI_SI_SI_SO<std::string, int, int, std::string> slice_fn{
|
|
"Slice", [](const std::string &str, int a, int b) {
|
|
const int len = BLI_strlen_utf8(str.c_str());
|
|
const int start = BLI_str_utf8_offset_from_index(str.c_str(), std::clamp(a, 0, len));
|
|
const int end = BLI_str_utf8_offset_from_index(str.c_str(), std::clamp(a + b, 0, len));
|
|
return str.substr(start, std::max<int>(end - start, 0));
|
|
}};
|
|
builder.set_matching_fn(&slice_fn);
|
|
}
|
|
|
|
} // namespace blender::nodes::node_fn_slice_string_cc
|
|
|
|
void register_node_type_fn_slice_string()
|
|
{
|
|
namespace file_ns = blender::nodes::node_fn_slice_string_cc;
|
|
|
|
static bNodeType ntype;
|
|
|
|
fn_node_type_base(&ntype, FN_NODE_SLICE_STRING, "Slice String", NODE_CLASS_CONVERTER);
|
|
ntype.declare = file_ns::fn_node_slice_string_declare;
|
|
ntype.build_multi_function = file_ns::fn_node_slice_string_build_multi_function;
|
|
nodeRegisterType(&ntype);
|
|
}
|