diff options
author | Ingo Schwarze <schwarze@openbsd.org> | 2017-04-24 23:06:17 +0000 |
---|---|---|
committer | Ingo Schwarze <schwarze@openbsd.org> | 2017-04-24 23:06:17 +0000 |
commit | 34d4ee2337055c6ee3b2c34dbcb0c4a24a7413d1 (patch) | |
tree | ce7efbe6ee6a0cdedc8ecc4d031b69b5516a73c1 /man_hash.c | |
parent | b6c38ba54b141f508c5d22eb714a3e7c79a6c33c (diff) | |
download | mandoc-34d4ee2337055c6ee3b2c34dbcb0c4a24a7413d1.tar.gz |
Continue parser unification:
* Make enum rofft an internal interface as enum roff_tok in "roff.h".
* Represent mdoc and man macros in enum roff_tok.
* Make TOKEN_NONE a proper enum value and use it throughout.
* Put the prologue macros first in the macro tables.
* Unify mdoc_macroname[] and man_macroname[] into roff_name[].
Diffstat (limited to 'man_hash.c')
-rw-r--r-- | man_hash.c | 14 |
1 files changed, 6 insertions, 8 deletions
@@ -1,7 +1,7 @@ /* $Id$ */ /* * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv> - * Copyright (c) 2015 Ingo Schwarze <schwarze@openbsd.org> + * Copyright (c) 2015, 2017 Ingo Schwarze <schwarze@openbsd.org> * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above @@ -60,8 +60,8 @@ man_hash_init(void) memset(table, UCHAR_MAX, sizeof(table)); - for (i = 0; i < (int)MAN_MAX; i++) { - x = man_macronames[i][0]; + for (i = 0; i < (int)(MAN_MAX - MAN_TH); i++) { + x = *roff_name[MAN_TH + i]; assert(isalpha((unsigned char)x)); @@ -77,11 +77,10 @@ man_hash_init(void) } } -int +enum roff_tok man_hash_find(const char *tmp) { int x, y, i; - int tok; if ('\0' == (x = tmp[0])) return TOKEN_NONE; @@ -94,9 +93,8 @@ man_hash_find(const char *tmp) if (UCHAR_MAX == (y = table[x + i])) return TOKEN_NONE; - tok = y; - if (0 == strcmp(tmp, man_macronames[tok])) - return tok; + if (strcmp(tmp, roff_name[MAN_TH + y]) == 0) + return MAN_TH + y; } return TOKEN_NONE; |