45#define PERLOUTPUT_MAX_INDENTATION 40
50 std::ostream *
m_t =
nullptr;
57 void add(
unsigned int n);
195 *s++ =
' '; *s++ =
' '; *s = 0;
210 const char *s = str.
data();
212 while ((c = *s++) != 0)
214 if ((c ==
'\'') || (c ==
'\\'))
233 if ((content ==
'\'') || (content ==
'\\'))
241 if (content ==
nullptr)
349 for (
const auto &child : t.children())
351 std::visit(*
this, child);
398 (link +=
"_1") += anchor;
399 m_output.addFieldQuotedString(
"link", link);
405 m_output.openHash().addFieldQuotedString(
"type", name);
419 m_output.addField(
"content").add(
'\'');
497 const char *accent=
nullptr;
551 .addFieldQuotedString(
"accent", accent)
552 .addFieldQuotedChar(
"letter", res->
symb[0]);
597 const char *style =
nullptr;
620 m_output.addFieldQuotedString(
"style", style)
621 .addFieldBoolean(
"enable", s.
enable());
627 const char *type =
nullptr;
665 m_output.addFieldQuotedString(
"id", anchor);
671 const char *type =
nullptr;
706 parseCode(m_ci,op.context(),op.text(),
FALSE,0);
724 m_output.addFieldQuotedString(
"id",
id).addFieldQuotedString(
"content", f.
text());
735 "<secondaryie></secondaryie>"
772 m_output.addFieldQuotedString(
"style",
"Unchecked");
776 m_output.addFieldQuotedString(
"style",
"Checked");
809 const char *type =
nullptr;
831 err(
"unknown simple section found\n");
840 std::visit(*
this,*s.
title());
860 m_output.addFieldQuotedString(
"style",
"itemized");
884 std::visit(*
this,*s.
title());
896 for (
const auto &opt : l.
attribs())
898 if (opt.name==
"type")
902 if (opt.name==
"start")
915 for (
const auto &opt : l.
attribs())
917 if (opt.name==
"value")
941 m_output.add(
"<varlistentry><term>");
945 m_output.add(
"</term></varlistentry>\n");
968 std::visit(*
this,*t.
caption());
1043 auto summary =
details.summary();
1046 std::visit(*
this,*summary);
1079 if ((i=baseName.
findRev(
'/'))!=-1 || (i=baseName.
findRev(
'\\'))!=-1)
1192 const char *type =
nullptr;
1200 err(
"unknown parameter section found\n");
1219 m_output.openHash().openList(
"parameters");
1223 const DocWord *
word = std::get_if<DocWord>(¶m);
1224 const DocLinkedWord *linkedWord = std::get_if<DocLinkedWord>(¶m);
1227 name =
word->word();
1229 else if (linkedWord)
1231 name = linkedWord->
word();
1256 .addFieldQuotedString(
"name", name).addFieldQuotedString(
"dir", dir)
1263 std::visit(*
this,par);
1289 m_output.add(
"</xrefdescription>");
1331 output.
openList(
"template_parameters");
1335 if (!a.type.isEmpty())
1337 if (!a.name.isEmpty())
1340 if (!a.defval.isEmpty())
1377 auto astImpl =
dynamic_cast<const DocNodeAST*
>(ast.get());
1381 std::visit(visitor,astImpl->root);
1494 bool isFortran = md->
getLanguage()==SrcLangExt::Fortran;
1499 .addFieldQuotedString(
"kind", memType)
1500 .addFieldQuotedString(
"name", name)
1503 .addFieldBoolean(
"static", md->
isStatic());
1519 if (!declAl.
empty())
1521 auto defIt = al.
begin();
1525 if (defIt!=al.
end())
1532 if (!a.name.isEmpty())
1533 m_output.addFieldQuotedString(
"declaration_name", a.name);
1536 m_output.addFieldQuotedString(
"definition_name", defArg->
name);
1538 if (isFortran && defArg && !defArg->
type.
isEmpty())
1540 else if (!a.type.isEmpty())
1541 m_output.addFieldQuotedString(
"type", a.type);
1543 if (!a.array.isEmpty())
1544 m_output.addFieldQuotedString(
"array", a.array);
1546 if (!a.defval.isEmpty())
1547 m_output.addFieldQuotedString(
"default_value", a.defval);
1549 if (!a.attrib.isEmpty())
1550 m_output.addFieldQuotedString(
"attributes", a.attrib);
1564 .addFieldQuotedString(
"name", a.type)
1584 if (!enumFields.
empty())
1587 for (
const auto &emd : enumFields)
1590 .addFieldQuotedString(
"name", emd->name());
1592 if (!emd->initializer().isEmpty())
1593 m_output.addFieldQuotedString(
"initializer", emd->initializer());
1595 addPerlModDocBlock(
m_output,
"brief",emd->getDefFileName(),emd->getDefLine(),emd->getOuterScope(),emd,emd->briefDescription());
1597 addPerlModDocBlock(
m_output,
"detailed",emd->getDefFileName(),emd->getDefLine(),emd->getOuterScope(),emd,emd->documentation());
1608 if (bitfield.
at(0) ==
':') bitfield = bitfield.
mid(1);
1609 m_output.addFieldQuotedString(
"bitfield", bitfield);
1615 .addFieldQuotedString(
"name", rmd->
name())
1621 m_output.openList(
"reimplemented_by");
1622 for (
const auto &rbmd : rbml)
1624 .addFieldQuotedString(
"name", rbmd->name())
1635 if (ml==
nullptr)
return;
1640 m_output.addFieldQuotedString(
"header", header);
1643 for (
const auto &md : *ml)
1656 for (
auto &mi : *mni)
1662 .addFieldQuotedString(
"name", md->
name())
1666 if (!mi->ambiguityResolutionScope().isEmpty())
1667 m_output.addFieldQuotedString(
"ambiguity_scope", mi->ambiguityResolutionScope());
1681 for (
const auto &mg : mgl)
1684 if (!mg->header().isEmpty())
1686 m_output.addFieldQuotedString(
"header", mg->header());
1689 if (!mg->members().empty())
1692 for (
const auto &md : mg->members())
1714 .addFieldQuotedString(
"name", nm)
1743 .addFieldQuotedString(
"name", cd->
name());
1753 .addFieldQuotedString(
"name", bcd.classDef->displayName())
1767 .addFieldQuotedString(
"name", bcd.classDef->displayName())
1779 .addFieldQuotedString(
"name", icd->name())
1818 DotClassGraph inheritanceGraph(cd,DotClassGraph::Inheritance);
1821 t <<
" <inheritancegraph>" << endl;
1822 inheritanceGraph.writePerlMod(t);
1823 t <<
" </inheritancegraph>" << endl;
1825 DotClassGraph collaborationGraph(cd,DotClassGraph::Implementation);
1828 t <<
" <collaborationgraph>" << endl;
1829 collaborationGraph.writePerlMod(t);
1830 t <<
" </collaborationgraph>" << endl;
1832 t <<
" <location file=\""
1851 .addFieldQuotedString(
"name", cd->
name());
1877 .addFieldQuotedString(
"name", mod->
name());
1886 .addFieldQuotedString(
"name", cd->name())
1896 .addFieldQuotedString(
"name", cd->name())
1914 .addFieldQuotedString(
"name", fd->name())
1936 .addFieldQuotedString(
"name", nd->
name());
1943 .addFieldQuotedString(
"name", cd->name())
1953 .addFieldQuotedString(
"name", ind->name())
1992 .addFieldQuotedString(
"name", fd->
name());
1998 .addFieldQuotedString(
"name", inc.includeName);
1999 if (inc.fileDef && !inc.fileDef->isReference())
2001 m_output.addFieldQuotedString(
"ref", inc.fileDef->getOutputFileBase());
2011 .addFieldQuotedString(
"name", inc.includeName);
2012 if (inc.fileDef && !inc.fileDef->isReference())
2014 m_output.addFieldQuotedString(
"ref", inc.fileDef->getOutputFileBase());
2052 .addFieldQuotedString(
"name", gd->
name())
2053 .addFieldQuotedString(
"title", gd->
groupTitle());
2058 for (
const auto &fd : gd->
getFiles())
2060 .addFieldQuotedString(
"name", fd->name())
2070 .addFieldQuotedString(
"name", cd->name())
2080 .addFieldQuotedString(
"name", cd->name())
2090 .addFieldQuotedString(
"name", mod->name())
2100 .addFieldQuotedString(
"name", nd->name())
2108 for (
const auto &pd : gd->
getPages())
2110 .addFieldQuotedString(
"title", pd->title())
2120 .addFieldQuotedString(
"title", sgd->groupTitle())
2149 .addFieldQuotedString(
"name", pd->
name());
2161 std::ofstream outputFileStream;
2166 m_output.setPerlModOutputStream(&outputStream);
2167 m_output.add(
"$doxydocs=").openHash();
2192 for (
const auto &fd : *fn)
2217 m_output.closeHash().add(
";\n1;\n");
2227 err(
"Cannot open file {} for writing!\n", s);
2236 perlModDir.
setPath(outputDirectory+
"/perlmod");
2237 if (!perlModDir.
exists() && !perlModDir.
mkdir(outputDirectory+
"/perlmod"))
2239 err(
"Could not create perlmod directory in {}\n",outputDirectory);
2247 std::ofstream doxyModelPMStream;
2251 doxyModelPMStream <<
2252 "sub memberlist($) {\n"
2253 " my $prefix = $_[0];\n"
2255 "\t[ \"hash\", $prefix . \"s\",\n"
2258 "\t [ \"list\", $prefix . \"List\",\n"
2259 "\t\t[ \"hash\", $prefix,\n"
2261 "\t\t kind => [ \"string\", $prefix . \"Kind\" ],\n"
2262 "\t\t name => [ \"string\", $prefix . \"Name\" ],\n"
2263 "\t\t static => [ \"string\", $prefix . \"Static\" ],\n"
2264 "\t\t virtualness => [ \"string\", $prefix . \"Virtualness\" ],\n"
2265 "\t\t protection => [ \"string\", $prefix . \"Protection\" ],\n"
2266 "\t\t type => [ \"string\", $prefix . \"Type\" ],\n"
2267 "\t\t parameters =>\n"
2268 "\t\t [ \"list\", $prefix . \"Params\",\n"
2269 "\t\t\t[ \"hash\", $prefix . \"Param\",\n"
2271 "\t\t\t declaration_name => [ \"string\", $prefix . \"ParamName\" ],\n"
2272 "\t\t\t type => [ \"string\", $prefix . \"ParamType\" ],\n"
2276 "\t\t detailed =>\n"
2277 "\t\t [ \"hash\", $prefix . \"Detailed\",\n"
2279 "\t\t\t doc => [ \"doc\", $prefix . \"DetailedDoc\" ],\n"
2280 "\t\t\t return => [ \"doc\", $prefix . \"Return\" ],\n"
2281 "\t\t\t see => [ \"doc\", $prefix . \"See\" ],\n"
2282 "\t\t\t params =>\n"
2283 "\t\t\t [ \"list\", $prefix . \"PDBlocks\",\n"
2284 "\t\t\t [ \"hash\", $prefix . \"PDBlock\",\n"
2286 "\t\t\t\t parameters =>\n"
2287 "\t\t\t\t [ \"list\", $prefix . \"PDParams\",\n"
2288 "\t\t\t\t [ \"hash\", $prefix . \"PDParam\",\n"
2290 "\t\t\t\t\t name => [ \"string\", $prefix . \"PDParamName\" ],\n"
2294 "\t\t\t\t doc => [ \"doc\", $prefix . \"PDDoc\" ],\n"
2307 "$doxystructure =\n"
2308 " [ \"hash\", \"Root\",\n"
2311 "\t [ \"list\", \"Files\",\n"
2312 "\t [ \"hash\", \"File\",\n"
2314 "\t\tname => [ \"string\", \"FileName\" ],\n"
2315 "\t\ttypedefs => memberlist(\"FileTypedef\"),\n"
2316 "\t\tvariables => memberlist(\"FileVariable\"),\n"
2317 "\t\tfunctions => memberlist(\"FileFunction\"),\n"
2319 "\t\t [ \"hash\", \"FileDetailed\",\n"
2321 "\t\t doc => [ \"doc\", \"FileDetailedDoc\" ],\n"
2328 "\t [ \"list\", \"Pages\",\n"
2329 "\t [ \"hash\", \"Page\",\n"
2331 "\t\tname => [ \"string\", \"PageName\" ],\n"
2333 "\t\t [ \"hash\", \"PageDetailed\",\n"
2335 "\t\t doc => [ \"doc\", \"PageDetailedDoc\" ],\n"
2342 "\t [ \"list\", \"Classes\",\n"
2343 "\t [ \"hash\", \"Class\",\n"
2345 "\t\tname => [ \"string\", \"ClassName\" ],\n"
2346 "\t\tpublic_typedefs => memberlist(\"ClassPublicTypedef\"),\n"
2347 "\t\tpublic_methods => memberlist(\"ClassPublicMethod\"),\n"
2348 "\t\tpublic_members => memberlist(\"ClassPublicMember\"),\n"
2349 "\t\tprotected_typedefs => memberlist(\"ClassProtectedTypedef\"),\n"
2350 "\t\tprotected_methods => memberlist(\"ClassProtectedMethod\"),\n"
2351 "\t\tprotected_members => memberlist(\"ClassProtectedMember\"),\n"
2352 "\t\tprivate_typedefs => memberlist(\"ClassPrivateTypedef\"),\n"
2353 "\t\tprivate_methods => memberlist(\"ClassPrivateMethod\"),\n"
2354 "\t\tprivate_members => memberlist(\"ClassPrivateMember\"),\n"
2356 "\t\t [ \"hash\", \"ClassDetailed\",\n"
2358 "\t\t doc => [ \"doc\", \"ClassDetailedDoc\" ],\n"
2365 "\t [ \"list\", \"Groups\",\n"
2366 "\t [ \"hash\", \"Group\",\n"
2368 "\t\tname => [ \"string\", \"GroupName\" ],\n"
2369 "\t\ttitle => [ \"string\", \"GroupTitle\" ],\n"
2371 "\t\t [ \"list\", \"Files\",\n"
2372 "\t\t [ \"hash\", \"File\",\n"
2374 "\t\t name => [ \"string\", \"Filename\" ]\n"
2379 "\t\t [ \"list\", \"Classes\",\n"
2380 "\t\t [ \"hash\", \"Class\",\n"
2382 "\t\t name => [ \"string\", \"Classname\" ]\n"
2386 "\t\tnamespaces =>\n"
2387 "\t\t [ \"list\", \"Namespaces\",\n"
2388 "\t\t [ \"hash\", \"Namespace\",\n"
2390 "\t\t name => [ \"string\", \"NamespaceName\" ]\n"
2395 "\t\t [ \"list\", \"Pages\",\n"
2396 "\t\t [ \"hash\", \"Page\","
2398 "\t\t title => [ \"string\", \"PageName\" ]\n"
2403 "\t\t [ \"list\", \"Groups\",\n"
2404 "\t\t [ \"hash\", \"Group\",\n"
2406 "\t\t title => [ \"string\", \"GroupName\" ]\n"
2410 "\t\tfunctions => memberlist(\"GroupFunction\"),\n"
2412 "\t\t [ \"hash\", \"GroupDetailed\",\n"
2414 "\t\t doc => [ \"doc\", \"GroupDetailedDoc\" ],\n"
2430 std::ofstream doxyRulesStream;
2456 ".PHONY: clean-perlmod\n"
2458 "\trm -f $(" <<
prefix <<
"DOXYSTRUCTURE_PM) \\\n"
2459 "\t$(" <<
prefix <<
"DOXYDOCS_PM)";
2463 "\t$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2464 "\t$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2465 "\t$(" <<
prefix <<
"DOXYDOCS_TEX) \\\n"
2466 "\t$(" <<
prefix <<
"DOXYSTRUCTURE_TEX) \\\n"
2467 "\t$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2468 "\t$(" <<
prefix <<
"DOXYLATEX_TEX) \\\n"
2469 "\t$(" <<
prefix <<
"DOXYLATEX_PDF) \\\n"
2470 "\t$(" <<
prefix <<
"DOXYLATEX_DVI) \\\n"
2471 "\t$(addprefix $(" <<
prefix <<
"DOXYLATEX_TEX:tex=),out aux log)";
2472 doxyRulesStream <<
"\n\n";
2475 "$(" <<
prefix <<
"DOXYRULES) \\\n"
2476 "$(" <<
prefix <<
"DOXYMAKEFILE) \\\n"
2477 "$(" <<
prefix <<
"DOXYSTRUCTURE_PM) \\\n"
2478 "$(" <<
prefix <<
"DOXYDOCS_PM)";
2482 "$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2483 "$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2484 "$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2485 "$(" <<
prefix <<
"DOXYLATEX_TEX)";
2489 "\t$(" <<
prefix <<
"DOXYFILE)\n"
2490 "\tcd $(" <<
prefix <<
"DOXY_EXEC_PATH) ; doxygen \"$<\"\n";
2495 "$(" <<
prefix <<
"DOXYDOCS_TEX): \\\n"
2496 "$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2497 "$(" <<
prefix <<
"DOXYDOCS_PM)\n"
2498 "\tperl -I\"$(<D)\" \"$<\" >\"$@\"\n"
2500 "$(" <<
prefix <<
"DOXYSTRUCTURE_TEX): \\\n"
2501 "$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2502 "$(" <<
prefix <<
"DOXYSTRUCTURE_PM)\n"
2503 "\tperl -I\"$(<D)\" \"$<\" >\"$@\"\n"
2505 "$(" <<
prefix <<
"DOXYLATEX_PDF) \\\n"
2506 "$(" <<
prefix <<
"DOXYLATEX_DVI): \\\n"
2507 "$(" <<
prefix <<
"DOXYLATEX_TEX) \\\n"
2508 "$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2509 "$(" <<
prefix <<
"DOXYSTRUCTURE_TEX) \\\n"
2510 "$(" <<
prefix <<
"DOXYDOCS_TEX)\n"
2512 "$(" <<
prefix <<
"DOXYLATEX_PDF): \\\n"
2513 "$(" <<
prefix <<
"DOXYLATEX_TEX)\n"
2514 "\tpdflatex -interaction=nonstopmode \"$<\"\n"
2516 "$(" <<
prefix <<
"DOXYLATEX_DVI): \\\n"
2517 "$(" <<
prefix <<
"DOXYLATEX_TEX)\n"
2518 "\tlatex -interaction=nonstopmode \"$<\"\n";
2526 std::ofstream makefileStream;
2534 ".PHONY: default clean" << (perlmodLatex ?
" pdf" :
"") <<
"\n"
2535 "default: " << (perlmodLatex ?
"pdf" :
"clean") <<
"\n"
2539 "clean: clean-perlmod\n";
2543 "pdf: $(" <<
prefix <<
"DOXYLATEX_PDF)\n"
2544 "dvi: $(" <<
prefix <<
"DOXYLATEX_DVI)\n";
2552 std::ofstream doxyLatexStructurePLStream;
2556 doxyLatexStructurePLStream <<
2557 "use DoxyStructure;\n"
2559 "sub process($) {\n"
2560 "\tmy $node = $_[0];\n"
2561 "\tmy ($type, $name) = @$node[0, 1];\n"
2563 "\tif ($type eq \"string\") { $command = \"String\" }\n"
2564 "\telsif ($type eq \"doc\") { $command = \"Doc\" }\n"
2565 "\telsif ($type eq \"hash\") {\n"
2566 "\t\t$command = \"Hash\";\n"
2567 "\t\tfor my $subnode (values %{$$node[2]}) {\n"
2568 "\t\t\tprocess($subnode);\n"
2571 "\telsif ($type eq \"list\") {\n"
2572 "\t\t$command = \"List\";\n"
2573 "\t\tprocess($$node[2]);\n"
2575 "\tprint \"\\\\\" . $command . \"Node{\" . $name . \"}%\\n\";\n"
2578 "process($doxystructure);\n";
2585 std::ofstream doxyLatexPLStream;
2589 doxyLatexPLStream <<
2590 "use DoxyStructure;\n"
2593 "sub latex_quote($) {\n"
2594 "\tmy $text = $_[0];\n"
2595 "\t$text =~ s/\\\\/\\\\textbackslash /g;\n"
2596 "\t$text =~ s/\\|/\\\\textbar /g;\n"
2597 "\t$text =~ s/</\\\\textless /g;\n"
2598 "\t$text =~ s/>/\\\\textgreater /g;\n"
2599 "\t$text =~ s/~/\\\\textasciitilde /g;\n"
2600 "\t$text =~ s/\\^/\\\\textasciicircum /g;\n"
2601 "\t$text =~ s/[\\$&%#_{}]/\\\\$&/g;\n"
2605 "sub generate_doc($) {\n"
2606 "\tmy $doc = $_[0];\n"
2607 "\tfor my $item (@$doc) {\n"
2608 "\t\tmy $type = $$item{type};\n"
2609 "\t\tif ($type eq \"text\") {\n"
2610 "\t\t\tlatex_quote($$item{content});\n"
2611 "\t\t} elsif ($type eq \"parbreak\") {\n"
2612 "\t\t\tprint \"\\n\\n\";\n"
2613 "\t\t} elsif ($type eq \"style\") {\n"
2614 "\t\t\tmy $style = $$item{style};\n"
2615 "\t\t\tif ($$item{enable} eq \"yes\") {\n"
2616 "\t\t\t\tif ($style eq \"bold\") { print '\\bfseries'; }\n"
2617 "\t\t\t\tif ($style eq \"italic\") { print '\\itshape'; }\n"
2618 "\t\t\t\tif ($style eq \"code\") { print '\\ttfamily'; }\n"
2620 "\t\t\t\tif ($style eq \"bold\") { print '\\mdseries'; }\n"
2621 "\t\t\t\tif ($style eq \"italic\") { print '\\upshape'; }\n"
2622 "\t\t\t\tif ($style eq \"code\") { print '\\rmfamily'; }\n"
2624 "\t\t\tprint '{}';\n"
2625 "\t\t} elsif ($type eq \"symbol\") {\n"
2626 "\t\t\tmy $symbol = $$item{symbol};\n"
2627 "\t\t\tif ($symbol eq \"copyright\") { print '\\copyright'; }\n"
2628 "\t\t\telsif ($symbol eq \"szlig\") { print '\\ss'; }\n"
2629 "\t\t\tprint '{}';\n"
2630 "\t\t} elsif ($type eq \"accent\") {\n"
2631 "\t\t\tmy ($accent) = $$item{accent};\n"
2632 "\t\t\tif ($accent eq \"umlaut\") { print '\\\"'; }\n"
2633 "\t\t\telsif ($accent eq \"acute\") { print '\\\\\\''; }\n"
2634 "\t\t\telsif ($accent eq \"grave\") { print '\\`'; }\n"
2635 "\t\t\telsif ($accent eq \"circ\") { print '\\^'; }\n"
2636 "\t\t\telsif ($accent eq \"tilde\") { print '\\~'; }\n"
2637 "\t\t\telsif ($accent eq \"cedilla\") { print '\\c'; }\n"
2638 "\t\t\telsif ($accent eq \"ring\") { print '\\r'; }\n"
2639 "\t\t\tprint \"{\" . $$item{letter} . \"}\"; \n"
2640 "\t\t} elsif ($type eq \"list\") {\n"
2641 "\t\t\tmy $env = ($$item{style} eq \"ordered\") ? \"enumerate\" : \"itemize\";\n"
2642 "\t\t\tprint \"\\n\\\\begin{\" . $env .\"}\";\n"
2643 "\t\t \tfor my $subitem (@{$$item{content}}) {\n"
2644 "\t\t\t\tprint \"\\n\\\\item \";\n"
2645 "\t\t\t\tgenerate_doc($subitem);\n"
2647 "\t\t\tprint \"\\n\\\\end{\" . $env .\"}\";\n"
2648 "\t\t} elsif ($type eq \"url\") {\n"
2649 "\t\t\tlatex_quote($$item{content});\n"
2654 "sub generate($$) {\n"
2655 "\tmy ($item, $node) = @_;\n"
2656 "\tmy ($type, $name) = @$node[0, 1];\n"
2657 "\tif ($type eq \"string\") {\n"
2658 "\t\tprint \"\\\\\" . $name . \"{\";\n"
2659 "\t\tlatex_quote($item);\n"
2660 "\t\tprint \"}\";\n"
2661 "\t} elsif ($type eq \"doc\") {\n"
2662 "\t\tif (@$item) {\n"
2663 "\t\t\tprint \"\\\\\" . $name . \"{\";\n"
2664 "\t\t\tgenerate_doc($item);\n"
2665 "\t\t\tprint \"}%\\n\";\n"
2667 "#\t\t\tprint \"\\\\\" . $name . \"Empty%\\n\";\n"
2669 "\t} elsif ($type eq \"hash\") {\n"
2670 "\t\tmy ($key, $value);\n"
2671 "\t\twhile (($key, $subnode) = each %{$$node[2]}) {\n"
2672 "\t\t\tmy $subname = $$subnode[1];\n"
2673 "\t\t\tprint \"\\\\Defcs{field\" . $subname . \"}{\";\n"
2674 "\t\t\tif ($$item{$key}) {\n"
2675 "\t\t\t\tgenerate($$item{$key}, $subnode);\n"
2677 "#\t\t\t\t\tprint \"\\\\\" . $subname . \"Empty%\\n\";\n"
2679 "\t\t\tprint \"}%\\n\";\n"
2681 "\t\tprint \"\\\\\" . $name . \"%\\n\";\n"
2682 "\t} elsif ($type eq \"list\") {\n"
2683 "\t\tmy $index = 0;\n"
2684 "\t\tif (@$item) {\n"
2685 "\t\t\tprint \"\\\\\" . $name . \"{%\\n\";\n"
2686 "\t\t\tfor my $subitem (@$item) {\n"
2687 "\t\t\t\tif ($index) {\n"
2688 "\t\t\t\t\tprint \"\\\\\" . $name . \"Sep%\\n\";\n"
2690 "\t\t\t\tgenerate($subitem, $$node[2]);\n"
2691 "\t\t\t\t$index++;\n"
2693 "\t\t\tprint \"}%\\n\";\n"
2695 "#\t\t\tprint \"\\\\\" . $name . \"Empty%\\n\";\n"
2700 "generate($doxydocs, $doxystructure);\n";
2707 std::ofstream doxyFormatTexStream;
2711 doxyFormatTexStream <<
2712 "\\def\\Defcs#1{\\long\\expandafter\\def\\csname#1\\endcsname}\n"
2713 "\\Defcs{Empty}{}\n"
2714 "\\def\\IfEmpty#1{\\expandafter\\ifx\\csname#1\\endcsname\\Empty}\n"
2716 "\\def\\StringNode#1{\\Defcs{#1}##1{##1}}\n"
2717 "\\def\\DocNode#1{\\Defcs{#1}##1{##1}}\n"
2718 "\\def\\ListNode#1{\\Defcs{#1}##1{##1}\\Defcs{#1Sep}{}}\n"
2719 "\\def\\HashNode#1{\\Defcs{#1}{}}\n"
2724 "\\dimendef\\DimenA=151\\relax\n"
2725 "\\dimendef\\DimenB=152\\relax\n"
2726 "\\countdef\\ZoneDepth=151\\relax\n"
2728 "\\def\\Cs#1{\\csname#1\\endcsname}\n"
2729 "\\def\\Letcs#1{\\expandafter\\let\\csname#1\\endcsname}\n"
2730 "\\def\\Heading#1{\\vskip 4mm\\relax\\textbf{#1}}\n"
2731 "\\def\\See#1{\\begin{flushleft}\\Heading{See also: }#1\\end{flushleft}}\n"
2733 "\\def\\Frame#1{\\vskip 3mm\\relax\\fbox{ \\vbox{\\hsize0.95\\hsize\\vskip 1mm\\relax\n"
2734 "\\raggedright#1\\vskip 0.5mm\\relax} }}\n"
2736 "\\def\\Zone#1#2#3{%\n"
2737 "\\Defcs{Test#1}{#2}%\n"
2738 "\\Defcs{Emit#1}{#3}%\n"
2740 "\\advance\\ZoneDepth1\\relax\n"
2741 "\\Letcs{Mode\\number\\ZoneDepth}0\\relax\n"
2742 "\\Letcs{Present\\number\\ZoneDepth}0\\relax\n"
2744 "\\expandafter\\if\\Cs{Present\\number\\ZoneDepth}1%\n"
2745 "\\advance\\ZoneDepth-1\\relax\n"
2746 "\\Letcs{Present\\number\\ZoneDepth}1\\relax\n"
2747 "\\expandafter\\if\\Cs{Mode\\number\\ZoneDepth}1%\n"
2748 "\\advance\\ZoneDepth1\\relax\n"
2749 "\\Letcs{Mode\\number\\ZoneDepth}1\\relax\n"
2751 "\\advance\\ZoneDepth-1\\relax\\fi\n"
2752 "\\advance\\ZoneDepth1\\relax\\fi\n"
2753 "\\advance\\ZoneDepth-1\\relax}}\n"
2755 "\\def\\Member#1#2{%\n"
2756 "\\Defcs{Test#1}{\\Cs{field#1Detailed}\n"
2757 "\\IfEmpty{field#1DetailedDoc}\\else\\Letcs{Present#1}1\\fi}\n"
2758 "\\Defcs{#1}{\\Letcs{Present#1}0\\relax\n"
2759 "\\Cs{Test#1}\\if1\\Cs{Present#1}\\Letcs{Present\\number\\ZoneDepth}1\\relax\n"
2760 "\\if1\\Cs{Mode\\number\\ZoneDepth}#2\\fi\\fi}}\n"
2762 "\\def\\TypedefMemberList#1#2{%\n"
2763 "\\Defcs{#1DetailedDoc}##1{\\vskip 5.5mm\\relax##1}%\n"
2764 "\\Defcs{#1Name}##1{\\textbf{##1}}%\n"
2765 "\\Defcs{#1See}##1{\\See{##1}}%\n"
2767 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2768 "\\Member{#1}{\\Frame{typedef \\Cs{field#1Type} \\Cs{field#1Name}}%\n"
2769 "\\Cs{field#1DetailedDoc}\\Cs{field#1See}\\vskip 5mm\\relax}}%\n"
2771 "\\def\\VariableMemberList#1#2{%\n"
2772 "\\Defcs{#1DetailedDoc}##1{\\vskip 5.5mm\\relax##1}%\n"
2773 "\\Defcs{#1Name}##1{\\textbf{##1}}%\n"
2774 "\\Defcs{#1See}##1{\\See{##1}}%\n"
2776 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2777 "\\Member{#1}{\\Frame{\\Cs{field#1Type}{} \\Cs{field#1Name}}%\n"
2778 "\\Cs{field#1DetailedDoc}\\Cs{field#1See}\\vskip 5mm\\relax}}%\n"
2780 "\\def\\FunctionMemberList#1#2{%\n"
2781 "\\Defcs{#1PDParamName}##1{\\textit{##1}}%\n"
2782 "\\Defcs{#1PDParam}{\\Cs{field#1PDParamName}}%\n"
2783 "\\Defcs{#1PDParamsSep}{, }%\n"
2784 "\\Defcs{#1PDBlocksSep}{\\vskip 2mm\\relax}%\n"
2786 "\\Defcs{#1PDBlocks}##1{%\n"
2787 "\\Heading{Parameters:}\\vskip 1.5mm\\relax\n"
2788 "\\DimenA0pt\\relax\n"
2789 "\\Defcs{#1PDBlock}{\\setbox\\BoxA\\hbox{\\Cs{field#1PDParams}}%\n"
2790 "\\ifdim\\DimenA<\\wd\\BoxA\\DimenA\\wd\\BoxA\\fi}%\n"
2792 "\\advance\\DimenA3mm\\relax\n"
2793 "\\DimenB\\hsize\\advance\\DimenB-\\DimenA\\relax\n"
2794 "\\Defcs{#1PDBlock}{\\hbox to\\hsize{\\vtop{\\hsize\\DimenA\\relax\n"
2795 "\\Cs{field#1PDParams}}\\hfill\n"
2796 "\\vtop{\\hsize\\DimenB\\relax\\Cs{field#1PDDoc}}}}%\n"
2799 "\\Defcs{#1ParamName}##1{\\textit{##1}}\n"
2800 "\\Defcs{#1Param}{\\Cs{field#1ParamType}{} \\Cs{field#1ParamName}}\n"
2801 "\\Defcs{#1ParamsSep}{, }\n"
2803 "\\Defcs{#1Name}##1{\\textbf{##1}}\n"
2804 "\\Defcs{#1See}##1{\\See{##1}}\n"
2805 "\\Defcs{#1Return}##1{\\Heading{Returns: }##1}\n"
2806 "\\Defcs{field#1Title}{\\Frame{\\Cs{field#1Type}{} \\Cs{field#1Name}(\\Cs{field#1Params})}}%\n"
2808 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2810 "\\Cs{field#1Title}\\vskip 6mm\\relax\\Cs{field#1DetailedDoc}\n"
2811 "\\Cs{field#1Return}\\Cs{field#1PDBlocks}\\Cs{field#1See}\\vskip 5mm\\relax}}\n"
2813 "\\def\\FileDetailed{\\fieldFileDetailedDoc\\par}\n"
2814 "\\def\\ClassDetailed{\\fieldClassDetailedDoc\\par}\n"
2816 "\\def\\FileSubzones{\\fieldFileTypedefs\\fieldFileVariables\\fieldFileFunctions}\n"
2818 "\\def\\ClassSubzones{%\n"
2819 "\\fieldClassPublicTypedefs\\fieldClassPublicMembers\\fieldClassPublicMethods\n"
2820 "\\fieldClassProtectedTypedefs\\fieldClassProtectedMembers\\fieldClassProtectedMethods\n"
2821 "\\fieldClassPrivateTypedefs\\fieldClassPrivateMembers\\fieldClassPrivateMethods}\n"
2823 "\\Member{Page}{\\subsection{\\fieldPageName}\\fieldPageDetailedDoc}\n"
2825 "\\TypedefMemberList{FileTypedef}{Typedefs}\n"
2826 "\\VariableMemberList{FileVariable}{Variables}\n"
2827 "\\FunctionMemberList{FileFunction}{Functions}\n"
2828 "\\Zone{File}{\\FileSubzones}{\\subsection{\\fieldFileName}\\fieldFileDetailed\\FileSubzones}\n"
2830 "\\TypedefMemberList{ClassPublicTypedef}{Public Typedefs}\n"
2831 "\\TypedefMemberList{ClassProtectedTypedef}{Protected Typedefs}\n"
2832 "\\TypedefMemberList{ClassPrivateTypedef}{Private Typedefs}\n"
2833 "\\VariableMemberList{ClassPublicMember}{Public Members}\n"
2834 "\\VariableMemberList{ClassProtectedMember}{Protected Members}\n"
2835 "\\VariableMemberList{ClassPrivateMember}{Private Members}\n"
2836 "\\FunctionMemberList{ClassPublicMethod}{Public Methods}\n"
2837 "\\FunctionMemberList{ClassProtectedMethod}{Protected Methods}\n"
2838 "\\FunctionMemberList{ClassPrivateMethod}{Private Methods}\n"
2839 "\\Zone{Class}{\\ClassSubzones}{\\subsection{\\fieldClassName}\\fieldClassDetailed\\ClassSubzones}\n"
2841 "\\Zone{AllPages}{\\fieldPages}{\\section{Pages}\\fieldPages}\n"
2842 "\\Zone{AllFiles}{\\fieldFiles}{\\section{Files}\\fieldFiles}\n"
2843 "\\Zone{AllClasses}{\\fieldClasses}{\\section{Classes}\\fieldClasses}\n"
2845 "\\newlength{\\oldparskip}\n"
2846 "\\newlength{\\oldparindent}\n"
2847 "\\newlength{\\oldfboxrule}\n"
2849 "\\ZoneDepth0\\relax\n"
2850 "\\Letcs{Mode0}1\\relax\n"
2852 "\\def\\EmitDoxyDocs{%\n"
2853 "\\setlength{\\oldparskip}{\\parskip}\n"
2854 "\\setlength{\\oldparindent}{\\parindent}\n"
2855 "\\setlength{\\oldfboxrule}{\\fboxrule}\n"
2856 "\\setlength{\\parskip}{0cm}\n"
2857 "\\setlength{\\parindent}{0cm}\n"
2858 "\\setlength{\\fboxrule}{1pt}\n"
2859 "\\AllPages\\AllFiles\\AllClasses\n"
2860 "\\setlength{\\parskip}{\\oldparskip}\n"
2861 "\\setlength{\\parindent}{\\oldparindent}\n"
2862 "\\setlength{\\fboxrule}{\\oldfboxrule}}\n";
2869 std::ofstream doxyLatexTexStream;
2873 doxyLatexTexStream <<
2874 "\\documentclass[a4paper,12pt]{article}\n"
2875 "\\usepackage[latin1]{inputenc}\n"
2876 "\\usepackage[none]{hyphenat}\n"
2877 "\\usepackage[T1]{fontenc}\n"
2878 "\\usepackage{hyperref}\n"
2879 "\\usepackage{times}\n"
2881 "\\input{doxyformat}\n"
2883 "\\begin{document}\n"
2887 "\\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 QCString briefDescription(bool abbreviate=FALSE) const =0
virtual bool isAnonymous() const =0
virtual QCString documentation() 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.
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 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.
IDocParserPtr createDocParser()
factory function to create a parser
IDocNodeASTPtr validatingParseDoc(IDocParser &parserIntf, const QCString &fileName, int startLine, const Definition *ctx, const MemberDef *md, const QCString &input, bool indexWords, bool isExample, const QCString &exampleName, bool singleLine, bool linkFromIndex, bool markdownSupport)
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 const char * to_string_lower(Protection prot)
QCString filterTitle(const QCString &title)
A bunch of utility functions.