-/* $Id: man_hash.c,v 1.18 2010/03/27 10:14:32 kristaps Exp $ */
+/* $Id: man_hash.c,v 1.23 2010/07/31 23:52:58 schwarze Exp $ */
/*
- * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
+ * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
#include <stdlib.h>
#include <string.h>
+#include "mandoc.h"
#include "libman.h"
#define HASH_DEPTH 6
#define HASH_ROW(x) do { \
- if ('.' == (x)) \
- (x) = 26; \
- else if (isupper((u_char)(x))) \
+ if (isupper((u_char)(x))) \
(x) -= 65; \
else \
(x) -= 97; \
* macro (the integer value of the enum stored as a char to save a bit
* of space).
*/
-static u_char table[27 * HASH_DEPTH];
+static u_char table[26 * HASH_DEPTH];
/*
* XXX - this hash has global scope, so if intended for use as a library
assert(/* LINTED */
MAN_MAX < UCHAR_MAX);
- for (i = 0; i < MAN_MAX; i++) {
+ for (i = 0; i < (int)MAN_MAX; i++) {
x = man_macronames[i][0];
- assert(isalpha((u_char)x) || '.' == x);
+ assert(isalpha((u_char)x));
HASH_ROW(x);
if ('\0' == (x = tmp[0]))
return(MAN_MAX);
- if ( ! (isalpha((u_char)x) || '.' == x))
+ if ( ! (isalpha((u_char)x)))
return(MAN_MAX);
HASH_ROW(x);