summaryrefslogtreecommitdiff
path: root/include/hashcomp.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/hashcomp.h')
-rw-r--r--include/hashcomp.h46
1 files changed, 40 insertions, 6 deletions
diff --git a/include/hashcomp.h b/include/hashcomp.h
index a4f341f24..c9debd698 100644
--- a/include/hashcomp.h
+++ b/include/hashcomp.h
@@ -53,27 +53,61 @@ namespace nspace
};
}
+/** This class returns true if two strings match.
+ * Case sensitivity is ignored, and the RFC 'character set'
+ * is adhered to
+ */
struct StrHashComp
{
-
+ /** The operator () does the actual comparison in hash_map
+ */
bool operator()(const string& s1, const string& s2) const;
};
+/** This class returns true if two in_addr structs match.
+ * Checking is done by copying both into a size_t then doing a
+ * numeric comparison of the two.
+ */
struct InAddr_HashComp
{
+ /** The operator () does the actual comparison in hash_map
+ */
bool operator()(const in_addr &s1, const in_addr &s2) const;
};
+/** The irc namespace contains a number of helper classes.
+ */
namespace irc
{
+ /** The irc_char_traits class is used for RFC-style comparison of strings.
+ * This class is used to implement irc::string, a case-insensitive, RFC-
+ * comparing string class.
+ */
struct irc_char_traits : std::char_traits<char> {
- static bool eq(char c1st, char c2nd);
- static bool ne(char c1st, char c2nd);
- static bool lt(char c1st, char c2nd);
- static int compare(const char* str1, const char* str2, size_t n);
- static const char* find(const char* s1, int n, char c);
+
+ /** Check if two chars match
+ */
+ static bool eq(char c1st, char c2nd);
+
+ /** Check if two chars do NOT match
+ */
+ static bool ne(char c1st, char c2nd);
+
+ /** Check if one char is less than another
+ */
+ static bool lt(char c1st, char c2nd);
+
+ /** Compare two strings of size n
+ */
+ static int compare(const char* str1, const char* str2, size_t n);
+
+ /** Find a char within a string up to position n
+ */
+ static const char* find(const char* s1, int n, char c);
};
+ /** This typedef declares irc::string based upon irc_char_traits
+ */
typedef basic_string<char, irc_char_traits, allocator<char> > string;
}