summaryrefslogtreecommitdiff
path: root/include/hashcomp.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/hashcomp.h')
-rw-r--r--include/hashcomp.h43
1 files changed, 4 insertions, 39 deletions
diff --git a/include/hashcomp.h b/include/hashcomp.h
index 0611cf239..42954fc37 100644
--- a/include/hashcomp.h
+++ b/include/hashcomp.h
@@ -1,9 +1,6 @@
#ifndef _HASHCOMP_H_
#define _HASHCOMP_H_
-#include "inspircd.h"
-#include "inspircd_io.h"
-#include "inspircd_util.h"
#include "inspircd_config.h"
#ifdef GCC3
@@ -28,12 +25,7 @@ namespace nspace
template<> struct nspace::hash<in_addr>
#endif
{
- size_t operator()(const struct in_addr &a) const
- {
- size_t q;
- memcpy(&q,&a,sizeof(size_t));
- return q;
- }
+ size_t operator()(const struct in_addr &a) const;
};
#ifdef GCC34
template<> struct hash<string>
@@ -41,14 +33,7 @@ namespace nspace
template<> struct nspace::hash<string>
#endif
{
- size_t operator()(const string &s) const
- {
- char a[MAXBUF];
- static struct hash<const char *> strhash;
- strlcpy(a,s.c_str(),MAXBUF);
- strlower(a);
- return strhash(a);
- }
+ size_t operator()(const string &s) const;
};
}
@@ -56,32 +41,12 @@ namespace nspace
struct StrHashComp
{
- bool operator()(const string& s1, const string& s2) const
- {
- char a[MAXBUF],b[MAXBUF];
- strlcpy(a,s1.c_str(),MAXBUF);
- strlcpy(b,s2.c_str(),MAXBUF);
- strlower(a);
- strlower(b);
- return (strcasecmp(a,b) == 0);
- }
-
+ bool operator()(const string& s1, const string& s2) const;
};
struct InAddr_HashComp
{
-
- bool operator()(const in_addr &s1, const in_addr &s2) const
- {
- size_t q;
- size_t p;
-
- memcpy(&q,&s1,sizeof(size_t));
- memcpy(&p,&s2,sizeof(size_t));
-
- return (q == p);
- }
-
+ bool operator()(const in_addr &s1, const in_addr &s2) const;
};