summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDimitri van Heesch <dimitri@stack.nl>2015-11-15 15:25:43 (GMT)
committerDimitri van Heesch <dimitri@stack.nl>2015-11-22 13:00:36 (GMT)
commit499ecaedf1ee1222535be27f77050ee633595685 (patch)
tree7447d83589769002d0793224a2b13b2a2569af42 /src
parentc5a7911741850777b699a63ae5b7702e379a5ada (diff)
downloadDoxygen-499ecaedf1ee1222535be27f77050ee633595685.zip
Doxygen-499ecaedf1ee1222535be27f77050ee633595685.tar.gz
Doxygen-499ecaedf1ee1222535be27f77050ee633595685.tar.bz2
Fixed problem with latex and PDF bookmarks
Diffstat (limited to 'src')
-rw-r--r--src/latexgen.cpp83
-rwxr-xr-xsrc/util.cpp23
-rwxr-xr-xsrc/util.h1
3 files changed, 34 insertions, 73 deletions
diff --git a/src/latexgen.cpp b/src/latexgen.cpp
index d8a3220..60bf2ba 100644
--- a/src/latexgen.cpp
+++ b/src/latexgen.cpp
@@ -682,7 +682,7 @@ static void writeDefaultHeaderPart1(FTextStream &t)
// To avoid duplicate page anchors due to reuse of same numbers for
// the index (be it as roman numbers)
t << "\\hypersetup{pageanchor=false,\n"
- << " bookmarks=true,\n"
+ // << " bookmarks=true,\n" // commented out to prevent warning
<< " bookmarksnumbered=true,\n"
<< " pdfencoding=unicode\n"
<< " }\n";
@@ -1569,13 +1569,22 @@ void LatexGenerator::startMemberDoc(const char *clname,
}
static const char *levelLab[] = { "subsubsection","paragraph","subparagraph", "subparagraph" };
static bool compactLatex = Config_getBool("COMPACT_LATEX");
+ static bool pdfHyperlinks = Config_getBool("PDF_HYPERLINKS");
int level=0;
if (showInline) level+=2;
if (compactLatex) level++;
t << "\\" << levelLab[level];
t << "[{";
+ if (pdfHyperlinks)
+ {
+ t << "\\texorpdfstring{";
+ }
t << latexEscapeIndexChars(title,insideTabbing);
+ if (pdfHyperlinks)
+ {
+ t << "}{" << latexEscapePDFString(title) << "}";
+ }
t << "}]";
t << "{\\setlength{\\rightskip}{0pt plus 5cm}";
disableLinks=TRUE;
@@ -2088,78 +2097,6 @@ void LatexGenerator::endConstraintList()
t << "\\end{Desc}" << endl;
}
-#if 0
-void LatexGenerator::escapeLabelName(const char *s)
-{
- if (s==0) return;
- const char *p=s;
- char c;
- QCString result(qstrlen(s)+1); // worst case allocation
- int i;
- while ((c=*p++))
- {
- switch (c)
- {
- case '|': t << "\\texttt{\"|}"; break;
- case '!': t << "\"!"; break;
- case '%': t << "\\%"; break;
- case '{': t << "\\lcurly{}"; break;
- case '}': t << "\\rcurly{}"; break;
- case '~': t << "````~"; break; // to get it a bit better in index together with other special characters
- // NOTE: adding a case here, means adding it to while below as well!
- default:
- i=0;
- // collect as long string as possible, before handing it to docify
- result[i++]=c;
- while ((c=*p) && c!='|' && c!='!' && c!='%' && c!='{' && c!='}' && c!='~')
- {
- result[i++]=c;
- p++;
- }
- result[i]=0;
- docify(result);
- break;
- }
- }
-}
-
-void LatexGenerator::escapeMakeIndexChars(const char *s)
-{
- if (s==0) return;
- const char *p=s;
- char c;
- QCString result(qstrlen(s)+1); // worst case allocation
- int i;
- while ((c=*p++))
- {
- switch (c)
- {
- case '!': t << "\"!"; break;
- case '"': t << "\"\""; break;
- case '@': t << "\"@"; break;
- case '|': t << "\\texttt{\"|}"; break;
- case '[': t << "["; break;
- case ']': t << "]"; break;
- case '{': t << "\\lcurly{}"; break;
- case '}': t << "\\rcurly{}"; break;
- // NOTE: adding a case here, means adding it to while below as well!
- default:
- i=0;
- // collect as long string as possible, before handing it to docify
- result[i++]=c;
- while ((c=*p) && c!='"' && c!='@' && c!='[' && c!=']' && c!='!' && c!='{' && c!='}' && c!='|')
- {
- result[i++]=c;
- p++;
- }
- result[i]=0;
- docify(result);
- break;
- }
- }
-}
-#endif
-
void LatexGenerator::startCodeFragment()
{
t << "\n\\begin{DoxyCode}\n";
diff --git a/src/util.cpp b/src/util.cpp
index 8472f3a..a032fe2 100755
--- a/src/util.cpp
+++ b/src/util.cpp
@@ -6713,6 +6713,29 @@ QCString latexEscapeIndexChars(const char *s,bool insideTabbing)
return result.data();
}
+QCString latexEscapePDFString(const char *s)
+{
+ QGString result;
+ FTextStream t(&result);
+ const char *p=s;
+ char c;
+ int i;
+ while ((c=*p++))
+ {
+ switch (c)
+ {
+ case '\\': t << "\\textbackslash{}"; break;
+ case '{': t << "\\{"; break;
+ case '}': t << "\\}"; break;
+ default:
+ t << c;
+ break;
+ }
+ }
+ return result.data();
+}
+
+
QCString rtfFormatBmkStr(const char *name)
{
static QCString g_nextTag( "AAAAAAAAAA" );
diff --git a/src/util.h b/src/util.h
index 51a5da1..3f976e3 100755
--- a/src/util.h
+++ b/src/util.h
@@ -344,6 +344,7 @@ void filterLatexString(FTextStream &t,const char *str,
QCString latexEscapeLabelName(const char *s,bool insideTabbing);
QCString latexEscapeIndexChars(const char *s,bool insideTabbing);
+QCString latexEscapePDFString(const char *s);
QCString rtfFormatBmkStr(const char *name);