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
5a640083
Commit
5a640083
authored
Mar 07, 2005
by
dimitri
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Release-1.4.1-20050307
parent
d745dd37
Changes
40
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
40 changed files
with
1005 additions
and
665 deletions
+1005
-665
INSTALL
INSTALL
+2
-2
README
README
+2
-2
VERSION
VERSION
+1
-1
doxywizard.cpp
addon/doxywizard/doxywizard.cpp
+6
-6
language.doc
doc/language.doc
+33
-33
maintainers.txt
doc/maintainers.txt
+1
-1
translator.py
doc/translator.py
+30
-5
translator_report.txt
doc/translator_report.txt
+136
-106
doxygen.spec
packages/rpm/doxygen.spec
+1
-1
code.l
src/code.l
+16
-8
commentcnv.l
src/commentcnv.l
+41
-34
commentscan.l
src/commentscan.l
+48
-13
doxygen.cpp
src/doxygen.cpp
+35
-110
htmlgen.cpp
src/htmlgen.cpp
+7
-2
index.cpp
src/index.cpp
+28
-49
memberdef.cpp
src/memberdef.cpp
+26
-7
memberdef.h
src/memberdef.h
+4
-0
pre.l
src/pre.l
+8
-3
scanner.l
src/scanner.l
+14
-11
tagreader.cpp
src/tagreader.cpp
+96
-26
translator.h
src/translator.h
+6
-0
translator_adapter.h
src/translator_adapter.h
+11
-1
translator_br.h
src/translator_br.h
+1
-1
translator_cn.h
src/translator_cn.h
+9
-60
translator_cz.h
src/translator_cz.h
+1
-1
translator_de.h
src/translator_de.h
+1
-1
translator_en.h
src/translator_en.h
+13
-0
translator_fr.h
src/translator_fr.h
+1
-1
translator_hr.h
src/translator_hr.h
+6
-41
translator_hu.h
src/translator_hu.h
+1
-1
translator_it.h
src/translator_it.h
+1
-1
translator_nl.h
src/translator_nl.h
+13
-0
translator_pl.h
src/translator_pl.h
+1
-1
translator_ro.h
src/translator_ro.h
+243
-33
translator_ru.h
src/translator_ru.h
+1
-1
translator_se.h
src/translator_se.h
+1
-1
translator_sr.h
src/translator_sr.h
+1
-1
translator_ua.h
src/translator_ua.h
+1
-1
util.cpp
src/util.cpp
+156
-99
util.h
src/util.h
+2
-0
No files found.
INSTALL
View file @
5a640083
DOXYGEN Version 1.4.1-20050
22
7
DOXYGEN Version 1.4.1-20050
30
7
Please read the installation section of the manual
Please read the installation section of the manual
(http://www.doxygen.org/install.html) for instructions.
(http://www.doxygen.org/install.html) for instructions.
--------
--------
Dimitri van Heesch (
27 February
2005)
Dimitri van Heesch (
07 March
2005)
README
View file @
5a640083
DOXYGEN Version 1.4.1_20050
22
7
DOXYGEN Version 1.4.1_20050
30
7
Please read INSTALL for compilation instructions.
Please read INSTALL for compilation instructions.
...
@@ -17,4 +17,4 @@ to subscribe to the lists or to visit the archives.
...
@@ -17,4 +17,4 @@ to subscribe to the lists or to visit the archives.
Enjoy,
Enjoy,
Dimitri van Heesch (dimitri@stack.nl) (
27 February
2005)
Dimitri van Heesch (dimitri@stack.nl) (
07 March
2005)
VERSION
View file @
5a640083
1.4.1-20050
22
7
1.4.1-20050
30
7
addon/doxywizard/doxywizard.cpp
View file @
5a640083
...
@@ -823,12 +823,12 @@ MainWidget::MainWidget(QWidget *parent)
...
@@ -823,12 +823,12 @@ MainWidget::MainWidget(QWidget *parent)
// load default settings
// load default settings
m_settings
.
setPath
(
"www.doxygen.org"
,
"Doxygen GUI"
);
m_settings
.
setPath
(
"www.doxygen.org"
,
"Doxygen GUI"
);
bool
ok
;
bool
ok
;
QString
config
=
m_settings
.
readEntry
(
"/config/default"
,
QString
::
null
,
&
ok
);
QString
config
=
m_settings
.
readEntry
(
"/
doxywizard/
config/default"
,
QString
::
null
,
&
ok
);
if
(
ok
&&
!
config
.
isEmpty
())
if
(
ok
&&
!
config
.
isEmpty
())
{
{
Config
::
instance
()
->
parseString
(
"default settings"
,
config
);
Config
::
instance
()
->
parseString
(
"default settings"
,
config
);
}
}
QString
workingDir
=
m_settings
.
readEntry
(
"/config/workingdir"
,
QString
::
null
,
&
ok
);
QString
workingDir
=
m_settings
.
readEntry
(
"/
doxywizard/
config/workingdir"
,
QString
::
null
,
&
ok
);
if
(
ok
&&
!
workingDir
.
isEmpty
())
if
(
ok
&&
!
workingDir
.
isEmpty
())
{
{
m_workingDir
->
setText
(
workingDir
);
m_workingDir
->
setText
(
workingDir
);
...
@@ -836,7 +836,7 @@ MainWidget::MainWidget(QWidget *parent)
...
@@ -836,7 +836,7 @@ MainWidget::MainWidget(QWidget *parent)
setConfigSaved
(
FALSE
);
setConfigSaved
(
FALSE
);
for
(
int
i
=
0
;
i
<
10
;
i
++
)
for
(
int
i
=
0
;
i
<
10
;
i
++
)
{
{
QString
entry
=
m_settings
.
readEntry
(
QString
().
sprintf
(
"/recent/config%d"
,
i
));
QString
entry
=
m_settings
.
readEntry
(
QString
().
sprintf
(
"/
doxywizard/
recent/config%d"
,
i
));
if
(
!
entry
.
isEmpty
())
if
(
!
entry
.
isEmpty
())
{
{
addRecentFile
(
entry
);
addRecentFile
(
entry
);
...
@@ -1178,8 +1178,8 @@ void MainWidget::saveDefaults()
...
@@ -1178,8 +1178,8 @@ void MainWidget::saveDefaults()
QString
newConfig
;
QString
newConfig
;
QTextStream
t
(
&
newConfig
,
IO_WriteOnly
);
QTextStream
t
(
&
newConfig
,
IO_WriteOnly
);
Config
::
instance
()
->
writeTemplate
(
t
,
TRUE
,
FALSE
);
Config
::
instance
()
->
writeTemplate
(
t
,
TRUE
,
FALSE
);
m_settings
.
writeEntry
(
"/config/default"
,
newConfig
);
m_settings
.
writeEntry
(
"/
doxywizard/
config/default"
,
newConfig
);
m_settings
.
writeEntry
(
"/config/workingdir"
,
m_workingDir
->
text
());
m_settings
.
writeEntry
(
"/
doxywizard/
config/workingdir"
,
m_workingDir
->
text
());
statusBar
()
->
message
(
"Current configuration saved as default"
,
messageTimeout
);
statusBar
()
->
message
(
"Current configuration saved as default"
,
messageTimeout
);
}
}
}
}
...
@@ -1361,7 +1361,7 @@ void MainWidget::addRecentFile(const QString &file)
...
@@ -1361,7 +1361,7 @@ void MainWidget::addRecentFile(const QString &file)
for
(
it
=
m_recentFiles
.
begin
();
it
!=
m_recentFiles
.
end
();
++
it
,
++
i
)
for
(
it
=
m_recentFiles
.
begin
();
it
!=
m_recentFiles
.
end
();
++
it
,
++
i
)
{
{
m_recentMenu
->
insertItem
(
*
it
);
m_recentMenu
->
insertItem
(
*
it
);
m_settings
.
writeEntry
(
QString
().
sprintf
(
"/recent/config%d"
,
i
),
*
it
);
m_settings
.
writeEntry
(
QString
().
sprintf
(
"/
doxywizard/
recent/config%d"
,
i
),
*
it
);
}
}
}
}
...
...
doc/language.doc
View file @
5a640083
...
@@ -60,7 +60,7 @@ when the translator was updated.
...
@@ -60,7 +60,7 @@ when the translator was updated.
<td>Brazilian Portuguese</td>
<td>Brazilian Portuguese</td>
<td>Fabio "FJTC" Jun Takada Chino</td>
<td>Fabio "FJTC" Jun Takada Chino</td>
<td>jun-chino at uol dot com dot br</td>
<td>jun-chino at uol dot com dot br</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Catalan</td>
<td>Catalan</td>
...
@@ -72,7 +72,7 @@ when the translator was updated.
...
@@ -72,7 +72,7 @@ when the translator was updated.
<td>Chinese</td>
<td>Chinese</td>
<td>Li Daobing<br>Wei Liu</td>
<td>Li Daobing<br>Wei Liu</td>
<td>lidaobing at gmail dot com<br>liuwei at asiainfo dot com</td>
<td>lidaobing at gmail dot com<br>liuwei at asiainfo dot com</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Chinese Traditional</td>
<td>Chinese Traditional</td>
...
@@ -84,13 +84,13 @@ when the translator was updated.
...
@@ -84,13 +84,13 @@ when the translator was updated.
<td>Croatian</td>
<td>Croatian</td>
<td>Boris Bralo</td>
<td>Boris Bralo</td>
<td>boris.bralo at zg dot htnet dot hr</td>
<td>boris.bralo at zg dot htnet dot hr</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Czech</td>
<td>Czech</td>
<td>Petr Přikryl</td>
<td>Petr Přikryl</td>
<td>prikrylp at skil dot cz</td>
<td>prikrylp at skil dot cz</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Danish</td>
<td>Danish</td>
...
@@ -120,13 +120,13 @@ when the translator was updated.
...
@@ -120,13 +120,13 @@ when the translator was updated.
<td>French</td>
<td>French</td>
<td>Xavier Outhier</td>
<td>Xavier Outhier</td>
<td>xouthier at yahoo dot fr</td>
<td>xouthier at yahoo dot fr</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>German</td>
<td>German</td>
<td>Jens Seidel</td>
<td>Jens Seidel</td>
<td>jensseidel at users dot sf dot net</td>
<td>jensseidel at users dot sf dot net</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Greek</td>
<td>Greek</td>
...
@@ -136,15 +136,15 @@ when the translator was updated.
...
@@ -136,15 +136,15 @@ when the translator was updated.
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Hungarian</td>
<td>Hungarian</td>
<td>
Földvári György<br>Ákos Kiss
</td>
<td>
Ákos Kiss<br>Földvári György
</td>
<td>
foldvari lost at cyberspace<br>akiss at users dot sourceforge dot net
</td>
<td>
akiss at users dot sourceforge dot net<br>foldvari lost at cyberspace
</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Italian</td>
<td>Italian</td>
<td>Alessandro Falappa<br>Ahmed Aldo Faisal</td>
<td>Alessandro Falappa<br>Ahmed Aldo Faisal</td>
<td>alessandro at falappa dot net<br>aaf23 at cam dot ac dot uk</td>
<td>alessandro at falappa dot net<br>aaf23 at cam dot ac dot uk</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Japanese</td>
<td>Japanese</td>
...
@@ -162,7 +162,7 @@ when the translator was updated.
...
@@ -162,7 +162,7 @@ when the translator was updated.
<td>Korean</td>
<td>Korean</td>
<td>SooYoung Jung<br>Richard Kim</td>
<td>SooYoung Jung<br>Richard Kim</td>
<td>jung5000 at gmail dot com<br>ryk at dspwiz dot com</td>
<td>jung5000 at gmail dot com<br>ryk at dspwiz dot com</td>
<td>
up-to-date
</td>
<td>
1.4.01
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>KoreanEn</td>
<td>KoreanEn</td>
...
@@ -186,7 +186,7 @@ when the translator was updated.
...
@@ -186,7 +186,7 @@ when the translator was updated.
<td>Polish</td>
<td>Polish</td>
<td>Piotr Kaminski<br>Grzegorz Kowal</td>
<td>Piotr Kaminski<br>Grzegorz Kowal</td>
<td>Piotr.Kaminski at ctm dot gdynia dot pl<br>g_kowal at poczta dot onet dot pl</td>
<td>Piotr.Kaminski at ctm dot gdynia dot pl<br>g_kowal at poczta dot onet dot pl</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Portuguese</td>
<td>Portuguese</td>
...
@@ -198,19 +198,19 @@ when the translator was updated.
...
@@ -198,19 +198,19 @@ when the translator was updated.
<td>Romanian</td>
<td>Romanian</td>
<td>Alexandru Iosup</td>
<td>Alexandru Iosup</td>
<td>aiosup at yahoo dot com</td>
<td>aiosup at yahoo dot com</td>
<td>1.
2.16
</td>
<td>1.
4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Russian</td>
<td>Russian</td>
<td>Alexandr Chelpanov</td>
<td>Alexandr Chelpanov</td>
<td>cav at cryptopro dot ru</td>
<td>cav at cryptopro dot ru</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Serbian</td>
<td>Serbian</td>
<td>Dejan Milosavljevic</td>
<td>Dejan Milosavljevic</td>
<td>dmilos at email dot com</td>
<td>dmilos at email dot com</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Slovak</td>
<td>Slovak</td>
...
@@ -234,13 +234,13 @@ when the translator was updated.
...
@@ -234,13 +234,13 @@ when the translator was updated.
<td>Swedish</td>
<td>Swedish</td>
<td>Mikael Hallin</td>
<td>Mikael Hallin</td>
<td>mikaelhallin at yahoo dot se</td>
<td>mikaelhallin at yahoo dot se</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<tr bgcolor="#ffffff">
<tr bgcolor="#ffffff">
<td>Ukrainian</td>
<td>Ukrainian</td>
<td>Olexij Tkatchenko</td>
<td>Olexij Tkatchenko</td>
<td>olexij.tkatchenko at parcs dot de</td>
<td>olexij.tkatchenko at parcs dot de</td>
<td>
up-to-date
</td>
<td>
1.4.1
</td>
</tr>
</tr>
<!-- table content end -->
<!-- table content end -->
</table>
</table>
...
@@ -259,19 +259,19 @@ when the translator was updated.
...
@@ -259,19 +259,19 @@ when the translator was updated.
\hline
\hline
Afrikaans & Johan Prinsloo & {\tt\tiny johan@zippysnoek.com} & 1.3.9 \\
Afrikaans & Johan Prinsloo & {\tt\tiny johan@zippysnoek.com} & 1.3.9 \\
\hline
\hline
Brazilian Portuguese & Fabio "FJTC" Jun Takada Chino & {\tt\tiny jun-chino@uol.com.br} &
up-to-date
\\
Brazilian Portuguese & Fabio "FJTC" Jun Takada Chino & {\tt\tiny jun-chino@uol.com.br} &
1.4.1
\\
\hline
\hline
Catalan & Albert Mora & {\tt\tiny amora@iua.upf.es} & 1.2.17 \\
Catalan & Albert Mora & {\tt\tiny amora@iua.upf.es} & 1.2.17 \\
\hline
\hline
Chinese & Li Daobing & {\tt\tiny lidaobing@gmail.com} &
up-to-date
\\
Chinese & Li Daobing & {\tt\tiny lidaobing@gmail.com} &
1.4.1
\\
~ & Wei Liu & {\tt\tiny liuwei@asiainfo.com} & ~ \\
~ & Wei Liu & {\tt\tiny liuwei@asiainfo.com} & ~ \\
\hline
\hline
Chinese Traditional & Daniel YC Lin & {\tt\tiny daniel@twpda.com} & 1.3.8 \\
Chinese Traditional & Daniel YC Lin & {\tt\tiny daniel@twpda.com} & 1.3.8 \\
~ & Gary Lee & {\tt\tiny garylee@ecosine.com.tw} & ~ \\
~ & Gary Lee & {\tt\tiny garylee@ecosine.com.tw} & ~ \\
\hline
\hline
Croatian & Boris Bralo & {\tt\tiny boris.bralo@zg.htnet.hr} &
up-to-date
\\
Croatian & Boris Bralo & {\tt\tiny boris.bralo@zg.htnet.hr} &
1.4.1
\\
\hline
\hline
Czech & Petr P\v{r}ikryl & {\tt\tiny prikrylp@skil.cz} &
up-to-date
\\
Czech & Petr P\v{r}ikryl & {\tt\tiny prikrylp@skil.cz} &
1.4.1
\\
\hline
\hline
Danish & Erik S\o{}e S\o{}rensen & {\tt\tiny eriksoe+doxygen@daimi.au.dk} & 1.3.9 \\
Danish & Erik S\o{}e S\o{}rensen & {\tt\tiny eriksoe+doxygen@daimi.au.dk} & 1.3.9 \\
\hline
\hline
...
@@ -281,16 +281,16 @@ when the translator was updated.
...
@@ -281,16 +281,16 @@ when the translator was updated.
\hline
\hline
Finnish & Olli Korhonen & {\tt\tiny olli.korhonen lost@cyberspace} & obsolete \\
Finnish & Olli Korhonen & {\tt\tiny olli.korhonen lost@cyberspace} & obsolete \\
\hline
\hline
French & Xavier Outhier & {\tt\tiny xouthier@yahoo.fr} &
up-to-date
\\
French & Xavier Outhier & {\tt\tiny xouthier@yahoo.fr} &
1.4.1
\\
\hline
\hline
German & Jens Seidel & {\tt\tiny jensseidel@users.sf.net} &
up-to-date
\\
German & Jens Seidel & {\tt\tiny jensseidel@users.sf.net} &
1.4.1
\\
\hline
\hline
Greek & Harry Kalogirou & {\tt\tiny harkal@rainbow.cs.unipi.gr} & 1.2.11 \\
Greek & Harry Kalogirou & {\tt\tiny harkal@rainbow.cs.unipi.gr} & 1.2.11 \\
\hline
\hline
Hungarian &
F\"{o}ldv\'{a}ri Gy\"{o}rgy & {\tt\tiny foldvari lost@cyberspace} & up-to-date
\\
Hungarian &
\'{A}kos Kiss & {\tt\tiny akiss@users.sourceforge.net} & 1.4.1
\\
~ &
\'{A}kos Kiss & {\tt\tiny akiss@users.sourceforge.net
} & ~ \\
~ &
F\"{o}ldv\'{a}ri Gy\"{o}rgy & {\tt\tiny foldvari lost@cyberspace
} & ~ \\
\hline
\hline
Italian & Alessandro Falappa & {\tt\tiny alessandro@falappa.net} &
up-to-date
\\
Italian & Alessandro Falappa & {\tt\tiny alessandro@falappa.net} &
1.4.1
\\
~ & Ahmed Aldo Faisal & {\tt\tiny aaf23@cam.ac.uk} & ~ \\
~ & Ahmed Aldo Faisal & {\tt\tiny aaf23@cam.ac.uk} & ~ \\
\hline
\hline
Japanese & Ryunosuke Satoh & {\tt\tiny sun594@hotmail.com} & 1.3.9 \\
Japanese & Ryunosuke Satoh & {\tt\tiny sun594@hotmail.com} & 1.3.9 \\
...
@@ -299,7 +299,7 @@ when the translator was updated.
...
@@ -299,7 +299,7 @@ when the translator was updated.
\hline
\hline
JapaneseEn & see the Japanese language & {\tt\tiny ~} & English based \\
JapaneseEn & see the Japanese language & {\tt\tiny ~} & English based \\
\hline
\hline
Korean & SooYoung Jung & {\tt\tiny jung5000@gmail.com} &
up-to-date
\\
Korean & SooYoung Jung & {\tt\tiny jung5000@gmail.com} &
1.4.01
\\
~ & Richard Kim & {\tt\tiny ryk@dspwiz.com} & ~ \\
~ & Richard Kim & {\tt\tiny ryk@dspwiz.com} & ~ \\
\hline
\hline
KoreanEn & see the Korean language & {\tt\tiny ~} & English based \\
KoreanEn & see the Korean language & {\tt\tiny ~} & English based \\
...
@@ -310,16 +310,16 @@ when the translator was updated.
...
@@ -310,16 +310,16 @@ when the translator was updated.
\hline
\hline
Norwegian & Lars Erik Jordet & {\tt\tiny lejordet@gmail.com} & 1.3.9 \\
Norwegian & Lars Erik Jordet & {\tt\tiny lejordet@gmail.com} & 1.3.9 \\
\hline
\hline
Polish & Piotr Kaminski & {\tt\tiny Piotr.Kaminski@ctm.gdynia.pl} &
up-to-date
\\
Polish & Piotr Kaminski & {\tt\tiny Piotr.Kaminski@ctm.gdynia.pl} &
1.4.1
\\
~ & Grzegorz Kowal & {\tt\tiny g\_kowal@poczta.onet.pl} & ~ \\
~ & Grzegorz Kowal & {\tt\tiny g\_kowal@poczta.onet.pl} & ~ \\
\hline
\hline
Portuguese & Rui Godinho Lopes & {\tt\tiny ruiglopes@yahoo.com} & 1.3.3 \\
Portuguese & Rui Godinho Lopes & {\tt\tiny ruiglopes@yahoo.com} & 1.3.3 \\
\hline
\hline
Romanian & Alexandru Iosup & {\tt\tiny aiosup@yahoo.com} & 1.
2.16
\\
Romanian & Alexandru Iosup & {\tt\tiny aiosup@yahoo.com} & 1.
4.1
\\
\hline
\hline
Russian & Alexandr Chelpanov & {\tt\tiny cav@cryptopro.ru} &
up-to-date
\\
Russian & Alexandr Chelpanov & {\tt\tiny cav@cryptopro.ru} &
1.4.1
\\
\hline
\hline
Serbian & Dejan Milosavljevic & {\tt\tiny dmilos@email.com} &
up-to-date
\\
Serbian & Dejan Milosavljevic & {\tt\tiny dmilos@email.com} &
1.4.1
\\
\hline
\hline
Slovak & Stanislav Kudl\'{a}\v{c} & {\tt\tiny skudlac@pobox.sk} & 1.2.18 \\
Slovak & Stanislav Kudl\'{a}\v{c} & {\tt\tiny skudlac@pobox.sk} & 1.2.18 \\
\hline
\hline
...
@@ -327,9 +327,9 @@ when the translator was updated.
...
@@ -327,9 +327,9 @@ when the translator was updated.
\hline
\hline
Spanish & Francisco Oltra Thennet & {\tt\tiny foltra@puc.cl} & 1.3.8 \\
Spanish & Francisco Oltra Thennet & {\tt\tiny foltra@puc.cl} & 1.3.8 \\
\hline
\hline
Swedish & Mikael Hallin & {\tt\tiny mikaelhallin@yahoo.se} &
up-to-date
\\
Swedish & Mikael Hallin & {\tt\tiny mikaelhallin@yahoo.se} &
1.4.1
\\
\hline
\hline
Ukrainian & Olexij Tkatchenko & {\tt\tiny olexij.tkatchenko@parcs.de} &
up-to-date
\\
Ukrainian & Olexij Tkatchenko & {\tt\tiny olexij.tkatchenko@parcs.de} &
1.4.1
\\
\hline
\hline
\end{tabular}
\end{tabular}
\endlatexonly
\endlatexonly
...
...
doc/maintainers.txt
View file @
5a640083
...
@@ -54,8 +54,8 @@ TranslatorGreek
...
@@ -54,8 +54,8 @@ TranslatorGreek
Harry Kalogirou: harkal@rainbow.cs.unipi.gr
Harry Kalogirou: harkal@rainbow.cs.unipi.gr
TranslatorHungarian
TranslatorHungarian
Földvári György: foldvari lost@cyberspace
Ákos Kiss: akiss@users.sourceforge.net
Ákos Kiss: akiss@users.sourceforge.net
Földvári György: foldvari lost@cyberspace
TranslatorItalian
TranslatorItalian
Alessandro Falappa: alessandro@falappa.net
Alessandro Falappa: alessandro@falappa.net
...
...
doc/translator.py
View file @
5a640083
...
@@ -45,6 +45,7 @@
...
@@ -45,6 +45,7 @@
2004/07/26 - Better reporting of not-needed adapters.
2004/07/26 - Better reporting of not-needed adapters.
2004/10/04 - Reporting of not called translator methods added.
2004/10/04 - Reporting of not called translator methods added.
2004/10/05 - Modified to check only doxygen/src sources for the previous report.
2004/10/05 - Modified to check only doxygen/src sources for the previous report.
2005/02/28 - Slight modification to generate "mailto.txt" auxiliary file.
"""
"""
from
__future__
import
generators
from
__future__
import
generators
...
@@ -1435,6 +1436,13 @@ class TrManager:
...
@@ -1435,6 +1436,13 @@ class TrManager:
return
trdic
return
trdic
def
__email
(
self
,
classId
):
"""Returns the first maintainer for the translator class"""
return
self
.
__maintainersDic
[
classId
][
0
][
1
]
def
generateTranslatorReport
(
self
):
def
generateTranslatorReport
(
self
):
"""Generates the translator report."""
"""Generates the translator report."""
...
@@ -1466,6 +1474,11 @@ class TrManager:
...
@@ -1466,6 +1474,11 @@ class TrManager:
s
+=
'and
%
d are English based.'
%
len
(
self
.
EnBasedIdLst
)
s
+=
'and
%
d are English based.'
%
len
(
self
.
EnBasedIdLst
)
f
.
write
(
fill
(
s
)
+
'
\n\n
'
)
f
.
write
(
fill
(
s
)
+
'
\n\n
'
)
# The e-mail addresses of the maintainers will be collected to
# the auxiliary file in the order of translator classes listed
# in the translator report.
fmail
=
file
(
'mailto.txt'
,
'w'
)
# Write the list of up-to-date translator classes.
# Write the list of up-to-date translator classes.
if
self
.
upToDateIdLst
:
if
self
.
upToDateIdLst
:
s
=
'''The following translator classes are up-to-date (sorted
s
=
'''The following translator classes are up-to-date (sorted
...
@@ -1476,12 +1489,18 @@ class TrManager:
...
@@ -1476,12 +1489,18 @@ class TrManager:
s
=
s
%
len
(
self
.
requiredMethodsDic
)
s
=
s
%
len
(
self
.
requiredMethodsDic
)
f
.
write
(
'-'
*
70
+
'
\n
'
)
f
.
write
(
'-'
*
70
+
'
\n
'
)
f
.
write
(
fill
(
s
)
+
'
\n\n
'
)
f
.
write
(
fill
(
s
)
+
'
\n\n
'
)
mailtoLst
=
[]
for
x
in
self
.
upToDateIdLst
:
for
x
in
self
.
upToDateIdLst
:
obj
=
self
.
__translDic
[
x
]
obj
=
self
.
__translDic
[
x
]
f
.
write
(
' '
+
obj
.
classId
)
f
.
write
(
' '
+
obj
.
classId
)
if
obj
.
note
:
if
obj
.
note
:
f
.
write
(
' -- '
+
obj
.
note
)
f
.
write
(
' -- '
+
obj
.
note
)
f
.
write
(
'
\n
'
)
f
.
write
(
'
\n
'
)
mailtoLst
.
append
(
self
.
__email
(
obj
.
classId
))
fmail
.
write
(
'up-to-date
\n
'
)
fmail
.
write
(
'; '
.
join
(
mailtoLst
))
# Write the list of the adapter based classes. The very obsolete
# Write the list of the adapter based classes. The very obsolete
# translators that derive from TranslatorEnglish are included.
# translators that derive from TranslatorEnglish are included.
...
@@ -1497,6 +1516,7 @@ class TrManager:
...
@@ -1497,6 +1516,7 @@ class TrManager:
# Find also whether some adapter classes may be removed.
# Find also whether some adapter classes may be removed.
adaptMinVersion
=
'9.9.99'
adaptMinVersion
=
'9.9.99'
mailtoLst
=
[]
for
x
in
self
.
adaptIdLst
:
for
x
in
self
.
adaptIdLst
:
obj
=
self
.
__translDic
[
x
]
obj
=
self
.
__translDic
[
x
]
f
.
write
(
'
%-30
s'
%
obj
.
classId
)
f
.
write
(
'
%-30
s'
%
obj
.
classId
)
...
@@ -1508,11 +1528,15 @@ class TrManager:
...
@@ -1508,11 +1528,15 @@ class TrManager:
if
obj
.
note
:
if
obj
.
note
:
f
.
write
(
'
\n\t
Note: '
+
obj
.
note
+
'
\n
'
)
f
.
write
(
'
\n\t
Note: '
+
obj
.
note
+
'
\n
'
)
f
.
write
(
'
\n
'
)
f
.
write
(
'
\n
'
)
mailtoLst
.
append
(
self
.
__email
(
obj
.
classId
))
# to maintainer
# Check the level of required adapter classes.
# Check the level of required adapter classes.
if
obj
.
status
!=
'0.0.00'
and
obj
.
status
<
adaptMinVersion
:
if
obj
.
status
!=
'0.0.00'
and
obj
.
status
<
adaptMinVersion
:
adaptMinVersion
=
obj
.
status
adaptMinVersion
=
obj
.
status
fmail
.
write
(
'
\n\n
translator based
\n
'
)
fmail
.
write
(
'; '
.
join
(
mailtoLst
))
# Set the note if some old translator adapters are not needed
# Set the note if some old translator adapters are not needed
# any more. Do it only when the script is called without arguments,
# any more. Do it only when the script is called without arguments,
# i.e. all languages were checked against the needed translator
# i.e. all languages were checked against the needed translator
...
@@ -1588,8 +1612,9 @@ class TrManager:
...
@@ -1588,8 +1612,9 @@ class TrManager:
assert
(
obj
.
classId
!=
'Translator'
)
assert
(
obj
.
classId
!=
'Translator'
)
obj
.
report
(
f
)
obj
.
report
(
f
)
# Close the report file
.
# Close the report file
and the auxiliary file with e-mails.
f
.
close
()
f
.
close
()
fmail
.
close
()
def
__loadMaintainers
(
self
):
def
__loadMaintainers
(
self
):
...
@@ -1599,7 +1624,7 @@ class TrManager:
...
@@ -1599,7 +1624,7 @@ class TrManager:
fname
=
os
.
path
.
join
(
self
.
script_path
,
self
.
maintainersFileName
)
fname
=
os
.
path
.
join
(
self
.
script_path
,
self
.
maintainersFileName
)
# Include the maintainers file to the
checked group of files
with
# Include the maintainers file to the
group of files checked
with
# respect to the modification time.
# respect to the modification time.
tim
=
os
.
path
.
getmtime
(
fname
)
tim
=
os
.
path
.
getmtime
(
fname
)
if
tim
>
self
.
lastModificationTime
:
if
tim
>
self
.
lastModificationTime
:
...
@@ -1625,7 +1650,7 @@ class TrManager:
...
@@ -1625,7 +1650,7 @@ class TrManager:
classId
=
line
classId
=
line
maintainersLst
=
[]
maintainersLst
=
[]
inside
=
True
inside
=
True
# Otherwise skip empty line that do not act as separator
s
.
# Otherwise skip empty line that do not act as separator.
else
:
# if inside the record
else
:
# if inside the record
if
line
==
''
:
# separator found
if
line
==
''
:
# separator found
...
...
doc/translator_report.txt
View file @
5a640083
This diff is collapsed.
Click to expand it.
packages/rpm/doxygen.spec
View file @
5a640083
Summary: A documentation system for C/C++.
Summary: A documentation system for C/C++.
Name: doxygen
Name: doxygen
Version: 1.4.1_20050
22
7
Version: 1.4.1_20050
30
7
Release: 1
Release: 1
Epoch: 1
Epoch: 1
Source0: ftp://ftp.stack.nl/pub/users/dimitri/%{name}-%{version}.src.tar.gz
Source0: ftp://ftp.stack.nl/pub/users/dimitri/%{name}-%{version}.src.tar.gz
...
...
src/code.l
View file @
5a640083
...
@@ -133,6 +133,8 @@ static int g_braceCount=0;
...
@@ -133,6 +133,8 @@ static int g_braceCount=0;
static void saveObjCContext();
static void saveObjCContext();
static void restoreObjCContext();
static void restoreObjCContext();
//-------------------------------------------------------------------
//-------------------------------------------------------------------
/*! Represents a stack of variable to class mappings as found in the
/*! Represents a stack of variable to class mappings as found in the
...
@@ -252,11 +254,16 @@ void VariableContext::addVariable(const QCString &type,const QCString &name)
...
@@ -252,11 +254,16 @@ void VariableContext::addVariable(const QCString &type,const QCString &name)
addVariable(typeName,name);
addVariable(typeName,name);
}
}
}
}
else // add a dummy entry so the name is hidden to avoid false links
else
{
if (m_scopes.count()>0) // for local variables add a dummy entry so the name
// is hidden to avoid false links to global variables with the same name
// TODO: make this work for namespaces as well!
{
{
DBG_CTX((stderr,"** addVariable: dummy context\n"));
DBG_CTX((stderr,"** addVariable: dummy context\n"));
scope->append(lname,dummyContext);
scope->append(lname,dummyContext);
}
}
}
}
}
ClassDef *VariableContext::findVariable(const QCString &name)
ClassDef *VariableContext::findVariable(const QCString &name)
...
@@ -281,9 +288,8 @@ ClassDef *VariableContext::findVariable(const QCString &name)
...
@@ -281,9 +288,8 @@ ClassDef *VariableContext::findVariable(const QCString &name)
return result;
return result;
}
}
const ClassDef *VariableContext::dummyContext = (ClassDef*)0x8;
static VariableContext g_theVarContext;
static VariableContext g_theVarContext;
const ClassDef *VariableContext::dummyContext = (ClassDef*)0x8;
//-------------------------------------------------------------------
//-------------------------------------------------------------------
...
@@ -848,6 +854,7 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
...
@@ -848,6 +854,7 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
}
}
ClassDef *cd=0,*lcd=0;
ClassDef *cd=0,*lcd=0;
MemberDef *md=0;
MemberDef *md=0;
bool isLocal=FALSE;
//fprintf(stderr,"generateClassOrGlobalLink(className=%s)\n",className.data());
//fprintf(stderr,"generateClassOrGlobalLink(className=%s)\n",className.data());
if ((lcd=g_theVarContext.findVariable(className))==0) // not a local variable
if ((lcd=g_theVarContext.findVariable(className))==0) // not a local variable
...
@@ -859,7 +866,7 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
...
@@ -859,7 +866,7 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
{
{
cd=getResolvedClass(d,g_sourceFileDef,className.left(i),&md);
cd=getResolvedClass(d,g_sourceFileDef,className.left(i),&md);
}
}
//print("is found as a type %s\n",cd?cd->name().data():"<null>");
//print
f
("is found as a type %s\n",cd?cd->name().data():"<null>");
if (cd==0 && md==0) // also see if it is variable or enum or enum value
if (cd==0 && md==0) // also see if it is variable or enum or enum value
{
{
if (getLink(g_classScope,clName,ol,clName))
if (getLink(g_classScope,clName,ol,clName))
...
@@ -874,7 +881,8 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
...
@@ -874,7 +881,8 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
{
{
g_theCallContext.setClass(lcd);
g_theCallContext.setClass(lcd);
}
}
//fprintf(stderr,"is a local variable!\n");
isLocal=TRUE;
//fprintf(stderr,"is a local variable cd=%p!\n",cd);
}
}
if (cd && cd->isLinkable()) // is it a linkable class
if (cd && cd->isLinkable()) // is it a linkable class
{
{
...
@@ -907,7 +915,7 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
...
@@ -907,7 +915,7 @@ static void generateClassOrGlobalLink(BaseCodeDocInterface &ol,char *clName,
else // not a class, maybe a global member
else // not a class, maybe a global member
{
{
//printf("class %s not linkable! cd=%p md=%p typeOnly=%d\n",clName,cd,md,typeOnly);
//printf("class %s not linkable! cd=%p md=%p typeOnly=%d\n",clName,cd,md,typeOnly);
if (
md!=0 || (cd==0 && !typeOnly
)) // not a class, see if it is a global enum/variable/typedef.
if (
!isLocal && (md!=0 || (cd==0 && !typeOnly)
)) // not a class, see if it is a global enum/variable/typedef.
{
{
if (md==0) // not found as a typedef
if (md==0) // not found as a typedef
{
{
...
...
src/commentcnv.l
View file @
5a640083
...
@@ -57,6 +57,8 @@ static QCString g_fileName;
...
@@ -57,6 +57,8 @@ static QCString g_fileName;
static int g_lineNr;
static int g_lineNr;
static int g_condCtx;
static int g_condCtx;
static QStack<CondCtx> g_condStack;
static QStack<CondCtx> g_condStack;
static QCString g_blockName;
static int g_lastCommentContext;
static void replaceCommentMarker(const char *s,int len)
static void replaceCommentMarker(const char *s,int len)
{
{
...
@@ -217,6 +219,32 @@ static QCString handleCondCmdInAliases(const QCString &s)
...
@@ -217,6 +219,32 @@ static QCString handleCondCmdInAliases(const QCString &s)
return result;
return result;
}
}
/** copies string \a s with length \a len to the output, while
* replacing any alias commands found in the string.
*/
static void replaceAliases(const char *s,int len)
{
static QRegExp cmd("[@\\\\][a-z_A-Z][a-z_A-Z0-9]*");
QCString in=s;
int p=0,i,l;
while ((i=cmd.match(in,p,&l))!=-1)
{
copyToOutput(s+p,i-p);
QCString *pValue=Doxygen::aliasDict[in.mid(i+1,l-1)];
if (pValue)
{
QCString val = handleCondCmdInAliases(*pValue);
copyToOutput(val.data(),val.length());
}
else
{
copyToOutput(s+i,l);
}
p=i+l;
}
copyToOutput(s+p,len-p);
}
#undef YY_INPUT
#undef YY_INPUT
#define YY_INPUT(buf,result,max_size) result=yyread(buf,max_size);
#define YY_INPUT(buf,result,max_size) result=yyread(buf,max_size);
...
@@ -245,7 +273,6 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
...
@@ -245,7 +273,6 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
%x Verbatim
%x Verbatim
%x ReadLine
%x ReadLine
%x CondLine
%x CondLine
%x SkipLang
%%
%%
...
@@ -271,7 +298,8 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
...
@@ -271,7 +298,8 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
}
}
g_blockHeadCol=g_col;
g_blockHeadCol=g_col;
copyToOutput("/**",3);
copyToOutput("/**",3);
copyToOutput(yytext+i,yyleng-i);
//copyToOutput(yytext+i,yyleng-i);
replaceAliases(yytext+i,yyleng-i);
BEGIN(SComment);
BEGIN(SComment);
}
}
<Scan>"//##Documentation".*/\n { /* Start of Rational Rose ANSI C++ comment block */
<Scan>"//##Documentation".*/\n { /* Start of Rational Rose ANSI C++ comment block */
...
@@ -279,7 +307,8 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
...
@@ -279,7 +307,8 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
int i=17; //=strlen("//##Documentation");
int i=17; //=strlen("//##Documentation");
g_blockHeadCol=g_col;
g_blockHeadCol=g_col;
copyToOutput("/**",3);
copyToOutput("/**",3);
copyToOutput(yytext+i,yyleng-i);
//copyToOutput(yytext+i,yyleng-i);
replaceAliases(yytext+i,yyleng-i);
BEGIN(SComment);
BEGIN(SComment);
}
}
<Scan>"//"/.*\n { /* one line C++ comment */
<Scan>"//"/.*\n { /* one line C++ comment */
...
@@ -291,16 +320,21 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
...
@@ -291,16 +320,21 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
BEGIN(CComment);
BEGIN(CComment);
}
}
<
Scan>[\\@]"verbatim"
{ /* start of a verbatim block */
<
CComment>[\\@]("verbatim"|"latexonly"|"htmlonly"|"xmlonly"|"rtfonly"|"manonly"|"dot"|"code")
{ /* start of a verbatim block */
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
g_blockName=&yytext[1];
g_lastCommentContext = YY_START;
BEGIN(Verbatim);
BEGIN(Verbatim);
}
}
<Scan>. { /* any other character */
<Scan>. { /* any other character */
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
}
}
<Verbatim>[\\@]
"endverbatim"
{ /* end of verbatim block */
<Verbatim>[\\@]
("endverbatim"|"endlatexonly"|"endhtmlonly"|"endxmlonly"|"endrtfonly"|"endmanonly"|"enddot"|"endcode")
{ /* end of verbatim block */
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
BEGIN(Scan);
if (&yytext[4]==g_blockName)
{
BEGIN(g_lastCommentContext);
}
}
}
<Verbatim>[^@\\\n]* { /* any character not a backslash or new line */
<Verbatim>[^@\\\n]* { /* any character not a backslash or new line */
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
...
@@ -311,25 +345,6 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
...
@@ -311,25 +345,6 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
<Verbatim>. { /* any other character */
<Verbatim>. { /* any other character */
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
}
}
<SkipLang>[\\@]"~"[a-zA-Z]* { /* end of verbatim block */
QCString langId = &yytext[2];
if (langId.isEmpty() ||
stricmp(Config_getEnum("OUTPUT_LANGUAGE"),langId)==0)
{ // enable language specific section
BEGIN(CComment);
}
}
<SkipLang>[^*@\\\n]* { /* any character not a *, @, backslash or new line */
}
<SkipLang>\n { /* new line in verbatim block */
copyToOutput(yytext,yyleng);
}
<SkipLang>"*/" { /* end of comment block */
copyToOutput(yytext,yyleng);
BEGIN(Scan);
}
<SkipLang>. { /* any other character */
}
<SkipString>\\. { /* escaped character in string */
<SkipString>\\. { /* escaped character in string */
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
}
}
...
@@ -411,14 +426,6 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
...
@@ -411,14 +426,6 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^' \\\n]{1,4}"'"))
<CComment,ReadLine>("\\\\"|"@@")[~a-z_A-Z][a-z_A-Z0-9]*[ \t]* { // escaped command
<CComment,ReadLine>("\\\\"|"@@")[~a-z_A-Z][a-z_A-Z0-9]*[ \t]* { // escaped command
copyToOutput(yytext,yyleng);
copyToOutput(yytext,yyleng);
}
}
<CComment>[@\\]"~"[a-zA-Z]* { // language switch
QCString langId = &yytext[2];
if (!langId.isEmpty() &&
stricmp(Config_getEnum("OUTPUT_LANGUAGE"),langId)!=0)
{
BEGIN(SkipLang);
}
}
<CComment,ReadLine>[\\@]"cond"[ \t]+ { // conditional section
<CComment,ReadLine>[\\@]"cond"[ \t]+ { // conditional section
g_condCtx = YY_START;
g_condCtx = YY_START;
BEGIN(CondLine);
BEGIN(CondLine);
...
@@ -492,7 +499,7 @@ void replaceComment(int offset)
...
@@ -492,7 +499,7 @@ void replaceComment(int offset)
}
}
}
}
/*! This function does t
wo
things:
/*! This function does t
hree
things:
* -# It converts multi-line C++ style comment blocks (that are aligned)
* -# It converts multi-line C++ style comment blocks (that are aligned)
* to C style comment blocks (if MULTILINE_CPP_IS_BRIEF is set to NO).
* to C style comment blocks (if MULTILINE_CPP_IS_BRIEF is set to NO).
* -# It replaces aliases with their definition (see ALIASES)
* -# It replaces aliases with their definition (see ALIASES)
...
...
src/commentscan.l
View file @
5a640083
...
@@ -161,7 +161,9 @@ static DocCmdMap docCmdMap[] =
...
@@ -161,7 +161,9 @@ static DocCmdMap docCmdMap[] =
{ "verbatim", &handleFormatBlock },
{ "verbatim", &handleFormatBlock },
{ "latexonly", &handleFormatBlock },
{ "latexonly", &handleFormatBlock },
{ "htmlonly", &handleFormatBlock },
{ "htmlonly", &handleFormatBlock },
{ "xmlonly", &handleFormatBlock },
{ "rtfonly", &handleFormatBlock },
{ "rtfonly", &handleFormatBlock },
{ "manonly", &handleFormatBlock },
{ "dot", &handleFormatBlock },
{ "dot", &handleFormatBlock },
{ "code", &handleFormatBlock },
{ "code", &handleFormatBlock },
{ "addindex", &handleAddIndex },
{ "addindex", &handleAddIndex },
...
@@ -316,7 +318,6 @@ static QCString xrefItemTitle;
...
@@ -316,7 +318,6 @@ static QCString xrefItemTitle;
static QCString xrefListTitle;
static QCString xrefListTitle;
static Protection protection;
static Protection protection;
static bool xrefAppendToPrev;
static bool xrefAppendFlag;
static bool xrefAppendFlag;
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
...
@@ -405,8 +406,8 @@ static void addXRefItem(const char *listName,const char *itemTitle,
...
@@ -405,8 +406,8 @@ static void addXRefItem(const char *listName,const char *itemTitle,
{
{
Entry *docEntry = current; // inBody && previous ? previous : current;
Entry *docEntry = current; // inBody && previous ? previous : current;
if (listName==0) return;
if (listName==0) return;
//printf("addXRefItem(%s,%s,%s,%d)\n",listName,itemTitle,listTitle,append);
//printf("addXRefItem(%s,%s,%s,%d)\n",listName,itemTitle,listTitle,append);
ListItemInfo *lii=0;
ListItemInfo *lii=0;
RefList *refList = Doxygen::xrefLists->find(listName);
RefList *refList = Doxygen::xrefLists->find(listName);
if (refList==0) // new list
if (refList==0) // new list
...
@@ -539,17 +540,20 @@ static void addSection()
...
@@ -539,17 +540,20 @@ static void addSection()
// selects the output to write to
// selects the output to write to
static inline void setOutput(OutputContext ctx)
static inline void setOutput(OutputContext ctx)
{
{
bool xrefAppendToPrev = xrefAppendFlag;
// determine append flag for the next item (i.e. the end of this item)
xrefAppendFlag = ctx==OutputXRef && newXRefKind==xrefKind &&
(xrefKind!=XRef_Item || newXRefItemKey==xrefItemKey);
//printf("refKind=%d newXRefKind=%d xrefAppendToPrev=%d xrefAppendFlag=%d\n",
// xrefKind,newXRefKind,xrefAppendToPrev,xrefAppendFlag);
xrefItemKey = newXRefItemKey;
//printf("setOutput(inContext=%d ctx=%d)\n",inContext,ctx);
//printf("setOutput(inContext=%d ctx=%d)\n",inContext,ctx);
if (inContext==OutputXRef) // end of XRef section => add the item
if (inContext==OutputXRef) // end of XRef section => add the item
{
{
// See if we can append this new xref item to the previous one.
// See if we can append this new xref item to the previous one.
// We know this at the start of the next item of the same
// We know this at the start of the next item of the same
// type and need to remember this until the end of that item.
// type and need to remember this until the end of that item.
xrefAppendToPrev = xrefAppendFlag;
xrefAppendFlag = ctx==OutputXRef && newXRefKind==xrefKind &&
(xrefKind!=XRef_Item || newXRefItemKey==xrefItemKey);
//printf("refKind=%d newXRefKind=%d xrefAppendToPrev=%d xrefAppendFlag=%d\n",
// xrefKind,newXRefKind,xrefAppendToPrev,xrefAppendFlag);
switch(xrefKind)
switch(xrefKind)
{
{
case XRef_Todo:
case XRef_Todo:
...
@@ -604,7 +608,7 @@ static inline void setOutput(OutputContext ctx)
...
@@ -604,7 +608,7 @@ static inline void setOutput(OutputContext ctx)
case OutputXRef:
case OutputXRef:
pOutputString = &outputXRef;
pOutputString = &outputXRef;
// first item found, so can't append to previous
// first item found, so can't append to previous
xrefAppendFlag = FALSE;
//
xrefAppendFlag = FALSE;
break;
break;
}
}
}
}
...
@@ -641,8 +645,7 @@ static int yyread(char *buf,int max_size)
...
@@ -641,8 +645,7 @@ static int yyread(char *buf,int max_size)
/* start command character */
/* start command character */
CMD ("\\"|"@")
CMD ("\\"|"@")
DETAILEDCMD {CMD}("arg"|"attention"|"author"|"bug"|"code"|"date"|"deprecated"|"dot"|"dotfile"|"example"|"htmlinclude"|"htmlonly"|"image"|"include"|"includelineno"|"internal"|"invariant"|"latexonly"|"li"|"line"|manonly"|"name"|"note"|"par"|"paragraph"|"param"|"post"|"pre"|"remarks"|"relate"[sd]"("also")?|"remarks"|"return"[s]?|"retval"|"sa"|"section"|"see"|"since"|"subsection"|"subsubsection"|"test"|"throw"|"todo"|"until"|"verbatim"|"verbinclude"|"version"|"warning"|"xmlonly"|"xrefitem")
DETAILEDCMD {CMD}("arg"|"attention"|"author"|"bug"|"code"|"date"|"deprecated"|"dot"|"dotfile"|"example"|"htmlinclude"|"htmlonly"|"image"|"include"|"includelineno"|"internal"|"invariant"|"latexonly"|"li"|"line"|manonly"|"name"|"note"|"par"|"paragraph"|"param"|"post"|"pre"|"remarks"|"relate"[sd]"("also")?|"remarks"|"return"[s]?|"retval"|"sa"|"section"|"see"|"since"|"subsection"|"subsubsection"|"test"|"throw"|"todo"|"until"|"verbatim"|"verbinclude"|"version"|"warning"|"xrefitem")
/* ("image"|"author"|"internal"|"version"|"date"|"deprecated"|"param"|"exception"|"return"[s]?|"retval"|"bug"|"warning"|"par"|"sa"|"see"|"pre"|"post"|"invariant"|"note"|"remark"[s]?|"todo"|"test"|"xrefitem"|"ingroup"|"callgraph"|"latexonly"|"htmlonly"|"xmlonly"|"{"|"verbatim"|"dotfile"|"dot"|"defgroup"|"addtogroup"|"weakgroup"|"class"|"namespace"|"union"|"struct"|"fn"|"var"|"details"|"typedef"|"def"|"overload")|("<"{PRE}">") */
PRE [pP][rR][eE]
PRE [pP][rR][eE]
TABLE [tT][aA][bB][lL][eE]
TABLE [tT][aA][bB][lL][eE]
P [pP]
P [pP]
...
@@ -706,6 +709,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -706,6 +709,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
%x ReadFormulaLong
%x ReadFormulaLong
%x AnchorLabel
%x AnchorLabel
%x HtmlComment
%x HtmlComment
%x SkipLang
%%
%%
...
@@ -720,11 +724,15 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -720,11 +724,15 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
* end of brief description due to some command (@command, or <command>).
* end of brief description due to some command (@command, or <command>).
* words and whitespace and other characters (#,?!, etc).
* words and whitespace and other characters (#,?!, etc).
* grouping commands (e.g. @{ and @})
* grouping commands (e.g. @{ and @})
* language switch (e.g. \~english or \~).
*/
*/
<Comment>{CMD}{CMD}[a-z_A-Z]+{B}* { // escaped command
<Comment>{CMD}{CMD}[a-z_A-Z]+{B}* { // escaped command
addOutput(yytext);
addOutput(yytext);
}
}
<Comment>{CMD}{CMD}"~"[a-z_A-Z]* { // escaped command
addOutput(yytext);
}
<Comment>("\\"[a-z_A-Z]+)+"\\" { // directory (or chain of commands!)
<Comment>("\\"[a-z_A-Z]+)+"\\" { // directory (or chain of commands!)
addOutput(yytext);
addOutput(yytext);
}
}
...
@@ -757,6 +765,14 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -757,6 +765,14 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
<Comment>("\\\\"|"@@")"f"[$\[{] { // escaped formula command
<Comment>("\\\\"|"@@")"f"[$\[{] { // escaped formula command
addOutput(yytext);
addOutput(yytext);
}
}
<Comment>{CMD}"~"[a-z_A-Z]* { // language switch command
QCString langId = &yytext[2];
if (!langId.isEmpty() &&
stricmp(Config_getEnum("OUTPUT_LANGUAGE"),langId)!=0)
{ // enable language specific section
BEGIN(SkipLang);
}
}
<Comment>{CMD}"f{"[^}\n]+"}" { // start of a formula with custom environment
<Comment>{CMD}"f{"[^}\n]+"}" { // start of a formula with custom environment
formulaText="\\begin";
formulaText="\\begin";
formulaEnv=&yytext[2];
formulaEnv=&yytext[2];
...
@@ -793,7 +809,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -793,7 +809,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
addOutput(yytext[0]);
addOutput(yytext[0]);
addOutput(yytext[2]);
addOutput(yytext[2]);
}
}
<Comment>
\n({B}*\n)+ { // at least one blank line
<Comment>
(\n|\\_linebr)({B}*(\n|\\_linebr))+ { // at least one blank line (or blank line command)
if (inContext)
if (inContext)
{
{
setOutput(OutputDoc);
setOutput(OutputDoc);
...
@@ -1091,7 +1107,6 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -1091,7 +1107,6 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
<XRefItemParam1>{ID} { // first argument
<XRefItemParam1>{ID} { // first argument
newXRefItemKey=yytext;
newXRefItemKey=yytext;
setOutput(OutputXRef);
setOutput(OutputXRef);
xrefItemKey==yytext;
BEGIN(XRefItemParam2);
BEGIN(XRefItemParam2);
}
}
<XRefItemParam1>{LC} { // line continuation
<XRefItemParam1>{LC} { // line continuation
...
@@ -1274,7 +1289,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -1274,7 +1289,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
/* ----- handle arguments of the preformatted block commands ------- */
/* ----- handle arguments of the preformatted block commands ------- */
<FormatBlock>{CMD}("endverbatim"|"endlatexonly"|"endhtmlonly"|"endxmlonly"|"enddot"|"endcode")/{NW} { // possible ends
<FormatBlock>{CMD}("endverbatim"|"endlatexonly"|"endhtmlonly"|"endxmlonly"|"end
rtfonly"|"endmanonly"|"end
dot"|"endcode")/{NW} { // possible ends
addOutput(yytext);
addOutput(yytext);
if (&yytext[4]==blockName) // found end of the block
if (&yytext[4]==blockName) // found end of the block
{
{
...
@@ -1429,6 +1444,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -1429,6 +1444,7 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
}
}
<NameParam>. { // ignore other stuff
<NameParam>. { // ignore other stuff
nameHeader+=*yytext;
nameHeader+=*yytext;
current->name+=*yytext;
}
}
/* ----- handle argument of ingroup command ------- */
/* ----- handle argument of ingroup command ------- */
...
@@ -1523,6 +1539,25 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
...
@@ -1523,6 +1539,25 @@ SCOPENAME "$"?(({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
BEGIN(Comment);
BEGIN(Comment);
}
}
/* ----- handle language specific sections ------- */
<SkipLang>[\\@]"~"[a-zA-Z]* { /* language switch */
QCString langId = &yytext[2];
if (langId.isEmpty() ||
stricmp(Config_getEnum("OUTPUT_LANGUAGE"),langId)==0)
{ // enable language specific section
BEGIN(Comment);
}
}
<SkipLang>[^*@\\\n]* { /* any character not a *, @, backslash or new line */
}
<SkipLang>{DOCNL} { /* new line in verbatim block */
if (*yytext=='\n') yyLineNr++;
}
<SkipLang>. { /* any other character */
}
%%
%%
//----------------------------------------------------------------------------
//----------------------------------------------------------------------------
...
...
src/doxygen.cpp
View file @
5a640083
This diff is collapsed.
Click to expand it.
src/htmlgen.cpp
View file @
5a640083
...
@@ -125,7 +125,8 @@ static const char *defaultStyleSheet =
...
@@ -125,7 +125,8 @@ static const char *defaultStyleSheet =
"A:hover { text-decoration: none; background-color: #f2f2ff }
\n
"
"A:hover { text-decoration: none; background-color: #f2f2ff }
\n
"
"DL.el { margin-left: -1cm }
\n
"
"DL.el { margin-left: -1cm }
\n
"
".fragment {
\n
"
".fragment {
\n
"
" font-family: monospace
\n
"
" font-family: Fixed, monospace;
\n
"
" font-size: 90%;
\n
"
"}
\n
"
"}
\n
"
"PRE.fragment {
\n
"
"PRE.fragment {
\n
"
" border: 1px solid #CCCCCC;
\n
"
" border: 1px solid #CCCCCC;
\n
"
...
@@ -843,8 +844,10 @@ void HtmlGenerator::codify(const char *str)
...
@@ -843,8 +844,10 @@ void HtmlGenerator::codify(const char *str)
t
<<
spaces
.
left
(
spacesToNextTabStop
);
t
<<
spaces
.
left
(
spacesToNextTabStop
);
col
+=
spacesToNextTabStop
;
col
+=
spacesToNextTabStop
;
break
;
break
;
case
'\n'
:
t
<<
'\n'
;
col
=
0
;
case
'\n'
:
t
<<
"
\n
"
;
col
=
0
;
break
;
break
;
//case '\n': t << "<br>"; col=0;
// break;
case
'\r'
:
break
;
case
'\r'
:
break
;
case
'<'
:
t
<<
"<"
;
col
++
;
case
'<'
:
t
<<
"<"
;
col
++
;
break
;
break
;
...
@@ -852,6 +855,8 @@ void HtmlGenerator::codify(const char *str)
...
@@ -852,6 +855,8 @@ void HtmlGenerator::codify(const char *str)
break
;
break
;
case
'&'
:
t
<<
"&"
;
col
++
;
case
'&'
:
t
<<
"&"
;
col
++
;
break
;
break
;
//case ' ': t << " "; col++;
// break;
case
'\\'
:
case
'\\'
:
if
(
*
p
==
'<'
)
if
(
*
p
==
'<'
)
{
t
<<
"<"
;
p
++
;
}
{
t
<<
"<"
;
p
++
;
}
...
...
src/index.cpp
View file @
5a640083
...
@@ -1707,34 +1707,24 @@ static void writeMemberIndexFiltered(OutputList &ol, ClassMemberHighlight hl)
...
@@ -1707,34 +1707,24 @@ static void writeMemberIndexFiltered(OutputList &ol, ClassMemberHighlight hl)
numPages
=
127
;
numPages
=
127
;
}
}
struct
struct
CmhlInfo
{
{
CmhlInfo
(
const
char
*
fn
,
const
char
*
t
)
:
fname
(
fn
),
title
(
t
)
{}
const
char
*
fname
;
const
char
*
fname
;
QCString
title
;
QCString
title
;
}
cmhlInfo
[]
=
}
cmhlInfo
[]
=
{
{
{
"functions"
,
0
},
CmhlInfo
(
"functions"
,
theTranslator
->
trAll
()),
{
"functions_func"
,
0
},
CmhlInfo
(
"functions_func"
,
theTranslator
->
trFunctions
()),
{
"functions_vars"
,
0
},
CmhlInfo
(
"functions_vars"
,
theTranslator
->
trVariables
()),
{
"functions_type"
,
0
},
CmhlInfo
(
"functions_type"
,
theTranslator
->
trTypedefs
()),
{
"functions_enum"
,
0
},
CmhlInfo
(
"functions_enum"
,
theTranslator
->
trEnumerations
()),
{
"functions_eval"
,
0
},
CmhlInfo
(
"functions_eval"
,
theTranslator
->
trEnumerationValues
()),
{
"functions_rela"
,
0
},
CmhlInfo
(
"functions_prop"
,
theTranslator
->
trProperties
()),
{
"functions_prop"
,
0
},
CmhlInfo
(
"functions_evnt"
,
theTranslator
->
trEvents
()),
{
"functions_evnt"
,
0
},
CmhlInfo
(
"functions_rela"
,
theTranslator
->
trRelatedFunctions
())
{
"functions_rela"
,
0
},
};
};
cmhlInfo
[
0
].
title
=
theTranslator
->
trAll
();
cmhlInfo
[
1
].
title
=
theTranslator
->
trFunctions
();
cmhlInfo
[
2
].
title
=
theTranslator
->
trVariables
();
cmhlInfo
[
3
].
title
=
theTranslator
->
trTypedefs
();
cmhlInfo
[
4
].
title
=
theTranslator
->
trEnumerations
();
cmhlInfo
[
5
].
title
=
theTranslator
->
trEnumerationValues
();
cmhlInfo
[
6
].
title
=
theTranslator
->
trProperties
();
cmhlInfo
[
7
].
title
=
theTranslator
->
trEvents
();
cmhlInfo
[
8
].
title
=
theTranslator
->
trRelatedFunctions
();
ol
.
pushGeneratorState
();
ol
.
pushGeneratorState
();
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
...
@@ -2114,27 +2104,21 @@ static void writeFileMemberIndexFiltered(OutputList &ol, FileMemberHighlight hl)
...
@@ -2114,27 +2104,21 @@ static void writeFileMemberIndexFiltered(OutputList &ol, FileMemberHighlight hl)
numPages
=
127
;
numPages
=
127
;
}
}
struct
struct
FmhlInfo
{
{
FmhlInfo
(
const
char
*
fn
,
const
char
*
t
)
:
fname
(
fn
),
title
(
t
)
{}
const
char
*
fname
;
const
char
*
fname
;
QCString
title
;
QCString
title
;
}
fmhlInfo
[]
=
}
fmhlInfo
[]
=
{
{
{
"globals"
,
0
}
,
FmhlInfo
(
"globals"
,
theTranslator
->
trAll
())
,
{
"globals_func"
,
0
}
,
FmhlInfo
(
"globals_func"
,
theTranslator
->
trFunctions
())
,
{
"globals_vars"
,
0
}
,
FmhlInfo
(
"globals_vars"
,
theTranslator
->
trVariables
())
,
{
"globals_type"
,
0
}
,
FmhlInfo
(
"globals_type"
,
theTranslator
->
trTypedefs
())
,
{
"globals_enum"
,
0
}
,
FmhlInfo
(
"globals_enum"
,
theTranslator
->
trEnumerations
())
,
{
"globals_eval"
,
0
}
,
FmhlInfo
(
"globals_eval"
,
theTranslator
->
trEnumerationValues
())
,
{
"globals_defs"
,
0
}
FmhlInfo
(
"globals_defs"
,
theTranslator
->
trDefines
())
};
};
fmhlInfo
[
0
].
title
=
theTranslator
->
trAll
();
fmhlInfo
[
1
].
title
=
theTranslator
->
trFunctions
();
fmhlInfo
[
2
].
title
=
theTranslator
->
trVariables
();
fmhlInfo
[
3
].
title
=
theTranslator
->
trTypedefs
();
fmhlInfo
[
4
].
title
=
theTranslator
->
trEnumerations
();
fmhlInfo
[
5
].
title
=
theTranslator
->
trEnumerationValues
();
fmhlInfo
[
6
].
title
=
theTranslator
->
trDefines
();
ol
.
pushGeneratorState
();
ol
.
pushGeneratorState
();
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
...
@@ -2241,25 +2225,20 @@ static void writeNamespaceMemberIndexFiltered(OutputList &ol,
...
@@ -2241,25 +2225,20 @@ static void writeNamespaceMemberIndexFiltered(OutputList &ol,
numPages
=
127
;
numPages
=
127
;
}
}
struct
struct
NmhlInfo
{
{
NmhlInfo
(
const
char
*
fn
,
const
char
*
t
)
:
fname
(
fn
),
title
(
t
)
{}
const
char
*
fname
;
const
char
*
fname
;
QCString
title
;
QCString
title
;
}
nmhlInfo
[]
=
}
nmhlInfo
[]
=
{
{
{
"namespacemembers"
,
0
}
,
NmhlInfo
(
"namespacemembers"
,
theTranslator
->
trAll
())
,
{
"namespacemembers_func"
,
0
}
,
NmhlInfo
(
"namespacemembers_func"
,
theTranslator
->
trFunctions
())
,
{
"namespacemembers_vars"
,
0
}
,
NmhlInfo
(
"namespacemembers_vars"
,
theTranslator
->
trVariables
())
,
{
"namespacemembers_type"
,
0
}
,
NmhlInfo
(
"namespacemembers_type"
,
theTranslator
->
trTypedefs
())
,
{
"namespacemembers_enum"
,
0
}
,
NmhlInfo
(
"namespacemembers_enum"
,
theTranslator
->
trEnumerations
())
,
{
"namespacemembers_eval"
,
0
}
NmhlInfo
(
"namespacemembers_eval"
,
theTranslator
->
trEnumerationValues
())
};
};
nmhlInfo
[
0
].
title
=
theTranslator
->
trAll
();
nmhlInfo
[
1
].
title
=
theTranslator
->
trFunctions
();
nmhlInfo
[
2
].
title
=
theTranslator
->
trVariables
();
nmhlInfo
[
3
].
title
=
theTranslator
->
trTypedefs
();
nmhlInfo
[
4
].
title
=
theTranslator
->
trEnumerations
();
nmhlInfo
[
5
].
title
=
theTranslator
->
trEnumerationValues
();
ol
.
pushGeneratorState
();
ol
.
pushGeneratorState
();
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
ol
.
disableAllBut
(
OutputGenerator
::
Html
);
...
...
src/memberdef.cpp
View file @
5a640083
...
@@ -509,7 +509,11 @@ bool MemberDef::hasExamples()
...
@@ -509,7 +509,11 @@ bool MemberDef::hasExamples()
QCString
MemberDef
::
getOutputFileBase
()
const
QCString
MemberDef
::
getOutputFileBase
()
const
{
{
QCString
baseName
;
QCString
baseName
;
if
(
m_templateMaster
)
if
(
explicitOutputFileBase
)
{
return
explicitOutputFileBase
;
}
else
if
(
m_templateMaster
)
{
{
return
m_templateMaster
->
getOutputFileBase
();
return
m_templateMaster
->
getOutputFileBase
();
}
}
...
@@ -835,6 +839,10 @@ void MemberDef::writeDeclaration(OutputList &ol,
...
@@ -835,6 +839,10 @@ void MemberDef::writeDeclaration(OutputList &ol,
// hide members whose brief section should not be visible
// hide members whose brief section should not be visible
//if (!isBriefSectionVisible()) return;
//if (!isBriefSectionVisible()) return;
Definition
*
d
=
0
;
ASSERT
(
cd
!=
0
||
nd
!=
0
||
fd
!=
0
||
gd
!=
0
);
// member should belong to something
if
(
cd
)
d
=
cd
;
else
if
(
nd
)
d
=
nd
;
else
if
(
fd
)
d
=
fd
;
else
d
=
gd
;
// write tag file information of this member
// write tag file information of this member
if
(
!
Config_getString
(
"GENERATE_TAGFILE"
).
isEmpty
())
if
(
!
Config_getString
(
"GENERATE_TAGFILE"
).
isEmpty
())
{
{
...
@@ -875,6 +883,7 @@ void MemberDef::writeDeclaration(OutputList &ol,
...
@@ -875,6 +883,7 @@ void MemberDef::writeDeclaration(OutputList &ol,
Doxygen
::
tagFile
<<
"
\"
>"
<<
endl
;
Doxygen
::
tagFile
<<
"
\"
>"
<<
endl
;
Doxygen
::
tagFile
<<
" <type>"
<<
convertToXML
(
typeString
())
<<
"</type>"
<<
endl
;
Doxygen
::
tagFile
<<
" <type>"
<<
convertToXML
(
typeString
())
<<
"</type>"
<<
endl
;
Doxygen
::
tagFile
<<
" <name>"
<<
convertToXML
(
name
())
<<
"</name>"
<<
endl
;
Doxygen
::
tagFile
<<
" <name>"
<<
convertToXML
(
name
())
<<
"</name>"
<<
endl
;
Doxygen
::
tagFile
<<
" <anchorfile>"
<<
convertToXML
(
getOutputFileBase
()
+
Doxygen
::
htmlFileExtension
)
<<
"</anchorfile>"
<<
endl
;
Doxygen
::
tagFile
<<
" <anchor>"
<<
convertToXML
(
anchor
())
<<
"</anchor>"
<<
endl
;
Doxygen
::
tagFile
<<
" <anchor>"
<<
convertToXML
(
anchor
())
<<
"</anchor>"
<<
endl
;
Doxygen
::
tagFile
<<
" <arglist>"
<<
convertToXML
(
argsString
())
<<
"</arglist>"
<<
endl
;
Doxygen
::
tagFile
<<
" <arglist>"
<<
convertToXML
(
argsString
())
<<
"</arglist>"
<<
endl
;
writeDocAnchorsToTagFile
();
writeDocAnchorsToTagFile
();
...
@@ -889,9 +898,6 @@ void MemberDef::writeDeclaration(OutputList &ol,
...
@@ -889,9 +898,6 @@ void MemberDef::writeDeclaration(OutputList &ol,
Doxygen
::
searchIndex
->
addWord
(
qualifiedName
(),
FALSE
);
Doxygen
::
searchIndex
->
addWord
(
qualifiedName
(),
FALSE
);
}
}
Definition
*
d
=
0
;
ASSERT
(
cd
!=
0
||
nd
!=
0
||
fd
!=
0
||
gd
!=
0
);
// member should belong to something
if
(
cd
)
d
=
cd
;
else
if
(
nd
)
d
=
nd
;
else
if
(
fd
)
d
=
fd
;
else
d
=
gd
;
QCString
cname
=
d
->
name
();
QCString
cname
=
d
->
name
();
QCString
cfname
=
getOutputFileBase
();
QCString
cfname
=
getOutputFileBase
();
QCString
osname
=
cname
;
QCString
osname
=
cname
;
...
@@ -2080,12 +2086,15 @@ void MemberDef::addListReference(Definition *)
...
@@ -2080,12 +2086,15 @@ void MemberDef::addListReference(Definition *)
}
}
QCString
memName
=
name
();
QCString
memName
=
name
();
Definition
*
pd
=
getOuterScope
();
Definition
*
pd
=
getOuterScope
();
if
((
!
Config_getBool
(
"HIDE_SCOPE_NAMES"
)
&&
// there is a scope
if
(
!
isRelated
()
&&
(
(
!
Config_getBool
(
"HIDE_SCOPE_NAMES"
)
&&
// there is a scope
pd
&&
pd
!=
Doxygen
::
globalScope
)
// and we can show it
pd
&&
pd
!=
Doxygen
::
globalScope
)
// and we can show it
||
||
((
pd
=
getClassDef
())
&&
!
isRelated
())
// it's a class so we
(
pd
=
getClassDef
())
// it's a class so we
// show the scope anyway
// show the scope anyway
)
)
)
{
{
if
(
Config_getBool
(
"OPTIMIZE_OUTPUT_JAVA"
))
if
(
Config_getBool
(
"OPTIMIZE_OUTPUT_JAVA"
))
{
{
...
@@ -2328,3 +2337,13 @@ QCString MemberDef::qualifiedName()
...
@@ -2328,3 +2337,13 @@ QCString MemberDef::qualifiedName()
}
}
}
}
void
MemberDef
::
setTagInfo
(
TagInfo
*
ti
)
{
if
(
ti
)
{
setAnchor
(
ti
->
anchor
);
setReference
(
ti
->
tagName
);
explicitOutputFileBase
=
stripExtension
(
ti
->
fileName
);
}
}
src/memberdef.h
View file @
5a640083
...
@@ -182,6 +182,7 @@ class MemberDef : public Definition
...
@@ -182,6 +182,7 @@ class MemberDef : public Definition
void
setHasDocumentedParams
(
bool
b
)
{
m_hasDocumentedParams
=
b
;
}
void
setHasDocumentedParams
(
bool
b
)
{
m_hasDocumentedParams
=
b
;
}
void
setHasDocumentedReturnType
(
bool
b
)
{
m_hasDocumentedReturnType
=
b
;
}
void
setHasDocumentedReturnType
(
bool
b
)
{
m_hasDocumentedReturnType
=
b
;
}
void
setInheritsDocsFrom
(
MemberDef
*
md
)
{
m_docProvider
=
md
;
}
void
setInheritsDocsFrom
(
MemberDef
*
md
)
{
m_docProvider
=
md
;
}
void
setTagInfo
(
TagInfo
*
i
);
// output generation
// output generation
void
writeLink
(
OutputList
&
ol
,
void
writeLink
(
OutputList
&
ol
,
...
@@ -400,6 +401,9 @@ class MemberDef : public Definition
...
@@ -400,6 +401,9 @@ class MemberDef : public Definition
// documentation inheritance
// documentation inheritance
MemberDef
*
m_docProvider
;
MemberDef
*
m_docProvider
;
// to store the output file base from tag files
QCString
explicitOutputFileBase
;
};
};
#endif
#endif
src/pre.l
View file @
5a640083
...
@@ -100,6 +100,7 @@ static bool g_expandOnlyPredef; // from the configuration
...
@@ -100,6 +100,7 @@ static bool g_expandOnlyPredef; // from the configuration
static int g_commentCount;
static int g_commentCount;
static bool g_insideComment;
static bool g_insideComment;
static bool g_isImported;
static bool g_isImported;
static QCString g_blockName;
static void setFileName(const char *name)
static void setFileName(const char *name)
...
@@ -1776,14 +1777,18 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
...
@@ -1776,14 +1777,18 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
outputChar('/');outputChar('*');
outputChar('/');outputChar('*');
//g_commentCount++;
//g_commentCount++;
}
}
<SkipCComment>[\\@]
"verbatim"
{BN}+ {
<SkipCComment>[\\@]
("verbatim"|"latexonly"|"htmlonly"|"xmlonly"|"rtfonly"|"manonly"|"dot"|"code")
{BN}+ {
outputArray(yytext,yyleng);
outputArray(yytext,yyleng);
g_blockName=&yytext[1];
BEGIN(SkipVerbatim);
BEGIN(SkipVerbatim);
}
}
<SkipVerbatim>[\\@]
"endverbatim" {
<SkipVerbatim>[\\@]
("endverbatim"|"endlatexonly"|"endhtmlonly"|"endxmlonly"|"endrtfonly"|"endmanonly"|"enddot"|"endcode") { /* end of verbatim block */
outputArray(yytext,yyleng);
outputArray(yytext,yyleng);
if (&yytext[4]==g_blockName)
{
BEGIN(SkipCComment);
BEGIN(SkipCComment);
}
}
}
<SkipCComment,SkipVerbatim>[^*\x06\n\/]+ {
<SkipCComment,SkipVerbatim>[^*\x06\n\/]+ {
outputArray(yytext,yyleng);
outputArray(yytext,yyleng);
}
}
...
...
src/scanner.l
View file @
5a640083
...
@@ -2121,7 +2121,12 @@ IDLATTR ("["[^\]]*"]"){BN}*
...
@@ -2121,7 +2121,12 @@ IDLATTR ("["[^\]]*"]"){BN}*
<FindMembers,FindFields>("//"([!/]?){B}*{CMD}"{")|("/*"([!*]?){B}*{CMD}"{") {
<FindMembers,FindFields>("//"([!/]?){B}*{CMD}"{")|("/*"([!*]?){B}*{CMD}"{") {
#ifdef COMMENTSCAN
#ifdef COMMENTSCAN
REJECT;
Entry *tmp = current;
current = previous;
handleGroupStartCommand(current->name);
current = tmp;
initEntry();
#else
#else
startGroup();
startGroup();
tmpDocType=-1;
tmpDocType=-1;
...
@@ -2154,7 +2159,7 @@ IDLATTR ("["[^\]]*"]"){BN}*
...
@@ -2154,7 +2159,7 @@ IDLATTR ("["[^\]]*"]"){BN}*
}
}
<FindMembers,FindFields,ReadInitializer>"//"([!/]?){B}*{CMD}"}".*|"/*"([!*]?){B}*{CMD}"}".*"*/" {
<FindMembers,FindFields,ReadInitializer>"//"([!/]?){B}*{CMD}"}".*|"/*"([!*]?){B}*{CMD}"}".*"*/" {
#ifdef COMMENTSCAN
#ifdef COMMENTSCAN
REJECT
;
handleGroupEndCommand()
;
#else
#else
if (memberGroupId==DOX_NOGROUP && autoGroupStack.isEmpty())
if (memberGroupId==DOX_NOGROUP && autoGroupStack.isEmpty())
{
{
...
@@ -3266,7 +3271,7 @@ IDLATTR ("["[^\]]*"]"){BN}*
...
@@ -3266,7 +3271,7 @@ IDLATTR ("["[^\]]*"]"){BN}*
<FuncQual>[{:;,] {
<FuncQual>[{:;,] {
if ( strcmp(yytext,";")==0 &&
if ( strcmp(yytext,";")==0 &&
insidePHP &&
insidePHP &&
current->type.left(8) != "function"
)
!containsWord(current->type,"function")
)
{
{
current->reset();
current->reset();
initEntry();
initEntry();
...
@@ -3497,26 +3502,24 @@ IDLATTR ("["[^\]]*"]"){BN}*
...
@@ -3497,26 +3502,24 @@ IDLATTR ("["[^\]]*"]"){BN}*
//printf("Adding entry `%s'\n",current->name.data());
//printf("Adding entry `%s'\n",current->name.data());
if ( insidePHP)
if ( insidePHP)
{
{
if (
current->type.left(6) == "final "
)
if (
findAndRemoveWord(current->type,"final")
)
{
{
current->type = current->type.mid(6);
current->memSpec |= Entry::Final;
current->memSpec |= Entry::Final;
}
}
if (
current->type.left(9) == "abstract "
)
if (
findAndRemoveWord(current->type,"abstract")
)
{
{
current->type = current->type.mid(9);
current->memSpec |= Entry::Abstract;
current->memSpec |= Entry::Abstract;
}
}
}
}
if ( insidePHP &&
current->type.left(8) != "function"
)
if ( insidePHP &&
!containsWord(current->type,"function")
)
{
{
initEntry();
initEntry();
}
}
else
else
{
{
if ( insidePHP
&& current->type.left(8) == "function"
)
if ( insidePHP)
{
{
current->type = current->type.mid(8
);
findAndRemoveWord(current->type,"function"
);
}
}
previous = current;
previous = current;
current_root->addSubEntry(current);
current_root->addSubEntry(current);
...
@@ -4303,7 +4306,7 @@ IDLATTR ("["[^\]]*"]"){BN}*
...
@@ -4303,7 +4306,7 @@ IDLATTR ("["[^\]]*"]"){BN}*
<FindMembers>"{" {
<FindMembers>"{" {
if (insideCS && !current->name.isEmpty() && !current->type.isEmpty())
if (insideCS && !current->name.isEmpty() && !current->type.isEmpty())
{
{
if (c
urrent->type.left(6)=="event " || current->type.find("event")!=-1
) // event
if (c
ontainsWord(current->type,"event")
) // event
{
{
current->mtype = mtype = Event;
current->mtype = mtype = Event;
}
}
...
...
src/tagreader.cpp
View file @
5a640083
This diff is collapsed.
Click to expand it.
src/translator.h
View file @
5a640083
...
@@ -433,6 +433,12 @@ class Translator
...
@@ -433,6 +433,12 @@ class Translator
virtual
QCString
trDirReference
(
const
char
*
dirName
)
=
0
;
virtual
QCString
trDirReference
(
const
char
*
dirName
)
=
0
;
virtual
QCString
trDir
(
bool
first_capital
,
bool
singular
)
=
0
;
virtual
QCString
trDir
(
bool
first_capital
,
bool
singular
)
=
0
;
//////////////////////////////////////////////////////////////////////////
// new since 1.4.1
//////////////////////////////////////////////////////////////////////////
virtual
QCString
trOverloadText
()
=
0
;
};
};
#endif
#endif
src/translator_adapter.h
View file @
5a640083
...
@@ -40,7 +40,17 @@ class TranslatorAdapterBase : public Translator
...
@@ -40,7 +40,17 @@ class TranslatorAdapterBase : public Translator
};
};
class
TranslatorAdapter_1_3_9
:
public
TranslatorAdapterBase
class
TranslatorAdapter_1_4_1
:
public
TranslatorAdapterBase
{
public
:
virtual
QCString
updateNeededMessage
()
{
return
createUpdateNeededMessage
(
idLanguage
(),
"release 1.4.1"
);
}
virtual
QCString
trOverloadText
()
{
return
english
.
trOverloadText
();
}
};
class
TranslatorAdapter_1_3_9
:
public
TranslatorAdapter_1_4_1
{
{
public
:
public
:
virtual
QCString
updateNeededMessage
()
virtual
QCString
updateNeededMessage
()
...
...
src/translator_br.h
View file @
5a640083
...
@@ -34,7 +34,7 @@
...
@@ -34,7 +34,7 @@
#ifndef TRANSLATOR_BR_H
#ifndef TRANSLATOR_BR_H
#define TRANSLATOR_BR_H
#define TRANSLATOR_BR_H
class
TranslatorBrazilian
:
public
Translator
class
TranslatorBrazilian
:
public
Translator
Adapter_1_4_1
{
{
public
:
public
:
...
...
src/translator_cn.h
View file @
5a640083
...
@@ -24,7 +24,7 @@
...
@@ -24,7 +24,7 @@
*/
*/
#define CN_SPC
#define CN_SPC
class
TranslatorChinese
:
public
Translator
class
TranslatorChinese
:
public
Translator
Adapter_1_4_1
{
{
public
:
public
:
/*! Used for identification of the language. The identification
/*! Used for identification of the language. The identification
...
@@ -83,9 +83,6 @@ class TranslatorChinese : public Translator
...
@@ -83,9 +83,6 @@ class TranslatorChinese : public Translator
virtual
QCString
trMemberEnumerationDocumentation
()
virtual
QCString
trMemberEnumerationDocumentation
()
{
return
"成员枚举类型文档"
;
}
{
return
"成员枚举类型文档"
;
}
virtual
QCString
trEnumerationValueDocumentation
()
{
return
"成员枚举值文档"
;
}
/*! header that is put before the list of member function. */
/*! header that is put before the list of member function. */
virtual
QCString
trMemberFunctionDocumentation
()
virtual
QCString
trMemberFunctionDocumentation
()
{
return
"成员函数文档"
;
}
{
return
"成员函数文档"
;
}
...
@@ -173,11 +170,6 @@ class TranslatorChinese : public Translator
...
@@ -173,11 +170,6 @@ class TranslatorChinese : public Translator
virtual
QCString
trFileList
()
virtual
QCString
trFileList
()
{
return
"文件列表"
;
}
{
return
"文件列表"
;
}
/*! This is put above each page as a link to the list of all verbatim headers */
virtual
QCString
trHeaderFiles
()
{
return
"头文件"
;
}
/*! This is put above each page as a link to all members of compounds. */
/*! This is put above each page as a link to all members of compounds. */
virtual
QCString
trCompoundMembers
()
virtual
QCString
trCompoundMembers
()
{
{
...
@@ -286,9 +278,6 @@ class TranslatorChinese : public Translator
...
@@ -286,9 +278,6 @@ class TranslatorChinese : public Translator
return
result
;
return
result
;
}
}
virtual
QCString
trHeaderFilesDescription
()
{
return
"这里列出组成API的头文件:"
;
}
virtual
QCString
trExamplesDescription
()
virtual
QCString
trExamplesDescription
()
{
return
"这里列出所有示例:"
;
}
{
return
"这里列出所有示例:"
;
}
...
@@ -298,9 +287,6 @@ class TranslatorChinese : public Translator
...
@@ -298,9 +287,6 @@ class TranslatorChinese : public Translator
virtual
QCString
trModulesDescription
()
virtual
QCString
trModulesDescription
()
{
return
"这里列出所有模块"
;
}
{
return
"这里列出所有模块"
;
}
virtual
QCString
trNoDescriptionAvailable
()
{
return
"无可用文档"
;
}
virtual
QCString
trDocumentation
()
virtual
QCString
trDocumentation
()
{
return
"文档"
;
}
{
return
"文档"
;
}
...
@@ -422,16 +408,9 @@ class TranslatorChinese : public Translator
...
@@ -422,16 +408,9 @@ class TranslatorChinese : public Translator
virtual
QCString
trForInternalUseOnly
()
virtual
QCString
trForInternalUseOnly
()
{
return
"仅限内部使用。"
;
}
{
return
"仅限内部使用。"
;
}
virtual
QCString
trReimplementedForInternalReasons
()
{
return
"由于内部原因被重载;但不影响API"
;
}
virtual
QCString
trWarning
()
virtual
QCString
trWarning
()
{
return
"警告"
;
}
{
return
"警告"
;
}
virtual
QCString
trBugsAndLimitations
()
{
return
"BUG"
CN_SPC
"与局限"
;
}
virtual
QCString
trVersion
()
virtual
QCString
trVersion
()
{
return
"版本"
;
}
{
return
"版本"
;
}
...
@@ -698,11 +677,6 @@ class TranslatorChinese : public Translator
...
@@ -698,11 +677,6 @@ class TranslatorChinese : public Translator
// new since 0.49-991106
// new since 0.49-991106
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
virtual
QCString
trSources
()
{
return
"源代码"
;
}
virtual
QCString
trDefinedAtLineInSourceFile
()
virtual
QCString
trDefinedAtLineInSourceFile
()
{
{
return
"在文件"
CN_SPC
"@1"
CN_SPC
"第"
CN_SPC
"@0"
CN_SPC
"行定义。"
;
return
"在文件"
CN_SPC
"@1"
CN_SPC
"第"
CN_SPC
"@0"
CN_SPC
"行定义。"
;
...
@@ -1025,12 +999,6 @@ class TranslatorChinese : public Translator
...
@@ -1025,12 +999,6 @@ class TranslatorChinese : public Translator
// new since 1.2.4
// new since 1.2.4
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
/*! Used for Java interfaces in the summary section of Java packages */
virtual
QCString
trInterfaces
()
{
return
"接口"
;
}
/*! Used for Java classes in the summary section of Java packages */
/*! Used for Java classes in the summary section of Java packages */
virtual
QCString
trClasses
()
virtual
QCString
trClasses
()
{
{
...
@@ -1068,12 +1036,6 @@ class TranslatorChinese : public Translator
...
@@ -1068,12 +1036,6 @@ class TranslatorChinese : public Translator
return
"包"
;
return
"包"
;
}
}
/*! Used as a chapter title for Latex & RTF output */
virtual
QCString
trPackageDocumentation
()
{
return
"包的文档"
;
}
/*! Text shown before a multi-line define */
/*! Text shown before a multi-line define */
virtual
QCString
trDefineValue
()
virtual
QCString
trDefineValue
()
{
{
...
@@ -1228,20 +1190,6 @@ class TranslatorChinese : public Translator
...
@@ -1228,20 +1190,6 @@ class TranslatorChinese : public Translator
return
"成员"
;
return
"成员"
;
}
}
/*! This is used for translation of the word that will possibly
* be followed by a single name or by a list of names
* of the category.
*/
virtual
QCString
trField
(
bool
/*first_capital*/
,
bool
/*singular*/
)
{
/*
QCString result((first_capital ? "Field" : "field"));
if (!singular) result+="s";
return result;
*/
return
"字段"
;
}
/*! This is used for translation of the word that will possibly
/*! This is used for translation of the word that will possibly
* be followed by a single name or by a list of names
* be followed by a single name or by a list of names
* of the category.
* of the category.
...
@@ -1492,7 +1440,7 @@ class TranslatorChinese : public Translator
...
@@ -1492,7 +1440,7 @@ class TranslatorChinese : public Translator
virtual
QCString
trDirIndex
()
virtual
QCString
trDirIndex
()
/* { return "Directory Hierarchy"; } */
/* { return "Directory Hierarchy"; } */
{
{
return
"
$(BL
\\
录结$(DC((B
"
;
return
"
目录结构
"
;
}
}
/*! This is used as the name of the chapter containing the documentation
/*! This is used as the name of the chapter containing the documentation
...
@@ -1501,7 +1449,7 @@ class TranslatorChinese : public Translator
...
@@ -1501,7 +1449,7 @@ class TranslatorChinese : public Translator
virtual
QCString
trDirDocumentation
()
virtual
QCString
trDirDocumentation
()
/* { return "Directory Documentation"; } */
/* { return "Directory Documentation"; } */
{
{
return
"
$(BL
\\
录J8[c(B
"
;
return
"
目录文档
"
;
}
}
/*! This is used as the title of the directory index and also in the
/*! This is used as the title of the directory index and also in the
...
@@ -1510,7 +1458,7 @@ class TranslatorChinese : public Translator
...
@@ -1510,7 +1458,7 @@ class TranslatorChinese : public Translator
virtual
QCString
trDirectories
()
virtual
QCString
trDirectories
()
/* { return "Directories"; } */
/* { return "Directories"; } */
{
{
return
"
$(BL
\\
录(B
"
;
return
"
目录
"
;
}
}
/*! This returns a sentences that introduces the directory hierarchy.
/*! This returns a sentences that introduces the directory hierarchy.
...
@@ -1521,7 +1469,7 @@ class TranslatorChinese : public Translator
...
@@ -1521,7 +1469,7 @@ class TranslatorChinese : public Translator
/* "but not completely, alphabetically:"; */
/* "but not completely, alphabetically:"; */
/* } */
/* } */
{
{
return
"
$(BL
\\
录结$(DC(仅经过$(BBgCWE*GSNs!$VuL$40A40D;zJl顺=x(B
"
;
return
"
目录结构仅经过粗略的排序
"
;
}
}
/*! This returns the title of a directory page. The name of the
/*! This returns the title of a directory page. The name of the
...
@@ -1531,7 +1479,7 @@ class TranslatorChinese : public Translator
...
@@ -1531,7 +1479,7 @@ class TranslatorChinese : public Translator
/* { QCString result=dirName; result+=" Directory Reference"; return result; } */
/* { QCString result=dirName; result+=" Directory Reference"; return result; } */
{
{
QCString
result
=
dirName
;
QCString
result
=
dirName
;
result
+=
CN_SPC
"
$(BL
\\
录;29M(B
"
;
result
+=
CN_SPC
"
目录参考
"
;
return
result
;
return
result
;
}
}
...
@@ -1543,9 +1491,10 @@ class TranslatorChinese : public Translator
...
@@ -1543,9 +1491,10 @@ class TranslatorChinese : public Translator
/* QCString result((first_capital ? "Director" : "director")); */
/* QCString result((first_capital ? "Director" : "director")); */
/* if (singular) result+="y"; else result+="ies"; */
/* if (singular) result+="y"; else result+="ies"; */
/* return result; */
/* return result; */
return
"
$(BL
\\
录(B
"
;
return
"
目录
"
;
}
}
};
};
#endif
#endif
src/translator_cz.h
View file @
5a640083
...
@@ -151,7 +151,7 @@
...
@@ -151,7 +151,7 @@
// Windows version. The version which does not call the function is
// Windows version. The version which does not call the function is
// probably slightly faster.
// probably slightly faster.
class
TranslatorCzech
:
public
Translator
class
TranslatorCzech
:
public
Translator
Adapter_1_4_1
{
{
private
:
private
:
/*! The decode() inline assumes the source written in the
/*! The decode() inline assumes the source written in the
...
...
src/translator_de.h
View file @
5a640083
...
@@ -102,7 +102,7 @@
...
@@ -102,7 +102,7 @@
#ifndef TRANSLATOR_DE_H
#ifndef TRANSLATOR_DE_H
#define TRANSLATOR_DE_H
#define TRANSLATOR_DE_H
class
TranslatorGerman
:
public
Translator
class
TranslatorGerman
:
public
Translator
Adapter_1_4_1
{
{
public
:
public
:
...
...
src/translator_en.h
View file @
5a640083
...
@@ -1602,6 +1602,19 @@ class TranslatorEnglish : public Translator
...
@@ -1602,6 +1602,19 @@ class TranslatorEnglish : public Translator
return
result
;
return
result
;
}
}
//////////////////////////////////////////////////////////////////////////
// new since 1.4.1
//////////////////////////////////////////////////////////////////////////
/*! This text is added to the documentation when the \\overload command
* is used for a overloaded function.
*/
virtual
QCString
trOverloadText
()
{
return
"This is an overloaded member function, "
"provided for convenience. It differs from the above "
"function only in what argument(s) it accepts."
;
}
};
};
#endif
#endif
src/translator_fr.h
View file @
5a640083
...
@@ -85,7 +85,7 @@
...
@@ -85,7 +85,7 @@
// Translator class (by the local maintainer) when the localized
// Translator class (by the local maintainer) when the localized
// translator is made up-to-date again.
// translator is made up-to-date again.
class
TranslatorFrench
:
public
Translator
class
TranslatorFrench
:
public
Translator
Adapter_1_4_1
{
{
public
:
public
:
...
...
src/translator_hr.h
View file @
5a640083
...
@@ -58,11 +58,15 @@
...
@@ -58,11 +58,15 @@
//
//
// 2004/09/15
// 2004/09/15
// - Added strings for 1.3.9
// - Added strings for 1.3.9
//
// 2005/02/28
// - Removed obsolete (unused) methods
//
#ifndef TRANSLATOR_HR_H
#ifndef TRANSLATOR_HR_H
#define TRANSLATOR_HR_H
#define TRANSLATOR_HR_H
class
TranslatorCroatian
:
public
Translator
class
TranslatorCroatian
:
public
Translator
Adapter_1_4_1
{
{
private
:
private
:
/*! to avoid macro redefinition from translator_cz.h */
/*! to avoid macro redefinition from translator_cz.h */
...
@@ -104,8 +108,6 @@ class TranslatorCroatian : public Translator
...
@@ -104,8 +108,6 @@ class TranslatorCroatian : public Translator
{
return
decode
(
"Dokumentacija typedef lanova"
);
}
{
return
decode
(
"Dokumentacija typedef lanova"
);
}
QCString
trMemberEnumerationDocumentation
()
QCString
trMemberEnumerationDocumentation
()
{
return
decode
(
"Dokumentacija enumeracijskih lanova"
);
}
{
return
decode
(
"Dokumentacija enumeracijskih lanova"
);
}
QCString
trEnumerationValueDocumentation
()
{
return
"Dokumentacija enumeracijskih vrijednosti"
;
}
QCString
trMemberFunctionDocumentation
()
QCString
trMemberFunctionDocumentation
()
{
return
"Dokumentacija funkcija"
;
}
{
return
"Dokumentacija funkcija"
;
}
QCString
trMemberDataDocumentation
()
QCString
trMemberDataDocumentation
()
...
@@ -149,8 +151,6 @@ class TranslatorCroatian : public Translator
...
@@ -149,8 +151,6 @@ class TranslatorCroatian : public Translator
}
}
QCString
trFileList
()
QCString
trFileList
()
{
return
"Popis datoteka"
;
}
{
return
"Popis datoteka"
;
}
QCString
trHeaderFiles
()
{
return
"Header datoteke"
;
}
QCString
trCompoundMembers
()
QCString
trCompoundMembers
()
{
{
if
(
Config_getBool
(
"OPTIMIZE_OUTPUT_FOR_C"
))
if
(
Config_getBool
(
"OPTIMIZE_OUTPUT_FOR_C"
))
...
@@ -217,16 +217,12 @@ class TranslatorCroatian : public Translator
...
@@ -217,16 +217,12 @@ class TranslatorCroatian : public Translator
result
+=
"datoteke u kojima se nalaze:"
;
result
+=
"datoteke u kojima se nalaze:"
;
return
decode
(
result
);
return
decode
(
result
);
}
}
QCString
trHeaderFilesDescription
()
{
return
decode
(
"Popis header datoteka koje ine API :"
);
}
QCString
trExamplesDescription
()
QCString
trExamplesDescription
()
{
return
"Popis primjera :"
;
}
{
return
"Popis primjera :"
;
}
QCString
trRelatedPagesDescription
()
QCString
trRelatedPagesDescription
()
{
return
"Popis povezanih stranica:"
;
}
{
return
"Popis povezanih stranica:"
;
}
QCString
trModulesDescription
()
QCString
trModulesDescription
()
{
return
"Popis svih modula:"
;
}
{
return
"Popis svih modula:"
;
}
QCString
trNoDescriptionAvailable
()
{
return
"Opis nije dostupan"
;
}
QCString
trDocumentation
()
QCString
trDocumentation
()
{
return
"Dokumentacija"
;
}
{
return
"Dokumentacija"
;
}
...
@@ -314,14 +310,8 @@ class TranslatorCroatian : public Translator
...
@@ -314,14 +310,8 @@ class TranslatorCroatian : public Translator
}
}
QCString
trForInternalUseOnly
()
QCString
trForInternalUseOnly
()
{
return
decode
(
"Iskljuivo za internu uporabu."
);
}
{
return
decode
(
"Iskljuivo za internu uporabu."
);
}
QCString
trReimplementedForInternalReasons
()
{
return
decode
(
"Reimplementirano zbog internih razloga; "
"Nema utjecaja na API."
);
}
QCString
trWarning
()
QCString
trWarning
()
{
return
"Upozorenje"
;
}
{
return
"Upozorenje"
;
}
QCString
trBugsAndLimitations
()
{
return
decode
(
"Greke i ogranienja"
);
}
QCString
trVersion
()
QCString
trVersion
()
{
return
"Verzija"
;
}
{
return
"Verzija"
;
}
QCString
trDate
()
QCString
trDate
()
...
@@ -563,10 +553,6 @@ class TranslatorCroatian : public Translator
...
@@ -563,10 +553,6 @@ class TranslatorCroatian : public Translator
// new since 0.49-991106
// new since 0.49-991106
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
QCString
trSources
()
{
return
"Izvorne datoteke"
;
}
QCString
trDefinedAtLineInSourceFile
()
QCString
trDefinedAtLineInSourceFile
()
{
{
return
"Definirano u liniji @0 datoteke @1."
;
return
"Definirano u liniji @0 datoteke @1."
;
...
@@ -852,11 +838,6 @@ class TranslatorCroatian : public Translator
...
@@ -852,11 +838,6 @@ class TranslatorCroatian : public Translator
// new since 1.2.4
// new since 1.2.4
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
/*! Used for Java interfaces in the summary section of Java packages */
virtual
QCString
trInterfaces
()
{
return
decode
(
"Suelja (interfaces)"
);
}
/*! Used for Java classes in the summary section of Java packages */
/*! Used for Java classes in the summary section of Java packages */
virtual
QCString
trClasses
()
virtual
QCString
trClasses
()
{
{
...
@@ -882,11 +863,6 @@ class TranslatorCroatian : public Translator
...
@@ -882,11 +863,6 @@ class TranslatorCroatian : public Translator
{
{
return
"Paketi"
;
return
"Paketi"
;
}
}
/*! Used as a chapter title for Latex & RTF output */
virtual
QCString
trPackageDocumentation
()
{
return
"Dokumentacija paketa"
;
}
/*! Text shown before a multi-line define */
/*! Text shown before a multi-line define */
virtual
QCString
trDefineValue
()
virtual
QCString
trDefineValue
()
{
{
...
@@ -996,17 +972,6 @@ class TranslatorCroatian : public Translator
...
@@ -996,17 +972,6 @@ class TranslatorCroatian : public Translator
return
decode
(
result
);
return
decode
(
result
);
}
}
/*! This is used for translation of the word that will possibly
* be followed by a single name or by a list of names
* of the category.
*/
virtual
QCString
trField
(
bool
first_capital
,
bool
singular
)
{
QCString
result
((
first_capital
?
"Polj"
:
"polj"
));
result
+=
(
singular
?
"e"
:
"a"
);
return
result
;
}
/*! This is used for translation of the word that will possibly
/*! This is used for translation of the word that will possibly
* be followed by a single name or by a list of names
* be followed by a single name or by a list of names
* of the category.
* of the category.
...
...
src/translator_hu.h
View file @
5a640083
...
@@ -29,7 +29,7 @@
...
@@ -29,7 +29,7 @@
#ifndef TRANSLATOR_HU_H
#ifndef TRANSLATOR_HU_H
#define TRANSLATOR_HU_H
#define TRANSLATOR_HU_H
class
TranslatorHungarian
:
public
Translator
class
TranslatorHungarian
:
public
Translator
Adapter_1_4_1
{
{
private
:
private
:
const
char
*
zed
(
char
c
)
const
char
*
zed
(
char
c
)
...
...
src/translator_it.h
View file @
5a640083
...
@@ -72,7 +72,7 @@
...
@@ -72,7 +72,7 @@
#ifndef TRANSLATOR_IT_H
#ifndef TRANSLATOR_IT_H
#define TRANSLATOR_IT_H
#define TRANSLATOR_IT_H
class
TranslatorItalian
:
public
Translator
class
TranslatorItalian
:
public
Translator
Adapter_1_4_1
{
{
public
:
public
:
...
...
src/translator_nl.h
View file @
5a640083
...
@@ -1200,6 +1200,19 @@ class TranslatorDutch : public Translator
...
@@ -1200,6 +1200,19 @@ class TranslatorDutch : public Translator
return
result
;
return
result
;
}
}
//////////////////////////////////////////////////////////////////////////
// new since 1.4.1
//////////////////////////////////////////////////////////////////////////
/*! This text is added to the documentation when the \\overload command
* is used for a function.
*/
virtual
QCString
trOverloadText
()
{
return
"Deze functie is overloaded en is beschikbaar gemaakt om het "
"gebruik te vergemakkelijken. Ze verschilt alleen van de "
"bovenstaande functie wat betreft de parameterlijst."
;
}
};
};
...
...
src/translator_pl.h
View file @
5a640083
...
@@ -20,7 +20,7 @@
...
@@ -20,7 +20,7 @@
#ifndef TRANSLATOR_PL_H
#ifndef TRANSLATOR_PL_H
#define TRANSLATOR_PL_H
#define TRANSLATOR_PL_H
class
TranslatorPolish
:
public
Translator
class
TranslatorPolish
:
public
Translator
Adapter_1_4_1
{
{
private
:
private
:
/*! to avoid macro redefinition from translator_pl.h */
/*! to avoid macro redefinition from translator_pl.h */
...
...
src/translator_ro.h
View file @
5a640083
This diff is collapsed.
Click to expand it.
src/translator_ru.h
View file @
5a640083
...
@@ -49,7 +49,7 @@
...
@@ -49,7 +49,7 @@
#ifndef TRANSLATOR_RU_H
#ifndef TRANSLATOR_RU_H
#define TRANSLATOR_RU_H
#define TRANSLATOR_RU_H
class
TranslatorRussian
:
public
Translator
class
TranslatorRussian
:
public
Translator
Adapter_1_4_1
{
{
private
:
private
:
/*! The Decode() inline assumes the source written in the
/*! The Decode() inline assumes the source written in the
...
...
src/translator_se.h
View file @
5a640083
...
@@ -69,7 +69,7 @@ Problem!
...
@@ -69,7 +69,7 @@ Problem!
#ifndef TRANSLATOR_SE_H
#ifndef TRANSLATOR_SE_H
#define TRANSLATOR_SE_H
#define TRANSLATOR_SE_H
class
TranslatorSwedish
:
public
Translator
class
TranslatorSwedish
:
public
Translator
Adapter_1_4_1
{
{
public
:
public
:
...
...
src/translator_sr.h
View file @
5a640083
...
@@ -21,7 +21,7 @@
...
@@ -21,7 +21,7 @@
// translation by Dejan D. M. Milosavljevic <dmilos@email.com>;<dmilosx@ptt.yu>;<office@ddmrm.com>
// translation by Dejan D. M. Milosavljevic <dmilos@email.com>;<dmilosx@ptt.yu>;<office@ddmrm.com>
// // 10x 2 Ivana Miletic for gramatical consutation.
// // 10x 2 Ivana Miletic for gramatical consutation.
class
TranslatorSerbian
:
public
Translator
class
TranslatorSerbian
:
public
Translator
Adapter_1_4_1
{
{
private
:
private
:
QCString
decode
(
const
QCString
&
sInput
)
QCString
decode
(
const
QCString
&
sInput
)
...
...
src/translator_ua.h
View file @
5a640083
...
@@ -20,7 +20,7 @@
...
@@ -20,7 +20,7 @@
#ifndef TRANSLATOR_UA_H
#ifndef TRANSLATOR_UA_H
#define TRANSLATOR_UA_H
#define TRANSLATOR_UA_H
class
TranslatorUkrainian
:
public
Translator
class
TranslatorUkrainian
:
public
TranslatorAdapter_1_4_1
{
{
private
:
private
:
/*! The Decode() inline assumes the source written in the
/*! The Decode() inline assumes the source written in the
...
...
src/util.cpp
View file @
5a640083
...
@@ -752,6 +752,8 @@ static Definition *followPath(Definition *start,FileDef *fileScope,const QCStrin
...
@@ -752,6 +752,8 @@ static Definition *followPath(Definition *start,FileDef *fileScope,const QCStrin
if
(
current
==
0
)
break
;
// failed to follow the path
if
(
current
==
0
)
break
;
// failed to follow the path
ps
=
is
+
l
;
ps
=
is
+
l
;
}
}
//printf("followPath(start=%s,path=%s) result=%s\n",
// start->name().data(),path.data(),current?current->name().data():"<null>");
return
current
;
// path could be followed
return
current
;
// path could be followed
}
}
...
@@ -1101,7 +1103,7 @@ ClassDef *getResolvedClassRec(Definition *scope,
...
@@ -1101,7 +1103,7 @@ ClassDef *getResolvedClassRec(Definition *scope,
g_visitedNamespaces
.
clear
();
g_visitedNamespaces
.
clear
();
// test accessibility of definition within scope.
// test accessibility of definition within scope.
int
distance
=
isAccessibleFromWithExpScope
(
scope
,
fileScope
,
d
,
explicitScopePart
);
int
distance
=
isAccessibleFromWithExpScope
(
scope
,
fileScope
,
d
,
explicitScopePart
);
//printf("distance %s is %d\n",d->name().data(),distance);
//printf("
distance %s is %d\n",d->name().data(),distance);
if
(
distance
!=-
1
)
// definition is accessible
if
(
distance
!=-
1
)
// definition is accessible
{
{
// see if we are dealing with a class or a typedef
// see if we are dealing with a class or a typedef
...
@@ -1398,7 +1400,9 @@ void linkifyText(const TextGeneratorIntf &out,Definition *scope,
...
@@ -1398,7 +1400,9 @@ void linkifyText(const TextGeneratorIntf &out,Definition *scope,
int
floatingIndex
=
0
;
int
floatingIndex
=
0
;
if
(
strLen
==
0
)
return
;
if
(
strLen
==
0
)
return
;
// read a word from the text string
// read a word from the text string
while
((
newIndex
=
regExp
.
match
(
txtStr
,
index
,
&
matchLen
))
!=-
1
)
while
((
newIndex
=
regExp
.
match
(
txtStr
,
index
,
&
matchLen
))
!=-
1
&&
(
newIndex
==
0
||
!
(
txtStr
.
at
(
newIndex
-
1
)
>=
'0'
&&
txtStr
.
at
(
newIndex
-
1
)
<=
'9'
))
// avoid matching part of hex numbers
)
{
{
// add non-word part to the result
// add non-word part to the result
floatingIndex
+=
newIndex
-
skipIndex
;
floatingIndex
+=
newIndex
-
skipIndex
;
...
@@ -2979,7 +2983,6 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -2979,7 +2983,6 @@ bool getDefs(const QCString &scName,const QCString &memberName,
//printf("mScope=`%s' mName=`%s'\n",mScope.data(),mName.data());
//printf("mScope=`%s' mName=`%s'\n",mScope.data(),mName.data());
if
(
mName
.
isEmpty
())
printf
(
"memberName=%s
\n
"
,
memberName
.
data
());
MemberName
*
mn
=
Doxygen
::
memberNameSDict
[
mName
];
MemberName
*
mn
=
Doxygen
::
memberNameSDict
[
mName
];
if
(
!
forceEmptyScope
&&
mn
&&
!
(
scopeName
.
isEmpty
()
&&
mScope
.
isEmpty
()))
if
(
!
forceEmptyScope
&&
mn
&&
!
(
scopeName
.
isEmpty
()
&&
mScope
.
isEmpty
()))
{
{
...
@@ -3016,8 +3019,8 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3016,8 +3019,8 @@ bool getDefs(const QCString &scName,const QCString &memberName,
}
}
for
(
mmli
.
toFirst
();(
mmd
=
mmli
.
current
());
++
mmli
)
for
(
mmli
.
toFirst
();(
mmd
=
mmli
.
current
());
++
mmli
)
{
{
if
(
mmd
->
isLinkable
())
//
if (mmd->isLinkable())
{
//
{
bool
match
=
args
==
0
||
bool
match
=
args
==
0
||
matchArguments
(
mmd
->
argumentList
(),
argList
,
className
,
0
,
checkCV
);
matchArguments
(
mmd
->
argumentList
(),
argList
,
className
,
0
,
checkCV
);
//printf("match=%d\n",match);
//printf("match=%d\n",match);
...
@@ -3032,7 +3035,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3032,7 +3035,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
md
=
mmd
;
md
=
mmd
;
}
}
}
}
}
//
}
}
}
if
(
argList
)
if
(
argList
)
{
{
...
@@ -3044,29 +3047,38 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3044,29 +3047,38 @@ bool getDefs(const QCString &scName,const QCString &memberName,
//printf(" >Searching for arbitrary member\n");
//printf(" >Searching for arbitrary member\n");
for
(
mmli
.
toFirst
();(
mmd
=
mmli
.
current
());
++
mmli
)
for
(
mmli
.
toFirst
();(
mmd
=
mmli
.
current
());
++
mmli
)
{
{
if
(
mmd
->
isLinkable
())
//
if (mmd->isLinkable())
{
//
{
ClassDef
*
mcd
=
mmd
->
getClassDef
();
ClassDef
*
mcd
=
mmd
->
getClassDef
();
//printf(" >Class %s found\n",mcd->name().data());
//printf(" >Class %s found\n",mcd->name().data());
int
m
=
minClassDistance
(
fcd
,
mcd
);
int
m
=
minClassDistance
(
fcd
,
mcd
);
if
(
m
<
mdist
&&
mcd
->
isLinkable
()
)
if
(
m
<
mdist
/* && mcd->isLinkable()*/
)
{
{
//printf("Class distance %d\n",m);
//printf("Class distance %d\n",m);
mdist
=
m
;
mdist
=
m
;
cd
=
mcd
;
cd
=
mcd
;
md
=
mmd
;
md
=
mmd
;
}
}
}
//
}
}
}
}
}
//printf(" >Succes=%d\n",mdist<maxInheritanceDepth);
//printf(" >Succes=%d\n",mdist<maxInheritanceDepth);
if
(
mdist
<
maxInheritanceDepth
)
if
(
mdist
<
maxInheritanceDepth
)
{
if
(
!
md
->
isLinkable
())
{
md
=
0
;
// avoid returning things we cannot link to
cd
=
0
;
return
FALSE
;
// match found, but was not linkable
}
else
{
{
gd
=
md
->
getGroupDef
();
gd
=
md
->
getGroupDef
();
if
(
gd
)
cd
=
0
;
if
(
gd
)
cd
=
0
;
return
TRUE
;
/* found match */
return
TRUE
;
/* found match */
}
}
}
}
}
/* go to the parent scope */
/* go to the parent scope */
if
(
scopeOffset
==
0
)
if
(
scopeOffset
==
0
)
...
@@ -3115,7 +3127,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3115,7 +3127,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
{
{
//printf("mmd->getNamespaceDef()=%p fnd=%p\n",
//printf("mmd->getNamespaceDef()=%p fnd=%p\n",
// mmd->getNamespaceDef(),fnd);
// mmd->getNamespaceDef(),fnd);
if
(
mmd
->
getNamespaceDef
()
==
fnd
&&
mmd
->
isLinkable
()
)
if
(
mmd
->
getNamespaceDef
()
==
fnd
/* && mmd->isLinkable() */
)
{
// namespace is found
{
// namespace is found
bool
match
=
TRUE
;
bool
match
=
TRUE
;
ArgumentList
*
argList
=
0
;
ArgumentList
*
argList
=
0
;
...
@@ -3144,7 +3156,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3144,7 +3156,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
{
{
for
(
mmli
.
toFirst
();((
mmd
=
mmli
.
current
())
&&
!
found
);
++
mmli
)
for
(
mmli
.
toFirst
();((
mmd
=
mmli
.
current
())
&&
!
found
);
++
mmli
)
{
{
if
(
mmd
->
getNamespaceDef
()
==
fnd
&&
mmd
->
isLinkable
()
)
if
(
mmd
->
getNamespaceDef
()
==
fnd
/*&& mmd->isLinkable() */
)
{
{
nd
=
fnd
;
nd
=
fnd
;
md
=
mmd
;
md
=
mmd
;
...
@@ -3153,12 +3165,21 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3153,12 +3165,21 @@ bool getDefs(const QCString &scName,const QCString &memberName,
}
}
}
}
if
(
found
)
if
(
found
)
{
if
(
!
md
->
isLinkable
())
{
md
=
0
;
// avoid returning things we cannot link to
nd
=
0
;
return
FALSE
;
// match found but not linkable
}
else
{
{
gd
=
md
->
getGroupDef
();
gd
=
md
->
getGroupDef
();
if
(
gd
&&
gd
->
isLinkable
())
nd
=
0
;
else
gd
=
0
;
if
(
gd
&&
gd
->
isLinkable
())
nd
=
0
;
else
gd
=
0
;
return
TRUE
;
return
TRUE
;
}
}
}
}
}
if
(
scopeOffset
==
0
)
if
(
scopeOffset
==
0
)
{
{
scopeOffset
=-
1
;
scopeOffset
=-
1
;
...
@@ -3168,6 +3189,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3168,6 +3189,7 @@ bool getDefs(const QCString &scName,const QCString &memberName,
scopeOffset
=
0
;
scopeOffset
=
0
;
}
}
}
while
(
scopeOffset
>=
0
);
}
while
(
scopeOffset
>=
0
);
//else // no scope => global function
//else // no scope => global function
{
{
QList
<
MemberDef
>
members
;
QList
<
MemberDef
>
members
;
...
@@ -3176,8 +3198,8 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3176,8 +3198,8 @@ bool getDefs(const QCString &scName,const QCString &memberName,
MemberListIterator
mli
(
*
mn
);
MemberListIterator
mli
(
*
mn
);
for
(
mli
.
toFirst
();(
md
=
mli
.
current
());
++
mli
)
for
(
mli
.
toFirst
();(
md
=
mli
.
current
());
++
mli
)
{
{
if
(
md
->
isLinkable
())
//
if (md->isLinkable())
{
//
{
fd
=
md
->
getFileDef
();
fd
=
md
->
getFileDef
();
gd
=
md
->
getGroupDef
();
gd
=
md
->
getGroupDef
();
//printf(" md->name()=`%s' md->args=`%s' fd=%p gd=%p\n",
//printf(" md->name()=`%s' md->args=`%s' fd=%p gd=%p\n",
...
@@ -3202,14 +3224,14 @@ bool getDefs(const QCString &scName,const QCString &memberName,
...
@@ -3202,14 +3224,14 @@ bool getDefs(const QCString &scName,const QCString &memberName,
members
.
append
(
md
);
members
.
append
(
md
);
}
}
}
}
}
//
}
}
}
if
(
members
.
count
()
!=
1
&&
args
&&
!
strcmp
(
args
,
"()"
))
if
(
members
.
count
()
!=
1
&&
args
&&
!
strcmp
(
args
,
"()"
))
{
{
// no exact match found, but if args="()" an arbitrary
// no exact match found, but if args="()" an arbitrary
// member will do
// member will do
md
=
mn
->
last
();
md
=
mn
->
last
();
while
(
md
&&
md
->
isLinkable
()
)
while
(
md
/* && md->isLinkable()*/
)
{
{
//printf("Found member `%s'\n",md->name().data());
//printf("Found member `%s'\n",md->name().data());
//printf("member is linkable md->name()=`%s'\n",md->name().data());
//printf("member is linkable md->name()=`%s'\n",md->name().data());
...
@@ -4234,9 +4256,10 @@ QCString convertToHtml(const char *s)
...
@@ -4234,9 +4256,10 @@ QCString convertToHtml(const char *s)
*/
*/
const
char
*
getOverloadDocs
()
const
char
*
getOverloadDocs
()
{
{
return
"This is an overloaded member function, "
return
theTranslator
->
trOverloadText
();
"provided for convenience. It differs from the above "
//"This is an overloaded member function, "
"function only in what argument(s) it accepts."
;
// "provided for convenience. It differs from the above "
// "function only in what argument(s) it accepts.";
}
}
void
addMembersToMemberGroup
(
MemberList
*
ml
,
void
addMembersToMemberGroup
(
MemberList
*
ml
,
...
@@ -5216,3 +5239,37 @@ QCString stripPath(const char *s)
...
@@ -5216,3 +5239,37 @@ QCString stripPath(const char *s)
}
}
return
result
;
return
result
;
}
}
/** returns \c TRUE iff string \a s contains word \a w */
bool
containsWord
(
const
QCString
&
s
,
const
QCString
&
word
)
{
static
QRegExp
wordExp
(
"[a-z_A-Z]+"
);
int
p
=
0
,
i
,
l
;
while
((
i
=
wordExp
.
match
(
s
,
p
,
&
l
))
!=-
1
)
{
if
(
s
.
mid
(
i
,
l
)
==
word
)
return
TRUE
;
p
=
i
+
l
;
}
return
FALSE
;
}
bool
findAndRemoveWord
(
QCString
&
s
,
const
QCString
&
word
)
{
static
QRegExp
wordExp
(
"[a-z_A-Z]+"
);
int
p
=
0
,
i
,
l
;
while
((
i
=
wordExp
.
match
(
s
,
p
,
&
l
))
!=-
1
)
{
if
(
s
.
mid
(
i
,
l
)
==
word
)
{
if
(
i
>
0
&&
isspace
(
s
.
at
(
i
-
1
)))
i
--
,
l
++
;
else
if
(
i
+
l
<
(
int
)
s
.
length
()
&&
isspace
(
s
.
at
(
i
+
l
)))
l
++
;
s
=
s
.
left
(
i
)
+
s
.
mid
(
i
+
l
);
// remove word + spacing
return
TRUE
;
}
p
=
i
+
l
;
}
return
FALSE
;
}
src/util.h
View file @
5a640083
...
@@ -228,6 +228,8 @@ QCString relativePathToRoot(const char *name);
...
@@ -228,6 +228,8 @@ QCString relativePathToRoot(const char *name);
#define REL_PATH_TO_ROOT "../../"
#define REL_PATH_TO_ROOT "../../"
void
createSubDirs
(
QDir
&
d
);
void
createSubDirs
(
QDir
&
d
);
QCString
stripPath
(
const
char
*
s
);
QCString
stripPath
(
const
char
*
s
);
bool
containsWord
(
const
QCString
&
s
,
const
QCString
&
word
);
bool
findAndRemoveWord
(
QCString
&
s
,
const
QCString
&
word
);
#endif
#endif
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