aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Enum.cc
blob: 8abce8bd07ce27b2b01fdc6d2e4f4ea351a3371e (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
55
56
57
/*--*-c++-*-------------------------------------------------------------
 *  $Id$
 *---------------------------------------------------------------------*/

#include "Enum.h"

void EnumBase::i2sMapper::add(long i, const char* s) {
	stringMap.insert(pair<long, const char* const>(i, s));
}

string EnumBase::i2sMapper::lookup (long i) const {
	i2s_map_t::const_iterator searchPtr = stringMap.find(i);

	if (searchPtr == stringMap.end())
		return "[OUT-OF-RANGE]";
	/*
	 * now combine the probably the multiple strings belonging to this
	 * integer
	 */
	string result;
	for (i = stringMap.count(i); i > 0 ; --i, ++searchPtr) {
		// this should be the case:
		assert(searchPtr != stringMap.end());
		if (result.length() != 0) 
			result += string(",");
		result += string(searchPtr->second);
	}
	return result;
}


long EnumBase::i2sMapper::lookup (const char *s) const {
	/*
	 * lookup a specific string.
	 * Since speed does not matter, we just do an exhaustive
	 * search.
	 * Otherwise we would have to maintain another map
	 * mapping strings to ints .. but its not worth the memory
	 */
	i2s_map_t::const_iterator run = stringMap.begin();
	while (run != stringMap.end() && strcmp(s, run->second)) {
		++run;
	}
	if (run == stringMap.end())
		return  -1;    // FIXME .. maybe throw an exception ?
	return run->first;
}

bool EnumBase::i2sMapper::inRange (long i) const {
	return (stringMap.find(i) != stringMap.end());
}

/* 
 * Local variables:
 * c-basic-offset: 8
 * End:
 */