46#define PERLOUTPUT_MAX_INDENTATION 40
51 std::ostream *
m_t =
nullptr;
58 void add(
unsigned int n);
196 *s++ =
' '; *s++ =
' '; *s = 0;
211 const char *s = str.
data();
213 while ((c = *s++) != 0)
215 if ((c ==
'\'') || (c ==
'\\'))
234 if ((content ==
'\'') || (content ==
'\\'))
242 if (content ==
nullptr)
351 for (
const auto &child : t.children())
353 std::visit(*
this, child);
400 (link +=
"_1") += anchor;
401 m_output.addFieldQuotedString(
"link", link);
407 m_output.openHash().addFieldQuotedString(
"type", name);
421 m_output.addField(
"content").add(
'\'');
499 const char *accent=
nullptr;
553 .addFieldQuotedString(
"accent", accent)
554 .addFieldQuotedChar(
"letter", res->
symb[0]);
599 const char *style =
nullptr;
622 m_output.addFieldQuotedString(
"style", style)
623 .addFieldBoolean(
"enable", s.
enable());
629 const char *type =
nullptr;
668 m_output.addFieldQuotedString(
"id", anchor);
674 const char *type =
nullptr;
709 parseCode(m_ci,op.context(),op.text(),
FALSE,0);
727 m_output.addFieldQuotedString(
"id",
id).addFieldQuotedString(
"content", f.
text());
738 "<secondaryie></secondaryie>"
758 if (!opt.noPar()) txt +=
"[";
760 if (!opt.noPar()) txt +=
"]";
762 m_output.addFieldQuotedString(
"text", txt);
787 m_output.addFieldQuotedString(
"style",
"Unchecked");
791 m_output.addFieldQuotedString(
"style",
"Checked");
824 const char *type =
nullptr;
846 err(
"unknown simple section found\n");
855 std::visit(*
this,*s.
title());
875 m_output.addFieldQuotedString(
"style",
"itemized");
899 std::visit(*
this,*s.
title());
911 for (
const auto &opt : l.
attribs())
913 if (opt.name==
"type")
917 if (opt.name==
"start")
930 for (
const auto &opt : l.
attribs())
932 if (opt.name==
"value")
956 m_output.add(
"<varlistentry><term>");
960 m_output.add(
"</term></varlistentry>\n");
983 std::visit(*
this,*t.
caption());
1058 auto summary =
details.summary();
1061 std::visit(*
this,*summary);
1094 if ((i=baseName.
findRev(
'/'))!=-1 || (i=baseName.
findRev(
'\\'))!=-1)
1217 const char *type =
nullptr;
1225 err(
"unknown parameter section found\n");
1244 m_output.openHash().openList(
"parameters");
1248 const DocWord *word = std::get_if<DocWord>(¶m);
1249 const DocLinkedWord *linkedWord = std::get_if<DocLinkedWord>(¶m);
1252 name = word->
word();
1254 else if (linkedWord)
1256 name = linkedWord->
word();
1281 .addFieldQuotedString(
"name", name).addFieldQuotedString(
"dir", dir)
1288 std::visit(*
this,par);
1314 m_output.add(
"</xrefdescription>");
1356 output.
openList(
"template_parameters");
1360 if (!a.type.isEmpty())
1362 if (!a.name.isEmpty())
1365 if (!a.defval.isEmpty())
1407 auto astImpl =
dynamic_cast<const DocNodeAST*
>(ast.get());
1411 std::visit(visitor,astImpl->root);
1524 bool isFortran = md->
getLanguage()==SrcLangExt::Fortran;
1529 .addFieldQuotedString(
"kind", memType)
1530 .addFieldQuotedString(
"name", name)
1533 .addFieldBoolean(
"static", md->
isStatic());
1549 if (!declAl.
empty())
1551 auto defIt = al.
begin();
1555 if (defIt!=al.
end())
1562 if (!a.name.isEmpty())
1563 m_output.addFieldQuotedString(
"declaration_name", a.name);
1566 m_output.addFieldQuotedString(
"definition_name", defArg->
name);
1568 if (isFortran && defArg && !defArg->
type.
isEmpty())
1570 else if (!a.type.isEmpty())
1571 m_output.addFieldQuotedString(
"type", a.type);
1573 if (!a.array.isEmpty())
1574 m_output.addFieldQuotedString(
"array", a.array);
1576 if (!a.defval.isEmpty())
1577 m_output.addFieldQuotedString(
"default_value", a.defval);
1579 if (!a.attrib.isEmpty())
1580 m_output.addFieldQuotedString(
"attributes", a.attrib);
1594 .addFieldQuotedString(
"name", a.type)
1614 if (!enumFields.
empty())
1617 for (
const auto &emd : enumFields)
1620 .addFieldQuotedString(
"name", emd->name());
1622 if (!emd->initializer().isEmpty())
1623 m_output.addFieldQuotedString(
"initializer", emd->initializer());
1638 if (bitfield.
at(0) ==
':') bitfield = bitfield.
mid(1);
1639 m_output.addFieldQuotedString(
"bitfield", bitfield);
1645 .addFieldQuotedString(
"name", rmd->
name())
1651 m_output.openList(
"reimplemented_by");
1652 for (
const auto &rbmd : rbml)
1654 .addFieldQuotedString(
"name", rbmd->name())
1665 if (ml==
nullptr)
return;
1670 m_output.addFieldQuotedString(
"header", header);
1673 for (
const auto &md : *ml)
1686 for (
auto &mi : *mni)
1692 .addFieldQuotedString(
"name", md->
name())
1696 if (!mi->ambiguityResolutionScope().isEmpty())
1697 m_output.addFieldQuotedString(
"ambiguity_scope", mi->ambiguityResolutionScope());
1711 for (
const auto &mg : mgl)
1714 if (!mg->header().isEmpty())
1716 m_output.addFieldQuotedString(
"header", mg->header());
1719 if (!mg->members().empty())
1722 for (
const auto &md : mg->members())
1744 .addFieldQuotedString(
"name", nm)
1773 .addFieldQuotedString(
"name", cd->
name());
1783 .addFieldQuotedString(
"name", bcd.classDef->displayName())
1797 .addFieldQuotedString(
"name", bcd.classDef->displayName())
1809 .addFieldQuotedString(
"name", icd->name())
1848 DotClassGraph inheritanceGraph(cd,DotClassGraph::Inheritance);
1851 t <<
" <inheritancegraph>" << endl;
1852 inheritanceGraph.writePerlMod(t);
1853 t <<
" </inheritancegraph>" << endl;
1855 DotClassGraph collaborationGraph(cd,DotClassGraph::Implementation);
1858 t <<
" <collaborationgraph>" << endl;
1859 collaborationGraph.writePerlMod(t);
1860 t <<
" </collaborationgraph>" << endl;
1862 t <<
" <location file=\""
1881 .addFieldQuotedString(
"name", cd->
name());
1907 .addFieldQuotedString(
"name", mod->
name());
1916 .addFieldQuotedString(
"name", cd->name())
1926 .addFieldQuotedString(
"name", cd->name())
1944 .addFieldQuotedString(
"name", fd->name())
1966 .addFieldQuotedString(
"name", nd->
name());
1973 .addFieldQuotedString(
"name", cd->name())
1983 .addFieldQuotedString(
"name", ind->name())
2022 .addFieldQuotedString(
"name", fd->
name());
2028 .addFieldQuotedString(
"name", inc.includeName);
2029 if (inc.fileDef && !inc.fileDef->isReference())
2031 m_output.addFieldQuotedString(
"ref", inc.fileDef->getOutputFileBase());
2041 .addFieldQuotedString(
"name", inc.includeName);
2042 if (inc.fileDef && !inc.fileDef->isReference())
2044 m_output.addFieldQuotedString(
"ref", inc.fileDef->getOutputFileBase());
2082 .addFieldQuotedString(
"name", gd->
name())
2083 .addFieldQuotedString(
"title", gd->
groupTitle());
2088 for (
const auto &fd : gd->
getFiles())
2090 .addFieldQuotedString(
"name", fd->name())
2100 .addFieldQuotedString(
"name", cd->name())
2110 .addFieldQuotedString(
"name", cd->name())
2120 .addFieldQuotedString(
"name", mod->name())
2130 .addFieldQuotedString(
"name", nd->name())
2138 for (
const auto &pd : gd->
getPages())
2140 .addFieldQuotedString(
"title", pd->title())
2150 .addFieldQuotedString(
"title", sgd->groupTitle())
2179 .addFieldQuotedString(
"name", pd->
name());
2191 std::ofstream outputFileStream;
2196 m_output.setPerlModOutputStream(&outputStream);
2197 m_output.add(
"$doxydocs=").openHash();
2222 for (
const auto &fd : *fn)
2247 m_output.closeHash().add(
";\n1;\n");
2257 err(
"Cannot open file {} for writing!\n", s);
2266 perlModDir.
setPath(outputDirectory+
"/perlmod");
2267 if (!perlModDir.
exists() && !perlModDir.
mkdir(outputDirectory+
"/perlmod"))
2269 err(
"Could not create perlmod directory in {}\n",outputDirectory);
2277 std::ofstream doxyModelPMStream;
2281 doxyModelPMStream <<
2282 "sub memberlist($) {\n"
2283 " my $prefix = $_[0];\n"
2285 "\t[ \"hash\", $prefix . \"s\",\n"
2288 "\t [ \"list\", $prefix . \"List\",\n"
2289 "\t\t[ \"hash\", $prefix,\n"
2291 "\t\t kind => [ \"string\", $prefix . \"Kind\" ],\n"
2292 "\t\t name => [ \"string\", $prefix . \"Name\" ],\n"
2293 "\t\t static => [ \"string\", $prefix . \"Static\" ],\n"
2294 "\t\t virtualness => [ \"string\", $prefix . \"Virtualness\" ],\n"
2295 "\t\t protection => [ \"string\", $prefix . \"Protection\" ],\n"
2296 "\t\t type => [ \"string\", $prefix . \"Type\" ],\n"
2297 "\t\t parameters =>\n"
2298 "\t\t [ \"list\", $prefix . \"Params\",\n"
2299 "\t\t\t[ \"hash\", $prefix . \"Param\",\n"
2301 "\t\t\t declaration_name => [ \"string\", $prefix . \"ParamName\" ],\n"
2302 "\t\t\t type => [ \"string\", $prefix . \"ParamType\" ],\n"
2306 "\t\t detailed =>\n"
2307 "\t\t [ \"hash\", $prefix . \"Detailed\",\n"
2309 "\t\t\t doc => [ \"doc\", $prefix . \"DetailedDoc\" ],\n"
2310 "\t\t\t return => [ \"doc\", $prefix . \"Return\" ],\n"
2311 "\t\t\t see => [ \"doc\", $prefix . \"See\" ],\n"
2312 "\t\t\t params =>\n"
2313 "\t\t\t [ \"list\", $prefix . \"PDBlocks\",\n"
2314 "\t\t\t [ \"hash\", $prefix . \"PDBlock\",\n"
2316 "\t\t\t\t parameters =>\n"
2317 "\t\t\t\t [ \"list\", $prefix . \"PDParams\",\n"
2318 "\t\t\t\t [ \"hash\", $prefix . \"PDParam\",\n"
2320 "\t\t\t\t\t name => [ \"string\", $prefix . \"PDParamName\" ],\n"
2324 "\t\t\t\t doc => [ \"doc\", $prefix . \"PDDoc\" ],\n"
2337 "$doxystructure =\n"
2338 " [ \"hash\", \"Root\",\n"
2341 "\t [ \"list\", \"Files\",\n"
2342 "\t [ \"hash\", \"File\",\n"
2344 "\t\tname => [ \"string\", \"FileName\" ],\n"
2345 "\t\ttypedefs => memberlist(\"FileTypedef\"),\n"
2346 "\t\tvariables => memberlist(\"FileVariable\"),\n"
2347 "\t\tfunctions => memberlist(\"FileFunction\"),\n"
2349 "\t\t [ \"hash\", \"FileDetailed\",\n"
2351 "\t\t doc => [ \"doc\", \"FileDetailedDoc\" ],\n"
2358 "\t [ \"list\", \"Pages\",\n"
2359 "\t [ \"hash\", \"Page\",\n"
2361 "\t\tname => [ \"string\", \"PageName\" ],\n"
2363 "\t\t [ \"hash\", \"PageDetailed\",\n"
2365 "\t\t doc => [ \"doc\", \"PageDetailedDoc\" ],\n"
2372 "\t [ \"list\", \"Classes\",\n"
2373 "\t [ \"hash\", \"Class\",\n"
2375 "\t\tname => [ \"string\", \"ClassName\" ],\n"
2376 "\t\tpublic_typedefs => memberlist(\"ClassPublicTypedef\"),\n"
2377 "\t\tpublic_methods => memberlist(\"ClassPublicMethod\"),\n"
2378 "\t\tpublic_members => memberlist(\"ClassPublicMember\"),\n"
2379 "\t\tprotected_typedefs => memberlist(\"ClassProtectedTypedef\"),\n"
2380 "\t\tprotected_methods => memberlist(\"ClassProtectedMethod\"),\n"
2381 "\t\tprotected_members => memberlist(\"ClassProtectedMember\"),\n"
2382 "\t\tprivate_typedefs => memberlist(\"ClassPrivateTypedef\"),\n"
2383 "\t\tprivate_methods => memberlist(\"ClassPrivateMethod\"),\n"
2384 "\t\tprivate_members => memberlist(\"ClassPrivateMember\"),\n"
2386 "\t\t [ \"hash\", \"ClassDetailed\",\n"
2388 "\t\t doc => [ \"doc\", \"ClassDetailedDoc\" ],\n"
2395 "\t [ \"list\", \"Groups\",\n"
2396 "\t [ \"hash\", \"Group\",\n"
2398 "\t\tname => [ \"string\", \"GroupName\" ],\n"
2399 "\t\ttitle => [ \"string\", \"GroupTitle\" ],\n"
2401 "\t\t [ \"list\", \"Files\",\n"
2402 "\t\t [ \"hash\", \"File\",\n"
2404 "\t\t name => [ \"string\", \"Filename\" ]\n"
2409 "\t\t [ \"list\", \"Classes\",\n"
2410 "\t\t [ \"hash\", \"Class\",\n"
2412 "\t\t name => [ \"string\", \"Classname\" ]\n"
2416 "\t\tnamespaces =>\n"
2417 "\t\t [ \"list\", \"Namespaces\",\n"
2418 "\t\t [ \"hash\", \"Namespace\",\n"
2420 "\t\t name => [ \"string\", \"NamespaceName\" ]\n"
2425 "\t\t [ \"list\", \"Pages\",\n"
2426 "\t\t [ \"hash\", \"Page\","
2428 "\t\t title => [ \"string\", \"PageName\" ]\n"
2433 "\t\t [ \"list\", \"Groups\",\n"
2434 "\t\t [ \"hash\", \"Group\",\n"
2436 "\t\t title => [ \"string\", \"GroupName\" ]\n"
2440 "\t\tfunctions => memberlist(\"GroupFunction\"),\n"
2442 "\t\t [ \"hash\", \"GroupDetailed\",\n"
2444 "\t\t doc => [ \"doc\", \"GroupDetailedDoc\" ],\n"
2460 std::ofstream doxyRulesStream;
2486 ".PHONY: clean-perlmod\n"
2488 "\trm -f $(" <<
prefix <<
"DOXYSTRUCTURE_PM) \\\n"
2489 "\t$(" <<
prefix <<
"DOXYDOCS_PM)";
2493 "\t$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2494 "\t$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2495 "\t$(" <<
prefix <<
"DOXYDOCS_TEX) \\\n"
2496 "\t$(" <<
prefix <<
"DOXYSTRUCTURE_TEX) \\\n"
2497 "\t$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2498 "\t$(" <<
prefix <<
"DOXYLATEX_TEX) \\\n"
2499 "\t$(" <<
prefix <<
"DOXYLATEX_PDF) \\\n"
2500 "\t$(" <<
prefix <<
"DOXYLATEX_DVI) \\\n"
2501 "\t$(addprefix $(" <<
prefix <<
"DOXYLATEX_TEX:tex=),out aux log)";
2502 doxyRulesStream <<
"\n\n";
2505 "$(" <<
prefix <<
"DOXYRULES) \\\n"
2506 "$(" <<
prefix <<
"DOXYMAKEFILE) \\\n"
2507 "$(" <<
prefix <<
"DOXYSTRUCTURE_PM) \\\n"
2508 "$(" <<
prefix <<
"DOXYDOCS_PM)";
2512 "$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2513 "$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2514 "$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2515 "$(" <<
prefix <<
"DOXYLATEX_TEX)";
2519 "\t$(" <<
prefix <<
"DOXYFILE)\n"
2520 "\tcd $(" <<
prefix <<
"DOXY_EXEC_PATH) ; doxygen \"$<\"\n";
2525 "$(" <<
prefix <<
"DOXYDOCS_TEX): \\\n"
2526 "$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2527 "$(" <<
prefix <<
"DOXYDOCS_PM)\n"
2528 "\tperl -I\"$(<D)\" \"$<\" >\"$@\"\n"
2530 "$(" <<
prefix <<
"DOXYSTRUCTURE_TEX): \\\n"
2531 "$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2532 "$(" <<
prefix <<
"DOXYSTRUCTURE_PM)\n"
2533 "\tperl -I\"$(<D)\" \"$<\" >\"$@\"\n"
2535 "$(" <<
prefix <<
"DOXYLATEX_PDF) \\\n"
2536 "$(" <<
prefix <<
"DOXYLATEX_DVI): \\\n"
2537 "$(" <<
prefix <<
"DOXYLATEX_TEX) \\\n"
2538 "$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2539 "$(" <<
prefix <<
"DOXYSTRUCTURE_TEX) \\\n"
2540 "$(" <<
prefix <<
"DOXYDOCS_TEX)\n"
2542 "$(" <<
prefix <<
"DOXYLATEX_PDF): \\\n"
2543 "$(" <<
prefix <<
"DOXYLATEX_TEX)\n"
2544 "\tpdflatex -interaction=nonstopmode \"$<\"\n"
2546 "$(" <<
prefix <<
"DOXYLATEX_DVI): \\\n"
2547 "$(" <<
prefix <<
"DOXYLATEX_TEX)\n"
2548 "\tlatex -interaction=nonstopmode \"$<\"\n";
2556 std::ofstream makefileStream;
2564 ".PHONY: default clean" << (perlmodLatex ?
" pdf" :
"") <<
"\n"
2565 "default: " << (perlmodLatex ?
"pdf" :
"clean") <<
"\n"
2569 "clean: clean-perlmod\n";
2573 "pdf: $(" <<
prefix <<
"DOXYLATEX_PDF)\n"
2574 "dvi: $(" <<
prefix <<
"DOXYLATEX_DVI)\n";
2582 std::ofstream doxyLatexStructurePLStream;
2586 doxyLatexStructurePLStream <<
2587 "use DoxyStructure;\n"
2589 "sub process($) {\n"
2590 "\tmy $node = $_[0];\n"
2591 "\tmy ($type, $name) = @$node[0, 1];\n"
2593 "\tif ($type eq \"string\") { $command = \"String\" }\n"
2594 "\telsif ($type eq \"doc\") { $command = \"Doc\" }\n"
2595 "\telsif ($type eq \"hash\") {\n"
2596 "\t\t$command = \"Hash\";\n"
2597 "\t\tfor my $subnode (values %{$$node[2]}) {\n"
2598 "\t\t\tprocess($subnode);\n"
2601 "\telsif ($type eq \"list\") {\n"
2602 "\t\t$command = \"List\";\n"
2603 "\t\tprocess($$node[2]);\n"
2605 "\tprint \"\\\\\" . $command . \"Node{\" . $name . \"}%\\n\";\n"
2608 "process($doxystructure);\n";
2615 std::ofstream doxyLatexPLStream;
2619 doxyLatexPLStream <<
2620 "use DoxyStructure;\n"
2623 "sub latex_quote($) {\n"
2624 "\tmy $text = $_[0];\n"
2625 "\t$text =~ s/\\\\/\\\\textbackslash /g;\n"
2626 "\t$text =~ s/\\|/\\\\textbar /g;\n"
2627 "\t$text =~ s/</\\\\textless /g;\n"
2628 "\t$text =~ s/>/\\\\textgreater /g;\n"
2629 "\t$text =~ s/~/\\\\textasciitilde /g;\n"
2630 "\t$text =~ s/\\^/\\\\textasciicircum /g;\n"
2631 "\t$text =~ s/[\\$&%#_{}]/\\\\$&/g;\n"
2635 "sub generate_doc($) {\n"
2636 "\tmy $doc = $_[0];\n"
2637 "\tfor my $item (@$doc) {\n"
2638 "\t\tmy $type = $$item{type};\n"
2639 "\t\tif ($type eq \"text\") {\n"
2640 "\t\t\tlatex_quote($$item{content});\n"
2641 "\t\t} elsif ($type eq \"parbreak\") {\n"
2642 "\t\t\tprint \"\\n\\n\";\n"
2643 "\t\t} elsif ($type eq \"style\") {\n"
2644 "\t\t\tmy $style = $$item{style};\n"
2645 "\t\t\tif ($$item{enable} eq \"yes\") {\n"
2646 "\t\t\t\tif ($style eq \"bold\") { print '\\bfseries'; }\n"
2647 "\t\t\t\tif ($style eq \"italic\") { print '\\itshape'; }\n"
2648 "\t\t\t\tif ($style eq \"code\") { print '\\ttfamily'; }\n"
2650 "\t\t\t\tif ($style eq \"bold\") { print '\\mdseries'; }\n"
2651 "\t\t\t\tif ($style eq \"italic\") { print '\\upshape'; }\n"
2652 "\t\t\t\tif ($style eq \"code\") { print '\\rmfamily'; }\n"
2654 "\t\t\tprint '{}';\n"
2655 "\t\t} elsif ($type eq \"symbol\") {\n"
2656 "\t\t\tmy $symbol = $$item{symbol};\n"
2657 "\t\t\tif ($symbol eq \"copyright\") { print '\\copyright'; }\n"
2658 "\t\t\telsif ($symbol eq \"szlig\") { print '\\ss'; }\n"
2659 "\t\t\tprint '{}';\n"
2660 "\t\t} elsif ($type eq \"accent\") {\n"
2661 "\t\t\tmy ($accent) = $$item{accent};\n"
2662 "\t\t\tif ($accent eq \"umlaut\") { print '\\\"'; }\n"
2663 "\t\t\telsif ($accent eq \"acute\") { print '\\\\\\''; }\n"
2664 "\t\t\telsif ($accent eq \"grave\") { print '\\`'; }\n"
2665 "\t\t\telsif ($accent eq \"circ\") { print '\\^'; }\n"
2666 "\t\t\telsif ($accent eq \"tilde\") { print '\\~'; }\n"
2667 "\t\t\telsif ($accent eq \"cedilla\") { print '\\c'; }\n"
2668 "\t\t\telsif ($accent eq \"ring\") { print '\\r'; }\n"
2669 "\t\t\tprint \"{\" . $$item{letter} . \"}\"; \n"
2670 "\t\t} elsif ($type eq \"list\") {\n"
2671 "\t\t\tmy $env = ($$item{style} eq \"ordered\") ? \"enumerate\" : \"itemize\";\n"
2672 "\t\t\tprint \"\\n\\\\begin{\" . $env .\"}\";\n"
2673 "\t\t \tfor my $subitem (@{$$item{content}}) {\n"
2674 "\t\t\t\tprint \"\\n\\\\item \";\n"
2675 "\t\t\t\tgenerate_doc($subitem);\n"
2677 "\t\t\tprint \"\\n\\\\end{\" . $env .\"}\";\n"
2678 "\t\t} elsif ($type eq \"url\") {\n"
2679 "\t\t\tlatex_quote($$item{content});\n"
2684 "sub generate($$) {\n"
2685 "\tmy ($item, $node) = @_;\n"
2686 "\tmy ($type, $name) = @$node[0, 1];\n"
2687 "\tif ($type eq \"string\") {\n"
2688 "\t\tprint \"\\\\\" . $name . \"{\";\n"
2689 "\t\tlatex_quote($item);\n"
2690 "\t\tprint \"}\";\n"
2691 "\t} elsif ($type eq \"doc\") {\n"
2692 "\t\tif (@$item) {\n"
2693 "\t\t\tprint \"\\\\\" . $name . \"{\";\n"
2694 "\t\t\tgenerate_doc($item);\n"
2695 "\t\t\tprint \"}%\\n\";\n"
2697 "#\t\t\tprint \"\\\\\" . $name . \"Empty%\\n\";\n"
2699 "\t} elsif ($type eq \"hash\") {\n"
2700 "\t\tmy ($key, $value);\n"
2701 "\t\twhile (($key, $subnode) = each %{$$node[2]}) {\n"
2702 "\t\t\tmy $subname = $$subnode[1];\n"
2703 "\t\t\tprint \"\\\\Defcs{field\" . $subname . \"}{\";\n"
2704 "\t\t\tif ($$item{$key}) {\n"
2705 "\t\t\t\tgenerate($$item{$key}, $subnode);\n"
2707 "#\t\t\t\t\tprint \"\\\\\" . $subname . \"Empty%\\n\";\n"
2709 "\t\t\tprint \"}%\\n\";\n"
2711 "\t\tprint \"\\\\\" . $name . \"%\\n\";\n"
2712 "\t} elsif ($type eq \"list\") {\n"
2713 "\t\tmy $index = 0;\n"
2714 "\t\tif (@$item) {\n"
2715 "\t\t\tprint \"\\\\\" . $name . \"{%\\n\";\n"
2716 "\t\t\tfor my $subitem (@$item) {\n"
2717 "\t\t\t\tif ($index) {\n"
2718 "\t\t\t\t\tprint \"\\\\\" . $name . \"Sep%\\n\";\n"
2720 "\t\t\t\tgenerate($subitem, $$node[2]);\n"
2721 "\t\t\t\t$index++;\n"
2723 "\t\t\tprint \"}%\\n\";\n"
2725 "#\t\t\tprint \"\\\\\" . $name . \"Empty%\\n\";\n"
2730 "generate($doxydocs, $doxystructure);\n";
2737 std::ofstream doxyFormatTexStream;
2741 doxyFormatTexStream <<
2742 "\\def\\Defcs#1{\\long\\expandafter\\def\\csname#1\\endcsname}\n"
2743 "\\Defcs{Empty}{}\n"
2744 "\\def\\IfEmpty#1{\\expandafter\\ifx\\csname#1\\endcsname\\Empty}\n"
2746 "\\def\\StringNode#1{\\Defcs{#1}##1{##1}}\n"
2747 "\\def\\DocNode#1{\\Defcs{#1}##1{##1}}\n"
2748 "\\def\\ListNode#1{\\Defcs{#1}##1{##1}\\Defcs{#1Sep}{}}\n"
2749 "\\def\\HashNode#1{\\Defcs{#1}{}}\n"
2754 "\\dimendef\\DimenA=151\\relax\n"
2755 "\\dimendef\\DimenB=152\\relax\n"
2756 "\\countdef\\ZoneDepth=151\\relax\n"
2758 "\\def\\Cs#1{\\csname#1\\endcsname}\n"
2759 "\\def\\Letcs#1{\\expandafter\\let\\csname#1\\endcsname}\n"
2760 "\\def\\Heading#1{\\vskip 4mm\\relax\\textbf{#1}}\n"
2761 "\\def\\See#1{\\begin{flushleft}\\Heading{See also: }#1\\end{flushleft}}\n"
2763 "\\def\\Frame#1{\\vskip 3mm\\relax\\fbox{ \\vbox{\\hsize0.95\\hsize\\vskip 1mm\\relax\n"
2764 "\\raggedright#1\\vskip 0.5mm\\relax} }}\n"
2766 "\\def\\Zone#1#2#3{%\n"
2767 "\\Defcs{Test#1}{#2}%\n"
2768 "\\Defcs{Emit#1}{#3}%\n"
2770 "\\advance\\ZoneDepth1\\relax\n"
2771 "\\Letcs{Mode\\number\\ZoneDepth}0\\relax\n"
2772 "\\Letcs{Present\\number\\ZoneDepth}0\\relax\n"
2774 "\\expandafter\\if\\Cs{Present\\number\\ZoneDepth}1%\n"
2775 "\\advance\\ZoneDepth-1\\relax\n"
2776 "\\Letcs{Present\\number\\ZoneDepth}1\\relax\n"
2777 "\\expandafter\\if\\Cs{Mode\\number\\ZoneDepth}1%\n"
2778 "\\advance\\ZoneDepth1\\relax\n"
2779 "\\Letcs{Mode\\number\\ZoneDepth}1\\relax\n"
2781 "\\advance\\ZoneDepth-1\\relax\\fi\n"
2782 "\\advance\\ZoneDepth1\\relax\\fi\n"
2783 "\\advance\\ZoneDepth-1\\relax}}\n"
2785 "\\def\\Member#1#2{%\n"
2786 "\\Defcs{Test#1}{\\Cs{field#1Detailed}\n"
2787 "\\IfEmpty{field#1DetailedDoc}\\else\\Letcs{Present#1}1\\fi}\n"
2788 "\\Defcs{#1}{\\Letcs{Present#1}0\\relax\n"
2789 "\\Cs{Test#1}\\if1\\Cs{Present#1}\\Letcs{Present\\number\\ZoneDepth}1\\relax\n"
2790 "\\if1\\Cs{Mode\\number\\ZoneDepth}#2\\fi\\fi}}\n"
2792 "\\def\\TypedefMemberList#1#2{%\n"
2793 "\\Defcs{#1DetailedDoc}##1{\\vskip 5.5mm\\relax##1}%\n"
2794 "\\Defcs{#1Name}##1{\\textbf{##1}}%\n"
2795 "\\Defcs{#1See}##1{\\See{##1}}%\n"
2797 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2798 "\\Member{#1}{\\Frame{typedef \\Cs{field#1Type} \\Cs{field#1Name}}%\n"
2799 "\\Cs{field#1DetailedDoc}\\Cs{field#1See}\\vskip 5mm\\relax}}%\n"
2801 "\\def\\VariableMemberList#1#2{%\n"
2802 "\\Defcs{#1DetailedDoc}##1{\\vskip 5.5mm\\relax##1}%\n"
2803 "\\Defcs{#1Name}##1{\\textbf{##1}}%\n"
2804 "\\Defcs{#1See}##1{\\See{##1}}%\n"
2806 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2807 "\\Member{#1}{\\Frame{\\Cs{field#1Type}{} \\Cs{field#1Name}}%\n"
2808 "\\Cs{field#1DetailedDoc}\\Cs{field#1See}\\vskip 5mm\\relax}}%\n"
2810 "\\def\\FunctionMemberList#1#2{%\n"
2811 "\\Defcs{#1PDParamName}##1{\\textit{##1}}%\n"
2812 "\\Defcs{#1PDParam}{\\Cs{field#1PDParamName}}%\n"
2813 "\\Defcs{#1PDParamsSep}{, }%\n"
2814 "\\Defcs{#1PDBlocksSep}{\\vskip 2mm\\relax}%\n"
2816 "\\Defcs{#1PDBlocks}##1{%\n"
2817 "\\Heading{Parameters:}\\vskip 1.5mm\\relax\n"
2818 "\\DimenA0pt\\relax\n"
2819 "\\Defcs{#1PDBlock}{\\setbox\\BoxA\\hbox{\\Cs{field#1PDParams}}%\n"
2820 "\\ifdim\\DimenA<\\wd\\BoxA\\DimenA\\wd\\BoxA\\fi}%\n"
2822 "\\advance\\DimenA3mm\\relax\n"
2823 "\\DimenB\\hsize\\advance\\DimenB-\\DimenA\\relax\n"
2824 "\\Defcs{#1PDBlock}{\\hbox to\\hsize{\\vtop{\\hsize\\DimenA\\relax\n"
2825 "\\Cs{field#1PDParams}}\\hfill\n"
2826 "\\vtop{\\hsize\\DimenB\\relax\\Cs{field#1PDDoc}}}}%\n"
2829 "\\Defcs{#1ParamName}##1{\\textit{##1}}\n"
2830 "\\Defcs{#1Param}{\\Cs{field#1ParamType}{} \\Cs{field#1ParamName}}\n"
2831 "\\Defcs{#1ParamsSep}{, }\n"
2833 "\\Defcs{#1Name}##1{\\textbf{##1}}\n"
2834 "\\Defcs{#1See}##1{\\See{##1}}\n"
2835 "\\Defcs{#1Return}##1{\\Heading{Returns: }##1}\n"
2836 "\\Defcs{field#1Title}{\\Frame{\\Cs{field#1Type}{} \\Cs{field#1Name}(\\Cs{field#1Params})}}%\n"
2838 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2840 "\\Cs{field#1Title}\\vskip 6mm\\relax\\Cs{field#1DetailedDoc}\n"
2841 "\\Cs{field#1Return}\\Cs{field#1PDBlocks}\\Cs{field#1See}\\vskip 5mm\\relax}}\n"
2843 "\\def\\FileDetailed{\\fieldFileDetailedDoc\\par}\n"
2844 "\\def\\ClassDetailed{\\fieldClassDetailedDoc\\par}\n"
2846 "\\def\\FileSubzones{\\fieldFileTypedefs\\fieldFileVariables\\fieldFileFunctions}\n"
2848 "\\def\\ClassSubzones{%\n"
2849 "\\fieldClassPublicTypedefs\\fieldClassPublicMembers\\fieldClassPublicMethods\n"
2850 "\\fieldClassProtectedTypedefs\\fieldClassProtectedMembers\\fieldClassProtectedMethods\n"
2851 "\\fieldClassPrivateTypedefs\\fieldClassPrivateMembers\\fieldClassPrivateMethods}\n"
2853 "\\Member{Page}{\\subsection{\\fieldPageName}\\fieldPageDetailedDoc}\n"
2855 "\\TypedefMemberList{FileTypedef}{Typedefs}\n"
2856 "\\VariableMemberList{FileVariable}{Variables}\n"
2857 "\\FunctionMemberList{FileFunction}{Functions}\n"
2858 "\\Zone{File}{\\FileSubzones}{\\subsection{\\fieldFileName}\\fieldFileDetailed\\FileSubzones}\n"
2860 "\\TypedefMemberList{ClassPublicTypedef}{Public Typedefs}\n"
2861 "\\TypedefMemberList{ClassProtectedTypedef}{Protected Typedefs}\n"
2862 "\\TypedefMemberList{ClassPrivateTypedef}{Private Typedefs}\n"
2863 "\\VariableMemberList{ClassPublicMember}{Public Members}\n"
2864 "\\VariableMemberList{ClassProtectedMember}{Protected Members}\n"
2865 "\\VariableMemberList{ClassPrivateMember}{Private Members}\n"
2866 "\\FunctionMemberList{ClassPublicMethod}{Public Methods}\n"
2867 "\\FunctionMemberList{ClassProtectedMethod}{Protected Methods}\n"
2868 "\\FunctionMemberList{ClassPrivateMethod}{Private Methods}\n"
2869 "\\Zone{Class}{\\ClassSubzones}{\\subsection{\\fieldClassName}\\fieldClassDetailed\\ClassSubzones}\n"
2871 "\\Zone{AllPages}{\\fieldPages}{\\section{Pages}\\fieldPages}\n"
2872 "\\Zone{AllFiles}{\\fieldFiles}{\\section{Files}\\fieldFiles}\n"
2873 "\\Zone{AllClasses}{\\fieldClasses}{\\section{Classes}\\fieldClasses}\n"
2875 "\\newlength{\\oldparskip}\n"
2876 "\\newlength{\\oldparindent}\n"
2877 "\\newlength{\\oldfboxrule}\n"
2879 "\\ZoneDepth0\\relax\n"
2880 "\\Letcs{Mode0}1\\relax\n"
2882 "\\def\\EmitDoxyDocs{%\n"
2883 "\\setlength{\\oldparskip}{\\parskip}\n"
2884 "\\setlength{\\oldparindent}{\\parindent}\n"
2885 "\\setlength{\\oldfboxrule}{\\fboxrule}\n"
2886 "\\setlength{\\parskip}{0cm}\n"
2887 "\\setlength{\\parindent}{0cm}\n"
2888 "\\setlength{\\fboxrule}{1pt}\n"
2889 "\\AllPages\\AllFiles\\AllClasses\n"
2890 "\\setlength{\\parskip}{\\oldparskip}\n"
2891 "\\setlength{\\parindent}{\\oldparindent}\n"
2892 "\\setlength{\\fboxrule}{\\oldfboxrule}}\n";
2899 std::ofstream doxyLatexTexStream;
2903 doxyLatexTexStream <<
2904 "\\documentclass[a4paper,12pt]{article}\n"
2905 "\\usepackage[latin1]{inputenc}\n"
2906 "\\usepackage[none]{hyphenat}\n"
2907 "\\usepackage[T1]{fontenc}\n"
2908 "\\usepackage{hyperref}\n"
2909 "\\usepackage{times}\n"
2911 "\\input{doxyformat}\n"
2913 "\\begin{document}\n"
2917 "\\end{document}\n";
This class represents an function or template argument list.
bool hasParameters() const
bool constSpecifier() const
bool volatileSpecifier() const
A abstract class representing of a compound symbol.
virtual const ArgumentList & templateArguments() const =0
Returns the template arguments of this class.
virtual QCString compoundTypeString() const =0
Returns the type of compound as a string.
virtual const BaseClassList & baseClasses() const =0
Returns the list of base classes from which this class directly inherits.
virtual MemberList * getMemberList(MemberListType lt) const =0
Returns the members in the list identified by lt.
virtual const MemberNameInfoLinkedMap & memberNameInfoLinkedMap() const =0
Returns a dictionary of all members.
virtual bool isImplicitTemplateInstance() const =0
virtual const MemberGroupList & getMemberGroups() const =0
Returns the member groups defined for this class.
virtual ClassLinkedRefMap getClasses() const =0
returns the classes nested into this class
virtual const IncludeInfo * includeInfo() const =0
virtual const BaseClassList & subClasses() const =0
Returns the list of sub classes that directly derive from this class.
virtual QCString initializer() const =0
virtual ArgumentList getTemplateParameterList() const =0
virtual const IncludeInfo * includeInfo() const =0
The common base class of all entity definitions found in the sources.
virtual QCString docFile() const =0
virtual int getEndBodyLine() const =0
virtual SrcLangExt getLanguage() const =0
Returns the programming language this definition was written in.
virtual int docLine() const =0
virtual QCString getDefFileName() const =0
virtual int getDefLine() const =0
virtual int briefLine() const =0
virtual QCString briefDescription(bool abbreviate=FALSE) const =0
virtual bool isAnonymous() const =0
virtual QCString documentation() const =0
virtual QCString briefFile() const =0
virtual Definition * getOuterScope() const =0
virtual int getStartBodyLine() const =0
virtual bool isReference() const =0
virtual const QCString & name() const =0
Class representing a directory in the file system.
static std::string currentDirPath()
std::string absPath() const
bool mkdir(const std::string &path, bool acceptsAbsPath=true) const
void setPath(const std::string &path)
Node representing an anchor.
Node representing an auto List.
bool isCheckedList() const
Node representing an item of a auto list.
Node representing a citation of some bibliographic reference.
CiteInfoOption option() const
Node representing a dia file.
Node representing a dot file.
Node representing an emoji.
Node representing a Hypertext reference.
Node representing a horizontal ruler.
Node representing an HTML blockquote.
Node representing a HTML table caption.
Node representing a HTML table cell.
Node representing a HTML description data.
Node representing a Html description list.
Node representing a Html description item.
Node representing a Html list.
const HtmlAttribList & attribs() const
Node representing a HTML list item.
const HtmlAttribList & attribs() const
Node representing a HTML table row.
Node representing a HTML table.
const DocNodeVariant * caption() const
Node representing an image.
Node representing a include/dontinclude operator block.
Node representing an included text block from file.
Node representing an entry in the index.
Node representing an internal section of documentation.
Node representing an internal reference to some item.
Node representing a line break.
Node representing a link to some item.
Node representing a word that can be linked to something.
Node representing a mermaid file.
Node representing a msc file.
Class representing the abstract syntax tree of a documentation block.
DocNodeVariant * parent()
Node representing an block of paragraphs.
Node representing a paragraph in the documentation tree.
Node representing a parameter list.
const DocNodeList & parameters() const
DocParamSect::Direction direction() const
const DocNodeList & paragraphs() const
Node representing a parameter section.
bool hasInOutSpecifier() const
Node representing a uml file.
Node representing a reference to some item.
QCString targetTitle() const
Root node of documentation tree.
Node representing a reference to a section.
Node representing a list of section references.
Node representing a normal section.
const DocNodeVariant * title() const
Node representing a separator.
Node representing a simple list.
Node representing a simple list item.
const DocNodeVariant * paragraph() const
Node representing a simple section.
const DocNodeVariant * title() const
Node representing a separator between two simple sections of the same type.
Node representing a style change.
Node representing a special symbol.
HtmlEntityMapper::SymType symbol() const
Root node of a text fragment.
Node representing a simple section title.
Node representing a URL (or email address).
Node representing a verbatim, unparsed text fragment.
Node representing a VHDL flow chart.
Node representing some amount of white space.
Node representing a word.
Node representing an item of a cross-referenced list.
Representation of a class inheritance or dependency graph.
static NamespaceLinkedMap * namespaceLinkedMap
static ConceptLinkedMap * conceptLinkedMap
static std::unique_ptr< PageDef > mainPage
static FileNameLinkedMap * inputNameLinkedMap
static ClassLinkedMap * classLinkedMap
static PageLinkedMap * pageLinkedMap
static GroupLinkedMap * groupLinkedMap
const char * name(int index) const
Access routine to the name of the Emoji entity.
static EmojiEntityMapper & instance()
Returns the one and only instance of the Emoji entity mapper.
A model of a file symbol.
virtual const MemberGroupList & getMemberGroups() const =0
virtual const IncludeInfoList & includeFileList() const =0
virtual MemberList * getMemberList(MemberListType lt) const =0
virtual const QCString & docName() const =0
virtual const IncludeInfoList & includedByFileList() const =0
A model of a group of symbols.
virtual const GroupList & getSubGroups() const =0
virtual QCString groupTitle() const =0
virtual const FileList & getFiles() const =0
virtual const MemberGroupList & getMemberGroups() const =0
virtual const ConceptLinkedRefMap & getConcepts() const =0
virtual const PageLinkedRefMap & getPages() const =0
virtual const NamespaceLinkedRefMap & getNamespaces() const =0
virtual const ClassLinkedRefMap & getClasses() const =0
virtual MemberList * getMemberList(MemberListType lt) const =0
virtual const ModuleLinkedRefMap & getModules() const =0
const PerlSymb * perl(SymType symb) const
Access routine to the perl struct with the perl code of the HTML entity.
static HtmlEntityMapper & instance()
Returns the one and only instance of the HTML entity mapper.
const T * find(const std::string &key) const
A model of a class/file/namespace member symbol.
virtual QCString typeString() const =0
virtual QCString enumBaseType() const =0
virtual QCString excpString() const =0
virtual const ClassDef * getClassDef() const =0
virtual const MemberVector & enumFieldList() const =0
virtual const ArgumentList & argumentList() const =0
virtual const MemberVector & reimplementedBy() const =0
virtual bool isStatic() const =0
virtual const MemberDef * reimplements() const =0
virtual QCString bitfieldString() const =0
virtual Protection protection() const =0
virtual MemberType memberType() const =0
virtual QCString argsString() const =0
virtual Specifier virtualness(int count=0) const =0
virtual const ArgumentList & declArgumentList() const =0
virtual const QCString & initializer() const =0
A list of MemberDef objects as shown in documentation sections.
A vector of MemberDef object.
bool empty() const noexcept
virtual MemberList * getMemberList(MemberListType lt) const =0
virtual const MemberGroupList & getMemberGroups() const =0
virtual FileList getUsedFiles() const =0
virtual const ConceptLinkedRefMap & getConcepts() const =0
virtual const ClassLinkedRefMap & getClasses() const =0
static ModuleManager & instance()
An abstract interface of a namespace symbol.
virtual MemberList * getMemberList(MemberListType lt) const =0
virtual NamespaceLinkedRefMap getNamespaces() const =0
virtual ClassLinkedRefMap getClasses() const =0
virtual const MemberGroupList & getMemberGroups() const =0
A model of a page symbol.
Concrete visitor implementation for PerlMod output.
PerlModDocVisitor(PerlModOutput &)
void openItem(const QCString &)
void visitChildren(const T &t)
void addLink(const QCString &ref, const QCString &file, const QCString &anchor)
void singleItem(const QCString &)
void openSubBlock(const QCString &=QCString())
void operator()(const DocWord &)
void generatePerlModForPage(PageDef *pi)
void generatePerlModForMember(const MemberDef *md, const Definition *)
bool generateDoxyFormatTex()
QCString pathDoxyStructureTex
bool generateDoxyLatexTex()
bool createOutputDir(Dir &perlModDir)
void generatePerlModSection(const Definition *d, MemberList *ml, const QCString &name, const QCString &header=QCString())
QCString pathDoxyStructurePM
void generatePerlModForClass(const ClassDef *cd)
QCString pathDoxyLatexDVI
bool generatePerlModOutput()
void generatePerlModForModule(const ModuleDef *mod)
void generatePerlModForNamespace(const NamespaceDef *nd)
PerlModGenerator(bool pretty)
void addIncludeInfo(const IncludeInfo *ii)
void addListOfAllMembers(const ClassDef *cd)
QCString pathDoxyLatexStructurePL
bool generateDoxyStructurePM()
bool generateDoxyLatexPL()
void generatePerlModForGroup(const GroupDef *gd)
void generatePerlModForFile(const FileDef *fd)
QCString pathDoxyFormatTex
QCString pathDoxyLatexPDF
bool createOutputFile(std::ofstream &f, const QCString &s)
void generatePerlModForConcept(const ConceptDef *cd)
bool generateDoxyLatexStructurePL()
QCString pathDoxyLatexTex
void generatePerlUserDefinedSection(const Definition *d, const MemberGroupList &mgl)
PerlModOutput & closeList()
PerlModOutput & add(char c)
void iaddFieldQuotedString(const QCString &, const QCString &)
char m_spaces[PERLOUTPUT_MAX_INDENTATION *2+2]
PerlModOutput(bool pretty)
PerlModOutput & add(QCString &s)
PerlModOutput & open(char c, const QCString &s=QCString())
PerlModOutput & addFieldQuotedChar(const QCString &field, char content)
PerlModOutputStream * m_stream
PerlModOutput & continueBlock()
PerlModOutput & addField(const QCString &s)
void iopen(char, const QCString &)
PerlModOutput & openHash(const QCString &s=QCString())
PerlModOutput & addFieldQuotedString(const QCString &field, const QCString &content)
PerlModOutput & add(int n)
PerlModOutput & openList(const QCString &s=QCString())
void setPerlModOutputStream(PerlModOutputStream *os)
PerlModOutput & close(char c=0)
PerlModOutput & closeHash()
PerlModOutput & addQuoted(const QCString &s)
PerlModOutput & add(const QCString &s)
void iaddFieldQuotedChar(const QCString &, char)
PerlModOutput & addFieldBoolean(const QCString &field, bool content)
void iaddQuoted(const QCString &)
void iaddField(const QCString &)
PerlModOutput & add(unsigned int n)
PerlModOutputStream(std::ostream &t)
This is an alternative implementation of QCString.
size_t length() const
Returns the length of the string, not counting the 0-terminator.
QCString mid(size_t index, size_t len=static_cast< size_t >(-1)) const
char & at(size_t i)
Returns a reference to the character at index i.
bool isEmpty() const
Returns TRUE iff the string is empty.
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
QCString & setNum(short n)
QCString right(size_t len) const
QCString & sprintf(const char *format,...)
int findRev(char c, int index=-1, bool cs=TRUE) const
const char * data() const
Returns a pointer to the contents of the string in the form of a 0-terminated C string.
class that provide information about a section.
static SectionManager & instance()
returns a reference to the singleton
#define Config_getBool(name)
#define Config_getString(name)
#define NON_COPYABLE(cls)
Macro to help implementing the rule of 5 for a non-copyable & movable class.
IDocNodeASTPtr validatingParseDoc(IDocParser &parserIntf, const QCString &fileName, int startLine, const Definition *ctx, const MemberDef *md, const QCString &input, const DocOptions &options)
IDocParserPtr createDocParser()
factory function to create a parser
std::ofstream openOutputStream(const QCString &name, bool append=false)
static void addTemplateArgumentList(const ArgumentList &al, PerlModOutput &output, const QCString &)
static const char * getVirtualnessName(Specifier virt)
static void addTemplateList(const ClassDef *cd, PerlModOutput &output)
static const char * getProtectionName(Protection prot)
static void addPerlModDocBlock(PerlModOutput &output, const QCString &name, const QCString &fileName, int lineNr, const Definition *scope, const MemberDef *md, const QCString &text)
static QCString pathDoxyExec
void setPerlModDoxyfile(const QCString &qs)
static QCString pathDoxyfile
#define PERLOUTPUT_MAX_INDENTATION
Portable versions of functions that are platform dependent.
const char * qPrint(const char *s)
This class contains the information about the argument of a function or template.
Class representing the data associated with a #include statement.
static constexpr const char * to_string_lower(Protection prot) noexcept
QCString filterTitle(const QCString &title)
A bunch of utility functions.