Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJacques Lucke <jacques@blender.org>2021-10-22 16:34:53 +0300
committerJacques Lucke <jacques@blender.org>2021-10-22 16:34:53 +0300
commit39f88480bb1fa0db7fda8bacb3c7d5a0b1cf2171 (patch)
tree8e922ab349c0a90d3dd68408b533fce145a0f9a5 /source/blender/nodes/function
parent0c16ac9ddfd9c0a7d5915caf8b6000bf7c408447 (diff)
Cleanup: improve consistency between function node implementations
Diffstat (limited to 'source/blender/nodes/function')
-rw-r--r--source/blender/nodes/function/nodes/node_fn_boolean_math.cc29
-rw-r--r--source/blender/nodes/function/nodes/node_fn_float_compare.cc31
-rw-r--r--source/blender/nodes/function/nodes/node_fn_float_to_int.cc30
-rw-r--r--source/blender/nodes/function/nodes/node_fn_input_color.cc4
-rw-r--r--source/blender/nodes/function/nodes/node_fn_input_string.cc21
-rw-r--r--source/blender/nodes/function/nodes/node_fn_input_vector.cc18
-rw-r--r--source/blender/nodes/function/nodes/node_fn_replace_string.cc18
-rw-r--r--source/blender/nodes/function/nodes/node_fn_rotate_euler.cc1
-rw-r--r--source/blender/nodes/function/nodes/node_fn_string_length.cc11
-rw-r--r--source/blender/nodes/function/nodes/node_fn_string_substring.cc11
-rw-r--r--source/blender/nodes/function/nodes/node_fn_value_to_string.cc11
11 files changed, 88 insertions, 97 deletions
diff --git a/source/blender/nodes/function/nodes/node_fn_boolean_math.cc b/source/blender/nodes/function/nodes/node_fn_boolean_math.cc
index d10490bb2ee..09caf12e425 100644
--- a/source/blender/nodes/function/nodes/node_fn_boolean_math.cc
+++ b/source/blender/nodes/function/nodes/node_fn_boolean_math.cc
@@ -34,8 +34,6 @@ static void fn_node_boolean_math_declare(NodeDeclarationBuilder &b)
b.add_output<decl::Bool>("Boolean");
};
-} // namespace blender::nodes
-
static void fn_node_boolean_math_layout(uiLayout *layout, bContext *UNUSED(C), PointerRNA *ptr)
{
uiItemR(layout, ptr, "operation", 0, "", ICON_NONE);
@@ -59,13 +57,13 @@ static void node_boolean_math_label(bNodeTree *UNUSED(ntree), bNode *node, char
BLI_strncpy(label, IFACE_(name), maxlen);
}
-static const blender::fn::MultiFunction *get_multi_function(bNode &bnode)
+static const fn::MultiFunction *get_multi_function(bNode &bnode)
{
- static blender::fn::CustomMF_SI_SI_SO<bool, bool, bool> and_fn{
- "And", [](bool a, bool b) { return a && b; }};
- static blender::fn::CustomMF_SI_SI_SO<bool, bool, bool> or_fn{
- "Or", [](bool a, bool b) { return a || b; }};
- static blender::fn::CustomMF_SI_SO<bool, bool> not_fn{"Not", [](bool a) { return !a; }};
+ static fn::CustomMF_SI_SI_SO<bool, bool, bool> and_fn{"And",
+ [](bool a, bool b) { return a && b; }};
+ static fn::CustomMF_SI_SI_SO<bool, bool, bool> or_fn{"Or",
+ [](bool a, bool b) { return a || b; }};
+ static fn::CustomMF_SI_SO<bool, bool> not_fn{"Not", [](bool a) { return !a; }};
switch (bnode.custom1) {
case NODE_BOOLEAN_MATH_AND:
@@ -80,22 +78,23 @@ static const blender::fn::MultiFunction *get_multi_function(bNode &bnode)
return nullptr;
}
-static void fn_node_boolean_math_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_boolean_math_build_multi_function(NodeMultiFunctionBuilder &builder)
{
- const blender::fn::MultiFunction *fn = get_multi_function(builder.node());
+ const fn::MultiFunction *fn = get_multi_function(builder.node());
builder.set_matching_fn(fn);
}
+} // namespace blender::nodes
+
void register_node_type_fn_boolean_math()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_BOOLEAN_MATH, "Boolean Math", NODE_CLASS_CONVERTER, 0);
ntype.declare = blender::nodes::fn_node_boolean_math_declare;
- node_type_label(&ntype, node_boolean_math_label);
- node_type_update(&ntype, node_boolean_math_update);
- ntype.build_multi_function = fn_node_boolean_math_build_multi_function;
- ntype.draw_buttons = fn_node_boolean_math_layout;
+ node_type_label(&ntype, blender::nodes::node_boolean_math_label);
+ node_type_update(&ntype, blender::nodes::node_boolean_math_update);
+ ntype.build_multi_function = blender::nodes::fn_node_boolean_math_build_multi_function;
+ ntype.draw_buttons = blender::nodes::fn_node_boolean_math_layout;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_float_compare.cc b/source/blender/nodes/function/nodes/node_fn_float_compare.cc
index 7905419ddb1..bdc4a3c1e02 100644
--- a/source/blender/nodes/function/nodes/node_fn_float_compare.cc
+++ b/source/blender/nodes/function/nodes/node_fn_float_compare.cc
@@ -37,8 +37,6 @@ static void fn_node_float_compare_declare(NodeDeclarationBuilder &b)
b.add_output<decl::Bool>("Result");
};
-} // namespace blender::nodes
-
static void geo_node_float_compare_layout(uiLayout *layout, bContext *UNUSED(C), PointerRNA *ptr)
{
uiItemR(layout, ptr, "operation", 0, "", ICON_NONE);
@@ -65,19 +63,19 @@ static void node_float_compare_label(bNodeTree *UNUSED(ntree),
BLI_strncpy(label, IFACE_(name), maxlen);
}
-static const blender::fn::MultiFunction *get_multi_function(bNode &node)
+static const fn::MultiFunction *get_multi_function(bNode &node)
{
- static blender::fn::CustomMF_SI_SI_SO<float, float, bool> less_than_fn{
+ static fn::CustomMF_SI_SI_SO<float, float, bool> less_than_fn{
"Less Than", [](float a, float b) { return a < b; }};
- static blender::fn::CustomMF_SI_SI_SO<float, float, bool> less_equal_fn{
+ static fn::CustomMF_SI_SI_SO<float, float, bool> less_equal_fn{
"Less Equal", [](float a, float b) { return a <= b; }};
- static blender::fn::CustomMF_SI_SI_SO<float, float, bool> greater_than_fn{
+ static fn::CustomMF_SI_SI_SO<float, float, bool> greater_than_fn{
"Greater Than", [](float a, float b) { return a > b; }};
- static blender::fn::CustomMF_SI_SI_SO<float, float, bool> greater_equal_fn{
+ static fn::CustomMF_SI_SI_SO<float, float, bool> greater_equal_fn{
"Greater Equal", [](float a, float b) { return a >= b; }};
- static blender::fn::CustomMF_SI_SI_SI_SO<float, float, float, bool> equal_fn{
+ static fn::CustomMF_SI_SI_SI_SO<float, float, float, bool> equal_fn{
"Equal", [](float a, float b, float epsilon) { return std::abs(a - b) <= epsilon; }};
- static blender::fn::CustomMF_SI_SI_SI_SO<float, float, float, bool> not_equal_fn{
+ static fn::CustomMF_SI_SI_SI_SO<float, float, float, bool> not_equal_fn{
"Not Equal", [](float a, float b, float epsilon) { return std::abs(a - b) > epsilon; }};
switch (node.custom1) {
@@ -99,22 +97,23 @@ static const blender::fn::MultiFunction *get_multi_function(bNode &node)
return nullptr;
}
-static void fn_node_float_compare_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_float_compare_build_multi_function(NodeMultiFunctionBuilder &builder)
{
- const blender::fn::MultiFunction *fn = get_multi_function(builder.node());
+ const fn::MultiFunction *fn = get_multi_function(builder.node());
builder.set_matching_fn(fn);
}
+} // namespace blender::nodes
+
void register_node_type_fn_float_compare()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_COMPARE_FLOATS, "Compare Floats", NODE_CLASS_CONVERTER, 0);
ntype.declare = blender::nodes::fn_node_float_compare_declare;
- node_type_label(&ntype, node_float_compare_label);
- node_type_update(&ntype, node_float_compare_update);
- ntype.build_multi_function = fn_node_float_compare_build_multi_function;
- ntype.draw_buttons = geo_node_float_compare_layout;
+ node_type_label(&ntype, blender::nodes::node_float_compare_label);
+ node_type_update(&ntype, blender::nodes::node_float_compare_update);
+ ntype.build_multi_function = blender::nodes::fn_node_float_compare_build_multi_function;
+ ntype.draw_buttons = blender::nodes::geo_node_float_compare_layout;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_float_to_int.cc b/source/blender/nodes/function/nodes/node_fn_float_to_int.cc
index 8bb5dafff8a..5dccd26158b 100644
--- a/source/blender/nodes/function/nodes/node_fn_float_to_int.cc
+++ b/source/blender/nodes/function/nodes/node_fn_float_to_int.cc
@@ -34,8 +34,6 @@ static void fn_node_float_to_int_declare(NodeDeclarationBuilder &b)
b.add_output<decl::Int>("Integer");
};
-} // namespace blender::nodes
-
static void fn_node_float_to_int_layout(uiLayout *layout, bContext *UNUSED(C), PointerRNA *ptr)
{
uiItemR(layout, ptr, "rounding_mode", 0, "", ICON_NONE);
@@ -51,16 +49,13 @@ static void node_float_to_int_label(bNodeTree *UNUSED(ntree), bNode *node, char
BLI_strncpy(label, IFACE_(name), maxlen);
}
-static const blender::fn::MultiFunction *get_multi_function(bNode &bnode)
+static const fn::MultiFunction *get_multi_function(bNode &bnode)
{
- static blender::fn::CustomMF_SI_SO<float, int> round_fn{"Round",
- [](float a) { return (int)round(a); }};
- static blender::fn::CustomMF_SI_SO<float, int> floor_fn{"Floor",
- [](float a) { return (int)floor(a); }};
- static blender::fn::CustomMF_SI_SO<float, int> ceil_fn{"Ceiling",
- [](float a) { return (int)ceil(a); }};
- static blender::fn::CustomMF_SI_SO<float, int> trunc_fn{"Truncate",
- [](float a) { return (int)trunc(a); }};
+ static fn::CustomMF_SI_SO<float, int> round_fn{"Round", [](float a) { return (int)round(a); }};
+ static fn::CustomMF_SI_SO<float, int> floor_fn{"Floor", [](float a) { return (int)floor(a); }};
+ static fn::CustomMF_SI_SO<float, int> ceil_fn{"Ceiling", [](float a) { return (int)ceil(a); }};
+ static fn::CustomMF_SI_SO<float, int> trunc_fn{"Truncate",
+ [](float a) { return (int)trunc(a); }};
switch (static_cast<FloatToIntRoundingMode>(bnode.custom1)) {
case FN_NODE_FLOAT_TO_INT_ROUND:
@@ -77,21 +72,22 @@ static const blender::fn::MultiFunction *get_multi_function(bNode &bnode)
return nullptr;
}
-static void fn_node_float_to_int_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_float_to_int_build_multi_function(NodeMultiFunctionBuilder &builder)
{
- const blender::fn::MultiFunction *fn = get_multi_function(builder.node());
+ const fn::MultiFunction *fn = get_multi_function(builder.node());
builder.set_matching_fn(fn);
}
+} // namespace blender::nodes
+
void register_node_type_fn_float_to_int()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_FLOAT_TO_INT, "Float to Integer", NODE_CLASS_CONVERTER, 0);
ntype.declare = blender::nodes::fn_node_float_to_int_declare;
- node_type_label(&ntype, node_float_to_int_label);
- ntype.build_multi_function = fn_node_float_to_int_build_multi_function;
- ntype.draw_buttons = fn_node_float_to_int_layout;
+ node_type_label(&ntype, blender::nodes::node_float_to_int_label);
+ ntype.build_multi_function = blender::nodes::fn_node_float_to_int_build_multi_function;
+ ntype.draw_buttons = blender::nodes::fn_node_float_to_int_layout;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_input_color.cc b/source/blender/nodes/function/nodes/node_fn_input_color.cc
index 5dc211da1b2..b6079835eae 100644
--- a/source/blender/nodes/function/nodes/node_fn_input_color.cc
+++ b/source/blender/nodes/function/nodes/node_fn_input_color.cc
@@ -32,7 +32,7 @@ static void fn_node_input_color_layout(uiLayout *layout, bContext *UNUSED(C), Po
uiItemR(layout, ptr, "color", UI_ITEM_R_SPLIT_EMPTY_NAME, "", ICON_NONE);
}
-static void fn_node_color_input_build_multi_function(
+static void fn_node_input_color_build_multi_function(
blender::nodes::NodeMultiFunctionBuilder &builder)
{
bNode &bnode = builder.node();
@@ -59,7 +59,7 @@ void register_node_type_fn_input_color()
node_type_init(&ntype, blender::nodes::fn_node_input_color_init);
node_type_storage(
&ntype, "NodeInputColor", node_free_standard_storage, node_copy_standard_storage);
- ntype.build_multi_function = blender::nodes::fn_node_color_input_build_multi_function;
+ ntype.build_multi_function = blender::nodes::fn_node_input_color_build_multi_function;
ntype.draw_buttons = blender::nodes::fn_node_input_color_layout;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_input_string.cc b/source/blender/nodes/function/nodes/node_fn_input_string.cc
index 704ae9d900c..0982096eaea 100644
--- a/source/blender/nodes/function/nodes/node_fn_input_string.cc
+++ b/source/blender/nodes/function/nodes/node_fn_input_string.cc
@@ -27,21 +27,17 @@ static void fn_node_input_string_declare(NodeDeclarationBuilder &b)
b.add_output<decl::String>("String");
};
-} // namespace blender::nodes
-
static void fn_node_input_string_layout(uiLayout *layout, bContext *UNUSED(C), PointerRNA *ptr)
{
uiItemR(layout, ptr, "string", 0, "", ICON_NONE);
}
-static void fn_node_input_string_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_input_string_build_multi_function(NodeMultiFunctionBuilder &builder)
{
bNode &bnode = builder.node();
NodeInputString *node_storage = static_cast<NodeInputString *>(bnode.storage);
std::string string = std::string((node_storage->string) ? node_storage->string : "");
- builder.construct_and_set_matching_fn<blender::fn::CustomMF_Constant<std::string>>(
- std::move(string));
+ builder.construct_and_set_matching_fn<fn::CustomMF_Constant<std::string>>(std::move(string));
}
static void fn_node_input_string_init(bNodeTree *UNUSED(ntree), bNode *node)
@@ -75,15 +71,20 @@ static void fn_node_string_copy(bNodeTree *UNUSED(dest_ntree),
dest_node->storage = destination_storage;
}
+} // namespace blender::nodes
+
void register_node_type_fn_input_string()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_INPUT_STRING, "String", NODE_CLASS_INPUT, 0);
ntype.declare = blender::nodes::fn_node_input_string_declare;
- node_type_init(&ntype, fn_node_input_string_init);
- node_type_storage(&ntype, "NodeInputString", fn_node_input_string_free, fn_node_string_copy);
- ntype.build_multi_function = fn_node_input_string_build_multi_function;
- ntype.draw_buttons = fn_node_input_string_layout;
+ node_type_init(&ntype, blender::nodes::fn_node_input_string_init);
+ node_type_storage(&ntype,
+ "NodeInputString",
+ blender::nodes::fn_node_input_string_free,
+ blender::nodes::fn_node_string_copy);
+ ntype.build_multi_function = blender::nodes::fn_node_input_string_build_multi_function;
+ ntype.draw_buttons = blender::nodes::fn_node_input_string_layout;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_input_vector.cc b/source/blender/nodes/function/nodes/node_fn_input_vector.cc
index 9548df7b423..f64fd182282 100644
--- a/source/blender/nodes/function/nodes/node_fn_input_vector.cc
+++ b/source/blender/nodes/function/nodes/node_fn_input_vector.cc
@@ -28,22 +28,20 @@ static void fn_node_input_vector_declare(NodeDeclarationBuilder &b)
b.add_output<decl::Vector>("Vector");
};
-} // namespace blender::nodes
-
static void fn_node_input_vector_layout(uiLayout *layout, bContext *UNUSED(C), PointerRNA *ptr)
{
uiLayout *col = uiLayoutColumn(layout, true);
uiItemR(col, ptr, "vector", UI_ITEM_R_EXPAND, "", ICON_NONE);
}
-static void fn_node_vector_input_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_input_vector_build_multi_function(NodeMultiFunctionBuilder &builder)
{
bNode &bnode = builder.node();
NodeInputVector *node_storage = static_cast<NodeInputVector *>(bnode.storage);
- blender::float3 vector(node_storage->vector);
- builder.construct_and_set_matching_fn<blender::fn::CustomMF_Constant<blender::float3>>(vector);
+ float3 vector(node_storage->vector);
+ builder.construct_and_set_matching_fn<fn::CustomMF_Constant<float3>>(vector);
}
+
static void fn_node_input_vector_init(bNodeTree *UNUSED(ntree), bNode *node)
{
NodeInputVector *data = (NodeInputVector *)MEM_callocN(sizeof(NodeInputVector),
@@ -51,16 +49,18 @@ static void fn_node_input_vector_init(bNodeTree *UNUSED(ntree), bNode *node)
node->storage = data;
}
+} // namespace blender::nodes
+
void register_node_type_fn_input_vector()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_INPUT_VECTOR, "Vector", 0, 0);
ntype.declare = blender::nodes::fn_node_input_vector_declare;
- node_type_init(&ntype, fn_node_input_vector_init);
+ node_type_init(&ntype, blender::nodes::fn_node_input_vector_init);
node_type_storage(
&ntype, "NodeInputVector", node_free_standard_storage, node_copy_standard_storage);
- ntype.build_multi_function = fn_node_vector_input_build_multi_function;
- ntype.draw_buttons = fn_node_input_vector_layout;
+ ntype.build_multi_function = blender::nodes::fn_node_input_vector_build_multi_function;
+ ntype.draw_buttons = blender::nodes::fn_node_input_vector_layout;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_replace_string.cc b/source/blender/nodes/function/nodes/node_fn_replace_string.cc
index d21044d54a5..1ec4979176e 100644
--- a/source/blender/nodes/function/nodes/node_fn_replace_string.cc
+++ b/source/blender/nodes/function/nodes/node_fn_replace_string.cc
@@ -28,8 +28,6 @@ static void fn_node_replace_string_declare(NodeDeclarationBuilder &b)
b.add_output<decl::String>("String");
};
-} // namespace blender::nodes
-
static std::string replace_all(std::string str, const std::string &from, const std::string &to)
{
if (from.length() <= 0) {
@@ -45,23 +43,23 @@ static std::string replace_all(std::string str, const std::string &from, const s
return str;
}
-static void fn_node_replace_string_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_replace_string_build_multi_function(NodeMultiFunctionBuilder &builder)
{
- static blender::fn::CustomMF_SI_SI_SI_SO<std::string, std::string, std::string, std::string>
- substring_fn{"Replace",
- [](const std::string &str,
- const std::string &find,
- const std::string &replace) { return replace_all(str, find, replace); }};
+ static fn::CustomMF_SI_SI_SI_SO<std::string, std::string, std::string, std::string> substring_fn{
+ "Replace", [](const std::string &str, const std::string &find, const std::string &replace) {
+ return replace_all(str, find, replace);
+ }};
builder.set_matching_fn(&substring_fn);
}
+} // namespace blender::nodes
+
void register_node_type_fn_replace_string()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_REPLACE_STRING, "Replace String", NODE_CLASS_CONVERTER, 0);
ntype.declare = blender::nodes::fn_node_replace_string_declare;
- ntype.build_multi_function = fn_node_replace_string_build_multi_function;
+ ntype.build_multi_function = blender::nodes::fn_node_replace_string_build_multi_function;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_rotate_euler.cc b/source/blender/nodes/function/nodes/node_fn_rotate_euler.cc
index 7db566e96b5..a01cc6b58dd 100644
--- a/source/blender/nodes/function/nodes/node_fn_rotate_euler.cc
+++ b/source/blender/nodes/function/nodes/node_fn_rotate_euler.cc
@@ -25,6 +25,7 @@
#include "node_function_util.hh"
namespace blender::nodes {
+
static void fn_node_rotate_euler_declare(NodeDeclarationBuilder &b)
{
b.is_function_node();
diff --git a/source/blender/nodes/function/nodes/node_fn_string_length.cc b/source/blender/nodes/function/nodes/node_fn_string_length.cc
index a0f85dfd2bf..d882280b566 100644
--- a/source/blender/nodes/function/nodes/node_fn_string_length.cc
+++ b/source/blender/nodes/function/nodes/node_fn_string_length.cc
@@ -28,22 +28,21 @@ static void fn_node_string_length_declare(NodeDeclarationBuilder &b)
b.add_output<decl::Int>("Length");
};
-} // namespace blender::nodes
-
-static void fn_node_string_length_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_string_length_build_multi_function(NodeMultiFunctionBuilder &builder)
{
- static blender::fn::CustomMF_SI_SO<std::string, int> str_len_fn{
+ static fn::CustomMF_SI_SO<std::string, int> str_len_fn{
"String Length", [](const std::string &a) { return BLI_strlen_utf8(a.c_str()); }};
builder.set_matching_fn(&str_len_fn);
}
+} // namespace blender::nodes
+
void register_node_type_fn_string_length()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_STRING_LENGTH, "String Length", NODE_CLASS_CONVERTER, 0);
ntype.declare = blender::nodes::fn_node_string_length_declare;
- ntype.build_multi_function = fn_node_string_length_build_multi_function;
+ ntype.build_multi_function = blender::nodes::fn_node_string_length_build_multi_function;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_string_substring.cc b/source/blender/nodes/function/nodes/node_fn_string_substring.cc
index 55a01093ae9..0f91b1af813 100644
--- a/source/blender/nodes/function/nodes/node_fn_string_substring.cc
+++ b/source/blender/nodes/function/nodes/node_fn_string_substring.cc
@@ -28,12 +28,9 @@ static void fn_node_string_substring_declare(NodeDeclarationBuilder &b)
b.add_output<decl::String>("String");
};
-} // namespace blender::nodes
-
-static void fn_node_string_substring_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_string_substring_build_multi_function(NodeMultiFunctionBuilder &builder)
{
- static blender::fn::CustomMF_SI_SI_SI_SO<std::string, int, int, std::string> substring_fn{
+ static fn::CustomMF_SI_SI_SI_SO<std::string, int, int, std::string> substring_fn{
"Substring", [](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));
@@ -43,12 +40,14 @@ static void fn_node_string_substring_build_multi_function(
builder.set_matching_fn(&substring_fn);
}
+} // namespace blender::nodes
+
void register_node_type_fn_string_substring()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_STRING_SUBSTRING, "String Substring", NODE_CLASS_CONVERTER, 0);
ntype.declare = blender::nodes::fn_node_string_substring_declare;
- ntype.build_multi_function = fn_node_string_substring_build_multi_function;
+ ntype.build_multi_function = blender::nodes::fn_node_string_substring_build_multi_function;
nodeRegisterType(&ntype);
}
diff --git a/source/blender/nodes/function/nodes/node_fn_value_to_string.cc b/source/blender/nodes/function/nodes/node_fn_value_to_string.cc
index c1e6373cb6d..112726f98dc 100644
--- a/source/blender/nodes/function/nodes/node_fn_value_to_string.cc
+++ b/source/blender/nodes/function/nodes/node_fn_value_to_string.cc
@@ -26,12 +26,9 @@ static void fn_node_value_to_string_declare(NodeDeclarationBuilder &b)
b.add_output<decl::String>("String");
};
-} // namespace blender::nodes
-
-static void fn_node_value_to_string_build_multi_function(
- blender::nodes::NodeMultiFunctionBuilder &builder)
+static void fn_node_value_to_string_build_multi_function(NodeMultiFunctionBuilder &builder)
{
- static blender::fn::CustomMF_SI_SI_SO<float, int, std::string> to_str_fn{
+ static fn::CustomMF_SI_SI_SO<float, int, std::string> to_str_fn{
"Value To String", [](float a, int b) {
std::stringstream stream;
stream << std::fixed << std::setprecision(std::max(0, b)) << a;
@@ -40,12 +37,14 @@ static void fn_node_value_to_string_build_multi_function(
builder.set_matching_fn(&to_str_fn);
}
+} // namespace blender::nodes
+
void register_node_type_fn_value_to_string()
{
static bNodeType ntype;
fn_node_type_base(&ntype, FN_NODE_VALUE_TO_STRING, "Value to String", NODE_CLASS_CONVERTER, 0);
ntype.declare = blender::nodes::fn_node_value_to_string_declare;
- ntype.build_multi_function = fn_node_value_to_string_build_multi_function;
+ ntype.build_multi_function = blender::nodes::fn_node_value_to_string_build_multi_function;
nodeRegisterType(&ntype);
}