File: RegExCont.cc

package info (click to toggle)
aspectc%2B%2B 1.0pre4~svn.20090918-1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 117,308 kB
  • ctags: 410,601
  • sloc: cpp: 1,883,007; ansic: 17,279; sh: 2,190; makefile: 1,088
file content (48 lines) | stat: -rw-r--r-- 1,728 bytes parent folder | download | duplicates (3)
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
// This file is part of the AspectC++ compiler 'ac++'.
// Copyright (C) 1999-2004  The 'ac++' developers (see aspectc.org)
//                                                                
// This program is free software;  you can redistribute it and/or 
// modify it under the terms of the GNU General Public License as 
// published by the Free Software Foundation; either version 2 of 
// the License, or (at your option) any later version.            
//                                                                
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of 
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the  
// GNU General Public License for more details.                   
//                                                                
// You should have received a copy of the GNU General Public      
// License along with this program; if not, write to the Free     
// Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, 
// MA  02111-1307  USA                                           


#include "RegExCont.h"
using namespace regex;


void RegExCont::add(string expr,RegComp* regcomp){
	_re_map.insert(regex_pair(expr,regcomp));
}

RegComp* RegExCont::lookup(string expr){
	map<string,RegComp*>::iterator iter=_re_map.find(expr);
	if(iter != _re_map.end()){
		return iter->second;
	}else{
		return NULL;
	}
}

RegExCont::~RegExCont(){
	//cout << "RegExCont stored: "<< _re_map.size() << " regular expressions" <<endl;
	for(map<string,RegComp*>::iterator iter=_re_map.begin();iter != _re_map.end();iter++){
			if(iter->second){
				delete(iter->second);
			}
	}
	_re_map.clear();
}