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;
619 m_output.addFieldQuotedString(
"style", style)
620 .addFieldBoolean(
"enable", s.
enable());
626 const char *type =
nullptr;
664 m_output.addFieldQuotedString(
"id", anchor);
670 const char *type =
nullptr;
705 parseCode(m_ci,op.context(),op.text(),
FALSE,0);
723 m_output.addFieldQuotedString(
"id",
id).addFieldQuotedString(
"content", f.
text());
734 "<secondaryie></secondaryie>"
771 m_output.addFieldQuotedString(
"style",
"Unchecked");
775 m_output.addFieldQuotedString(
"style",
"Checked");
808 const char *type =
nullptr;
830 err(
"unknown simple section found\n");
839 std::visit(*
this,*s.
title());
859 m_output.addFieldQuotedString(
"style",
"itemized");
883 std::visit(*
this,*s.
title());
895 for (
const auto &opt : l.
attribs())
897 if (opt.name==
"type")
901 if (opt.name==
"start")
914 for (
const auto &opt : l.
attribs())
916 if (opt.name==
"value")
940 m_output.add(
"<varlistentry><term>");
944 m_output.add(
"</term></varlistentry>\n");
967 std::visit(*
this,*t.
caption());
1042 auto summary =
details.summary();
1045 std::visit(*
this,*summary);
1078 if ((i=baseName.
findRev(
'/'))!=-1 || (i=baseName.
findRev(
'\\'))!=-1)
1191 const char *type =
nullptr;
1199 err(
"unknown parameter section found\n");
1218 m_output.openHash().openList(
"parameters");
1222 const DocWord *
word = std::get_if<DocWord>(¶m);
1223 const DocLinkedWord *linkedWord = std::get_if<DocLinkedWord>(¶m);
1226 name =
word->word();
1228 else if (linkedWord)
1230 name = linkedWord->
word();
1255 .addFieldQuotedString(
"name", name).addFieldQuotedString(
"dir", dir)
1262 std::visit(*
this,par);
1288 m_output.add(
"</xrefdescription>");
1330 output.
openList(
"template_parameters");
1334 if (!a.type.isEmpty())
1336 if (!a.name.isEmpty())
1339 if (!a.defval.isEmpty())
1376 auto astImpl =
dynamic_cast<const DocNodeAST*
>(ast.get());
1380 std::visit(visitor,astImpl->root);
1511 .addFieldQuotedString(
"kind", memType)
1512 .addFieldQuotedString(
"name", name)
1515 .addFieldBoolean(
"static", md->
isStatic());
1531 if (!declAl.
empty())
1533 auto defIt = al.
begin();
1537 if (defIt!=al.
end())
1544 if (!a.name.isEmpty())
1545 m_output.addFieldQuotedString(
"declaration_name", a.name);
1548 m_output.addFieldQuotedString(
"definition_name", defArg->
name);
1550 if (isFortran && defArg && !defArg->
type.
isEmpty())
1552 else if (!a.type.isEmpty())
1553 m_output.addFieldQuotedString(
"type", a.type);
1555 if (!a.array.isEmpty())
1556 m_output.addFieldQuotedString(
"array", a.array);
1558 if (!a.defval.isEmpty())
1559 m_output.addFieldQuotedString(
"default_value", a.defval);
1561 if (!a.attrib.isEmpty())
1562 m_output.addFieldQuotedString(
"attributes", a.attrib);
1576 .addFieldQuotedString(
"name", a.type)
1596 if (!enumFields.
empty())
1599 for (
const auto &emd : enumFields)
1602 .addFieldQuotedString(
"name", emd->name());
1604 if (!emd->initializer().isEmpty())
1605 m_output.addFieldQuotedString(
"initializer", emd->initializer());
1607 addPerlModDocBlock(
m_output,
"brief",emd->getDefFileName(),emd->getDefLine(),emd->getOuterScope(),emd,emd->briefDescription());
1609 addPerlModDocBlock(
m_output,
"detailed",emd->getDefFileName(),emd->getDefLine(),emd->getOuterScope(),emd,emd->documentation());
1620 if (bitfield.
at(0) ==
':') bitfield = bitfield.
mid(1);
1621 m_output.addFieldQuotedString(
"bitfield", bitfield);
1627 .addFieldQuotedString(
"name", rmd->
name())
1633 m_output.openList(
"reimplemented_by");
1634 for (
const auto &rbmd : rbml)
1636 .addFieldQuotedString(
"name", rbmd->name())
1647 if (ml==
nullptr)
return;
1652 m_output.addFieldQuotedString(
"header", header);
1655 for (
const auto &md : *ml)
1668 for (
auto &mi : *mni)
1674 .addFieldQuotedString(
"name", md->
name())
1678 if (!mi->ambiguityResolutionScope().isEmpty())
1679 m_output.addFieldQuotedString(
"ambiguity_scope", mi->ambiguityResolutionScope());
1693 for (
const auto &mg : mgl)
1696 if (!mg->header().isEmpty())
1698 m_output.addFieldQuotedString(
"header", mg->header());
1701 if (!mg->members().empty())
1704 for (
const auto &md : mg->members())
1726 .addFieldQuotedString(
"name", nm)
1755 .addFieldQuotedString(
"name", cd->
name());
1765 .addFieldQuotedString(
"name", bcd.classDef->displayName())
1779 .addFieldQuotedString(
"name", bcd.classDef->displayName())
1791 .addFieldQuotedString(
"name", icd->name())
1830 DotClassGraph inheritanceGraph(cd,DotClassGraph::Inheritance);
1833 t <<
" <inheritancegraph>" << endl;
1834 inheritanceGraph.writePerlMod(t);
1835 t <<
" </inheritancegraph>" << endl;
1837 DotClassGraph collaborationGraph(cd,DotClassGraph::Implementation);
1840 t <<
" <collaborationgraph>" << endl;
1841 collaborationGraph.writePerlMod(t);
1842 t <<
" </collaborationgraph>" << endl;
1844 t <<
" <location file=\""
1863 .addFieldQuotedString(
"name", cd->
name());
1889 .addFieldQuotedString(
"name", mod->
name());
1898 .addFieldQuotedString(
"name", cd->name())
1908 .addFieldQuotedString(
"name", cd->name())
1926 .addFieldQuotedString(
"name", fd->name())
1948 .addFieldQuotedString(
"name", nd->
name());
1955 .addFieldQuotedString(
"name", cd->name())
1965 .addFieldQuotedString(
"name", ind->name())
2004 .addFieldQuotedString(
"name", fd->
name());
2010 .addFieldQuotedString(
"name", inc.includeName);
2011 if (inc.fileDef && !inc.fileDef->isReference())
2013 m_output.addFieldQuotedString(
"ref", inc.fileDef->getOutputFileBase());
2023 .addFieldQuotedString(
"name", inc.includeName);
2024 if (inc.fileDef && !inc.fileDef->isReference())
2026 m_output.addFieldQuotedString(
"ref", inc.fileDef->getOutputFileBase());
2064 .addFieldQuotedString(
"name", gd->
name())
2065 .addFieldQuotedString(
"title", gd->
groupTitle());
2070 for (
const auto &fd : gd->
getFiles())
2072 .addFieldQuotedString(
"name", fd->name())
2082 .addFieldQuotedString(
"name", cd->name())
2092 .addFieldQuotedString(
"name", cd->name())
2102 .addFieldQuotedString(
"name", mod->name())
2112 .addFieldQuotedString(
"name", nd->name())
2120 for (
const auto &pd : gd->
getPages())
2122 .addFieldQuotedString(
"title", pd->title())
2132 .addFieldQuotedString(
"title", sgd->groupTitle())
2161 .addFieldQuotedString(
"name", pd->
name());
2173 std::ofstream outputFileStream;
2178 m_output.setPerlModOutputStream(&outputStream);
2179 m_output.add(
"$doxydocs=").openHash();
2204 for (
const auto &fd : *fn)
2229 m_output.closeHash().add(
";\n1;\n");
2239 err(
"Cannot open file %s for writing!\n",
qPrint(s));
2248 perlModDir.
setPath(outputDirectory+
"/perlmod");
2249 if (!perlModDir.
exists() && !perlModDir.
mkdir(outputDirectory+
"/perlmod"))
2251 err(
"Could not create perlmod directory in %s\n",outputDirectory.data());
2259 std::ofstream doxyModelPMStream;
2263 doxyModelPMStream <<
2264 "sub memberlist($) {\n"
2265 " my $prefix = $_[0];\n"
2267 "\t[ \"hash\", $prefix . \"s\",\n"
2270 "\t [ \"list\", $prefix . \"List\",\n"
2271 "\t\t[ \"hash\", $prefix,\n"
2273 "\t\t kind => [ \"string\", $prefix . \"Kind\" ],\n"
2274 "\t\t name => [ \"string\", $prefix . \"Name\" ],\n"
2275 "\t\t static => [ \"string\", $prefix . \"Static\" ],\n"
2276 "\t\t virtualness => [ \"string\", $prefix . \"Virtualness\" ],\n"
2277 "\t\t protection => [ \"string\", $prefix . \"Protection\" ],\n"
2278 "\t\t type => [ \"string\", $prefix . \"Type\" ],\n"
2279 "\t\t parameters =>\n"
2280 "\t\t [ \"list\", $prefix . \"Params\",\n"
2281 "\t\t\t[ \"hash\", $prefix . \"Param\",\n"
2283 "\t\t\t declaration_name => [ \"string\", $prefix . \"ParamName\" ],\n"
2284 "\t\t\t type => [ \"string\", $prefix . \"ParamType\" ],\n"
2288 "\t\t detailed =>\n"
2289 "\t\t [ \"hash\", $prefix . \"Detailed\",\n"
2291 "\t\t\t doc => [ \"doc\", $prefix . \"DetailedDoc\" ],\n"
2292 "\t\t\t return => [ \"doc\", $prefix . \"Return\" ],\n"
2293 "\t\t\t see => [ \"doc\", $prefix . \"See\" ],\n"
2294 "\t\t\t params =>\n"
2295 "\t\t\t [ \"list\", $prefix . \"PDBlocks\",\n"
2296 "\t\t\t [ \"hash\", $prefix . \"PDBlock\",\n"
2298 "\t\t\t\t parameters =>\n"
2299 "\t\t\t\t [ \"list\", $prefix . \"PDParams\",\n"
2300 "\t\t\t\t [ \"hash\", $prefix . \"PDParam\",\n"
2302 "\t\t\t\t\t name => [ \"string\", $prefix . \"PDParamName\" ],\n"
2306 "\t\t\t\t doc => [ \"doc\", $prefix . \"PDDoc\" ],\n"
2319 "$doxystructure =\n"
2320 " [ \"hash\", \"Root\",\n"
2323 "\t [ \"list\", \"Files\",\n"
2324 "\t [ \"hash\", \"File\",\n"
2326 "\t\tname => [ \"string\", \"FileName\" ],\n"
2327 "\t\ttypedefs => memberlist(\"FileTypedef\"),\n"
2328 "\t\tvariables => memberlist(\"FileVariable\"),\n"
2329 "\t\tfunctions => memberlist(\"FileFunction\"),\n"
2331 "\t\t [ \"hash\", \"FileDetailed\",\n"
2333 "\t\t doc => [ \"doc\", \"FileDetailedDoc\" ],\n"
2340 "\t [ \"list\", \"Pages\",\n"
2341 "\t [ \"hash\", \"Page\",\n"
2343 "\t\tname => [ \"string\", \"PageName\" ],\n"
2345 "\t\t [ \"hash\", \"PageDetailed\",\n"
2347 "\t\t doc => [ \"doc\", \"PageDetailedDoc\" ],\n"
2354 "\t [ \"list\", \"Classes\",\n"
2355 "\t [ \"hash\", \"Class\",\n"
2357 "\t\tname => [ \"string\", \"ClassName\" ],\n"
2358 "\t\tpublic_typedefs => memberlist(\"ClassPublicTypedef\"),\n"
2359 "\t\tpublic_methods => memberlist(\"ClassPublicMethod\"),\n"
2360 "\t\tpublic_members => memberlist(\"ClassPublicMember\"),\n"
2361 "\t\tprotected_typedefs => memberlist(\"ClassProtectedTypedef\"),\n"
2362 "\t\tprotected_methods => memberlist(\"ClassProtectedMethod\"),\n"
2363 "\t\tprotected_members => memberlist(\"ClassProtectedMember\"),\n"
2364 "\t\tprivate_typedefs => memberlist(\"ClassPrivateTypedef\"),\n"
2365 "\t\tprivate_methods => memberlist(\"ClassPrivateMethod\"),\n"
2366 "\t\tprivate_members => memberlist(\"ClassPrivateMember\"),\n"
2368 "\t\t [ \"hash\", \"ClassDetailed\",\n"
2370 "\t\t doc => [ \"doc\", \"ClassDetailedDoc\" ],\n"
2377 "\t [ \"list\", \"Groups\",\n"
2378 "\t [ \"hash\", \"Group\",\n"
2380 "\t\tname => [ \"string\", \"GroupName\" ],\n"
2381 "\t\ttitle => [ \"string\", \"GroupTitle\" ],\n"
2383 "\t\t [ \"list\", \"Files\",\n"
2384 "\t\t [ \"hash\", \"File\",\n"
2386 "\t\t name => [ \"string\", \"Filename\" ]\n"
2391 "\t\t [ \"list\", \"Classes\",\n"
2392 "\t\t [ \"hash\", \"Class\",\n"
2394 "\t\t name => [ \"string\", \"Classname\" ]\n"
2398 "\t\tnamespaces =>\n"
2399 "\t\t [ \"list\", \"Namespaces\",\n"
2400 "\t\t [ \"hash\", \"Namespace\",\n"
2402 "\t\t name => [ \"string\", \"NamespaceName\" ]\n"
2407 "\t\t [ \"list\", \"Pages\",\n"
2408 "\t\t [ \"hash\", \"Page\","
2410 "\t\t title => [ \"string\", \"PageName\" ]\n"
2415 "\t\t [ \"list\", \"Groups\",\n"
2416 "\t\t [ \"hash\", \"Group\",\n"
2418 "\t\t title => [ \"string\", \"GroupName\" ]\n"
2422 "\t\tfunctions => memberlist(\"GroupFunction\"),\n"
2424 "\t\t [ \"hash\", \"GroupDetailed\",\n"
2426 "\t\t doc => [ \"doc\", \"GroupDetailedDoc\" ],\n"
2442 std::ofstream doxyRulesStream;
2468 ".PHONY: clean-perlmod\n"
2470 "\trm -f $(" <<
prefix <<
"DOXYSTRUCTURE_PM) \\\n"
2471 "\t$(" <<
prefix <<
"DOXYDOCS_PM)";
2475 "\t$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2476 "\t$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2477 "\t$(" <<
prefix <<
"DOXYDOCS_TEX) \\\n"
2478 "\t$(" <<
prefix <<
"DOXYSTRUCTURE_TEX) \\\n"
2479 "\t$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2480 "\t$(" <<
prefix <<
"DOXYLATEX_TEX) \\\n"
2481 "\t$(" <<
prefix <<
"DOXYLATEX_PDF) \\\n"
2482 "\t$(" <<
prefix <<
"DOXYLATEX_DVI) \\\n"
2483 "\t$(addprefix $(" <<
prefix <<
"DOXYLATEX_TEX:tex=),out aux log)";
2484 doxyRulesStream <<
"\n\n";
2487 "$(" <<
prefix <<
"DOXYRULES) \\\n"
2488 "$(" <<
prefix <<
"DOXYMAKEFILE) \\\n"
2489 "$(" <<
prefix <<
"DOXYSTRUCTURE_PM) \\\n"
2490 "$(" <<
prefix <<
"DOXYDOCS_PM)";
2494 "$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2495 "$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2496 "$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2497 "$(" <<
prefix <<
"DOXYLATEX_TEX)";
2501 "\t$(" <<
prefix <<
"DOXYFILE)\n"
2502 "\tcd $(" <<
prefix <<
"DOXY_EXEC_PATH) ; doxygen \"$<\"\n";
2507 "$(" <<
prefix <<
"DOXYDOCS_TEX): \\\n"
2508 "$(" <<
prefix <<
"DOXYLATEX_PL) \\\n"
2509 "$(" <<
prefix <<
"DOXYDOCS_PM)\n"
2510 "\tperl -I\"$(<D)\" \"$<\" >\"$@\"\n"
2512 "$(" <<
prefix <<
"DOXYSTRUCTURE_TEX): \\\n"
2513 "$(" <<
prefix <<
"DOXYLATEXSTRUCTURE_PL) \\\n"
2514 "$(" <<
prefix <<
"DOXYSTRUCTURE_PM)\n"
2515 "\tperl -I\"$(<D)\" \"$<\" >\"$@\"\n"
2517 "$(" <<
prefix <<
"DOXYLATEX_PDF) \\\n"
2518 "$(" <<
prefix <<
"DOXYLATEX_DVI): \\\n"
2519 "$(" <<
prefix <<
"DOXYLATEX_TEX) \\\n"
2520 "$(" <<
prefix <<
"DOXYFORMAT_TEX) \\\n"
2521 "$(" <<
prefix <<
"DOXYSTRUCTURE_TEX) \\\n"
2522 "$(" <<
prefix <<
"DOXYDOCS_TEX)\n"
2524 "$(" <<
prefix <<
"DOXYLATEX_PDF): \\\n"
2525 "$(" <<
prefix <<
"DOXYLATEX_TEX)\n"
2526 "\tpdflatex -interaction=nonstopmode \"$<\"\n"
2528 "$(" <<
prefix <<
"DOXYLATEX_DVI): \\\n"
2529 "$(" <<
prefix <<
"DOXYLATEX_TEX)\n"
2530 "\tlatex -interaction=nonstopmode \"$<\"\n";
2538 std::ofstream makefileStream;
2546 ".PHONY: default clean" << (perlmodLatex ?
" pdf" :
"") <<
"\n"
2547 "default: " << (perlmodLatex ?
"pdf" :
"clean") <<
"\n"
2551 "clean: clean-perlmod\n";
2555 "pdf: $(" <<
prefix <<
"DOXYLATEX_PDF)\n"
2556 "dvi: $(" <<
prefix <<
"DOXYLATEX_DVI)\n";
2564 std::ofstream doxyLatexStructurePLStream;
2568 doxyLatexStructurePLStream <<
2569 "use DoxyStructure;\n"
2571 "sub process($) {\n"
2572 "\tmy $node = $_[0];\n"
2573 "\tmy ($type, $name) = @$node[0, 1];\n"
2575 "\tif ($type eq \"string\") { $command = \"String\" }\n"
2576 "\telsif ($type eq \"doc\") { $command = \"Doc\" }\n"
2577 "\telsif ($type eq \"hash\") {\n"
2578 "\t\t$command = \"Hash\";\n"
2579 "\t\tfor my $subnode (values %{$$node[2]}) {\n"
2580 "\t\t\tprocess($subnode);\n"
2583 "\telsif ($type eq \"list\") {\n"
2584 "\t\t$command = \"List\";\n"
2585 "\t\tprocess($$node[2]);\n"
2587 "\tprint \"\\\\\" . $command . \"Node{\" . $name . \"}%\\n\";\n"
2590 "process($doxystructure);\n";
2597 std::ofstream doxyLatexPLStream;
2601 doxyLatexPLStream <<
2602 "use DoxyStructure;\n"
2605 "sub latex_quote($) {\n"
2606 "\tmy $text = $_[0];\n"
2607 "\t$text =~ s/\\\\/\\\\textbackslash /g;\n"
2608 "\t$text =~ s/\\|/\\\\textbar /g;\n"
2609 "\t$text =~ s/</\\\\textless /g;\n"
2610 "\t$text =~ s/>/\\\\textgreater /g;\n"
2611 "\t$text =~ s/~/\\\\textasciitilde /g;\n"
2612 "\t$text =~ s/\\^/\\\\textasciicircum /g;\n"
2613 "\t$text =~ s/[\\$&%#_{}]/\\\\$&/g;\n"
2617 "sub generate_doc($) {\n"
2618 "\tmy $doc = $_[0];\n"
2619 "\tfor my $item (@$doc) {\n"
2620 "\t\tmy $type = $$item{type};\n"
2621 "\t\tif ($type eq \"text\") {\n"
2622 "\t\t\tlatex_quote($$item{content});\n"
2623 "\t\t} elsif ($type eq \"parbreak\") {\n"
2624 "\t\t\tprint \"\\n\\n\";\n"
2625 "\t\t} elsif ($type eq \"style\") {\n"
2626 "\t\t\tmy $style = $$item{style};\n"
2627 "\t\t\tif ($$item{enable} eq \"yes\") {\n"
2628 "\t\t\t\tif ($style eq \"bold\") { print '\\bfseries'; }\n"
2629 "\t\t\t\tif ($style eq \"italic\") { print '\\itshape'; }\n"
2630 "\t\t\t\tif ($style eq \"code\") { print '\\ttfamily'; }\n"
2632 "\t\t\t\tif ($style eq \"bold\") { print '\\mdseries'; }\n"
2633 "\t\t\t\tif ($style eq \"italic\") { print '\\upshape'; }\n"
2634 "\t\t\t\tif ($style eq \"code\") { print '\\rmfamily'; }\n"
2636 "\t\t\tprint '{}';\n"
2637 "\t\t} elsif ($type eq \"symbol\") {\n"
2638 "\t\t\tmy $symbol = $$item{symbol};\n"
2639 "\t\t\tif ($symbol eq \"copyright\") { print '\\copyright'; }\n"
2640 "\t\t\telsif ($symbol eq \"szlig\") { print '\\ss'; }\n"
2641 "\t\t\tprint '{}';\n"
2642 "\t\t} elsif ($type eq \"accent\") {\n"
2643 "\t\t\tmy ($accent) = $$item{accent};\n"
2644 "\t\t\tif ($accent eq \"umlaut\") { print '\\\"'; }\n"
2645 "\t\t\telsif ($accent eq \"acute\") { print '\\\\\\''; }\n"
2646 "\t\t\telsif ($accent eq \"grave\") { print '\\`'; }\n"
2647 "\t\t\telsif ($accent eq \"circ\") { print '\\^'; }\n"
2648 "\t\t\telsif ($accent eq \"tilde\") { print '\\~'; }\n"
2649 "\t\t\telsif ($accent eq \"cedilla\") { print '\\c'; }\n"
2650 "\t\t\telsif ($accent eq \"ring\") { print '\\r'; }\n"
2651 "\t\t\tprint \"{\" . $$item{letter} . \"}\"; \n"
2652 "\t\t} elsif ($type eq \"list\") {\n"
2653 "\t\t\tmy $env = ($$item{style} eq \"ordered\") ? \"enumerate\" : \"itemize\";\n"
2654 "\t\t\tprint \"\\n\\\\begin{\" . $env .\"}\";\n"
2655 "\t\t \tfor my $subitem (@{$$item{content}}) {\n"
2656 "\t\t\t\tprint \"\\n\\\\item \";\n"
2657 "\t\t\t\tgenerate_doc($subitem);\n"
2659 "\t\t\tprint \"\\n\\\\end{\" . $env .\"}\";\n"
2660 "\t\t} elsif ($type eq \"url\") {\n"
2661 "\t\t\tlatex_quote($$item{content});\n"
2666 "sub generate($$) {\n"
2667 "\tmy ($item, $node) = @_;\n"
2668 "\tmy ($type, $name) = @$node[0, 1];\n"
2669 "\tif ($type eq \"string\") {\n"
2670 "\t\tprint \"\\\\\" . $name . \"{\";\n"
2671 "\t\tlatex_quote($item);\n"
2672 "\t\tprint \"}\";\n"
2673 "\t} elsif ($type eq \"doc\") {\n"
2674 "\t\tif (@$item) {\n"
2675 "\t\t\tprint \"\\\\\" . $name . \"{\";\n"
2676 "\t\t\tgenerate_doc($item);\n"
2677 "\t\t\tprint \"}%\\n\";\n"
2679 "#\t\t\tprint \"\\\\\" . $name . \"Empty%\\n\";\n"
2681 "\t} elsif ($type eq \"hash\") {\n"
2682 "\t\tmy ($key, $value);\n"
2683 "\t\twhile (($key, $subnode) = each %{$$node[2]}) {\n"
2684 "\t\t\tmy $subname = $$subnode[1];\n"
2685 "\t\t\tprint \"\\\\Defcs{field\" . $subname . \"}{\";\n"
2686 "\t\t\tif ($$item{$key}) {\n"
2687 "\t\t\t\tgenerate($$item{$key}, $subnode);\n"
2689 "#\t\t\t\t\tprint \"\\\\\" . $subname . \"Empty%\\n\";\n"
2691 "\t\t\tprint \"}%\\n\";\n"
2693 "\t\tprint \"\\\\\" . $name . \"%\\n\";\n"
2694 "\t} elsif ($type eq \"list\") {\n"
2695 "\t\tmy $index = 0;\n"
2696 "\t\tif (@$item) {\n"
2697 "\t\t\tprint \"\\\\\" . $name . \"{%\\n\";\n"
2698 "\t\t\tfor my $subitem (@$item) {\n"
2699 "\t\t\t\tif ($index) {\n"
2700 "\t\t\t\t\tprint \"\\\\\" . $name . \"Sep%\\n\";\n"
2702 "\t\t\t\tgenerate($subitem, $$node[2]);\n"
2703 "\t\t\t\t$index++;\n"
2705 "\t\t\tprint \"}%\\n\";\n"
2707 "#\t\t\tprint \"\\\\\" . $name . \"Empty%\\n\";\n"
2712 "generate($doxydocs, $doxystructure);\n";
2719 std::ofstream doxyFormatTexStream;
2723 doxyFormatTexStream <<
2724 "\\def\\Defcs#1{\\long\\expandafter\\def\\csname#1\\endcsname}\n"
2725 "\\Defcs{Empty}{}\n"
2726 "\\def\\IfEmpty#1{\\expandafter\\ifx\\csname#1\\endcsname\\Empty}\n"
2728 "\\def\\StringNode#1{\\Defcs{#1}##1{##1}}\n"
2729 "\\def\\DocNode#1{\\Defcs{#1}##1{##1}}\n"
2730 "\\def\\ListNode#1{\\Defcs{#1}##1{##1}\\Defcs{#1Sep}{}}\n"
2731 "\\def\\HashNode#1{\\Defcs{#1}{}}\n"
2736 "\\dimendef\\DimenA=151\\relax\n"
2737 "\\dimendef\\DimenB=152\\relax\n"
2738 "\\countdef\\ZoneDepth=151\\relax\n"
2740 "\\def\\Cs#1{\\csname#1\\endcsname}\n"
2741 "\\def\\Letcs#1{\\expandafter\\let\\csname#1\\endcsname}\n"
2742 "\\def\\Heading#1{\\vskip 4mm\\relax\\textbf{#1}}\n"
2743 "\\def\\See#1{\\begin{flushleft}\\Heading{See also: }#1\\end{flushleft}}\n"
2745 "\\def\\Frame#1{\\vskip 3mm\\relax\\fbox{ \\vbox{\\hsize0.95\\hsize\\vskip 1mm\\relax\n"
2746 "\\raggedright#1\\vskip 0.5mm\\relax} }}\n"
2748 "\\def\\Zone#1#2#3{%\n"
2749 "\\Defcs{Test#1}{#2}%\n"
2750 "\\Defcs{Emit#1}{#3}%\n"
2752 "\\advance\\ZoneDepth1\\relax\n"
2753 "\\Letcs{Mode\\number\\ZoneDepth}0\\relax\n"
2754 "\\Letcs{Present\\number\\ZoneDepth}0\\relax\n"
2756 "\\expandafter\\if\\Cs{Present\\number\\ZoneDepth}1%\n"
2757 "\\advance\\ZoneDepth-1\\relax\n"
2758 "\\Letcs{Present\\number\\ZoneDepth}1\\relax\n"
2759 "\\expandafter\\if\\Cs{Mode\\number\\ZoneDepth}1%\n"
2760 "\\advance\\ZoneDepth1\\relax\n"
2761 "\\Letcs{Mode\\number\\ZoneDepth}1\\relax\n"
2763 "\\advance\\ZoneDepth-1\\relax\\fi\n"
2764 "\\advance\\ZoneDepth1\\relax\\fi\n"
2765 "\\advance\\ZoneDepth-1\\relax}}\n"
2767 "\\def\\Member#1#2{%\n"
2768 "\\Defcs{Test#1}{\\Cs{field#1Detailed}\n"
2769 "\\IfEmpty{field#1DetailedDoc}\\else\\Letcs{Present#1}1\\fi}\n"
2770 "\\Defcs{#1}{\\Letcs{Present#1}0\\relax\n"
2771 "\\Cs{Test#1}\\if1\\Cs{Present#1}\\Letcs{Present\\number\\ZoneDepth}1\\relax\n"
2772 "\\if1\\Cs{Mode\\number\\ZoneDepth}#2\\fi\\fi}}\n"
2774 "\\def\\TypedefMemberList#1#2{%\n"
2775 "\\Defcs{#1DetailedDoc}##1{\\vskip 5.5mm\\relax##1}%\n"
2776 "\\Defcs{#1Name}##1{\\textbf{##1}}%\n"
2777 "\\Defcs{#1See}##1{\\See{##1}}%\n"
2779 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2780 "\\Member{#1}{\\Frame{typedef \\Cs{field#1Type} \\Cs{field#1Name}}%\n"
2781 "\\Cs{field#1DetailedDoc}\\Cs{field#1See}\\vskip 5mm\\relax}}%\n"
2783 "\\def\\VariableMemberList#1#2{%\n"
2784 "\\Defcs{#1DetailedDoc}##1{\\vskip 5.5mm\\relax##1}%\n"
2785 "\\Defcs{#1Name}##1{\\textbf{##1}}%\n"
2786 "\\Defcs{#1See}##1{\\See{##1}}%\n"
2788 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2789 "\\Member{#1}{\\Frame{\\Cs{field#1Type}{} \\Cs{field#1Name}}%\n"
2790 "\\Cs{field#1DetailedDoc}\\Cs{field#1See}\\vskip 5mm\\relax}}%\n"
2792 "\\def\\FunctionMemberList#1#2{%\n"
2793 "\\Defcs{#1PDParamName}##1{\\textit{##1}}%\n"
2794 "\\Defcs{#1PDParam}{\\Cs{field#1PDParamName}}%\n"
2795 "\\Defcs{#1PDParamsSep}{, }%\n"
2796 "\\Defcs{#1PDBlocksSep}{\\vskip 2mm\\relax}%\n"
2798 "\\Defcs{#1PDBlocks}##1{%\n"
2799 "\\Heading{Parameters:}\\vskip 1.5mm\\relax\n"
2800 "\\DimenA0pt\\relax\n"
2801 "\\Defcs{#1PDBlock}{\\setbox\\BoxA\\hbox{\\Cs{field#1PDParams}}%\n"
2802 "\\ifdim\\DimenA<\\wd\\BoxA\\DimenA\\wd\\BoxA\\fi}%\n"
2804 "\\advance\\DimenA3mm\\relax\n"
2805 "\\DimenB\\hsize\\advance\\DimenB-\\DimenA\\relax\n"
2806 "\\Defcs{#1PDBlock}{\\hbox to\\hsize{\\vtop{\\hsize\\DimenA\\relax\n"
2807 "\\Cs{field#1PDParams}}\\hfill\n"
2808 "\\vtop{\\hsize\\DimenB\\relax\\Cs{field#1PDDoc}}}}%\n"
2811 "\\Defcs{#1ParamName}##1{\\textit{##1}}\n"
2812 "\\Defcs{#1Param}{\\Cs{field#1ParamType}{} \\Cs{field#1ParamName}}\n"
2813 "\\Defcs{#1ParamsSep}{, }\n"
2815 "\\Defcs{#1Name}##1{\\textbf{##1}}\n"
2816 "\\Defcs{#1See}##1{\\See{##1}}\n"
2817 "\\Defcs{#1Return}##1{\\Heading{Returns: }##1}\n"
2818 "\\Defcs{field#1Title}{\\Frame{\\Cs{field#1Type}{} \\Cs{field#1Name}(\\Cs{field#1Params})}}%\n"
2820 "\\Zone{#1s}{\\Cs{field#1List}}{\\subsubsection{#2}\\Cs{field#1List}}%\n"
2822 "\\Cs{field#1Title}\\vskip 6mm\\relax\\Cs{field#1DetailedDoc}\n"
2823 "\\Cs{field#1Return}\\Cs{field#1PDBlocks}\\Cs{field#1See}\\vskip 5mm\\relax}}\n"
2825 "\\def\\FileDetailed{\\fieldFileDetailedDoc\\par}\n"
2826 "\\def\\ClassDetailed{\\fieldClassDetailedDoc\\par}\n"
2828 "\\def\\FileSubzones{\\fieldFileTypedefs\\fieldFileVariables\\fieldFileFunctions}\n"
2830 "\\def\\ClassSubzones{%\n"
2831 "\\fieldClassPublicTypedefs\\fieldClassPublicMembers\\fieldClassPublicMethods\n"
2832 "\\fieldClassProtectedTypedefs\\fieldClassProtectedMembers\\fieldClassProtectedMethods\n"
2833 "\\fieldClassPrivateTypedefs\\fieldClassPrivateMembers\\fieldClassPrivateMethods}\n"
2835 "\\Member{Page}{\\subsection{\\fieldPageName}\\fieldPageDetailedDoc}\n"
2837 "\\TypedefMemberList{FileTypedef}{Typedefs}\n"
2838 "\\VariableMemberList{FileVariable}{Variables}\n"
2839 "\\FunctionMemberList{FileFunction}{Functions}\n"
2840 "\\Zone{File}{\\FileSubzones}{\\subsection{\\fieldFileName}\\fieldFileDetailed\\FileSubzones}\n"
2842 "\\TypedefMemberList{ClassPublicTypedef}{Public Typedefs}\n"
2843 "\\TypedefMemberList{ClassProtectedTypedef}{Protected Typedefs}\n"
2844 "\\TypedefMemberList{ClassPrivateTypedef}{Private Typedefs}\n"
2845 "\\VariableMemberList{ClassPublicMember}{Public Members}\n"
2846 "\\VariableMemberList{ClassProtectedMember}{Protected Members}\n"
2847 "\\VariableMemberList{ClassPrivateMember}{Private Members}\n"
2848 "\\FunctionMemberList{ClassPublicMethod}{Public Methods}\n"
2849 "\\FunctionMemberList{ClassProtectedMethod}{Protected Methods}\n"
2850 "\\FunctionMemberList{ClassPrivateMethod}{Private Methods}\n"
2851 "\\Zone{Class}{\\ClassSubzones}{\\subsection{\\fieldClassName}\\fieldClassDetailed\\ClassSubzones}\n"
2853 "\\Zone{AllPages}{\\fieldPages}{\\section{Pages}\\fieldPages}\n"
2854 "\\Zone{AllFiles}{\\fieldFiles}{\\section{Files}\\fieldFiles}\n"
2855 "\\Zone{AllClasses}{\\fieldClasses}{\\section{Classes}\\fieldClasses}\n"
2857 "\\newlength{\\oldparskip}\n"
2858 "\\newlength{\\oldparindent}\n"
2859 "\\newlength{\\oldfboxrule}\n"
2861 "\\ZoneDepth0\\relax\n"
2862 "\\Letcs{Mode0}1\\relax\n"
2864 "\\def\\EmitDoxyDocs{%\n"
2865 "\\setlength{\\oldparskip}{\\parskip}\n"
2866 "\\setlength{\\oldparindent}{\\parindent}\n"
2867 "\\setlength{\\oldfboxrule}{\\fboxrule}\n"
2868 "\\setlength{\\parskip}{0cm}\n"
2869 "\\setlength{\\parindent}{0cm}\n"
2870 "\\setlength{\\fboxrule}{1pt}\n"
2871 "\\AllPages\\AllFiles\\AllClasses\n"
2872 "\\setlength{\\parskip}{\\oldparskip}\n"
2873 "\\setlength{\\parindent}{\\oldparindent}\n"
2874 "\\setlength{\\fboxrule}{\\oldfboxrule}}\n";
2881 std::ofstream doxyLatexTexStream;
2885 doxyLatexTexStream <<
2886 "\\documentclass[a4paper,12pt]{article}\n"
2887 "\\usepackage[latin1]{inputenc}\n"
2888 "\\usepackage[none]{hyphenat}\n"
2889 "\\usepackage[T1]{fontenc}\n"
2890 "\\usepackage{hyperref}\n"
2891 "\\usepackage{times}\n"
2893 "\\input{doxyformat}\n"
2895 "\\begin{document}\n"
2899 "\\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 const MemberGroupList & getMemberGroups() const =0
Returns the member groups defined for this class.
virtual const ClassDef * templateMaster() const =0
Returns the template master of which this class is an instance.
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
Find an object given the key.
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.
Protection
Protection level of members.
Specifier
Virtualness of a member.
QCString filterTitle(const QCString &title)
A bunch of utility functions.