version 1.6, 2009/09/21 21:11:37 |
version 1.7, 2010/03/02 00:38:59 |
|
|
|
|
#include "libmdoc.h" |
#include "libmdoc.h" |
|
|
static u_char table[27 * 12]; |
static u_char table[27 * 13]; |
|
|
/* |
/* |
* XXX - this hash has global scope, so if intended for use as a library |
* XXX - this hash has global scope, so if intended for use as a library |
|
|
p = mdoc_macronames[i]; |
p = mdoc_macronames[i]; |
|
|
if (isalpha((u_char)p[1])) |
if (isalpha((u_char)p[1])) |
major = 12 * (tolower((u_char)p[1]) - 97); |
major = 13 * (tolower((u_char)p[1]) - 97); |
else |
else |
major = 12 * 26; |
major = 13 * 26; |
|
|
for (j = 0; j < 12; j++) |
for (j = 0; j < 13; j++) |
if (UCHAR_MAX == table[major + j]) { |
if (UCHAR_MAX == table[major + j]) { |
table[major + j] = (u_char)i; |
table[major + j] = (u_char)i; |
break; |
break; |
} |
} |
|
|
assert(j < 12); |
assert(j < 13); |
} |
} |
} |
} |
|
|
|
|
return(MDOC_MAX); |
return(MDOC_MAX); |
|
|
if (isalpha((u_char)p[1])) |
if (isalpha((u_char)p[1])) |
major = 12 * (tolower((u_char)p[1]) - 97); |
major = 13 * (tolower((u_char)p[1]) - 97); |
else if ('1' == p[1]) |
else if ('1' == p[1]) |
major = 12 * 26; |
major = 13 * 26; |
else |
else |
return(MDOC_MAX); |
return(MDOC_MAX); |
|
|
if (p[2] && p[3]) |
if (p[2] && p[3]) |
return(MDOC_MAX); |
return(MDOC_MAX); |
|
|
for (j = 0; j < 12; j++) { |
for (j = 0; j < 13; j++) { |
if (UCHAR_MAX == (i = table[major + j])) |
if (UCHAR_MAX == (i = table[major + j])) |
break; |
break; |
if (0 == strcmp(p, mdoc_macronames[i])) |
if (0 == strcmp(p, mdoc_macronames[i])) |