summaryrefslogtreecommitdiff
path: root/src/CSGTermEvaluator.h
blob: beb120137708ea5a54a5408e285a02743e29736f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#ifndef CSGTERMEVALUATOR_H_
#define CSGTERMEVALUATOR_H_

#include <string>
#include <map>
#include <list>
#include <vector>
#include "Tree.h"
#include "visitor.h"
#include "node.h"

using std::string;
using std::map;
using std::list;
using std::vector;

class CSGTermEvaluator : public Visitor
{
public:
	CSGTermEvaluator(const Tree &tree, class PolySetEvaluator *psevaluator = NULL)
		: tree(tree), psevaluator(psevaluator) {
	}
  virtual ~CSGTermEvaluator() {}

  virtual Response visit(State &state, const AbstractNode &node);
 	virtual Response visit(State &state, const AbstractIntersectionNode &node);
 	virtual Response visit(State &state, const AbstractPolyNode &node);
 	virtual Response visit(State &state, const CsgNode &node);
 	virtual Response visit(State &state, const TransformNode &node);
 	virtual Response visit(State &state, const RenderNode &node);

	class CSGTerm *evaluateCSGTerm(const AbstractNode &node,
																 vector<CSGTerm*> &highlights, 
																 vector<CSGTerm*> &background);

private:
	enum CsgOp {UNION, INTERSECTION, DIFFERENCE, MINKOWSKI};
  void addToParent(const State &state, const AbstractNode &node);
	void applyToChildren(const AbstractNode &node, CSGTermEvaluator::CsgOp op);

  const AbstractNode *root;
  typedef list<const AbstractNode *> ChildList;
  map<int, ChildList> visitedchildren;

public:
  map<int, class CSGTerm*> stored_term; // The term evaluated from each node index

	vector<CSGTerm*> highlights;
	vector<CSGTerm*> background;
	const Tree &tree;
	class PolySetEvaluator *psevaluator;
};

#endif
contact: Jan Huwald // Impressum