version 1.30, 2019/04/14 20:13:25 |
version 1.41, 2019/05/02 11:58:18 |
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
*/ |
*/ |
|
#include <sys/types.h> |
|
|
#include <assert.h> |
#include <assert.h> |
#include <ctype.h> |
#include <ctype.h> |
#include <err.h> |
#include <err.h> |
|
|
#include <string.h> |
#include <string.h> |
#include <unistd.h> |
#include <unistd.h> |
|
|
|
#include "xmalloc.h" |
|
|
/* |
/* |
* Count parent-child element relations in a corpus of DocBook documents. |
* Count parent-child element relations in a corpus of DocBook documents. |
* |
* |
Line 125 table_add(const char *parent, const char *child) |
|
Line 129 table_add(const char *parent, const char *child) |
|
|
|
if (tablei == tablesz) { |
if (tablei == tablesz) { |
tablesz += 64; |
tablesz += 64; |
table = reallocarray(table, tablesz, sizeof(*table)); |
table = xreallocarray(table, tablesz, sizeof(*table)); |
if (table == NULL) |
|
err(1, NULL); |
|
} |
} |
|
|
/* Add a new entry to the table. */ |
/* Add a new entry to the table. */ |
|
|
if ((table[tablei].parent = strdup(parent)) == NULL) |
table[tablei].parent = xstrdup(parent); |
err(1, NULL); |
table[tablei].child = child == NULL ? NULL : xstrdup(child); |
if (child == NULL) |
|
table[tablei].child = NULL; |
|
else if ((table[tablei].child = strdup(child)) == NULL) |
|
err(1, NULL); |
|
table[tablei++].count = init_done ? 1 : -1; |
table[tablei++].count = init_done ? 1 : -1; |
} |
} |
|
|
Line 152 stack_push(const char *name) |
|
Line 150 stack_push(const char *name) |
|
|
|
if (stacki == stacksz) { |
if (stacki == stacksz) { |
stacksz += 8; |
stacksz += 8; |
stack = reallocarray(stack, stacksz, sizeof(*stack)); |
stack = xreallocarray(stack, stacksz, sizeof(*stack)); |
if (stack == NULL) |
|
err(1, NULL); |
|
} |
} |
if ((stack[stacki++] = strdup(name)) == NULL) |
stack[stacki++] = xstrdup(name); |
err(1, NULL); |
|
} |
} |
|
|
/* |
/* |
Line 360 main(int argc, char *argv[]) |
|
Line 355 main(int argc, char *argv[]) |
|
|
|
/* Exclude relations that are already fully implemented. */ |
/* Exclude relations that are already fully implemented. */ |
if (show_all == 0) { |
if (show_all == 0) { |
|
table_add("ROOT", "appendix"); |
table_add("ROOT", "article"); |
table_add("ROOT", "article"); |
table_add("ROOT", "book"); |
table_add("ROOT", "book"); |
table_add("ROOT", "chapter"); |
table_add("ROOT", "chapter"); |
|
table_add("ROOT", "glossary"); |
|
table_add("ROOT", "part"); |
|
table_add("ROOT", "preface"); |
table_add("ROOT", "refentry"); |
table_add("ROOT", "refentry"); |
|
table_add("ROOT", "reference"); |
|
table_add("ROOT", "sect1"); |
|
table_add("ROOT", "sect2"); |
|
table_add("abstract", NULL); |
table_add("acronym", "TEXT"); |
table_add("acronym", "TEXT"); |
|
table_add("affiliation", "jobtitle"); |
table_add("affiliation", "orgdiv"); |
table_add("affiliation", "orgdiv"); |
table_add("affiliation", "orgname"); |
table_add("affiliation", "orgname"); |
table_add("appendix", NULL); |
table_add("appendix", NULL); |
table_add("application", "TEXT"); |
table_add("application", "TEXT"); |
table_add("arg", "option"); |
table_add("arg", "option"); |
table_add("article", NULL); |
table_add("article", NULL); |
|
table_add("articleinfo", "abstract"); |
table_add("articleinfo", "author"); |
table_add("articleinfo", "author"); |
table_add("articleinfo", "authorgroup"); |
table_add("articleinfo", "authorgroup"); |
table_add("articleinfo", "copyright"); |
table_add("articleinfo", "copyright"); |
Line 392 main(int argc, char *argv[]) |
|
Line 397 main(int argc, char *argv[]) |
|
table_add("authorgroup", "othercredit"); |
table_add("authorgroup", "othercredit"); |
table_add("blockquote", NULL); |
table_add("blockquote", NULL); |
table_add("book", NULL); |
table_add("book", NULL); |
|
table_add("bookinfo", "abstract"); |
table_add("bookinfo", "authorgroup"); |
table_add("bookinfo", "authorgroup"); |
table_add("bookinfo", "copyright"); |
table_add("bookinfo", "copyright"); |
table_add("bookinfo", "legalnotice"); |
table_add("bookinfo", "legalnotice"); |
Line 399 main(int argc, char *argv[]) |
|
Line 405 main(int argc, char *argv[]) |
|
table_add("bookinfo", "releaseinfo"); |
table_add("bookinfo", "releaseinfo"); |
table_add("bookinfo", "subtitle"); |
table_add("bookinfo", "subtitle"); |
table_add("bookinfo", "title"); |
table_add("bookinfo", "title"); |
|
table_add("caption", "TEXT"); |
table_add("chapter", NULL); |
table_add("chapter", NULL); |
table_add("citerefentry", "manvolnum"); |
table_add("citerefentry", "manvolnum"); |
table_add("citerefentry", "refentrytitle"); |
table_add("citerefentry", "refentrytitle"); |
Line 406 main(int argc, char *argv[]) |
|
Line 413 main(int argc, char *argv[]) |
|
table_add("cmdsynopsis", "arg"); |
table_add("cmdsynopsis", "arg"); |
table_add("cmdsynopsis", "command"); |
table_add("cmdsynopsis", "command"); |
table_add("cmdsynopsis", "group"); |
table_add("cmdsynopsis", "group"); |
|
table_add("cmdsynopsis", "sbr"); |
table_add("code", "TEXT"); |
table_add("code", "TEXT"); |
table_add("command", "TEXT"); |
table_add("command", "TEXT"); |
table_add("computeroutput", "TEXT"); |
table_add("computeroutput", "TEXT"); |
Line 423 main(int argc, char *argv[]) |
|
Line 431 main(int argc, char *argv[]) |
|
table_add("emphasis", "TEXT"); |
table_add("emphasis", "TEXT"); |
table_add("entry", NULL); |
table_add("entry", NULL); |
table_add("errorname", "TEXT"); |
table_add("errorname", "TEXT"); |
|
table_add("figure", "mediaobject"); |
|
table_add("figure", "title"); |
table_add("filename", "TEXT"); |
table_add("filename", "TEXT"); |
table_add("firstname", "TEXT"); |
table_add("firstname", "TEXT"); |
table_add("firstterm", "TEXT"); |
table_add("firstterm", "TEXT"); |
|
table_add("footnote", "para"); |
table_add("funcdef", "function"); |
table_add("funcdef", "function"); |
table_add("funcdef", "TEXT"); |
table_add("funcdef", "TEXT"); |
|
table_add("funcparams", "TEXT"); |
table_add("funcprototype", "funcdef"); |
table_add("funcprototype", "funcdef"); |
table_add("funcprototype", "paramdef"); |
table_add("funcprototype", "paramdef"); |
|
table_add("funcprototype", "void"); |
table_add("funcsynopsis", "funcprototype"); |
table_add("funcsynopsis", "funcprototype"); |
table_add("funcsynopsis", "funcsynopsisinfo"); |
table_add("funcsynopsis", "funcsynopsisinfo"); |
table_add("funcsynopsisinfo", "TEXT"); |
table_add("funcsynopsisinfo", "TEXT"); |
Line 443 main(int argc, char *argv[]) |
|
Line 456 main(int argc, char *argv[]) |
|
table_add("glossentry", "glossterm"); |
table_add("glossentry", "glossterm"); |
table_add("glossentry", "indexterm"); |
table_add("glossentry", "indexterm"); |
table_add("glosslist", "glossentry"); |
table_add("glosslist", "glossentry"); |
|
table_add("glossterm", "emphasis"); |
table_add("glossterm", "TEXT"); |
table_add("glossterm", "TEXT"); |
table_add("group", "arg"); |
table_add("group", "arg"); |
table_add("holder", "TEXT"); |
table_add("holder", "TEXT"); |
|
table_add("imageobject", "imagedata"); |
table_add("indexterm", "primary"); |
table_add("indexterm", "primary"); |
table_add("indexterm", "secondary"); |
table_add("indexterm", "secondary"); |
table_add("informaltable", "tgroup"); |
table_add("informaltable", "tgroup"); |
table_add("itemizedlist", "listitem"); |
table_add("itemizedlist", "listitem"); |
|
table_add("jobtitle", "TEXT"); |
table_add("keycap", "TEXT"); |
table_add("keycap", "TEXT"); |
table_add("keycode", "TEXT"); |
table_add("keycode", "TEXT"); |
|
table_add("keycombo", "keycap"); |
table_add("keysym", "TEXT"); |
table_add("keysym", "TEXT"); |
table_add("legalnotice", NULL); |
table_add("legalnotice", NULL); |
table_add("link", NULL); |
table_add("link", NULL); |
Line 460 main(int argc, char *argv[]) |
|
Line 477 main(int argc, char *argv[]) |
|
table_add("literallayout", NULL); |
table_add("literallayout", NULL); |
table_add("manvolnum", "TEXT"); |
table_add("manvolnum", "TEXT"); |
table_add("markup", "TEXT"); |
table_add("markup", "TEXT"); |
|
table_add("mediaobject", "caption"); |
|
table_add("mediaobject", "imageobject"); |
table_add("member", "constant"); |
table_add("member", "constant"); |
table_add("member", "emphasis"); |
table_add("member", "emphasis"); |
table_add("member", "function"); |
table_add("member", "function"); |
Line 467 main(int argc, char *argv[]) |
|
Line 486 main(int argc, char *argv[]) |
|
table_add("member", "symbol"); |
table_add("member", "symbol"); |
table_add("member", "TEXT"); |
table_add("member", "TEXT"); |
table_add("note", NULL); |
table_add("note", NULL); |
|
table_add("olink", "citetitle"); |
|
table_add("olink", "function"); |
|
table_add("olink", "TEXT"); |
table_add("option", "parameter"); |
table_add("option", "parameter"); |
table_add("option", "replaceable"); |
table_add("option", "replaceable"); |
table_add("option", "TEXT"); |
table_add("option", "TEXT"); |
Line 481 main(int argc, char *argv[]) |
|
Line 503 main(int argc, char *argv[]) |
|
table_add("othercredit", "surname"); |
table_add("othercredit", "surname"); |
table_add("othername", "TEXT"); |
table_add("othername", "TEXT"); |
table_add("para", NULL); |
table_add("para", NULL); |
|
table_add("paramdef", "funcparams"); |
table_add("paramdef", "parameter"); |
table_add("paramdef", "parameter"); |
table_add("paramdef", "TEXT"); |
table_add("paramdef", "TEXT"); |
table_add("parameter", "TEXT"); |
table_add("parameter", "TEXT"); |
Line 490 main(int argc, char *argv[]) |
|
Line 513 main(int argc, char *argv[]) |
|
table_add("phrase", "TEXT"); |
table_add("phrase", "TEXT"); |
table_add("preface", NULL); |
table_add("preface", NULL); |
table_add("primary", NULL); |
table_add("primary", NULL); |
|
table_add("productname", "TEXT"); |
table_add("programlisting", NULL); |
table_add("programlisting", NULL); |
table_add("property", "TEXT"); |
table_add("property", "TEXT"); |
table_add("pubdate", "TEXT"); |
table_add("pubdate", "TEXT"); |
table_add("quote", "command"); |
table_add("quote", "command"); |
|
table_add("quote", "filename"); |
table_add("quote", "literal"); |
table_add("quote", "literal"); |
table_add("quote", "TEXT"); |
table_add("quote", "TEXT"); |
table_add("refentry", "refentryinfo"); |
table_add("refentry", "refentryinfo"); |
Line 502 main(int argc, char *argv[]) |
|
Line 527 main(int argc, char *argv[]) |
|
table_add("refentry", "refsect1"); |
table_add("refentry", "refsect1"); |
table_add("refentry", "refsynopsisdiv"); |
table_add("refentry", "refsynopsisdiv"); |
table_add("refentryinfo", "author"); |
table_add("refentryinfo", "author"); |
|
table_add("refentryinfo", "authorgroup"); |
table_add("refentryinfo", "copyright"); |
table_add("refentryinfo", "copyright"); |
table_add("refentryinfo", "date"); |
table_add("refentryinfo", "date"); |
|
table_add("refentryinfo", "productname"); |
table_add("refentrytitle", "TEXT"); |
table_add("refentrytitle", "TEXT"); |
|
table_add("reference", "refentry"); |
table_add("refmeta", "manvolnum"); |
table_add("refmeta", "manvolnum"); |
table_add("refmeta", "refentrytitle"); |
table_add("refmeta", "refentrytitle"); |
table_add("refmeta", "refmiscinfo"); |
table_add("refmeta", "refmiscinfo"); |
Line 540 main(int argc, char *argv[]) |
|
Line 568 main(int argc, char *argv[]) |
|
table_add("superscript", "TEXT"); |
table_add("superscript", "TEXT"); |
table_add("surname", "TEXT"); |
table_add("surname", "TEXT"); |
table_add("symbol", "TEXT"); |
table_add("symbol", "TEXT"); |
|
table_add("synopsis", "function"); |
|
table_add("synopsis", "parameter"); |
|
table_add("synopsis", "type"); |
table_add("synopsis", "TEXT"); |
table_add("synopsis", "TEXT"); |
table_add("systemitem", "TEXT"); |
table_add("systemitem", "TEXT"); |
table_add("table", "tgroup"); |
table_add("table", "tgroup"); |