summaryrefslogtreecommitdiff
path: root/csgops.cc
diff options
context:
space:
mode:
authorclifford <clifford@b57f626f-c46c-0410-a088-ec61d464b74c>2009-06-29 20:30:43 (GMT)
committerclifford <clifford@b57f626f-c46c-0410-a088-ec61d464b74c>2009-06-29 20:30:43 (GMT)
commited687599bf1ca36869dc64dab2b9969f1d96b4c1 (patch)
treec0aa344d2dd28e03eddd8b5cfdb2f47cdea807d3 /csgops.cc
parent934e2cef98bc16d2552641314dae1f17a8841079 (diff)
Clifford Wolf:
Restructured AST evaluation for control statements git-svn-id: http://svn.clifford.at/openscad/trunk@37 b57f626f-c46c-0410-a088-ec61d464b74c
Diffstat (limited to 'csgops.cc')
-rw-r--r--csgops.cc16
1 files changed, 8 insertions, 8 deletions
diff --git a/csgops.cc b/csgops.cc
index e1aa246..6d625f7 100644
--- a/csgops.cc
+++ b/csgops.cc
@@ -33,7 +33,7 @@ class CsgModule : public AbstractModule
public:
csg_type_e type;
CsgModule(csg_type_e type) : type(type) { }
- virtual AbstractNode *evaluate(const Context *ctx, const QVector<QString> &call_argnames, const QVector<Value> &call_argvalues, const QVector<AbstractNode*> child_nodes) const;
+ virtual AbstractNode *evaluate(const Context *ctx, const QVector<QString> &call_argnames, const QVector<Value> &call_argvalues, const QVector<ModuleInstanciation*> arg_children, const Context *arg_context) const;
};
class CsgNode : public AbstractNode
@@ -48,14 +48,14 @@ public:
virtual QString dump(QString indent) const;
};
-AbstractNode *CsgModule::evaluate(const Context*, const QVector<QString>&, const QVector<Value>&, const QVector<AbstractNode*> child_nodes) const
+AbstractNode *CsgModule::evaluate(const Context*, const QVector<QString>&, const QVector<Value>&, const QVector<ModuleInstanciation*> arg_children, const Context *arg_context) const
{
- if (child_nodes.size() == 1)
- return child_nodes[0];
-
CsgNode *node = new CsgNode(type);
- foreach (AbstractNode *v, child_nodes)
- node->children.append(v);
+ foreach (ModuleInstanciation *v, arg_children) {
+ AbstractNode *n = v->evaluate(arg_context);
+ if (n != NULL)
+ node->children.append(n);
+ }
return node;
}
@@ -117,7 +117,7 @@ QString CsgNode::dump(QString indent) const
return text + indent + "}\n";
}
-void register_builtin_csg()
+void register_builtin_csgops()
{
builtin_modules["union"] = new CsgModule(UNION);
builtin_modules["difference"] = new CsgModule(DIFFERENCE);
contact: Jan Huwald // Impressum