Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
D
doxverilog
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
Elphel
doxverilog
Commits
9d98e802
Commit
9d98e802
authored
Jan 28, 2001
by
Dimitri van Heesch
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Release-1.2.4-20010128
parent
cbf50dc7
Changes
30
Show whitespace changes
Inline
Side-by-side
Showing
30 changed files
with
449 additions
and
194 deletions
+449
-194
INSTALL
INSTALL
+2
-2
README
README
+2
-2
VERSION
VERSION
+1
-1
config_templ.l
addon/configgen/config_templ.l
+5
-1
configgen.cpp
addon/configgen/configgen.cpp
+10
-1
Makefile.in
addon/xmlgen/Makefile.in
+2
-2
config.doc
doc/config.doc
+9
-0
doxygen.spec
packages/rpm/doxygen.spec
+1
-1
classdef.cpp
src/classdef.cpp
+18
-5
config.h
src/config.h
+2
-2
config.l
src/config.l
+23
-27
constexp.y
src/constexp.y
+1
-1
definition.cpp
src/definition.cpp
+5
-2
doc.l
src/doc.l
+9
-9
doxygen.cpp
src/doxygen.cpp
+3
-2
groupdef.cpp
src/groupdef.cpp
+70
-53
groupdef.h
src/groupdef.h
+3
-2
index.cpp
src/index.cpp
+66
-38
index.h
src/index.h
+1
-0
main.cpp
src/main.cpp
+18
-0
outputgen.h
src/outputgen.h
+1
-1
pre.l
src/pre.l
+2
-2
scanner.l
src/scanner.l
+3
-1
section.h
src/section.h
+2
-1
tagreader.cpp
src/tagreader.cpp
+31
-11
translator.h
src/translator.h
+92
-12
translator_cz.h
src/translator_cz.h
+64
-13
translator_de.h
src/translator_de.h
+1
-1
translator_nl.h
src/translator_nl.h
+1
-1
util.cpp
src/util.cpp
+1
-0
No files found.
INSTALL
View file @
9d98e802
DOXYGEN Version 1.2.4-2001012
1
DOXYGEN Version 1.2.4-2001012
8
Please read the installation section of the manual for instructions.
--------
Dimitri van Heesch (2
1
January 2001)
Dimitri van Heesch (2
8
January 2001)
README
View file @
9d98e802
DOXYGEN Version 1.2.4-2001012
1
DOXYGEN Version 1.2.4-2001012
8
Please read INSTALL for compilation instructions.
...
...
@@ -7,4 +7,4 @@ The latest version of doxygen can be obtained at
Enjoy,
Dimitri van Heesch (2
1
January 2001)
Dimitri van Heesch (2
8
January 2001)
VERSION
View file @
9d98e802
1.2.4-2001012
1
1.2.4-2001012
8
addon/configgen/config_templ.l
View file @
9d98e802
...
...
@@ -950,9 +950,13 @@ void checkConfig()
}
}
#undef PUTENV
#if defined(_WIN32)
if (Config::haveDotFlag) _putenv("DOTFONTPATH=.");
#define PUTENV _putenv
#else
#define PUTENV putenv
#endif
if (Config::haveDotFlag) PUTENV("DOTFONTPATH=.");
}
...
...
addon/configgen/configgen.cpp
View file @
9d98e802
...
...
@@ -1046,6 +1046,15 @@ void init()
"will result in a user defined paragraph with heading
\"
Side Effects:
\"
.
\n
"
"You can put
\\
n's in the value part of an alias to insert newlines.
\n
"
);
ConfigBool
::
add
(
"optimizeForCFlag"
,
"OPTIMIZE_OUTPUT_FOR_C"
,
"FALSE"
,
"do we parse C code?"
,
"Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C sources
\n
"
"only. Doxygen will then generate output that is more tailored for C.
\n
"
"For instance some of the names that are used will be different. The list
\n
"
"of all members will be omitted, etc.
\n
"
);
//-----------------------------------------------------------------------------------------------
ConfigInfo
::
add
(
"Messages"
,
"configuration options related to warning and progress messages"
);
//-----------------------------------------------------------------------------------------------
...
...
@@ -1306,7 +1315,7 @@ void init()
"GENERATE_TREEVIEW"
,
"FALSE"
,
"should a folder tree view be generated?"
,
"If the GENERATE_TREEVIEW tag is set to YES, a side pan
n
el will be
\n
"
"If the GENERATE_TREEVIEW tag is set to YES, a side panel will be
\n
"
"generated containing a tree-like index structure (just like the one that
\n
"
"is generated for HTML Help). For this to work a browser that supports
\n
"
"JavaScript and frames is required (for instance Netscape 4.0+
\n
"
...
...
addon/xmlgen/Makefile.in
View file @
9d98e802
...
...
@@ -5,8 +5,8 @@ distclean: clean
$(RM)
-f
Makefile.xmlgen
tmake
:
export
TMAKEPATH
=
$(TMAKEPATH)
;
$(PERL)
$(TMAKE)
xmlgen.pro
>
Makefile.xmlgen
$(ENV)
$(PERL)
$(TMAKE)
xmlgen.pro
>
Makefile.xmlgen
Makefile.xmlgen
:
xmlgen.pro
export
TMAKEPATH
=
$(TMAKEPATH)
;
$(PERL)
$(TMAKE)
xmlgen.pro
>
Makefile.xmlgen
$(ENV)
$(PERL)
$(TMAKE)
xmlgen.pro
>
Makefile.xmlgen
doc/config.doc
View file @
9d98e802
...
...
@@ -140,6 +140,7 @@ followed by the descriptions of the tags grouped by category.
<
li
>
\
refitem
cfg_man_output
MAN_OUTPUT
<
li
>
\
refitem
cfg_max_dot_graph_height
MAX_DOT_GRAPH_HEIGHT
<
li
>
\
refitem
cfg_max_dot_graph_width
MAX_DOT_GRAPH_WIDTH
<
li
>
\
refitem
cfg_optimize_output_for_c
OPTIMIZE_OUTPUT_FOR_C
<
li
>
\
refitem
cfg_output_directory
OUTPUT_DIRECTORY
<
li
>
\
refitem
cfg_output_language
OUTPUT_LANGUAGE
<
li
>
\
refitem
cfg_paper_type
PAPER_TYPE
...
...
@@ -445,6 +446,14 @@ followed by the descriptions of the tags grouped by category.
will
result
in
a
user
defined
paragraph
with
heading
"Side Effects:"
.
You
can
put
\\
n
's in the value part of an alias to insert newlines.
\anchor cfg_optimize_output_for_c
<dt>\c OPTIMIZE_OUTPUT_FOR_C
\addindex OPTIMIZE_OUTPUT_FOR_C
Set the \c OPTIMIZE_OUTPUT_FOR_C tag to \c YES if your project consists
of C sources only. Doxygen will then generate output that is more tailored
for C. For instance some of the names that are used will be different.
The list of all members will be omitted, etc.
</dl>
\subsection messages_input Options related to warning and progress messages
...
...
packages/rpm/doxygen.spec
View file @
9d98e802
Name: doxygen
Version: 1.2.4-2001012
1
Version: 1.2.4-2001012
8
Summary: documentation system for C, C++ and IDL
Release: 1
Source0: doxygen-%{version}.src.tar.gz
...
...
src/classdef.cpp
View file @
9d98e802
...
...
@@ -897,7 +897,7 @@ void ClassDef::writeDocumentation(OutputList &ol)
}
// write link to list of all members (HTML only)
if
(
allMemberNameInfoList
->
count
()
>
0
/*&& compType==Class*/
)
if
(
allMemberNameInfoList
->
count
()
>
0
&&
!
Config
::
optimizeForCFlag
)
{
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
ol
.
startTextLink
(
memListFileName
,
0
);
...
...
@@ -1179,7 +1179,7 @@ void ClassDef::writeDocumentation(OutputList &ol)
// write the list of all (inherited) members for this class
void
ClassDef
::
writeMemberList
(
OutputList
&
ol
)
{
if
(
allMemberNameInfoList
->
count
()
==
0
)
return
;
if
(
allMemberNameInfoList
->
count
()
==
0
||
Config
::
optimizeForCFlag
)
return
;
// only for HTML
ol
.
pushGeneratorState
();
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
...
...
@@ -1208,7 +1208,6 @@ void ClassDef::writeMemberList(OutputList &ol)
if
(
mi
->
prot
==
Protected
)
// inherited protection
{
if
(
protect
==
Public
)
protect
=
Protected
;
else
if
(
protect
==
Protected
)
protect
=
Private
;
}
//printf("Member %s of class %s mi->prot=%d prot=%d\n",
...
...
@@ -1646,11 +1645,25 @@ void ClassDef::mergeMembers()
MemberInfo
*
mi
;
for
(;(
mi
=
mnii
.
current
());
++
mnii
)
{
if
(
mi
->
memberDef
->
protection
()
!=
Private
)
Protection
prot
=
mi
->
memberDef
->
protection
();
if
(
bcd
->
prot
==
Protected
)
{
if
(
prot
==
Public
)
prot
=
Protected
;
}
else
if
(
bcd
->
prot
==
Private
)
{
prot
=
Private
;
}
//printf("%s::%s: prot=%d bcd->prot=%d result=%d\n",
// name().data(),mi->memberDef->name().data(),mi->memberDef->protection(),
// bcd->prot,prot);
if
(
prot
!=
Private
)
{
Specifier
virt
=
mi
->
virt
;
if
(
mi
->
virt
==
Normal
&&
bcd
->
virt
!=
Normal
)
virt
=
bcd
->
virt
;
MemberInfo
*
newMi
=
new
MemberInfo
(
mi
->
memberDef
,
bcd
->
prot
,
virt
);
MemberInfo
*
newMi
=
new
MemberInfo
(
mi
->
memberDef
,
prot
,
virt
);
newMi
->
scopePath
=
bClass
->
name
()
+
"::"
+
mi
->
scopePath
;
newMi
->
ambigClass
=
mi
->
ambigClass
;
newMi
->
ambiguityResolutionScope
=
mi
->
ambiguityResolutionScope
.
copy
();
...
...
src/config.h
View file @
9d98e802
/* This file was generated by configgen on S
un Jan 14 14:24:47
2001
/* This file was generated by configgen on S
at Jan 27 18:27:32
2001
* from config_templ.h
*
* DO NOT EDIT!
...
...
@@ -70,6 +70,7 @@ struct Config
static
bool
generateTodoList
;
// do we want a todo list?
static
bool
generateTestList
;
// do we want a test list?
static
QStrList
aliasList
;
// list of aliases
static
bool
optimizeForCFlag
;
// do we parse C code?
static
bool
quietFlag
;
// generate progress messages flag
static
bool
warningFlag
;
// generate warnings flag
static
bool
warningUndocFlag
;
// generate undocumented warnings
...
...
@@ -116,7 +117,6 @@ struct Config
static
bool
generateMan
;
// generate Man pages
static
QCString
manOutputDir
;
// the directory to put the man pages
static
QCString
manExtension
;
// extension the man page files
static
bool
generateXML
;
// generate XML output
static
bool
preprocessingFlag
;
// enable preprocessing
static
bool
macroExpansionFlag
;
// expand macros in the source.
static
bool
onlyPredefinedFlag
;
// expand only predefined macros
...
...
src/config.l
View file @
9d98e802
/* This file was generated by configgen on S
un Jan 14 14:24:47
2001
/* This file was generated by configgen on S
at Jan 27 18:27:33
2001
* from config_templ.l
*
* DO NOT EDIT!
...
...
@@ -107,6 +107,7 @@ QStrList Config::sectionFilterList;
bool Config::generateTodoList = TRUE;
bool Config::generateTestList = TRUE;
QStrList Config::aliasList;
bool Config::optimizeForCFlag = FALSE;
bool Config::quietFlag = FALSE;
bool Config::warningFlag = TRUE;
bool Config::warningUndocFlag = TRUE;
...
...
@@ -153,7 +154,6 @@ QCString Config::rtfStylesheetFile;
bool Config::generateMan = TRUE;
QCString Config::manOutputDir = "man";
QCString Config::manExtension = ".3";
bool Config::generateXML = FALSE;
bool Config::preprocessingFlag = TRUE;
bool Config::macroExpansionFlag = FALSE;
bool Config::onlyPredefinedFlag = FALSE;
...
...
@@ -379,6 +379,7 @@ static void readIncludeFile(const char *incName)
<Start>"GENERATE_TESTLIST"[ \t]*"=" { BEGIN(GetBool); b=&Config::generateTestList; }
<Start>"ALIASES"[ \t]*"=" { BEGIN(GetStrList); l=&Config::aliasList; l->clear(); elemStr=""; }
<Start>"ALIASES"[ \t]*"+=" { BEGIN(GetStrList); l=&Config::aliasList; elemStr=""; }
<Start>"OPTIMIZE_OUTPUT_FOR_C"[ \t]*"=" { BEGIN(GetBool); b=&Config::optimizeForCFlag; }
<Start>"QUIET"[ \t]*"=" { BEGIN(GetBool); b=&Config::quietFlag; }
<Start>"WARNINGS"[ \t]*"=" { BEGIN(GetBool); b=&Config::warningFlag; }
<Start>"WARN_IF_UNDOCUMENTED"[ \t]*"=" { BEGIN(GetBool); b=&Config::warningUndocFlag; }
...
...
@@ -434,7 +435,6 @@ static void readIncludeFile(const char *incName)
<Start>"GENERATE_MAN"[ \t]*"=" { BEGIN(GetBool); b=&Config::generateMan; }
<Start>"MAN_OUTPUT"[ \t]*"=" { BEGIN(GetString); s=&Config::manOutputDir; s->resize(0); }
<Start>"MAN_EXTENSION"[ \t]*"=" { BEGIN(GetString); s=&Config::manExtension; s->resize(0); }
<Start>"GENERATE_XML"[ \t]*"=" { BEGIN(GetBool); b=&Config::generateXML; }
<Start>"ENABLE_PREPROCESSING"[ \t]*"=" { BEGIN(GetBool); b=&Config::preprocessingFlag; }
<Start>"MACRO_EXPANSION"[ \t]*"=" { BEGIN(GetBool); b=&Config::macroExpansionFlag; }
<Start>"EXPAND_ONLY_PREDEF"[ \t]*"=" { BEGIN(GetBool); b=&Config::onlyPredefinedFlag; }
...
...
@@ -628,6 +628,7 @@ void dumpConfig()
is=Config::aliasList.next();
}
}
printf("optimizeForCFlag=`%d'\n",Config::optimizeForCFlag);
printf("# configuration options related to warning and progress messages\n");
printf("quietFlag=`%d'\n",Config::quietFlag);
printf("warningFlag=`%d'\n",Config::warningFlag);
...
...
@@ -744,8 +745,6 @@ void dumpConfig()
printf("generateMan=`%d'\n",Config::generateMan);
printf("manOutputDir=`%s'\n",Config::manOutputDir.data());
printf("manExtension=`%s'\n",Config::manExtension.data());
printf("# configuration options related to the XML output\n");
printf("generateXML=`%d'\n",Config::generateXML);
printf("# Configuration options related to the preprocessor \n");
printf("preprocessingFlag=`%d'\n",Config::preprocessingFlag);
printf("macroExpansionFlag=`%d'\n",Config::macroExpansionFlag);
...
...
@@ -858,6 +857,7 @@ void Config::init()
Config::generateTodoList = TRUE;
Config::generateTestList = TRUE;
Config::aliasList.clear();
Config::optimizeForCFlag = FALSE;
Config::quietFlag = FALSE;
Config::warningFlag = TRUE;
Config::warningUndocFlag = TRUE;
...
...
@@ -904,7 +904,6 @@ void Config::init()
Config::generateMan = TRUE;
Config::manOutputDir = "man";
Config::manExtension = ".3";
Config::generateXML = FALSE;
Config::preprocessingFlag = TRUE;
Config::macroExpansionFlag = FALSE;
Config::onlyPredefinedFlag = FALSE;
...
...
@@ -1383,6 +1382,18 @@ void writeTemplateConfig(QFile *f,bool sl)
writeStringList(t,Config::aliasList);
t << "\n";
if (!sl)
{
t << "\n";
t << "# Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C sources \n";
t << "# only. Doxygen will then generate output that is more tailored for C. \n";
t << "# For instance some of the names that are used will be different. The list \n";
t << "# of all members will be omitted, etc. \n";
t << "\n";
}
t << "OPTIMIZE_OUTPUT_FOR_C = ";
writeBoolValue(t,Config::optimizeForCFlag);
t << "\n";
if (!sl)
{
t << "\n";
}
...
...
@@ -1717,7 +1728,7 @@ void writeTemplateConfig(QFile *f,bool sl)
if (!sl)
{
t << "\n";
t << "# If the GENERATE_TREEVIEW tag is set to YES, a side pan
n
el will be\n";
t << "# If the GENERATE_TREEVIEW tag is set to YES, a side panel will be\n";
t << "# generated containing a tree-like index structure (just like the one that \n";
t << "# is generated for HTML Help). For this to work a browser that supports \n";
t << "# JavaScript and frames is required (for instance Netscape 4.0+ \n";
...
...
@@ -1953,25 +1964,6 @@ void writeTemplateConfig(QFile *f,bool sl)
t << "\n";
}
t << "#---------------------------------------------------------------------------\n";
t << "# configuration options related to the XML output\n";
t << "#---------------------------------------------------------------------------\n";
if (!sl)
{
t << "\n";
t << "# If the GENERATE_XML tag is set to YES Doxygen will \n";
t << "# generate an XML file that captures the structure of \n";
t << "# the code including all documentation. Warning: This feature \n";
t << "# is still experimental and very incomplete.\n";
t << "\n";
}
t << "GENERATE_XML = ";
writeBoolValue(t,Config::generateXML);
t << "\n";
if (!sl)
{
t << "\n";
}
t << "#---------------------------------------------------------------------------\n";
t << "# Configuration options related to the preprocessor \n";
t << "#---------------------------------------------------------------------------\n";
if (!sl)
...
...
@@ -2912,9 +2904,13 @@ void checkConfig()
}
}
#undef PUTENV
#if defined(_WIN32)
if (Config::haveDotFlag) _putenv("DOTFONTPATH=.");
#define PUTENV _putenv
#else
#define PUTENV putenv
#endif
if (Config::haveDotFlag) PUTENV("DOTFONTPATH=.");
}
...
...
src/constexp.y
View file @
9d98e802
...
...
@@ -32,7 +32,7 @@
int cppExpYYerror(const char *s)
{
printf("E
RROR
: %s\n",s);
printf("E
rror in constant expression evaluation
: %s\n",s);
return 0;
}
...
...
src/definition.cpp
View file @
9d98e802
...
...
@@ -115,11 +115,14 @@ void Definition::writeDocAnchorsToTagFile()
QDictIterator
<
SectionInfo
>
sdi
(
*
sectionDict
);
SectionInfo
*
si
;
for
(;(
si
=
sdi
.
current
());
++
sdi
)
{
if
(
!
si
->
generated
)
{
if
(
definitionType
()
==
TypeMember
)
Doxygen
::
tagFile
<<
" "
;
Doxygen
::
tagFile
<<
" <docanchor>"
<<
si
->
label
<<
"</docanchor>"
<<
endl
;
}
}
}
}
...
...
src/doc.l
View file @
9d98e802
...
...
@@ -1514,6 +1514,10 @@ OPMASK ({B}*{OPNORM}({OPARG}?))|({OPCAST}{OPARG})
outDoc->endSection(sec->label,
sec->type==SectionInfo::Subsection);
}
else
{
warn(yyFileName,yyLineNr,"Warning: reference to unknown section %s in the documentation of this entity!",yytext);
}
}
<DocScan>{CMD}"anchor "{ID}"\n" {
QCString secName=&yytext[8];
...
...
@@ -1580,8 +1584,10 @@ OPMASK ({B}*{OPNORM}({OPARG}?))|({OPCAST}{OPARG})
<DocRefName>{SCOPENAME}|{FILE} {
QCString ref=yytext;
SectionInfo *sec;
//printf(">>> ref `%s'\n",yytext);
if ((sec=Doxygen::sectionDict[ref]))
{
//printf("Is a section!\n");
QCString text;
if (sec->title.isEmpty())
text=sec->label;
...
...
@@ -1598,7 +1604,7 @@ OPMASK ({B}*{OPNORM}({OPARG}?))|({OPCAST}{OPARG})
else
{
//printf(" ref sec=%p sec->fileName=%s text=%s\n",sec,sec->fileName.data(),text.data());
outDoc->writeSectionRef(sec->
fileName,sec->label,text,sec->ref
);
outDoc->writeSectionRef(sec->
ref,sec->fileName,sec->label,text
);
}
}
else if (!generateLink(*outDoc,className,yytext,TRUE,0))
...
...
@@ -1631,7 +1637,7 @@ OPMASK ({B}*{OPNORM}({OPARG}?))|({OPCAST}{OPARG})
}
else
{
outDoc->writeSectionRef(sec->
fileName,sec->label,text,sec->ref
);
outDoc->writeSectionRef(sec->
ref,sec->fileName,sec->label,text
);
}
}
else if (!generateLink(*outDoc,className,sectionRef,TRUE,text))
...
...
@@ -1744,13 +1750,7 @@ OPMASK ({B}*{OPNORM}({OPARG}?))|({OPCAST}{OPARG})
generateRef(*outDoc,className,yytext,inSeeBlock);
BEGIN(DocScan);
}
<DocScan,DocRefName>({SCOPEMASK}"::")?"operator()"("("[a-z_A-Z0-9,\<\> \t\*\&]*")")? {
QCString oName=yytext;
generateRef(*outDoc,className,
removeRedundantWhiteSpace(oName),inSeeBlock);
BEGIN(DocScan);
}
<DocScan,DocRefName>({SCOPEMASK}"::")?"operator"[^(\r\n.,]+("("[a-z_A-Z0-9,\<\> \t\*\&]*")")? {
<DocScan,DocRefName>({SCOPEMASK}"::")?"operator"{OPMASK} {
QCString oName=yytext;
generateRef(*outDoc,className,
removeRedundantWhiteSpace(oName),inSeeBlock);
...
...
src/doxygen.cpp
View file @
9d98e802
...
...
@@ -2522,7 +2522,7 @@ static void addTodoTestReferences()
GroupDef
*
gd
=
Doxygen
::
groupList
.
first
();
while
(
gd
)
{
addRefItem
(
gd
->
todoId
(),
gd
->
testId
(),
"group"
,
gd
->
getOutputFileBase
(),
gd
->
nam
e
());
addRefItem
(
gd
->
todoId
(),
gd
->
testId
(),
"group"
,
gd
->
getOutputFileBase
(),
gd
->
groupTitl
e
());
gd
=
Doxygen
::
groupList
.
next
();
}
PageSDictIterator
pdi
(
*
Doxygen
::
pageSDict
);
...
...
@@ -4798,6 +4798,7 @@ static void resolveUserReferences()
if
(
si
->
label
.
left
(
5
)
==
"_todo"
||
si
->
label
.
left
(
5
)
==
"_test"
)
{
si
->
fileName
=
si
->
label
.
mid
(
1
,
4
);
// extract "todo" or "test"
si
->
generated
=
TRUE
;
}
}
}
...
...
@@ -4839,7 +4840,7 @@ static void generatePageDocs()
endFile
(
*
outputList
);
outputList
->
enable
(
OutputGenerator
::
Man
);
if
(
!
Config
::
genTagFile
.
isEmpty
())
if
(
!
Config
::
genTagFile
.
isEmpty
()
&&
pi
->
name
!=
"todo"
&&
pi
->
name
!=
"test"
)
{
Doxygen
::
tagFile
<<
" <compound kind=
\"
page
\"
>"
<<
endl
;
Doxygen
::
tagFile
<<
" <name>"
<<
pi
->
name
<<
"</name>"
<<
endl
;
...
...
src/groupdef.cpp
View file @
9d98e802
...
...
@@ -42,7 +42,7 @@ GroupDef::GroupDef(const char *df,int dl,const char *na,const char *t) :
pageDict
=
new
PageSDict
(
257
);
exampleDict
=
new
PageSDict
(
257
);
allMemberList
=
new
MemberList
;
allMember
Dict
=
new
QDict
<
MemberDef
>
;
allMember
NameInfoDict
=
new
MemberNameInfoDict
(
1009
)
;
if
(
t
)
title
=
t
;
else
...
...
@@ -67,7 +67,7 @@ GroupDef::~GroupDef()
delete
pageDict
;
delete
exampleDict
;
delete
allMemberList
;
delete
allMemberDict
;
delete
allMember
NameInfo
Dict
;
delete
memberGroupList
;
delete
memberGroupDict
;
}
...
...
@@ -161,11 +161,29 @@ void GroupDef::addMembersToMemberGroup()
void
GroupDef
::
insertMember
(
MemberDef
*
md
)
{
QCString
funcDecl
=
md
->
name
()
+
md
->
argsString
();
if
(
allMemberDict
->
find
(
funcDecl
)
==
0
)
//printf("GroupDef::insertMember(%s)\n",md->name().data());
MemberNameInfo
*
mni
=
0
;
if
((
mni
=
(
*
allMemberNameInfoDict
)[
md
->
name
()]))
{
// member with this name already found
MemberNameInfoIterator
srcMnii
(
*
mni
);
MemberInfo
*
srcMi
;
for
(
;
(
srcMi
=
srcMnii
.
current
())
;
++
srcMnii
)
{
MemberDef
*
srcMd
=
srcMi
->
memberDef
;
if
(
matchArguments
(
srcMd
->
argumentList
(),
md
->
argumentList
()))
{
return
;
// member already added
}
}
mni
->
append
(
new
MemberInfo
(
md
,
Public
,
Normal
));
}
else
{
mni
=
new
MemberNameInfo
(
md
->
name
());
mni
->
append
(
new
MemberInfo
(
md
,
Public
,
Normal
));
allMemberNameInfoDict
->
insert
(
mni
->
memberName
(),
mni
);
}
allMemberList
->
append
(
md
);
allMemberDict
->
insert
(
funcDecl
,
md
);
switch
(
md
->
memberType
())
{
case
MemberDef
:
:
Variable
:
...
...
@@ -214,7 +232,6 @@ void GroupDef::insertMember(MemberDef *md)
err
(
"FileDef::insertMembers(): unexpected member insert in file!
\n
"
);
}
//addMemberToGroup(md,groupId);
}
}
void
GroupDef
::
addGroup
(
const
GroupDef
*
def
)
...
...
src/groupdef.h
View file @
9d98e802
...
...
@@ -36,6 +36,7 @@ class OutputList;
class
NamespaceList
;
class
MemberGroupList
;
class
MemberGroupDict
;
class
MemberNameInfoDict
;
class
PageSDict
;
class
PageInfo
;
...
...
@@ -86,8 +87,8 @@ class GroupDef : public Definition
PageSDict
*
pageDict
;
// list of pages in the group
PageSDict
*
exampleDict
;
// list of examples in the group
MemberList
*
allMemberList
;
// list of all members in the group
QDict
<
MemberDef
>
*
allMember
Dict
;
MemberList
*
allMemberList
;
MemberNameInfoDict
*
allMemberNameInfo
Dict
;
// members sorted by type
MemberList
defineMembers
;
...
...
src/index.cpp
View file @
9d98e802
...
...
@@ -49,6 +49,7 @@ int documentedNamespaces;
int
documentedNamespaceMembers
;
int
documentedIncludeFiles
;
int
documentedPages
;
int
indexedPages
;
int
documentedPackages
;
int
countClassHierarchy
();
...
...
@@ -60,7 +61,7 @@ int countNamespaces();
int
countAnnotatedClasses
();
int
countNamespaceMembers
();
int
countIncludeFiles
();
int
countRelatedPages
(
);
void
countRelatedPages
(
int
&
docPages
,
int
&
indexPages
);
int
countPackages
();
void
countDataStructures
()
...
...
@@ -70,10 +71,10 @@ void countDataStructures()
documentedMembers
=
countClassMembers
();
documentedFunctions
=
countFileMembers
();
countFiles
(
documentedHtmlFiles
,
documentedFiles
);
countRelatedPages
(
documentedPages
,
indexedPages
);
documentedGroups
=
countGroups
();
documentedNamespaces
=
countNamespaces
();
documentedNamespaceMembers
=
countNamespaceMembers
();
documentedPages
=
countRelatedPages
();
documentedPackages
=
countPackages
();
}
...
...
@@ -249,7 +250,7 @@ void writeQuickLinks(OutputList &ol,bool compact ,bool ext=FALSE)
parseText
(
ol
,
theTranslator
->
trFileMembers
());
ol
.
endQuickIndexItem
();
}
if
(
document
edPages
>
0
)
if
(
index
edPages
>
0
)
{
if
(
!
compact
)
ol
.
writeListItem
();
ol
.
startQuickIndexItem
(
extLink
,
"pages.html"
);
...
...
@@ -780,6 +781,8 @@ void writeFileIndex(OutputList &ol)
OutputNameList
outputNameList
;
outputNameList
.
setAutoDelete
(
TRUE
);
if
(
Config
::
fullPathNameFlag
)
{
// re-sort input files in (dir,file) output order instead of (file,dir) input order
FileName
*
fn
=
Doxygen
::
inputNameList
.
first
();
while
(
fn
)
...
...
@@ -807,9 +810,18 @@ void writeFileIndex(OutputList &ol)
}
fn
=
Doxygen
::
inputNameList
.
next
();
}
}
ol
.
startIndexList
();
FileList
*
fl
=
outputNameList
.
first
();
FileList
*
fl
=
0
;
if
(
Config
::
fullPathNameFlag
)
{
fl
=
outputNameList
.
first
();
}
else
{
fl
=
Doxygen
::
inputNameList
.
first
();
}
while
(
fl
)
{
FileDef
*
fd
=
fl
->
first
();
...
...
@@ -910,8 +922,15 @@ void writeFileIndex(OutputList &ol)
}
fd
=
fl
->
next
();
}
if
(
Config
::
fullPathNameFlag
)
{
fl
=
outputNameList
.
next
();
}
else
{
fl
=
Doxygen
::
inputNameList
.
next
();
}
}
ol
.
endIndexList
();
if
(
hasHtmlHelp
)
{
...
...
@@ -1944,16 +1963,19 @@ void writeExampleIndex(OutputList &ol)
//----------------------------------------------------------------------------
int
countRelatedPages
(
)
void
countRelatedPages
(
int
&
docPages
,
int
&
indexPages
)
{
int
count
=
0
;
docPages
=
indexPages
=
0
;
PageSDictIterator
pdi
(
*
Doxygen
::
pageSDict
);
PageInfo
*
pi
=
0
;
for
(
pdi
.
toFirst
();(
pi
=
pdi
.
current
());
++
pdi
)
{
if
(
!
pi
->
inGroup
&&
!
pi
->
isReference
())
count
++
;
if
(
!
pi
->
inGroup
)
{
indexPages
++
;
if
(
!
pi
->
isReference
())
docPages
++
;
}
}
return
count
;
}
//----------------------------------------------------------------------------
...
...
@@ -1977,7 +1999,7 @@ int countPackages()
void
writePageIndex
(
OutputList
&
ol
)
{
if
(
document
edPages
==
0
)
return
;
if
(
index
edPages
==
0
)
return
;
ol
.
pushGeneratorState
();
ol
.
disable
(
OutputGenerator
::
Man
);
startFile
(
ol
,
"pages"
,
"Page Index"
);
...
...
@@ -2013,7 +2035,7 @@ void writePageIndex(OutputList &ol)
PageInfo
*
pi
=
0
;
for
(
pdi
.
toFirst
();(
pi
=
pdi
.
current
());
++
pdi
)
{
if
(
!
pi
->
inGroup
&&
!
pi
->
isReference
()
)
if
(
!
pi
->
inGroup
/*&& !pi->isReference()*/
)
{
QCString
pageName
,
pageTitle
;
...
...
@@ -2027,10 +2049,16 @@ void writePageIndex(OutputList &ol)
else
pageTitle
=
pi
->
title
;
//ol.writeListItem();
ol
.
writeStartAnnoItem
(
"pages"
,
pageName
,
0
,
pageTitle
);
//ol.writeObjectLink(0,pageName,0,pageTitle);
ol
.
writeEndAnnoItem
(
pageName
);
ol
.
writeIndexItem
(
pi
->
getReference
(),
pi
->
getOutputFileBase
(),
pageTitle
);
if
(
pi
->
isReference
())
{
ol
.
startTypewriter
();
ol
.
docify
(
" [external]"
);
ol
.
endTypewriter
();
}
//ol.writeStartAnnoItem("pages",pageName,0,pageTitle);
////ol.writeObjectLink(0,pageName,0,pageTitle);
//ol.writeEndAnnoItem(pageName);
ol
.
writeString
(
"
\n
"
);
if
(
hasHtmlHelp
)
htmlHelp
->
addContentsItem
(
FALSE
,
pageTitle
,
pageName
);
if
(
hasFtvHelp
)
ftvHelp
->
addContentsItem
(
FALSE
,
0
,
pageName
,
0
,
pageTitle
);
...
...
@@ -2535,7 +2563,7 @@ void writeIndex(OutputList &ol)
parseText
(
ol
,
projPrefix
+
theTranslator
->
trFileIndex
());
ol
.
endIndexSection
(
isFileIndex
);
}
if
(
document
edPages
>
0
)
if
(
index
edPages
>
0
)
{
ol
.
startIndexSection
(
isPageIndex
);
parseText
(
ol
,
projPrefix
+
theTranslator
->
trPageIndex
());
...
...
@@ -2578,7 +2606,7 @@ void writeIndex(OutputList &ol)
parseText
(
ol
,
projPrefix
+
theTranslator
->
trExampleDocumentation
());
ol
.
endIndexSection
(
isExampleDocumentation
);
}
if
(
Doxygen
::
pageSDict
->
count
()
>
0
)
if
(
documentedPages
>
0
)
{
ol
.
startIndexSection
(
isPageDocumentation
);
parseText
(
ol
,
projPrefix
+
theTranslator
->
trPageDocumentation
());
...
...
src/index.h
View file @
9d98e802
...
...
@@ -81,6 +81,7 @@ extern int documentedNamespaces;
extern
int
documentedNamespaceMembers
;
extern
int
documentedIncludeFiles
;
extern
int
documentedPages
;
extern
int
indexedPages
;
extern
int
documentedPackages
;
void
startTitle
(
OutputList
&
ol
,
const
char
*
fileName
);
...
...
src/main.cpp
View file @
9d98e802
/******************************************************************************
*
*
*
*
* Copyright (C) 1997-2001 by Dimitri van Heesch.
*
* Permission to use, copy, modify, and distribute this software and its
* documentation under the terms of the GNU General Public License is hereby
* granted. No representations are made about the suitability of this software
* for any purpose. It is provided "as is" without express or implied warranty.
* See the GNU General Public License for more details.
*
* Documents produced by Doxygen are derivative works derived from the
* input used in their production; they are not affected by this license.
*
*/
#include "doxygen.h"
/*! \file
...
...
src/outputgen.h
View file @
9d98e802
...
...
@@ -368,7 +368,7 @@ class OutputGenerator : public BaseOutputDocInterface
QStack
<
bool
>
*
genStack
;
};
/*! \brief
Base
Interface used for generating documentation.
/*! \brief Interface used for generating documentation.
*
* This abstract class is used by the documentation block
* parser to generate the output for a specific format.
...
...
src/pre.l
View file @
9d98e802
...
...
@@ -1242,7 +1242,7 @@ BN [ \t\r\n]
<Command>.
<UndefName>{ID} {
Define *def;
if ((def=isDefined(yytext)))
if ((def=isDefined(yytext))
&& !def->isPredefined
)
{
//printf("undefining %s\n",yytext);
def->undef=TRUE;
...
...
src/scanner.l
View file @
9d98e802
...
...
@@ -273,6 +273,7 @@ static void addSection()
warn(yyFileName,yyLineNr,
"Warning: Duplicate label %s found!",sectionLabel.data());
}
sectionTitle.resize(0);
}
// Adds a formula text to the list/dictionary of formulas if it was
...
...
@@ -1385,6 +1386,7 @@ TITLE [tT][iI][tT][lL][eE]
current->name.resize(0);
current->args.resize(0);
current->initializer.resize(0);
current->bitfields.resize(0);
int i=oldType.length();
while (i>0 && (oldType[i-1]=='*' || oldType[i-1]=='&' || oldType[i-1]==' ')) i--;
current->type = oldType.left(i);
...
...
@@ -3085,8 +3087,8 @@ TITLE [tT][iI][tT][lL][eE]
<SectionTitle>[^\n*]*/"\n" {
sectionTitle+=yytext;
sectionTitle=sectionTitle.stripWhiteSpace();
addSection();
current->doc += "\\section "+sectionLabel+"\n";
addSection();
BEGIN(PageDoc);
}
<SectionTitle>"*" {
...
...
src/section.h
View file @
9d98e802
...
...
@@ -30,7 +30,7 @@ struct SectionInfo
{
enum
SectionType
{
Section
,
Subsection
,
Anchor
};
SectionInfo
(
const
char
*
l
,
const
char
*
t
,
SectionType
st
,
const
char
*
r
=
0
)
{
label
=
l
;
title
=
t
;
type
=
st
;
ref
=
r
;
definition
=
0
;
pageRef
=
0
;
}
{
label
=
l
;
title
=
t
;
type
=
st
;
ref
=
r
;
definition
=
0
;
pageRef
=
0
;
generated
=
FALSE
;
}
~
SectionInfo
()
{}
QCString
label
;
QCString
title
;
...
...
@@ -39,6 +39,7 @@ struct SectionInfo
Definition
*
definition
;
PageInfo
*
pageRef
;
QCString
fileName
;
bool
generated
;
};
class
SectionDict
:
public
QDict
<
SectionInfo
>
...
...
src/tagreader.cpp
View file @
9d98e802
...
...
@@ -32,6 +32,7 @@
#include "doxygen.h"
#include "util.h"
#include "message.h"
//#include "reflist.h"
/*! Container for member specific info that can be read from a tagfile */
class
TagMemberInfo
...
...
@@ -740,6 +741,24 @@ void TagFileParser::addDocAnchors(Entry *e,QStrList &l)
while
(
s
)
{
QCString
*
anchorName
=
new
QCString
(
s
);
//if (anchorName->left(5)=="_todo")
//{
// int todoItemId = todoList.addRefItem();
// char anchorLabel[12];
// sprintf(anchorLabel,"_todo%06d",todoItemId);
// RefItem *item = todoList.getRefItem(todoItemId);
// item->listAnchor = anchorLabel;
//}
//else if (anchorName->left(5)=="_test")
//{
// int testItemId = testList.addRefItem();
// char anchorLabel[12];
// sprintf(anchorLabel,"_test%06d",testItemId);
// RefItem *item = testList.getRefItem(testItemId);
// item->listAnchor = anchorLabel;
//}
//else
//{
if
(
Doxygen
::
sectionDict
.
find
(
*
anchorName
)
==
0
)
{
SectionInfo
*
si
=
new
SectionInfo
(
*
anchorName
,
*
anchorName
,
...
...
@@ -751,6 +770,7 @@ void TagFileParser::addDocAnchors(Entry *e,QStrList &l)
{
err
(
"Duplicate anchor %s found
\n
"
,
anchorName
->
data
());
}
//}
s
=
l
.
next
();
}
}
...
...
src/translator.h
View file @
9d98e802
...
...
@@ -21,6 +21,7 @@
#include "qtbc.h"
#include "classdef.h"
#include "util.h"
#include "config.h"
class
Translator
{
...
...
@@ -167,7 +168,16 @@ class Translator
/*! header that is put before the list of member attributes. */
virtual
QCString
trMemberDataDocumentation
()
{
return
"Member Data Documentation"
;
}
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Field Documentation"
;
}
else
{
return
"Member Data Documentation"
;
}
}
/*! this is the text of a link put after brief descriptions. */
virtual
QCString
trMore
()
...
...
@@ -231,7 +241,16 @@ class Translator
/*! This is put above each page as a link to the list of annotated classes */
virtual
QCString
trCompoundList
()
{
return
"Compound List"
;
}
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Data Structures"
;
}
else
{
return
"Compound List"
;
}
}
/*! This is put above each page as a link to the list of documented files */
virtual
QCString
trFileList
()
...
...
@@ -243,11 +262,29 @@ class Translator
/*! This is put above each page as a link to all members of compounds. */
virtual
QCString
trCompoundMembers
()
{
return
"Compound Members"
;
}
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Data Fields"
;
}
else
{
return
"Compound Members"
;
}
}
/*! This is put above each page as a link to all members of files. */
virtual
QCString
trFileMembers
()
{
return
"File Members"
;
}
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Globals"
;
}
else
{
return
"File Members"
;
}
}
/*! This is put above each page as a link to all related pages. */
virtual
QCString
trRelatedPages
()
...
...
@@ -278,9 +315,18 @@ class Translator
/*! This is an introduction to the annotated compound list. */
virtual
QCString
trCompoundListDescription
()
{
return
"Here are the classes, structs, "
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Here are the data structures with brief descriptions:"
;
}
else
{
return
"Here are the classes, structs, "
"unions and interfaces with brief descriptions:"
;
}
}
/*! This is an introduction to the page with all class members. */
virtual
QCString
trCompoundMembersDescription
(
bool
extractAll
)
...
...
@@ -300,11 +346,20 @@ class Translator
{
QCString
result
=
"Here is a list of all "
;
if
(
!
extractAll
)
result
+=
"documented "
;
result
+=
"file members with links to "
;
if
(
extractAll
)
result
+=
"the file documentation for each member:"
;
if
(
Config
::
optimizeForCFlag
)
{
result
+=
"functions, variables, defines, enums, and typedefs"
;
}
else
{
result
+=
"file members"
;
}
result
+=
" with links to "
;
if
(
extractAll
)
result
+=
"the files they belong to:"
;
else
result
+=
"the documentation:"
;
return
result
;
}
...
...
@@ -353,7 +408,16 @@ class Translator
* annotated compound index.
*/
virtual
QCString
trCompoundIndex
()
{
return
"Compound Index"
;
}
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Data Structure Index"
;
}
else
{
return
"Compound Index"
;
}
}
/*! This is used in LaTeX as the title of the chapter with the
* list of all files.
...
...
@@ -487,7 +551,16 @@ class Translator
* the list of links to documented compounds
*/
virtual
QCString
trCompounds
()
{
return
"Compounds"
;
}
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Data Structures"
;
}
else
{
return
"Compounds"
;
}
}
/*! This is used in the documentation of a group before the list of
* links to documented files
...
...
@@ -918,9 +991,16 @@ class Translator
return
"Public Types"
;
}
virtual
QCString
trPublicAttribs
()
{
if
(
Config
::
optimizeForCFlag
)
{
return
"Data Fields"
;
}
else
{
return
"Public Attributes"
;
}
}
virtual
QCString
trStaticPublicAttribs
()
{
return
"Static Public Attributes"
;
...
...
src/translator_cz.h
View file @
9d98e802
...
...
@@ -20,24 +20,30 @@
#include "translator.h"
// The translation from English to Czech by Vlastimil Havran.
// In the cases where are more translations possible I hope
// The first translation from English to Czech was started by
// Vlastimil Havran. He wrote:
//
// "In the cases where are more translations possible I hope
// that I have selected the most reasonable text. If not, please,
// mail the comments and text proposals to
//
// havran@fel.cvut.cz, 1999/04/11
// havran@fel.cvut.cz, 1999/04/11"
//
// The prototype version of Czech strings with diacritics was
// implemented by Petr Prikryl (prikrylp@skil.cz), 2000/06/20. As
// Vlastimil was quite busy at the time, he agreed that Petr be the
// second maintainer.
//
// Updates:
// --------
// 2000/06/20
// - The prototype version of Czech strings with diacritics implemented by
// Petr Prikryl (prikrylp@skil.cz). (Vlastimil Havran is still
// the maintainer.) The translation was based on translator.h
// of Doxygen versison 1.1.4 (from scratch).
// 2000/06/20 (Petr Prikryl)
// - The prototype version of Czech strings with diacritics. The
// translation was based on translator.h of Doxygen version
// 1.1.4 (from scratch).
//
// 2000/07/10 (Petr Prikryl)
// - Updated version based on 1.1.5 sources (including important updates
// of the up-to-1.1.4 strings). Czech strings this file were written
// of the up-to-1.1.4 strings). Czech strings
in
this file were written
// in windows-1250 encoding. On-line decoding into iso-8859-2 ensured
// via conditional compilation if the sources are compiled under UNIX.
//
...
...
@@ -74,13 +80,18 @@
// 2000/10/17 (Petr Prikryl)
// - Update for "new since 1.2.2" version.
//
// 2001/01/09 (Petr Prikryl)
// - Update for "new since 1.2.4" version. As I do not use Java,
// I tried my best to guess the Czech terminology for the Java.
// Let me know if some wording should be changed/improved.
//
// Notices:
// --------
// The conditional compilation ensures or the neutral functionality
// of the private inline Decode(), or calling the WinToISO() method
// for on-line encoding conversion. If you want to maintain the
// source in the iso-8859-2, do convert the
source encoding, change
// the conditional definition of the inline Decode() using the
// source in the iso-8859-2, do convert the
encoding of the source,
//
change
the conditional definition of the inline Decode() using the
// method ISO88592ToWin1250() -- for conversion of strings for the
// Windows version. The version which does not call the function is
// probably slightly faster.
...
...
@@ -1126,6 +1137,46 @@ class TranslatorCzech : public Translator
{
return
Decode
(
"Dokumentace k vlastnosti"
);
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.4
//////////////////////////////////////////////////////////////////////////
/*! Used for Java interfaces in the summary section of Java packages */
virtual
QCString
trInterfaces
()
{
return
Decode
(
"Rozhraní"
);
}
/*! Used for Java classes in the summary section of Java packages */
virtual
QCString
trClasses
()
{
return
Decode
(
"Tøídy"
);
}
/*! Used as the title of a Java package */
virtual
QCString
trPackage
(
const
char
*
name
)
{
return
Decode
((
QCString
)
"Balík "
+
name
);
}
/*! Title of the package index page */
virtual
QCString
trPackageList
()
{
return
Decode
(
"Seznam balíkù"
);
}
/*! The description of the package index page */
virtual
QCString
trPackageListDescription
()
{
return
Decode
(
"Zde naleznete seznam balíkù se struèným popisem "
"(pokud byl uveden):"
);
}
/*! The link name in the Quick links header for each page */
virtual
QCString
trPackages
()
{
return
Decode
(
"Balíky"
);
}
/*! Used as a chapter title for Latex & RTF output */
virtual
QCString
trPackageDocumentation
()
{
return
Decode
(
"Dokumentace balíku"
);
}
};
#endif // TRANSLATOR_CZ_H
src/translator_de.h
View file @
9d98e802
...
...
@@ -383,7 +383,7 @@ class TranslatorGerman : public Translator
QCString
trNamespaceList
()
// used as the title of page containing all the index of all namespaces.
{
return
"Liste
r aller Namensber
iche"
;
}
{
return
"Liste
aller Namensbere
iche"
;
}
QCString
trNamespaceListDescription
(
bool
extractAll
)
// used as an introduction to the namespace list
{
...
...
src/translator_nl.h
View file @
9d98e802
...
...
@@ -218,7 +218,7 @@ class TranslatorDutch : public Translator
QCString
trAuthors
()
{
return
"Auteur(s)"
;
}
QCString
trReturns
()
{
return
"Retourneer
d
"
;
}
{
return
"Retourneer
t
"
;
}
QCString
trSeeAlso
()
{
return
"Zie ook"
;
}
QCString
trParameters
()
...
...
src/util.cpp
View file @
9d98e802
...
...
@@ -158,6 +158,7 @@ int iSystem(const char *command,const char *args,bool isBatchFile)
else
if
(
sInfo
.
hProcess
)
/* executable was launched, wait for it to finish */
{
WaitForSingleObject
(
sInfo
.
hProcess
,
INFINITE
);
CloseHandle
(
sInfo
.
hProcess
);
}
}
return
0
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment