diff options
author | Ingo Schwarze <schwarze@openbsd.org> | 2015-07-25 14:02:06 +0000 |
---|---|---|
committer | Ingo Schwarze <schwarze@openbsd.org> | 2015-07-25 14:02:06 +0000 |
commit | 8ecd58a3e222c5d6df72c264a6aad988c28321a4 (patch) | |
tree | b9e03a585ffa25006118286ff62be9f72972a303 | |
parent | bb2b6d70625fb83d3ac31a1015588226c42b8457 (diff) | |
download | mandoc-8ecd58a3e222c5d6df72c264a6aad988c28321a4.tar.gz |
basic support for tag priorities; written at YYC
-rw-r--r-- | mdoc_term.c | 4 | ||||
-rw-r--r-- | tag.c | 8 | ||||
-rw-r--r-- | tag.h | 4 |
3 files changed, 9 insertions, 7 deletions
diff --git a/mdoc_term.c b/mdoc_term.c index 95790806..10ebbc51 100644 --- a/mdoc_term.c +++ b/mdoc_term.c @@ -2268,7 +2268,7 @@ termp_tag_pre(DECL_ARGS) (n->parent->tok == MDOC_Xo && n->parent->parent->prev == NULL && n->parent->parent->parent->tok == MDOC_It)) && - ! tag_get(n->child->string, 0)) - tag_put(n->child->string, 0, p->line); + ! tag_get(n->child->string, 0, 1)) + tag_put(n->child->string, 0, 1, p->line); return(1); } @@ -34,6 +34,7 @@ struct tag_entry { size_t line; + int prio; char s[]; }; @@ -81,7 +82,7 @@ tag_init(void) * or 0 if the term is unknown. */ size_t -tag_get(const char *s, size_t len) +tag_get(const char *s, size_t len, int prio) { struct tag_entry *entry; const char *end; @@ -94,14 +95,14 @@ tag_get(const char *s, size_t len) end = s + len; slot = ohash_qlookupi(&tag_data, s, &end); entry = ohash_find(&tag_data, slot); - return(entry == NULL ? 0 : entry->line); + return((entry == NULL || prio < entry->prio) ? 0 : entry->line); } /* * Set the line number where a term is defined. */ void -tag_put(const char *s, size_t len, size_t line) +tag_put(const char *s, size_t len, int prio, size_t line) { struct tag_entry *entry; const char *end; @@ -121,6 +122,7 @@ tag_put(const char *s, size_t len, size_t line) ohash_insert(&tag_data, slot, entry); } entry->line = line; + entry->prio = prio; } /* @@ -18,8 +18,8 @@ __BEGIN_DECLS char *tag_init(void); -size_t tag_get(const char *, size_t); -void tag_put(const char *, size_t, size_t); +size_t tag_get(const char *, size_t, int); +void tag_put(const char *, size_t, int, size_t); void tag_write(void); void tag_unlink(void); |