File: selector.C

package info (click to toggle)
ball 1.5.0%2Bgit20180813.37fc53c-3
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 239,848 kB
  • sloc: cpp: 326,149; ansic: 4,208; python: 2,303; yacc: 1,778; lex: 1,099; xml: 958; sh: 322; makefile: 93
file content (106 lines) | stat: -rw-r--r-- 2,031 bytes parent folder | download | duplicates (6)
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
// -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
// $Id: selector.C,v 1.28 2003/12/20 16:00:53 amoll Exp $
//

#include <BALL/KERNEL/selector.h>
#include <BALL/KERNEL/atom.h>

namespace BALL 
{
	
	Selector::Selector()
		:	UnaryProcessor<Composite>(),
			selected_atoms_(),
			expression_()
	{
	}
	
	Selector::Selector(const String& expression_string)
		:	UnaryProcessor<Composite>(),
			selected_atoms_(),
			expression_(expression_string)
	{
	}

	Selector::Selector(const Selector& selector)
		:	UnaryProcessor<Composite>(selector),
			selected_atoms_(selector.selected_atoms_),
			expression_(selector.expression_)
	{
	}

	Selector::~Selector()
	{
		clear();
	}

	void Selector::clear()
	{
		expression_.clear();
		selected_atoms_.clear();
	}

	Selector& Selector::operator = (const Selector& selector)
	{
		selected_atoms_ = selector.selected_atoms_;
		expression_ = selector.expression_;
		
		return *this;
	}

	bool Selector::operator == (const Selector& selector) const
	{
		return ((selected_atoms_ == selector.selected_atoms_)
				&& (expression_ == selector.expression_));
	}

	Size Selector::getNumberOfSelectedAtoms() const
	{
		return selected_atoms_.size();
	}

	void Selector::setExpression(const Expression& expression)
	{
		clear();
		expression_ = expression;
	}

	const Expression& Selector::getExpression() const
	{
		return expression_;
	}

	bool Selector::start() 
	{
		// reset the number of selected atoms
		selected_atoms_.clear();

		// and continue
		return true;
	}

  Processor::Result Selector::operator () (Composite& composite)
  {
		// if the composite is an atom, we apply the expression tree...
        if (RTTI::isKindOf<Atom>(&composite))
		{
			Atom& atom = dynamic_cast<Atom&>(composite);
			if (expression_.operator () (atom))
			{
				// select the atoms and increase the atom counter
				atom.select();
				selected_atoms_.push_back(&atom);
			}
		}

    return Processor::CONTINUE;
	}

	list<Atom*>& Selector::getSelectedAtoms()
	{
		return selected_atoms_;
	}

} // namespace BALL