/* * Copyright (c) 2002,2003 Robert Collins * * 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, USA. * */ #ifndef LIBTRIE_TRIENODE_H #define LIBTRIE_TRIENODE_H /* This is an internal header for libTrie. * libTrie provides both C and C++ * bindings. * libTrie itself is written in C++. * For C bindings see Trei.h */ #ifdef HAVE_CONFIG_H #include "config.h" #endif /* C bindings */ #ifndef __cplusplus /* C++ bindings */ #else #include #include /* MinGW needs NULL definition */ #ifndef NULL #define NULL 0 #endif /* TODO: parameterize this to be more generic - * i.e. M-ary internal node sizes etc */ class TrieCharTransform; class TrieNode { public: TrieNode(); ~TrieNode(); TrieNode(TrieNode const &); TrieNode &operator= (TrieNode const &); /* Find a string. * If found, return the private data. * If not found, return NULL. */ _SQUID_INLINE_ void *find (char const *, size_t, TrieCharTransform *, bool const prefix) const; /* Add a string. * returns false if the string is already * present or can't be added. */ bool add (char const *, size_t, void *, TrieCharTransform *); private: /* 256-way Trie */ /* The char index into internal is an * 8-bit prefix to a string in the trie. * internal[0] is the terminal node for * a string and may not be used */ TrieNode * internal[256]; /* If a string ends here, non NULL */ void *_privateData; }; #endif /* __cplusplus */ #ifdef _USE_INLINE_ #include "TrieNode.cci" #endif #endif /* LIBTRIE_TRIENODE_H */