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:
authorJeroen Bakker <jeroen@blender.org>2021-03-16 17:02:37 +0300
committerJeroen Bakker <jeroen@blender.org>2021-03-16 17:03:30 +0300
commit93e2491ee724874a28030ae4d32f39bed6835923 (patch)
tree66fde1e2a9c5e3cadbf5195861893849f7ed799e
parent4ca8e09b24defcbe74f6f7f65c82e5a14a10e96b (diff)
Cleanup: replace std::map with blender::Map.
-rw-r--r--source/blender/compositor/intern/COM_NodeOperationBuilder.cc44
-rw-r--r--source/blender/compositor/intern/COM_NodeOperationBuilder.h14
2 files changed, 13 insertions, 45 deletions
diff --git a/source/blender/compositor/intern/COM_NodeOperationBuilder.cc b/source/blender/compositor/intern/COM_NodeOperationBuilder.cc
index 46954e04cb8..aac1d1d747c 100644
--- a/source/blender/compositor/intern/COM_NodeOperationBuilder.cc
+++ b/source/blender/compositor/intern/COM_NodeOperationBuilder.cc
@@ -67,19 +67,19 @@ void NodeOperationBuilder::convertToOperations(ExecutionSystem *system)
* Inverting yields a map of node inputs to all connected operation inputs,
* so multiple operations can use the same node input.
*/
- OpInputInverseMap inverse_input_map;
- for (InputSocketMap::const_iterator it = m_input_map.begin(); it != m_input_map.end(); ++it) {
- inverse_input_map[it->second].append(it->first);
+ blender::Map<NodeInput *, blender::Vector<NodeOperationInput *>> inverse_input_map;
+ for (blender::Map<NodeOperationInput *, NodeInput *>::MutableItem item : m_input_map.items()) {
+ inverse_input_map.lookup_or_add_default(item.value).append(item.key);
}
for (const NodeGraph::Link &link : m_graph.links()) {
NodeOutput *from = link.from;
NodeInput *to = link.to;
- NodeOperationOutput *op_from = find_operation_output(m_output_map, from);
- const blender::Vector<NodeOperationInput *> &op_to_list = find_operation_inputs(
- inverse_input_map, to);
- if (!op_from || op_to_list.is_empty()) {
+ NodeOperationOutput *op_from = m_output_map.lookup(from);
+
+ const blender::Vector<NodeOperationInput *> *op_to_list = inverse_input_map.lookup_ptr(to);
+ if (!op_from || op_to_list == nullptr || op_to_list->is_empty()) {
/* XXX allow this? error/debug message? */
// BLI_assert(false);
/* XXX note: this can happen with certain nodes (e.g. OutputFile)
@@ -89,7 +89,7 @@ void NodeOperationBuilder::convertToOperations(ExecutionSystem *system)
continue;
}
- for (NodeOperationInput *op_to : op_to_list) {
+ for (NodeOperationInput *op_to : *op_to_list) {
addLink(op_from, op_to);
}
}
@@ -136,7 +136,7 @@ void NodeOperationBuilder::mapInputSocket(NodeInput *node_socket,
* for resolving links the map will be inverted first in convertToOperations,
* to get a list of links for each node input socket.
*/
- m_input_map[operation_socket] = node_socket;
+ m_input_map.add_new(operation_socket, node_socket);
}
void NodeOperationBuilder::mapOutputSocket(NodeOutput *node_socket,
@@ -145,7 +145,7 @@ void NodeOperationBuilder::mapOutputSocket(NodeOutput *node_socket,
BLI_assert(m_current_node);
BLI_assert(node_socket->getNode() == m_current_node);
- m_output_map[node_socket] = operation_socket;
+ m_output_map.add_new(node_socket, operation_socket);
}
void NodeOperationBuilder::addLink(NodeOperationOutput *from, NodeOperationInput *to)
@@ -175,28 +175,6 @@ void NodeOperationBuilder::removeInputLink(NodeOperationInput *to)
}
}
-NodeInput *NodeOperationBuilder::find_node_input(const InputSocketMap &map,
- NodeOperationInput *op_input)
-{
- InputSocketMap::const_iterator it = map.find(op_input);
- return (it != map.end() ? it->second : NULL);
-}
-
-const blender::Vector<NodeOperationInput *> &NodeOperationBuilder::find_operation_inputs(
- const OpInputInverseMap &map, NodeInput *node_input)
-{
- static const blender::Vector<NodeOperationInput *> empty_list;
- OpInputInverseMap::const_iterator it = map.find(node_input);
- return (it != map.end() ? it->second : empty_list);
-}
-
-NodeOperationOutput *NodeOperationBuilder::find_operation_output(const OutputSocketMap &map,
- NodeOutput *node_output)
-{
- OutputSocketMap::const_iterator it = map.find(node_output);
- return (it != map.end() ? it->second : NULL);
-}
-
PreviewOperation *NodeOperationBuilder::make_preview_operation() const
{
BLI_assert(m_current_node);
@@ -312,7 +290,7 @@ void NodeOperationBuilder::add_operation_input_constants()
}
for (Inputs::const_iterator it = pending_inputs.begin(); it != pending_inputs.end(); ++it) {
NodeOperationInput *input = *it;
- add_input_constant_value(input, find_node_input(m_input_map, input));
+ add_input_constant_value(input, m_input_map.lookup(input));
}
}
diff --git a/source/blender/compositor/intern/COM_NodeOperationBuilder.h b/source/blender/compositor/intern/COM_NodeOperationBuilder.h
index 391c40116a7..5d497e8ec7d 100644
--- a/source/blender/compositor/intern/COM_NodeOperationBuilder.h
+++ b/source/blender/compositor/intern/COM_NodeOperationBuilder.h
@@ -62,10 +62,6 @@ class NodeOperationBuilder {
}
};
- typedef std::map<NodeOperationInput *, NodeInput *> InputSocketMap;
- typedef std::map<NodeOutput *, NodeOperationOutput *> OutputSocketMap;
- typedef std::map<NodeInput *, blender::Vector<NodeOperationInput *>> OpInputInverseMap;
-
private:
const CompositorContext *m_context;
NodeGraph m_graph;
@@ -75,9 +71,9 @@ class NodeOperationBuilder {
blender::Vector<ExecutionGroup *> m_groups;
/** Maps operation inputs to node inputs */
- InputSocketMap m_input_map;
+ blender::Map<NodeOperationInput *, NodeInput *> m_input_map;
/** Maps node outputs to operation outputs */
- OutputSocketMap m_output_map;
+ blender::Map<NodeOutput *, NodeOperationOutput *> m_output_map;
Node *m_current_node;
@@ -122,12 +118,6 @@ class NodeOperationBuilder {
}
protected:
- static NodeInput *find_node_input(const InputSocketMap &map, NodeOperationInput *op_input);
- static const blender::Vector<NodeOperationInput *> &find_operation_inputs(
- const OpInputInverseMap &map, NodeInput *node_input);
- static NodeOperationOutput *find_operation_output(const OutputSocketMap &map,
- NodeOutput *node_output);
-
/** Add datatype conversion where needed */
void add_datatype_conversions();