=================================================================== RCS file: /cvs/docbook2mdoc/Attic/rules.c,v retrieving revision 1.16 retrieving revision 1.25 diff -u -p -r1.16 -r1.25 --- docbook2mdoc/Attic/rules.c 2014/04/02 10:59:07 1.16 +++ docbook2mdoc/Attic/rules.c 2015/03/19 10:04:32 1.25 @@ -16,6 +16,9 @@ isattrkey(enum nodeid node, enum attrkey key) break; } return(0); + case (ATTRKEY_OPEN): + case (ATTRKEY_CLOSE): + return(node == NODE_MML_MFENCED); case (ATTRKEY_ID): /* Common to all. */ return(1); @@ -87,6 +90,9 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_ANCHOR): + /* We'll ignore this. */ + return(1); case (NODE_APPLICATION): switch (parent) { case (NODE_EMPHASIS): @@ -212,6 +218,16 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_COLSPEC): + switch (parent) { + case (NODE_TFOOT): + case (NODE_THEAD): + case (NODE_TGROUP): + return(1); + default: + break; + } + return(0); case (NODE_COMMAND): switch (parent) { case (NODE_CMDSYNOPSIS): @@ -237,11 +253,46 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_CONSTANT): + switch (parent) { + case (NODE_EMPHASIS): + case (NODE_ENTRY): + case (NODE_FUNCSYNOPSISINFO): + case (NODE_LINK): + case (NODE_ULINK): + case (NODE_PARA): + case (NODE_PROGRAMLISTING): + case (NODE_QUOTE): + case (NODE_REFDESCRIPTOR): + case (NODE_REFENTRYTITLE): + case (NODE_REFNAME): + case (NODE_REFPURPOSE): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TERM): + case (NODE_TITLE): + case (NODE_USERINPUT): + return(1); + default: + break; + } + return(0); + case (NODE_COPYRIGHT): + switch (parent) { + case (NODE_INFO): + case (NODE_REFENTRYINFO): + case (NODE_REFMETAINFO): + return(1); + default: + break; + } + return(0); case (NODE_DATE): switch (parent) { case (NODE_EMPHASIS): case (NODE_ENTRY): case (NODE_FUNCSYNOPSISINFO): + case (NODE_INFO): case (NODE_LINK): case (NODE_PARA): case (NODE_PROGRAMLISTING): @@ -309,6 +360,28 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_FIELDSYNOPSIS): + switch (parent) { + case (NODE_CAUTION): + case (NODE_ENTRY): + case (NODE_ITEMIZEDLIST): + case (NODE_LISTITEM): + case (NODE_NOTE): + case (NODE_ORDEREDLIST): + case (NODE_PARA): + case (NODE_REFSECT1): + case (NODE_REFSECT2): + case (NODE_REFSECT3): + case (NODE_REFSECTION): + case (NODE_REFSYNOPSISDIV): + case (NODE_TIP): + case (NODE_VARIABLELIST): + case (NODE_WARNING): + return(1); + default: + break; + } + return(0); case (NODE_FILENAME): switch (parent) { case (NODE_EMPHASIS): @@ -386,9 +459,55 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); - case (NODE_ITEMIZEDLIST): + case (NODE_GROUP): switch (parent) { + case (NODE_ARG): + case (NODE_CMDSYNOPSIS): + case (NODE_GROUP): + return(1); + default: + break; + } + return(0); + case (NODE_HOLDER): + switch (parent) { + case (NODE_COPYRIGHT): + return(1); + default: + break; + } + return(0); + case (NODE_INFO): + switch (parent) { case (NODE_CAUTION): + case (NODE_CMDSYNOPSIS): + case (NODE_FUNCSYNOPSIS): + case (NODE_FUNCSYNOPSISINFO): + case (NODE_INFORMALTABLE): + case (NODE_ITEMIZEDLIST): + case (NODE_NOTE): + case (NODE_ORDEREDLIST): + case (NODE_PARA): + case (NODE_PROGRAMLISTING): + case (NODE_REFENTRY): + case (NODE_REFSECT1): + case (NODE_REFSECT2): + case (NODE_REFSECT3): + case (NODE_REFSECTION): + case (NODE_REFSYNOPSISDIV): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TABLE): + case (NODE_VARIABLELIST): + case (NODE_WARNING): + return(1); + default: + break; + } + return(0); + case (NODE_INFORMALEQUATION): + switch (parent) { + case (NODE_CAUTION): case (NODE_ENTRY): case (NODE_ITEMIZEDLIST): case (NODE_LISTITEM): @@ -400,7 +519,6 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_REFSECT3): case (NODE_REFSECTION): case (NODE_REFSYNOPSISDIV): - case (NODE_TIP): case (NODE_VARIABLELIST): case (NODE_WARNING): return(1); @@ -408,16 +526,48 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); - case (NODE_GROUP): + case (NODE_INLINEEQUATION): switch (parent) { - case (NODE_ARG): - case (NODE_CMDSYNOPSIS): - case (NODE_GROUP): + case (NODE_APPLICATION): + case (NODE_EMPHASIS): + case (NODE_ENTRY): + case (NODE_LINK): + case (NODE_PARA): + case (NODE_PROGRAMLISTING): + case (NODE_QUOTE): + case (NODE_REFENTRYTITLE): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TERM): + case (NODE_TITLE): + case (NODE_ULINK): return(1); default: break; } return(0); + case (NODE_ITEMIZEDLIST): + switch (parent) { + case (NODE_CAUTION): + case (NODE_ENTRY): + case (NODE_ITEMIZEDLIST): + case (NODE_LISTITEM): + case (NODE_NOTE): + case (NODE_ORDEREDLIST): + case (NODE_PARA): + case (NODE_REFSECT1): + case (NODE_REFSECT2): + case (NODE_REFSECT3): + case (NODE_REFSECTION): + case (NODE_REFSYNOPSISDIV): + case (NODE_TIP): + case (NODE_VARIABLELIST): + case (NODE_WARNING): + return(1); + default: + break; + } + return(0); case (NODE_LINK): case (NODE_ULINK): /* Synonyms. */ switch (parent) { @@ -426,16 +576,19 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_ARG): case (NODE_CODE): case (NODE_COMMAND): + case (NODE_CONSTANT): case (NODE_EMPHASIS): case (NODE_ENTRY): - case (NODE_ENVAR): + case (NODE_ENVAR): case (NODE_FILENAME): case (NODE_FUNCDEF): case (NODE_FUNCSYNOPSISINFO): case (NODE_FUNCTION): + case (NODE_HOLDER): case (NODE_LINK): case (NODE_LITERAL): case (NODE_MANVOLNUM): + case (NODE_MODIFIER): case (NODE_OPTION): case (NODE_PARA): case (NODE_PARAMDEF): @@ -451,9 +604,13 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_SCREEN): case (NODE_SYNOPSIS): case (NODE_TERM): + case (NODE_TRADEMARK): + case (NODE_TYPE): case (NODE_ULINK): case (NODE_USERINPUT): case (NODE_VARNAME): + case (NODE_WORDASWORD): + case (NODE_YEAR): return(1); default: break; @@ -502,6 +659,63 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_MML_MATH): + switch (parent) { + case (NODE_INFORMALEQUATION): + case (NODE_INLINEEQUATION): + return(1); + default: + break; + } + return(0); + case (NODE_MML_MFENCED): + case (NODE_MML_MFRAC): + case (NODE_MML_MI): + case (NODE_MML_MN): + case (NODE_MML_MO): + case (NODE_MML_MROW): + case (NODE_MML_MSUB): + case (NODE_MML_MSUP): + switch (parent) { + case (NODE_MML_MATH): + case (NODE_MML_MFENCED): + case (NODE_MML_MFRAC): + case (NODE_MML_MI): + case (NODE_MML_MN): + case (NODE_MML_MO): + case (NODE_MML_MROW): + case (NODE_MML_MSUB): + case (NODE_MML_MSUP): + return(1); + default: + break; + } + return(0); + case (NODE_MODIFIER): + switch (parent) { + case (NODE_CODE): + case (NODE_EMPHASIS): + case (NODE_ENTRY): + case (NODE_FIELDSYNOPSIS): + case (NODE_FUNCSYNOPSISINFO): + case (NODE_LINK): + case (NODE_ULINK): + case (NODE_PARA): + case (NODE_PROGRAMLISTING): + case (NODE_QUOTE): + case (NODE_REFDESCRIPTOR): + case (NODE_REFENTRYTITLE): + case (NODE_REFNAME): + case (NODE_REFPURPOSE): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TERM): + case (NODE_TITLE): + return(1); + default: + break; + } + return(0); case (NODE_NOTE): switch (parent) { case (NODE_CAUTION): @@ -598,6 +812,7 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_PARAMETER): switch (parent) { case (NODE_CODE): + case (NODE_EMPHASIS): case (NODE_ENTRY): case (NODE_FUNCSYNOPSISINFO): case (NODE_LINK): @@ -689,7 +904,6 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); - case (NODE_REFCLASS): return(parent == NODE_REFNAMEDIV); case (NODE_REFDESCRIPTOR): @@ -708,6 +922,8 @@ isparent(enum nodeid node, enum nodeid parent) } case (NODE_REFMETA): return(parent == NODE_REFENTRY); + case (NODE_REFMETAINFO): + return(parent == NODE_REFMETA); case (NODE_REFMISCINFO): return(parent == NODE_REFMETA); case (NODE_REFNAME): @@ -748,17 +964,20 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_ARG): case (NODE_CODE): case (NODE_COMMAND): + case (NODE_CONSTANT): case (NODE_EMPHASIS): case (NODE_ENTRY): - case (NODE_ENVAR): + case (NODE_ENVAR): case (NODE_FILENAME): case (NODE_FUNCDEF): case (NODE_FUNCSYNOPSISINFO): case (NODE_FUNCTION): case (NODE_GROUP): + case (NODE_HOLDER): case (NODE_LINK): case (NODE_LITERAL): case (NODE_MANVOLNUM): + case (NODE_MODIFIER): case (NODE_OPTION): case (NODE_PARA): case (NODE_PARAMDEF): @@ -773,12 +992,17 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_REFPURPOSE): case (NODE_REPLACEABLE): case (NODE_SCREEN): + case (NODE_SGMLTAG): case (NODE_SYNOPSIS): case (NODE_TERM): case (NODE_TITLE): + case (NODE_TRADEMARK): + case (NODE_TYPE): case (NODE_ULINK): case (NODE_USERINPUT): case (NODE_VARNAME): + case (NODE_WORDASWORD): + case (NODE_YEAR): default: return(1); } @@ -825,6 +1049,37 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_SGMLTAG): + switch (parent) { + case (NODE_APPLICATION): + case (NODE_CODE): + case (NODE_COMMAND): + case (NODE_EMPHASIS): + case (NODE_ENTRY): + case (NODE_FILENAME): + case (NODE_FUNCSYNOPSISINFO): + case (NODE_FUNCTION): + case (NODE_LINK): + case (NODE_LITERAL): + case (NODE_OPTION): + case (NODE_PARA): + case (NODE_PARAMETER): + case (NODE_PROGRAMLISTING): + case (NODE_QUOTE): + case (NODE_REFDESCRIPTOR): + case (NODE_REFENTRYTITLE): + case (NODE_REFNAME): + case (NODE_REFPURPOSE): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TERM): + case (NODE_TITLE): + case (NODE_USERINPUT): + return(1); + default: + break; + } + return(0); case (NODE_STRUCTNAME): switch (parent) { case (NODE_CODE): @@ -866,6 +1121,8 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_INFORMALTABLE): + /* FALLTHROUGH */ case (NODE_TABLE): switch (parent) { case (NODE_CAUTION): @@ -893,11 +1150,20 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_TFOOT): return(NODE_TGROUP == parent); case (NODE_TGROUP): - return(NODE_TABLE == parent); + switch (parent) { + case (NODE_INFORMALTABLE): + case (NODE_TABLE): + return(1); + default: + break; + } + return(0); case (NODE_THEAD): return(NODE_TGROUP == parent); case (NODE_TITLE): switch (parent) { + case (NODE_INFO): + case (NODE_INFORMALTABLE): case (NODE_ITEMIZEDLIST): case (NODE_ORDEREDLIST): case (NODE_REFENTRYINFO): @@ -939,6 +1205,55 @@ isparent(enum nodeid node, enum nodeid parent) break; } return(0); + case (NODE_TRADEMARK): + switch (parent) { + case (NODE_ACRONYM): + case (NODE_EMPHASIS): + case (NODE_ENTRY): + case (NODE_FUNCSYNOPSISINFO): + case (NODE_LINK): + case (NODE_ULINK): + case (NODE_PARA): + case (NODE_PROGRAMLISTING): + case (NODE_QUOTE): + case (NODE_REFDESCRIPTOR): + case (NODE_REFENTRYTITLE): + case (NODE_REFNAME): + case (NODE_REFPURPOSE): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TERM): + case (NODE_TITLE): + return(1); + default: + break; + } + return(0); + case (NODE_TYPE): + switch (parent) { + case (NODE_CODE): + case (NODE_EMPHASIS): + case (NODE_ENTRY): + case (NODE_FIELDSYNOPSIS): + case (NODE_FUNCSYNOPSISINFO): + case (NODE_LINK): + case (NODE_ULINK): + case (NODE_PARA): + case (NODE_PROGRAMLISTING): + case (NODE_QUOTE): + case (NODE_REFDESCRIPTOR): + case (NODE_REFENTRYTITLE): + case (NODE_REFNAME): + case (NODE_REFPURPOSE): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TERM): + case (NODE_TITLE): + return(1); + default: + break; + } + return(0); case (NODE_USERINPUT): switch (parent) { case (NODE_EMPHASIS): @@ -989,6 +1304,7 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_CODE): case (NODE_EMPHASIS): case (NODE_ENTRY): + case (NODE_FIELDSYNOPSIS): case (NODE_FUNCSYNOPSISINFO): case (NODE_LINK): case (NODE_PARA): @@ -1027,6 +1343,37 @@ isparent(enum nodeid node, enum nodeid parent) case (NODE_TIP): case (NODE_VARIABLELIST): case (NODE_WARNING): + return(1); + default: + break; + } + return(0); + case (NODE_WORDASWORD): + switch (parent) { + case (NODE_EMPHASIS): + case (NODE_ENTRY): + case (NODE_FUNCSYNOPSISINFO): + case (NODE_LINK): + case (NODE_PARA): + case (NODE_PROGRAMLISTING): + case (NODE_QUOTE): + case (NODE_REFDESCRIPTOR): + case (NODE_REFENTRYTITLE): + case (NODE_REFNAME): + case (NODE_REFPURPOSE): + case (NODE_SCREEN): + case (NODE_SYNOPSIS): + case (NODE_TERM): + case (NODE_TITLE): + case (NODE_ULINK): + return(1); + default: + break; + } + return(0); + case (NODE_YEAR): + switch (parent) { + case (NODE_COPYRIGHT): return(1); default: break;