[Bf-blender-cvs] [49ec3cef69b] master: Geometry Nodes: Input data type utility function
Hans Goudey
noreply at git.blender.org
Mon Dec 14 18:44:27 CET 2020
Commit: 49ec3cef69bf183b488b680b7ab98105ce8acdd0
Author: Hans Goudey
Date: Mon Dec 14 11:43:46 2020 -0600
Branches: master
https://developer.blender.org/rB49ec3cef69bf183b488b680b7ab98105ce8acdd0
Geometry Nodes: Input data type utility function
This commit adds a simple utility function for getting the data type of an
attribute or its "constant" socket counterparts. No functional changes.
Differential Revision: https://developer.blender.org/D9819
===================================================================
M source/blender/nodes/NOD_geometry_exec.hh
M source/blender/nodes/intern/node_geometry_exec.cc
===================================================================
diff --git a/source/blender/nodes/NOD_geometry_exec.hh b/source/blender/nodes/NOD_geometry_exec.hh
index a7df4bc3e1b..5fe554e0478 100644
--- a/source/blender/nodes/NOD_geometry_exec.hh
+++ b/source/blender/nodes/NOD_geometry_exec.hh
@@ -168,10 +168,21 @@ class GeoNodeExecParams {
return this->get_input_attribute(name, component, domain, type, &default_value);
}
+ /**
+ * Get the type of an input property or the associated constant socket types with the
+ * same names. Fall back to the default value if no attribute exists with the name.
+ */
+ CustomDataType get_input_attribute_data_type(const StringRef name,
+ const GeometryComponent &component,
+ const CustomDataType default_type) const;
+
private:
/* Utilities for detecting common errors at when using this class. */
void check_extract_input(StringRef identifier, const CPPType *requested_type = nullptr) const;
void check_set_output(StringRef identifier, const CPPType &value_type) const;
+
+ /* Find the active socket socket with the input name (not the identifier). */
+ const bNodeSocket *find_available_socket(const StringRef name) const;
};
} // namespace blender::nodes
diff --git a/source/blender/nodes/intern/node_geometry_exec.cc b/source/blender/nodes/intern/node_geometry_exec.cc
index a6d9115f01f..6a22adb25a7 100644
--- a/source/blender/nodes/intern/node_geometry_exec.cc
+++ b/source/blender/nodes/intern/node_geometry_exec.cc
@@ -19,23 +19,31 @@
namespace blender::nodes {
-ReadAttributePtr GeoNodeExecParams::get_input_attribute(const StringRef name,
- const GeometryComponent &component,
- const AttributeDomain domain,
- const CustomDataType type,
- const void *default_value) const
+const bNodeSocket *GeoNodeExecParams::find_available_socket(const StringRef name) const
{
- const bNodeSocket *found_socket = nullptr;
LISTBASE_FOREACH (const bNodeSocket *, socket, &node_.inputs) {
if ((socket->flag & SOCK_UNAVAIL) != 0) {
continue;
}
if (name == socket->name) {
- found_socket = socket;
- break;
+ return socket;
}
}
- BLI_assert(found_socket != nullptr);
+
+ return nullptr;
+}
+
+ReadAttributePtr GeoNodeExecParams::get_input_attribute(const StringRef name,
+ const GeometryComponent &component,
+ const AttributeDomain domain,
+ const CustomDataType type,
+ const void *default_value) const
+{
+ const bNodeSocket *found_socket = this->find_available_socket(name);
+ BLI_assert(found_socket != nullptr); /* There should always be available socket for the name. */
+ if (found_socket == nullptr) {
+ return component.attribute_get_constant_for_read(domain, type, default_value);
+ }
if (found_socket->type == SOCK_STRING) {
const std::string name = this->get_input<std::string>(found_socket->identifier);
@@ -60,6 +68,39 @@ ReadAttributePtr GeoNodeExecParams::get_input_attribute(const StringRef name,
return component.attribute_get_constant_for_read(domain, type, default_value);
}
+CustomDataType GeoNodeExecParams::get_input_attribute_data_type(
+ const StringRef name,
+ const GeometryComponent &component,
+ const CustomDataType default_type) const
+{
+ const bNodeSocket *found_socket = this->find_available_socket(name);
+ BLI_assert(found_socket != nullptr); /* There should always be available socket for the name. */
+ if (found_socket == nullptr) {
+ return default_type;
+ }
+
+ if (found_socket->type == SOCK_STRING) {
+ const std::string name = this->get_input<std::string>(found_socket->identifier);
+ ReadAttributePtr attribute = component.attribute_try_get_for_read(name);
+ if (!attribute) {
+ return default_type;
+ }
+ return attribute->custom_data_type();
+ }
+ if (found_socket->type == SOCK_FLOAT) {
+ return CD_PROP_FLOAT;
+ }
+ if (found_socket->type == SOCK_VECTOR) {
+ return CD_PROP_FLOAT3;
+ }
+ if (found_socket->type == SOCK_RGBA) {
+ return CD_PROP_COLOR;
+ }
+
+ BLI_assert(false);
+ return default_type;
+}
+
void GeoNodeExecParams::check_extract_input(StringRef identifier,
const CPPType *requested_type) const
{
More information about the Bf-blender-cvs
mailing list