OpenGTA/util/pf_tree.cpp

97 lines
3.3 KiB
C++
Raw Normal View History

2015-12-03 00:38:22 +00:00
/************************************************************************
* Copyright (c) 2005-2007 tok@openlinux.org.uk *
* *
* This software is provided as-is, without any express or implied *
* warranty. In no event will the authors be held liable for any *
* damages arising from the use of this software. *
* *
* Permission is granted to anyone to use this software for any purpose, *
* including commercial applications, and to alter it and redistribute *
* it freely, subject to the following restrictions: *
* *
* 1. The origin of this software must not be misrepresented; you must *
* not claim that you wrote the original software. If you use this *
* software in a product, an acknowledgment in the product documentation *
* would be appreciated but is not required. *
* *
* 2. Altered source versions must be plainly marked as such, and must *
* not be misrepresented as being the original software. *
* *
* 3. This notice may not be removed or altered from any source *
* distribution. *
************************************************************************/
#include "pf_tree.hpp"
namespace PrefixFreeTree {
Node::~Node() {
for (MapType::iterator i = map.begin(); i != map.end(); i++) {
delete i->second;
}
map.clear();
}
Node & Node::insert(const char * str, size_t offset) {
size_t str_len = strlen(str);
if (offset < str_len) {
value_t node_val = str[offset];
MapType::iterator i = map.find(node_val);
offset++;
if (i == map.end()) {
map[node_val] = new Node();
return map[node_val]->insert(str, offset);
}
else {
if (i->second->isLeaf()) {
std::ostringstream os;
os << "Cannot enter '" << str << "' at offset " << offset <<
" as a leaf node already exists";
throw E_INVALIDFORMAT(os.str());
}
if ((offset == str_len) && (!i->second->isLeaf())) {
std::ostringstream os;
os << "Cannot enter '" << str
<< "' as a non-leaf node already exists" << std::endl;
throw E_INVALIDFORMAT(os.str());
}
return i->second->insert(str, offset);
}
}
return *this;
}
}
#ifdef SIMPLE_TREE_DEMO
#include <iostream>
template <typename T>
struct Echo {
void call(T t) {
std::cout << "Echo: " << t << std::endl;
}
};
using namespace std;
int main(int argc, char* argv[]) {
PrefixFreeTree::Walker<uint32_t, Echo> m;
uint32_t i = 1;
while (!cin.eof()) {
std::string inputs;
cin >> inputs;
if (inputs.size()) {
std::cout << "-" << inputs << "-" << std::endl;
PrefixFreeTree::Node & n = m.insert(inputs.c_str());
n.leaf_value = i;
i++;
}
}
const char* input = argv[1];
int len = strlen(input);
for (int i = 0; i < len; i++) {
m.push(input[i]);
}
}
#endif