Commit 784e2b65 authored by dimitri's avatar dimitri

Release-1.2.16-20020609

parent 4c054d84
DOXYGEN Version 1.2.16-20020603 DOXYGEN Version 1.2.16-20020609
Please read the installation section of the manual for instructions. Please read the installation section of the manual for instructions.
-------- --------
Dimitri van Heesch (03 June 2002) Dimitri van Heesch (09 June 2002)
...@@ -48,7 +48,7 @@ install: doxywizard_install ...@@ -48,7 +48,7 @@ install: doxywizard_install
$(INSTTOOL) -m 755 bin/doxytag $(INSTALL)/bin $(INSTTOOL) -m 755 bin/doxytag $(INSTALL)/bin
$(INSTTOOL) -m 755 bin/doxysearch $(INSTALL)/bin $(INSTTOOL) -m 755 bin/doxysearch $(INSTALL)/bin
install_docs: install_docs: install
$(INSTTOOL) -d $(DOCDIR) $(INSTTOOL) -d $(DOCDIR)
cp -r doc $(DOCDIR) cp -r doc $(DOCDIR)
cp -r examples $(DOCDIR) cp -r examples $(DOCDIR)
...@@ -62,16 +62,12 @@ install_docs: ...@@ -62,16 +62,12 @@ install_docs:
rm -rf $(DOCDIR)/doc rm -rf $(DOCDIR)/doc
cd $(DOCDIR)/latex ; $(MAKE) cd $(DOCDIR)/latex ; $(MAKE)
cp $(DOCDIR)/latex/doxygen_manual.pdf $(DOCDIR) cp $(DOCDIR)/latex/doxygen_manual.pdf $(DOCDIR)
cp $(DOCDIR)/latex/doxygen_manual.ps $(DOCDIR)
rm -rf $(DOCDIR)/latex rm -rf $(DOCDIR)/latex
docs: FORCE docs: FORCE
cd examples ; $(MAKE) cd examples ; $(MAKE)
cd doc ; $(MAKE) cd doc ; $(MAKE)
ps: docs
cd latex ; $(MAKE)
pdf: docs pdf: docs
cd latex ; $(MAKE) cd latex ; $(MAKE)
......
DOXYGEN Version 1.2.16_20020603 DOXYGEN Version 1.2.16_20020609
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) (03 June 2002) Dimitri van Heesch (dimitri@stack.nl) (09 June 2002)
1.2.16-20020603 1.2.16-20020609
...@@ -27,7 +27,7 @@ f_prefix=/usr ...@@ -27,7 +27,7 @@ f_prefix=/usr
f_insttool=NO f_insttool=NO
f_english=NO f_english=NO
f_wizard=NO f_wizard=NO
f_langs=nl,se,cz,fr,it,de,jp,es,fi,ru,hr,pl,pt,hu,kr,ro,si,cn,no,br,dk,sk,ua,gr,tw f_langs=nl,se,cz,fr,it,de,jp,es,fi,ru,hr,pl,pt,hu,kr,ro,si,cn,no,br,dk,sk,ua,gr,tw,sr
while test -n "$1"; do while test -n "$1"; do
case $1 in case $1 in
...@@ -483,7 +483,7 @@ echo -n " Generating src/lang_cfg.h..." ...@@ -483,7 +483,7 @@ echo -n " Generating src/lang_cfg.h..."
echo $f_langs | $f_perl -e '@l=split(/,/,<STDIN>); echo $f_langs | $f_perl -e '@l=split(/,/,<STDIN>);
chomp @l; chomp @l;
@allowed=(NL,SE,CZ,FR,IT,DE,JP,ES,FI,RU,HR,PL,PT,HU,KR,RO,SI,CN,NO,BR, @allowed=(NL,SE,CZ,FR,IT,DE,JP,ES,FI,RU,HR,PL,PT,HU,KR,RO,SI,CN,NO,BR,
DK,SK,UA,GR,TW); DK,SK,UA,GR,TW,SR);
foreach my $elem (@l){ foreach my $elem (@l){
$elem =~ tr/a-z/A-Z/; $elem =~ tr/a-z/A-Z/;
$r=0; $r=0;
......
...@@ -239,7 +239,7 @@ followed by the descriptions of the tags grouped by category. ...@@ -239,7 +239,7 @@ followed by the descriptions of the tags grouped by category.
The default language is English, other supported languages are: The default language is English, other supported languages are:
Brazilian, Chinese, Croatian, Czech, Danish, Dutch, Finnish, French, Brazilian, Chinese, Croatian, Czech, Danish, Dutch, Finnish, French,
German, Greek, Hungarian, Italian, Japanese, Korean, Norwegian, Polish, German, Greek, Hungarian, Italian, Japanese, Korean, Norwegian, Polish,
Portuguese, Romanian, Russian, Slovak, Slovene, Spanish and Swedish. Portuguese, Romanian, Russian, Serbian, Slovak, Slovene, Spanish and Swedish.
\anchor cfg_extract_all \anchor cfg_extract_all
<dt>\c EXTRACT_ALL <dd> <dt>\c EXTRACT_ALL <dd>
......
...@@ -474,6 +474,7 @@ Here is what is required: ...@@ -474,6 +474,7 @@ Here is what is required:
and the collaboration graphs. and the collaboration graphs.
</ul> </ul>
Compilation is now done by performing the following steps: Compilation is now done by performing the following steps:
<ol> <ol>
......
...@@ -25,14 +25,14 @@ Doxygen has built-in support for multiple languages. This means ...@@ -25,14 +25,14 @@ Doxygen has built-in support for multiple languages. This means
that the text fragments that doxygen generates can be produced in that the text fragments that doxygen generates can be produced in
languages other than English (the default) at configuration time. languages other than English (the default) at configuration time.
Currently (version 1.2.14-20020317), 26 languages Currently (version 1.2.16-20020603), 27 languages
are supported (sorted alphabetically): are supported (sorted alphabetically):
Brazilian Portuguese, Chinese, Chinesetraditional, Croatian, Czech, Brazilian Portuguese, Chinese, Chinese Traditional, Croatian, Czech,
Danish, Dutch, English, Finnish, French, Danish, Dutch, English, Finnish, French,
German, Greek, Hungarian, Italian, Japanese, German, Greek, Hungarian, Italian, Japanese,
Korean, Norwegian, Polish, Portuguese, Romanian, Korean, Norwegian, Polish, Portuguese, Romanian,
Russian, Slovak, Slovene, Spanish, Swedish, Russian, Serbian, Slovak, Slovene, Spanish,
and Ukrainian. Swedish, and Ukrainian.
The table of information related to the supported languages follows. The table of information related to the supported languages follows.
It is sorted by language alphabetically. The <b>Status</b> column It is sorted by language alphabetically. The <b>Status</b> column
...@@ -52,7 +52,7 @@ when the translator was updated. ...@@ -52,7 +52,7 @@ when the translator was updated.
<TD ><b><font size=+1 color="#ffffff"> Status </font></b></TD> <TD ><b><font size=+1 color="#ffffff"> Status </font></b></TD>
</TR> </TR>
<TR BGCOLOR="#ffffff"> <TR BGCOLOR="#ffffff">
<TD>Brazilian</TD> <TD>Brazilian Portuguese</TD>
<TD>Fabio "FJTC" Jun Takada Chino</TD> <TD>Fabio "FJTC" Jun Takada Chino</TD>
<TD>chino@NOSPAM.icmc.sc.usp.br</TD> <TD>chino@NOSPAM.icmc.sc.usp.br</TD>
<TD>up-to-date</TD> <TD>up-to-date</TD>
...@@ -64,7 +64,7 @@ when the translator was updated. ...@@ -64,7 +64,7 @@ when the translator was updated.
<TD>1.2.13</TD> <TD>1.2.13</TD>
</TR> </TR>
<TR BGCOLOR="#ffffff"> <TR BGCOLOR="#ffffff">
<TD>Chinesetraditional</TD> <TD>Chinese Traditional</TD>
<TD>Gary Lee</TD> <TD>Gary Lee</TD>
<TD>garylee@NOSPAM.ecosine.com.tw</TD> <TD>garylee@NOSPAM.ecosine.com.tw</TD>
<TD>up-to-date</TD> <TD>up-to-date</TD>
...@@ -177,6 +177,12 @@ when the translator was updated. ...@@ -177,6 +177,12 @@ when the translator was updated.
<TD>cav@NOSPAM.cryptopro.ru</TD> <TD>cav@NOSPAM.cryptopro.ru</TD>
<TD>up-to-date</TD> <TD>up-to-date</TD>
</TR> </TR>
<TR BGCOLOR="#ffffff">
<TD>Serbian</TD>
<TD>Dejan Milosavljevic</TD>
<TD>dmilos@NOSPAM.email.com</TD>
<TD>up-to-date</TD>
</TR>
<TR BGCOLOR="#ffffff"> <TR BGCOLOR="#ffffff">
<TD>Slovak</TD> <TD>Slovak</TD>
<TD>Stanislav Kudl&aacute;&#x010d;</TD> <TD>Stanislav Kudl&aacute;&#x010d;</TD>
...@@ -218,12 +224,12 @@ when the translator was updated. ...@@ -218,12 +224,12 @@ when the translator was updated.
{\bf Language} & {\bf Maintainer} & {\bf Contact address} & {\bf Status} \\ {\bf Language} & {\bf Maintainer} & {\bf Contact address} & {\bf Status} \\
\hline \hline
\hline \hline
Brazilian & Fabio "FJTC" Jun Takada Chino & {\tt chino@icmc.sc.usp.br} & up-to-date \\ Brazilian Portuguese & Fabio "FJTC" Jun Takada Chino & {\tt chino@icmc.sc.usp.br} & up-to-date \\
\hline \hline
Chinese & Wei Liu & {\tt liuwei@asiainfo.com} & 1.2.13 \\ Chinese & Wei Liu & {\tt liuwei@asiainfo.com} & 1.2.13 \\
& Wang Weihan & {\tt wangweihan@capinfo.com.cn} & \\ & Wang Weihan & {\tt wangweihan@capinfo.com.cn} & \\
\hline \hline
Chinesetraditional & Gary Lee & {\tt garylee@ecosine.com.tw} & up-to-date \\ Chinese Traditional & Gary Lee & {\tt garylee@ecosine.com.tw} & up-to-date \\
\hline \hline
Croatian & Boris Bralo & {\tt boris.bralo@zg.tel.hr} & up-to-date \\ Croatian & Boris Bralo & {\tt boris.bralo@zg.tel.hr} & up-to-date \\
\hline \hline
...@@ -265,6 +271,8 @@ when the translator was updated. ...@@ -265,6 +271,8 @@ when the translator was updated.
\hline \hline
Russian & Alexandr Chelpanov & {\tt cav@cryptopro.ru} & up-to-date \\ Russian & Alexandr Chelpanov & {\tt cav@cryptopro.ru} & up-to-date \\
\hline \hline
Serbian & Dejan Milosavljevic & {\tt dmilos@email.com} & up-to-date \\
\hline
Slovak & Stanislav Kudl\'{a}\v{c} & {\tt skudlac@pobox.sk} & 1.2.13 \\ Slovak & Stanislav Kudl\'{a}\v{c} & {\tt skudlac@pobox.sk} & 1.2.13 \\
\hline \hline
Slovene & Matjaz Ostroversnik & {\tt matjaz.ostroversnik@zrs-tk.si} & up-to-date \\ Slovene & Matjaz Ostroversnik & {\tt matjaz.ostroversnik@zrs-tk.si} & up-to-date \\
......
...@@ -69,6 +69,9 @@ Alexandru Iosup: aiosup@yahoo.com ...@@ -69,6 +69,9 @@ Alexandru Iosup: aiosup@yahoo.com
Russian Russian
Alexandr Chelpanov: cav@cryptopro.ru Alexandr Chelpanov: cav@cryptopro.ru
Serbian
Dejan Milosavljevic: dmilos@email.com
Slovak Slovak
Stanislav Kudl&aacute;&ccaron;: skudlac@pobox.sk Stanislav Kudl&aacute;&ccaron;: skudlac@pobox.sk
......
...@@ -118,6 +118,11 @@ ...@@ -118,6 +118,11 @@
# - Some defined() operators used on hash elements were replaced # - Some defined() operators used on hash elements were replaced
# by exists() operators where appropriate. # by exists() operators where appropriate.
# #
# 2002/05/21
# - Changes to display languages with two words more naturally
# (like "Chinese Traditional" instead of "Chinesetraditional"
# or "Brazilian Portuguese" instead of "Brazilian").
#
################################################################ ################################################################
use 5.005; use 5.005;
...@@ -607,6 +612,7 @@ xxxTABLE_FOOTxxx ...@@ -607,6 +612,7 @@ xxxTABLE_FOOTxxx
my $languages = join(", ", @languages); my $languages = join(", ", @languages);
$languages =~ s{((\w+,\s){5})}{$1\n}g; $languages =~ s{((\w+,\s){5})}{$1\n}g;
$languages =~ s{Brazilian}{Brazilian Portuguese}; $languages =~ s{Brazilian}{Brazilian Portuguese};
$languages =~ s{Chinesetraditional}{Chinese Traditional};
$languages =~ s{(,\s+)(\w+)$}{$1and $2}s; $languages =~ s{(,\s+)(\w+)$}{$1and $2}s;
$output =~ s{\$languages}{$languages}; $output =~ s{\$languages}{$languages};
...@@ -693,6 +699,15 @@ xxxTABLE_FOOTxxx ...@@ -693,6 +699,15 @@ xxxTABLE_FOOTxxx
# #
foreach my $lang (sort keys %language) { foreach my $lang (sort keys %language) {
# Transform the key for the language into more human readable
# form. Basically, only languages with two words are going to be
# corrected. #{{{
#
my $lang_readable = $lang;
$lang_readable =~ s{Brazilian}{Brazilian Portuguese};
$lang_readable =~ s{Chinesetraditional}{Chinese Traditional};
##}}}
# Read the line with info for the language and separate # Read the line with info for the language and separate
# the status. #{{{ # the status. #{{{
# #
...@@ -748,7 +763,7 @@ xxxTABLE_FOOTxxx ...@@ -748,7 +763,7 @@ xxxTABLE_FOOTxxx
# #
my $item = $htmlTableRow; my $item = $htmlTableRow;
$item =~ s{\$lang}{$lang}; $item =~ s{\$lang}{$lang_readable};
$item =~ s{\$maintainer}{$name}; $item =~ s{\$maintainer}{$name};
$item =~ s{\$email}{$email}; $item =~ s{\$email}{$email};
$item =~ s{\$status}{$status}; $item =~ s{\$status}{$status};
...@@ -774,7 +789,7 @@ xxxTABLE_FOOTxxx ...@@ -774,7 +789,7 @@ xxxTABLE_FOOTxxx
$name = $1; $name = $1;
$email = $2; $email = $2;
$item =~ s{\$lang}{$lang}; $item =~ s{\$lang}{$lang_readable};
$item =~ s{\$maintainer}{$name}; $item =~ s{\$maintainer}{$name};
$item =~ s{\$email}{$email}; $item =~ s{\$email}{$email};
$item =~ s{\$status}{$status}; $item =~ s{\$status}{$status};
...@@ -1187,6 +1202,7 @@ print STDERR "\n\n"; ...@@ -1187,6 +1202,7 @@ print STDERR "\n\n";
my $languages = join(", ", @languages); my $languages = join(", ", @languages);
$languages =~ s{((\w+,\s){5})}{$1\n}g; $languages =~ s{((\w+,\s){5})}{$1\n}g;
$languages =~ s{Brazilian}{Brazilian Portuguese}; $languages =~ s{Brazilian}{Brazilian Portuguese};
$languages =~ s{Chinesetraditional}{Chinese Traditional};
$languages =~ s{(,\s+)(\w+)$}{$1and $2.}s; $languages =~ s{(,\s+)(\w+)$}{$1and $2.}s;
print FOUT "$languages\n"; print FOUT "$languages\n";
......
Summary: A documentation system for C/C++. Summary: A documentation system for C/C++.
Name: doxygen Name: doxygen
Version: 1.2.16_20020603 Version: 1.2.16_20020609
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
......
...@@ -1189,6 +1189,9 @@ void ClassDef::writeDocumentation(OutputList &ol) ...@@ -1189,6 +1189,9 @@ void ClassDef::writeDocumentation(OutputList &ol)
ol.docify(stripFromPath(path)); ol.docify(stripFromPath(path));
} }
// for HTML
ol.pushGeneratorState();
ol.disableAllBut(OutputGenerator::Html);
if (fd->generateSourceFile()) if (fd->generateSourceFile())
{ {
ol.writeObjectLink(0,fd->getSourceFileBase(),0,fd->name()); ol.writeObjectLink(0,fd->getSourceFileBase(),0,fd->name());
...@@ -1202,6 +1205,24 @@ void ClassDef::writeDocumentation(OutputList &ol) ...@@ -1202,6 +1205,24 @@ void ClassDef::writeDocumentation(OutputList &ol)
{ {
ol.docify(fd->name()); ol.docify(fd->name());
} }
ol.popGeneratorState();
// for other output formats
ol.pushGeneratorState();
ol.disable(OutputGenerator::Html);
if (fd->isLinkable())
{
ol.writeObjectLink(fd->getReference(),fd->getOutputFileBase(),0,
fd->name());
}
else
{
ol.docify(fd->name());
}
ol.popGeneratorState();
} }
file=m_files.next(); file=m_files.next();
} }
......
...@@ -1047,6 +1047,7 @@ TYPEKW ("bool"|"char"|"double"|"float"|"int"|"long"|"short"|"signed"|"unsigned" ...@@ -1047,6 +1047,7 @@ TYPEKW ("bool"|"char"|"double"|"float"|"int"|"long"|"short"|"signed"|"unsigned"
bool ambig; bool ambig;
bool found=FALSE; bool found=FALSE;
FileDef *fd=0; FileDef *fd=0;
//printf("looking for include %s\n",yytext);
if ((fd=findFileDef(Doxygen::inputNameDict,yytext,ambig)) && if ((fd=findFileDef(Doxygen::inputNameDict,yytext,ambig)) &&
fd->isLinkable()) fd->isLinkable())
{ {
......
...@@ -162,22 +162,22 @@ static int yyread(char *buf,int max_size) ...@@ -162,22 +162,22 @@ static int yyread(char *buf,int max_size)
copyToOutput(yytext,yyleng); copyToOutput(yytext,yyleng);
BEGIN(Scan); BEGIN(Scan);
} }
<SComment>^[ \t]*"///"[\/]*\n { <SComment>^[ \t]*"///"[\/]*/\n {
replaceCommentMarker(yytext,yyleng); replaceCommentMarker(yytext,yyleng);
} }
<SComment>^[ \t]*"///"[^\/\n].*/\n { <SComment>\n[ \t]*"///"[\/]*/\n {
replaceCommentMarker(yytext,yyleng); replaceCommentMarker(yytext,yyleng);
} }
<SComment>^[ \t]*"//!".*/\n { /* second line of special comment */ <SComment>^[ \t]*"///"[^\/\n].*/\n {
replaceCommentMarker(yytext,yyleng); replaceCommentMarker(yytext,yyleng);
} }
<SComment>\n[ \t]*"///"[\/]*\n { <SComment>\n[ \t]*"///"[^\/\n].*/\n {
replaceCommentMarker(yytext,yyleng); replaceCommentMarker(yytext,yyleng);
} }
<SComment>\n[ \t]*"///"[^\/\n].*/\n { <SComment>^[ \t]*"//!".*/\n {
replaceCommentMarker(yytext,yyleng); replaceCommentMarker(yytext,yyleng);
} }
<SComment>\n[ \t]*"//!".*/\n { /* other line of special comment */ <SComment>\n[ \t]*"//!".*/\n {
replaceCommentMarker(yytext,yyleng); replaceCommentMarker(yytext,yyleng);
} }
<SComment>\n { /* end of special comment */ <SComment>\n { /* end of special comment */
......
...@@ -1248,9 +1248,9 @@ void Config::create() ...@@ -1248,9 +1248,9 @@ void Config::create()
"information to generate all constant output in the proper language. \n" "information to generate all constant output in the proper language. \n"
"The default language is English, other supported languages are: \n" "The default language is English, other supported languages are: \n"
"Brazilian, Chinese, Chinese-Traditional, Croatian, Czech, Danish, Dutch, \n" "Brazilian, Chinese, Chinese-Traditional, Croatian, Czech, Danish, Dutch, \n"
"Finnish, French, German, Greek, Hungarian, Italian, Japanese, Korean, \n" "Finnish, French, German, Greek, Hungarian, Italian, Japanese, Japanese-en \n"
"Norwegian, Polish, Portuguese, Romanian, Russian, Slovak, Slovene, \n" "(Japanese with english messages), Korean, Norwegian, Polish, Portuguese, \n"
"Spanish, Swedish and Ukrainian.\n", "Romanian, Russian, Serbian, Slovak, Slovene, Spanish, Swedish and Ukrainian.\n",
"English" "English"
); );
#ifdef LANG_BR #ifdef LANG_BR
...@@ -1295,6 +1295,7 @@ void Config::create() ...@@ -1295,6 +1295,7 @@ void Config::create()
#endif #endif
#ifdef LANG_JP #ifdef LANG_JP
ce->addValue("Japanese"); ce->addValue("Japanese");
ce->addValue("Japanese-en");
#endif #endif
#ifdef LANG_KR #ifdef LANG_KR
ce->addValue("Korean"); ce->addValue("Korean");
...@@ -1314,6 +1315,9 @@ void Config::create() ...@@ -1314,6 +1315,9 @@ void Config::create()
#ifdef LANG_RU #ifdef LANG_RU
ce->addValue("Russian"); ce->addValue("Russian");
#endif #endif
#ifdef LANG_SR
ce->addValue("Serbian");
#endif
#ifdef LANG_SK #ifdef LANG_SK
ce->addValue("Slovak"); ce->addValue("Slovak");
#endif #endif
......
...@@ -966,6 +966,13 @@ static void checkArgName(const QCString &name,bool isParam) ...@@ -966,6 +966,13 @@ static void checkArgName(const QCString &name,bool isParam)
/* ----------------------------------------------------------------- */ /* ----------------------------------------------------------------- */
/*! Looks for a documentation block with name commandName in the current
* context (copyDocScope). The resulting documentation string is
* put in pDoc, the definition in which the documentation was found is
* put in pDef.
* @retval TRUE if name was found.
* @retval FALSE if name was not found.
*/
bool findDocsForMemberOrCompound(const char *commandName, bool findDocsForMemberOrCompound(const char *commandName,
QCString *pDoc, QCString *pDoc,
Definition **pDef) Definition **pDef)
...@@ -976,33 +983,15 @@ bool findDocsForMemberOrCompound(const char *commandName, ...@@ -976,33 +983,15 @@ bool findDocsForMemberOrCompound(const char *commandName,
int l=cmdArg.length(); int l=cmdArg.length();
if (l==0) return FALSE; if (l==0) return FALSE;
int scopeOffset=copyDocScope.length();
do // for each scope
{
int funcStart=cmdArg.find('('); int funcStart=cmdArg.find('(');
if (funcStart==-1) funcStart=l; if (funcStart==-1) funcStart=l;
int lastScopeStart=cmdArg.findRev("::",funcStart); //int lastScopeStart=cmdArg.findRev("::",funcStart);
int lastScopeEnd = lastScopeStart==-1 ? 0 : lastScopeStart+2; //int lastScopeEnd = lastScopeStart==-1 ? 0 : lastScopeStart+2;
QCString scope=cmdArg.left(QMAX(lastScopeStart,0)); //QCString scope=cmdArg.left(QMAX(lastScopeStart,0));
QCString name=cmdArg.mid(lastScopeEnd,funcStart-lastScopeEnd); //QCString name=cmdArg.mid(lastScopeEnd,funcStart-lastScopeEnd);
QCString name=cmdArg.left(funcStart);
QCString args=cmdArg.right(l-funcStart); QCString args=cmdArg.right(l-funcStart);
if (scope.isEmpty())
{
if (scopeOffset>0)
{
scope=copyDocScope.left(scopeOffset);
}
}
else
{
if (scopeOffset>0)
{
scope.prepend(copyDocScope.left(scopeOffset)+"::");
}
}
//printf("findDocsForMemberOrCompound: scope=`%s' name=`%s' arg=`%s'\n",scope.data(),name.data(),args.data());
// try if the link is to a member // try if the link is to a member
MemberDef *md=0; MemberDef *md=0;
ClassDef *cd=0; ClassDef *cd=0;
...@@ -1010,7 +999,7 @@ bool findDocsForMemberOrCompound(const char *commandName, ...@@ -1010,7 +999,7 @@ bool findDocsForMemberOrCompound(const char *commandName,
NamespaceDef *nd=0; NamespaceDef *nd=0;
GroupDef *gd=0; GroupDef *gd=0;
PageInfo *pi=0; PageInfo *pi=0;
bool found = getDefs(scope,name,args,md,cd,fd,nd,gd,FALSE,0,TRUE); bool found = getDefs(copyDocScope,name,args,md,cd,fd,nd,gd,FALSE,0,TRUE);
if (found && md) if (found && md)
{ {
*pDoc=md->documentation(); *pDoc=md->documentation();
...@@ -1018,11 +1007,16 @@ bool findDocsForMemberOrCompound(const char *commandName, ...@@ -1018,11 +1007,16 @@ bool findDocsForMemberOrCompound(const char *commandName,
return TRUE; return TRUE;
} }
int scopeOffset=copyDocScope.length();
do // for each scope
{
QCString fullName=cmdArg; QCString fullName=cmdArg;
if (scopeOffset>0) if (scopeOffset>0)
{ {
fullName.prepend(copyDocScope.left(scopeOffset)+"::"); fullName.prepend(copyDocScope.left(scopeOffset)+"::");
} }
//printf("Trying fullName=`%s'\n",fullName.data());
// try class, namespace, group, page, file reference // try class, namespace, group, page, file reference
cd = Doxygen::classSDict[fullName]; cd = Doxygen::classSDict[fullName];
...@@ -1071,7 +1065,7 @@ bool findDocsForMemberOrCompound(const char *commandName, ...@@ -1071,7 +1065,7 @@ bool findDocsForMemberOrCompound(const char *commandName,
scopeOffset = copyDocScope.findRev("::",scopeOffset-1); scopeOffset = copyDocScope.findRev("::",scopeOffset-1);
if (scopeOffset==-1) scopeOffset=0; if (scopeOffset==-1) scopeOffset=0;
} }
} while (scopeOffset>0); } while (scopeOffset>=0);
return FALSE; return FALSE;
...@@ -1108,8 +1102,8 @@ FILE ({FILESCHAR}*{FILEECHAR}+("."{FILESCHAR}*{FILEECHAR}+)*)|("\""[^\n\"]+ ...@@ -1108,8 +1102,8 @@ FILE ({FILESCHAR}*{FILEECHAR}+("."{FILESCHAR}*{FILEECHAR}+)*)|("\""[^\n\"]+
ID [a-z_A-Z][a-z_A-Z0-9]* ID [a-z_A-Z][a-z_A-Z0-9]*
SCOPENAME (({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID}) SCOPENAME (({ID}?{BN}*"::"{BN}*)*)((~{BN}*)?{ID})
SCOPEMASK {ID}?(("::"|"#")?(~)?{ID})+ SCOPEMASK {ID}?(("::"|"#")?(~)?{ID})+
URLCHAR [a-z_A-Z0-9\!\~\:\;\'\$\?\@\&\%\#\.\-\+\/\=\(\)] URLCHAR [a-z_A-Z0-9\!\~\:\;\'\$\?\@\&\%\#\.\-\+\/\=]
URLMASK ([a-z_A-Z][^\>\"\n]*{URLCHAR})|({URLCHAR}+) URLMASK (([a-z_A-Z][^\>\"\n]*{URLCHAR})|({URLCHAR}+))("("{URLCHAR}*")")?
NONTERM [\{\}\[\]\`\~\@\|\-\+\#\$\/\\\!\%\^\&\*()a-z_A-Z<>0-9\x80-\xff] NONTERM [\{\}\[\]\`\~\@\|\-\+\#\$\/\\\!\%\^\&\*()a-z_A-Z<>0-9\x80-\xff]
WORD ({NONTERM}+([^\n\t ]*{NONTERM}+)?)|("\""[^\n\"]*"\"") WORD ({NONTERM}+([^\n\t ]*{NONTERM}+)?)|("\""[^\n\"]*"\"")
ATTR ({B}+[^>\n]*)? ATTR ({B}+[^>\n]*)?
...@@ -2983,9 +2977,13 @@ void resolveCopyDocCommands(const char *scope,QCString &docString) ...@@ -2983,9 +2977,13 @@ void resolveCopyDocCommands(const char *scope,QCString &docString)
void parseDoc(OutputDocInterface &od,const char *fileName,int startLine, void parseDoc(OutputDocInterface &od,const char *fileName,int startLine,
const char *clName,MemberDef *md,const QCString &docStr) const char *clName,MemberDef *md,const QCString &docStr)
{ {
strcpy(yyFileName,fileName);
yyLineNr = startLine;
QCString docString=docStr; QCString docString=docStr;
resolveCopyDocCommands(clName,docString); resolveCopyDocCommands(clName,docString);
yyLineNr = startLine;
//printf("parseDoc(file=`%s',line=%d)\n",fileName,startLine); //printf("parseDoc(file=`%s',line=%d)\n",fileName,startLine);
initParser(); initParser();
initParseCodeContext(); initParseCodeContext();
...@@ -2995,8 +2993,6 @@ void parseDoc(OutputDocInterface &od,const char *fileName,int startLine, ...@@ -2995,8 +2993,6 @@ void parseDoc(OutputDocInterface &od,const char *fileName,int startLine,
hasParamCommand = FALSE; hasParamCommand = FALSE;
paramsFound.setAutoDelete(FALSE); paramsFound.setAutoDelete(FALSE);
paramsFound.clear(); paramsFound.clear();
strcpy(yyFileName,fileName);
yyLineNr = startLine;
parseDocument(od,docString); parseDocument(od,docString);
if (md && hasParamCommand && Config_getBool("WARN_IF_UNDOCUMENTED")) if (md && hasParamCommand && Config_getBool("WARN_IF_UNDOCUMENTED"))
......
...@@ -5754,15 +5754,21 @@ static void resolveUserReferences() ...@@ -5754,15 +5754,21 @@ static void resolveUserReferences()
si->fileName=si->definition->getOutputFileBase().copy(); si->fileName=si->definition->getOutputFileBase().copy();
} }
} }
// hack: the items of a todo/test list are all fragments from different files, // hack: the items of a todo/test/bug list are all fragments from
// so the resulting section's all have the wrong file name (not from the // different files, so the resulting section's all have the wrong file
// todo/test list, but from the file in which they are defined). We correct this // name (not from the todo/test/bug list, but from the file in which they
// here by looking at the generated section labels! // are defined). We correct this here by looking at the generated section
// labels!
if (si->label.left(5)=="_todo" || si->label.left(5)=="_test") if (si->label.left(5)=="_todo" || si->label.left(5)=="_test")
{ {
si->fileName=si->label.mid(1,4); // extract "todo" or "test" si->fileName=si->label.mid(1,4); // extract "todo" or "test"
si->generated=TRUE; si->generated=TRUE;
} }
else if (si->label.left(4)=="_bug")
{
si->fileName="bug";
si->generated=TRUE;
}
} }
} }
...@@ -7158,7 +7164,7 @@ void parseInput() ...@@ -7158,7 +7164,7 @@ void parseInput()
**************************************************************************/ **************************************************************************/
Entry *root=new Entry; Entry *root=new Entry;
msg("Reading tag files\n"); msg("Reading and parsing tag files\n");
QStrList &tagFileList = Config_getList("TAGFILES"); QStrList &tagFileList = Config_getList("TAGFILES");
s=tagFileList.first(); s=tagFileList.first();
......
...@@ -23,3 +23,4 @@ ...@@ -23,3 +23,4 @@
#define LANG_UA #define LANG_UA
#define LANG_GR #define LANG_GR
#define LANG_TW #define LANG_TW
#define LANG_SR
...@@ -97,6 +97,9 @@ ...@@ -97,6 +97,9 @@
#ifdef LANG_GR #ifdef LANG_GR
#include "translator_gr.h" #include "translator_gr.h"
#endif #endif
#ifdef LANG_SR
#include "translator_sr.h"
#endif
//#ifdef LANG_JS //#ifdef LANG_JS
//#include "translator_js.h" //#include "translator_js.h"
//#endif //#endif
...@@ -154,6 +157,10 @@ bool setTranslator(const char *langName) ...@@ -154,6 +157,10 @@ bool setTranslator(const char *langName)
{ {
theTranslator=new TranslatorJapanese; theTranslator=new TranslatorJapanese;
} }
else if (L_EQUAL("japanese-en"))
{
theTranslator=new TranslatorJapaneseEn;
}
#endif #endif
#ifdef LANG_ES #ifdef LANG_ES
else if (L_EQUAL("spanish")) else if (L_EQUAL("spanish"))
...@@ -263,6 +270,12 @@ bool setTranslator(const char *langName) ...@@ -263,6 +270,12 @@ bool setTranslator(const char *langName)
theTranslator=new TranslatorGreek; theTranslator=new TranslatorGreek;
} }
#endif #endif
#ifdef LANG_SR
else if (L_EQUAL("serbian"))
{
theTranslator=new TranslatorSerbian;
}
#endif
// else if (L_EQUAL("japanese-sjis")) // else if (L_EQUAL("japanese-sjis"))
// { // {
// theTranslator=new TranslatorJapaneseSjis; // theTranslator=new TranslatorJapaneseSjis;
......
...@@ -152,6 +152,8 @@ void LatexGenerator::init() ...@@ -152,6 +152,8 @@ void LatexGenerator::init()
QCString mkidx_command = Config_getString("MAKEINDEX_CMD_NAME"); QCString mkidx_command = Config_getString("MAKEINDEX_CMD_NAME");
// end insertion by KONNO Akihisa <konno@researchers.jp> 2002-03-05 // end insertion by KONNO Akihisa <konno@researchers.jp> 2002-03-05
QTextStream t(&file); QTextStream t(&file);
if (!Config_getBool("USE_PDFLATEX")) // use plain old latex
{
t << "all: refman.dvi" << endl t << "all: refman.dvi" << endl
<< endl << endl
<< "ps: refman.ps" << endl << "ps: refman.ps" << endl
...@@ -165,15 +167,6 @@ void LatexGenerator::init() ...@@ -165,15 +167,6 @@ void LatexGenerator::init()
<< "refman.ps: refman.dvi" << endl << "refman.ps: refman.dvi" << endl
<< "\tdvips -o refman.ps refman.dvi" << endl << "\tdvips -o refman.ps refman.dvi" << endl
<< endl; << endl;
if (Config_getBool("USE_PDFLATEX")) // use pdflatex instead of latex
{
t << "refman.pdf: refman.tex" << endl;
t << "\tpdflatex refman.tex" << endl;
t << "\tmakeindex refman.idx" << endl;
t << "\tpdflatex refman.tex" << endl << endl;
}
else // otherwise use ps2pdf: not as nice :(
{
t << "refman.pdf: refman.ps" << endl; t << "refman.pdf: refman.ps" << endl;
#if defined(_MSC_VER) #if defined(_MSC_VER)
// ps2pdf.bat does not work properly from a makefile using GNU make! // ps2pdf.bat does not work properly from a makefile using GNU make!
...@@ -182,9 +175,21 @@ void LatexGenerator::init() ...@@ -182,9 +175,21 @@ void LatexGenerator::init()
#else #else
t << "\tps2pdf refman.ps refman.pdf" << endl << endl; t << "\tps2pdf refman.ps refman.pdf" << endl << endl;
#endif #endif
} t << "refman.dvi: refman.tex doxygen.sty" << endl
<< "\techo \"Running latex...\"" << endl
t << "refman_2on1.ps: refman.ps" << endl << "\t" << latex_command << " refman.tex" << endl
<< "\techo \"Running makeindex...\"" << endl
<< "\t" << mkidx_command << " refman.idx" << endl
<< "\techo \"Rerunning latex....\"" << endl
<< "\t" << latex_command << " refman.tex" << endl
<< "\tlatex_count=5 ; \\" << endl
<< "\twhile egrep -s 'Rerun (LaTeX|to get cross-references right)' refman.log && [ $$latex_count -gt 0 ] ;\\" << endl
<< "\t do \\" << endl
<< "\t echo \"Rerunning latex....\" ;\\" << endl
<< "\t " << latex_command << " refman.tex ;\\" << endl
<< "\t latex_count=`expr $$latex_count - 1` ;\\" << endl
<< "\t done" << endl << endl
<< "refman_2on1.ps: refman.ps" << endl
<< "\tpsnup -2 refman.ps >refman_2on1.ps" << endl << "\tpsnup -2 refman.ps >refman_2on1.ps" << endl
<< endl << endl
<< "refman_2on1.pdf: refman_2on1.ps" << endl << "refman_2on1.pdf: refman_2on1.ps" << endl
...@@ -193,23 +198,26 @@ void LatexGenerator::init() ...@@ -193,23 +198,26 @@ void LatexGenerator::init()
<< "\tgswin32c -q -dNOPAUSE -dBATCH -sDEVICE=pdfwrite " << "\tgswin32c -q -dNOPAUSE -dBATCH -sDEVICE=pdfwrite "
"-sOutputFile=refman_2on1.pdf -c save pop -f refman_2on1.ps" << endl "-sOutputFile=refman_2on1.pdf -c save pop -f refman_2on1.ps" << endl
#else #else
<< "\tps2pdf refman_2on1.ps refman_2on1.pdf" << endl << "\tps2pdf refman_2on1.ps refman_2on1.pdf" << endl;
#endif #endif
<< endl }
<< "refman.dvi: refman.tex doxygen.sty" << endl else // use pdflatex for higher quality output
<< "\techo \"Running latex...\"" << endl {
<< "\t" << latex_command << " refman.tex" << endl t << "all: refman.pdf" << endl << endl;
<< "\techo \"Running makeindex...\"" << endl t << "refman.pdf: refman.tex" << endl;
<< "\t" << mkidx_command << " refman.idx" << endl t << "\tpdflatex refman.tex" << endl;
<< "\techo \"Rerunning latex....\"" << endl t << "\tmakeindex refman.idx" << endl;
<< "\t" << latex_command << " refman.tex" << endl t << "\tpdflatex refman.tex" << endl << endl
<< "\tlatex_count=5 ; \\" << endl << "\tlatex_count=5 ; \\" << endl
<< "\twhile egrep -s 'Rerun (LaTeX|to get cross-references right)' refman.log && [ $$latex_count -gt 0 ] ;\\" << endl << "\twhile egrep -s 'Rerun (LaTeX|to get cross-references right)' refman.log && [ $$latex_count -gt 0 ] ;\\" << endl
<< "\t do \\" << endl << "\t do \\" << endl
<< "\t echo \"Rerunning latex....\" ;\\" << endl << "\t echo \"Rerunning latex....\" ;\\" << endl
<< "\t " << latex_command << " refman.tex ;\\" << endl << "\t pdflatex refman.tex ;\\" << endl
<< "\t latex_count=`expr $$latex_count - 1` ;\\" << endl << "\t latex_count=`expr $$latex_count - 1` ;\\" << endl
<< "\t done" << endl << endl << "\t done" << endl << endl;
}
t << endl
<< "clean:" << endl << "clean:" << endl
<< "\trm -f *.ps *.dvi *.aux *.toc *.idx *.ind *.ilg *.log *.out" << endl; << "\trm -f *.ps *.dvi *.aux *.toc *.idx *.ind *.ilg *.log *.out" << endl;
} }
...@@ -1033,7 +1041,7 @@ void LatexGenerator::endTitleHead(const char *fileName,const char *name) ...@@ -1033,7 +1041,7 @@ void LatexGenerator::endTitleHead(const char *fileName,const char *name)
{ {
t << "\\label{" << fileName << "}\\index{" t << "\\label{" << fileName << "}\\index{"
<< name << "@{"; << name << "@{";
docify(name); escapeMakeIndexChars(this,t,name);
t << "}}" << endl; t << "}}" << endl;
} }
if (Config_getBool("PDF_HYPERLINKS") && fileName) if (Config_getBool("PDF_HYPERLINKS") && fileName)
...@@ -1183,7 +1191,7 @@ void LatexGenerator::addIndexItem(const char *s1,const char *s2) ...@@ -1183,7 +1191,7 @@ void LatexGenerator::addIndexItem(const char *s1,const char *s2)
if (s2) if (s2)
{ {
t << "!" << escapeLabelName(s2) << "@{"; t << "!" << escapeLabelName(s2) << "@{";
docify(s2); escapeMakeIndexChars(this,t,s2);
t << "}"; t << "}";
} }
t << "}"; t << "}";
...@@ -1389,7 +1397,6 @@ void LatexGenerator::docify(const char *str) ...@@ -1389,7 +1397,6 @@ void LatexGenerator::docify(const char *str)
{ {
static bool isCzech = theTranslator->idLanguage()=="czech"; static bool isCzech = theTranslator->idLanguage()=="czech";
static bool isJapanese = theTranslator->idLanguage()=="japanese"; static bool isJapanese = theTranslator->idLanguage()=="japanese";
static bool isJapaneseSjis = theTranslator->idLanguage()=="japanese-sjis";
static bool isKorean = theTranslator->idLanguage()=="korean"; static bool isKorean = theTranslator->idLanguage()=="korean";
static bool isRussian = theTranslator->idLanguage()=="russian"; static bool isRussian = theTranslator->idLanguage()=="russian";
static bool isUkrainian = theTranslator->idLanguage()=="ukrainian"; static bool isUkrainian = theTranslator->idLanguage()=="ukrainian";
...@@ -1404,7 +1411,27 @@ void LatexGenerator::docify(const char *str) ...@@ -1404,7 +1411,27 @@ void LatexGenerator::docify(const char *str)
unsigned char pc='\0'; unsigned char pc='\0';
while (*p) while (*p)
{ {
static bool MultiByte = FALSE;
c=*p++; c=*p++;
if( isJapanese)
{
if (MultiByte)
{
t << (char)c;
MultiByte = FALSE;
pc = c;
continue;
}
if (c>=0x80)
{
MultiByte = TRUE;
t << (char)c;
pc = c;
continue;
}
}
if (insidePre) if (insidePre)
{ {
switch(c) switch(c)
...@@ -1462,7 +1489,7 @@ void LatexGenerator::docify(const char *str) ...@@ -1462,7 +1489,7 @@ void LatexGenerator::docify(const char *str)
default: default:
// Some languages uses wide characters // Some languages uses wide characters
if (isJapanese || isJapaneseSjis || isKorean || isChinese) if (isJapanese || isKorean || isChinese)
{ {
if (c>=128) if (c>=128)
{ {
...@@ -1600,6 +1627,8 @@ void LatexGenerator::docify(const char *str) ...@@ -1600,6 +1627,8 @@ void LatexGenerator::docify(const char *str)
void LatexGenerator::codify(const char *str) void LatexGenerator::codify(const char *str)
{ {
static bool isJapanese = theTranslator->idLanguage()=="japanese";
if (str) if (str)
{ {
const char *p=str; const char *p=str;
...@@ -1608,7 +1637,25 @@ void LatexGenerator::codify(const char *str) ...@@ -1608,7 +1637,25 @@ void LatexGenerator::codify(const char *str)
int &tabSize = Config_getInt("TAB_SIZE"); int &tabSize = Config_getInt("TAB_SIZE");
while (*p) while (*p)
{ {
static bool MultiByte = FALSE;
c=*p++; c=*p++;
if( isJapanese )
{
if ( MultiByte )
{
t << (char)c;
MultiByte = FALSE;
continue;
}
if ( c<0 ) // char in range [0x80..0xff]
{
t << (char)c;
MultiByte = TRUE;
continue;
}
}
switch(c) switch(c)
{ {
case 0x0c: break; // remove ^L case 0x0c: break; // remove ^L
......
...@@ -105,6 +105,7 @@ static void setFileName(const char *name) ...@@ -105,6 +105,7 @@ static void setFileName(const char *name)
bool ambig; bool ambig;
g_yyFileName=name; g_yyFileName=name;
g_yyFileDef=findFileDef(Doxygen::inputNameDict,g_yyFileName,ambig); g_yyFileDef=findFileDef(Doxygen::inputNameDict,g_yyFileName,ambig);
if (g_yyFileDef && g_yyFileDef->isReference()) g_yyFileDef=0;
} }
static void incrLevel() static void incrLevel()
...@@ -164,6 +165,7 @@ static Define *isDefined(const char *name) ...@@ -164,6 +165,7 @@ static Define *isDefined(const char *name)
static FILE *checkAndOpenFile(const QCString &absName) static FILE *checkAndOpenFile(const QCString &absName)
{ {
FILE *f = 0; FILE *f = 0;
//printf("checkAndOpenFile(%s)\n",absName.data());
QFileInfo fi(absName); QFileInfo fi(absName);
if (fi.exists() && fi.isFile()) if (fi.exists() && fi.isFile())
{ {
...@@ -942,6 +944,7 @@ static void readIncludeFile(const QCString &inc) ...@@ -942,6 +944,7 @@ static void readIncludeFile(const QCString &inc)
//printf("Searching for `%s'\n",incFileName.data()); //printf("Searching for `%s'\n",incFileName.data());
if ((f=findFile(incFileName,localInclude))) // see if the include file can be found if ((f=findFile(incFileName,localInclude))) // see if the include file can be found
{ {
//printf("Found include file!\n");
if (Debug::isFlagSet(Debug::Preprocessor)) if (Debug::isFlagSet(Debug::Preprocessor))
{ {
for (i=0;i<g_includeStack.count();i++) msg(" "); for (i=0;i<g_includeStack.count();i++) msg(" ");
...@@ -983,6 +986,7 @@ static void readIncludeFile(const QCString &inc) ...@@ -983,6 +986,7 @@ static void readIncludeFile(const QCString &inc)
{ {
bool ambig; bool ambig;
FileDef *fd = findFileDef(Doxygen::inputNameDict,incFileName,ambig); FileDef *fd = findFileDef(Doxygen::inputNameDict,incFileName,ambig);
//printf("findFileDef(%s)=%p\n",incFileName.data(),fd);
// add include dependency to the file in which the #include was found // add include dependency to the file in which the #include was found
oldFileDef->addIncludeDependency(fd,incFileName,localInclude); oldFileDef->addIncludeDependency(fd,incFileName,localInclude);
// add included by dependency // add included by dependency
......
...@@ -123,8 +123,11 @@ static QCString aliasName; ...@@ -123,8 +123,11 @@ static QCString aliasName;
static QCString baseName; static QCString baseName;
static QCString* specName; static QCString* specName;
static QCString formulaText; static QCString formulaText;
static bool useOverrideCommands = FALSE;
static bool insideIDL = FALSE; static bool insideIDL = FALSE;
static bool insideJava = FALSE; static bool insideJava = FALSE;
static bool insidePHP = FALSE;
static bool insidePHPCode = FALSE;
static bool insideCppQuote = FALSE; static bool insideCppQuote = FALSE;
static int argRoundCount; static int argRoundCount;
...@@ -320,8 +323,11 @@ static QCString addFormula() ...@@ -320,8 +323,11 @@ static QCString addFormula()
static bool nameIsOperator(QCString &name) static bool nameIsOperator(QCString &name)
{ {
return name.right(8)=="operator" && int i=name.find("operator");
(name.length()==8 || !isId(name.at(name.length()-9))); if (i==-1) return FALSE;
if (i==0 && !isId(name.at(8))) return TRUE; // case operator ::X
if (i>0 && !isId(name.at(i-1)) && !isId(name.at(i+8))) return TRUE; // case X::operator
return FALSE; // case TEXToperatorTEXT
} }
static void checkFormula() static void checkFormula()
...@@ -379,6 +385,11 @@ static void setContext() ...@@ -379,6 +385,11 @@ static void setContext()
QCString fileName = yyFileName; QCString fileName = yyFileName;
insideIDL = fileName.right(4)==".idl"; insideIDL = fileName.right(4)==".idl";
insideJava = fileName.right(5)==".java"; insideJava = fileName.right(5)==".java";
insidePHP = fileName.right(4)==".php";
if ( insidePHP )
{
useOverrideCommands = TRUE;
}
//printf("setContext(%s) insideIDL=%d\n",yyFileName,insideIDL); //printf("setContext(%s) insideIDL=%d\n",yyFileName,insideIDL);
} }
...@@ -471,6 +482,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -471,6 +482,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
%x NextSemi %x NextSemi
%x BitFields %x BitFields
%x FindMembers %x FindMembers
%x FindMembersPHP
%x FindMemberName %x FindMemberName
%x FindFields %x FindFields
%x FindFieldArg %x FindFieldArg
...@@ -614,8 +626,15 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -614,8 +626,15 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
current_root->addSubEntry(current); current_root->addSubEntry(current);
current = new Entry; current = new Entry;
} }
if ( insidePHP )
{
BEGIN( FindMembersPHP );
}
else
{
BEGIN( FindMembers ); BEGIN( FindMembers );
} }
}
<NextSemi>"{" { <NextSemi>"{" {
curlyCount=0; curlyCount=0;
needsSemi = TRUE; needsSemi = TRUE;
...@@ -664,6 +683,17 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -664,6 +683,17 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
unput(*yytext); unput(*yytext);
BEGIN( FindMembers ); BEGIN( FindMembers );
} }
<FindMembersPHP>"<?"("php"?) { // PHP code start
insidePHPCode = TRUE;
BEGIN( FindMembers );
}
<FindMembersPHP>. { // Non-PHP code text, ignore
}
<FindMembers>"?>" { // PHP code end
insidePHPCode = FALSE;
BEGIN( FindMembersPHP );
}
<FindMembers>{B}*("properties"|"__property"){BN}*":"{BN}* { // IDL or Borland C++ builder property <FindMembers>{B}*("properties"|"__property"){BN}*":"{BN}* { // IDL or Borland C++ builder property
current->mtype = mtype = Property; current->mtype = mtype = Property;
current->protection = protection = Public ; current->protection = protection = Public ;
...@@ -1133,6 +1163,10 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -1133,6 +1163,10 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
} }
<FindMembers,FindMemberName>{SCOPENAME} { <FindMembers,FindMemberName>{SCOPENAME} {
lineCount(); lineCount();
// if ( insidePHP && strcmp(yytext,"define")==0)
// {
// BEGIN(DefinePHP);
// }
if (insideIDL && yyleng==9 && strcmp(yytext,"cpp_quote")==0) if (insideIDL && yyleng==9 && strcmp(yytext,"cpp_quote")==0)
{ {
BEGIN(CppQuote); BEGIN(CppQuote);
...@@ -1153,6 +1187,10 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -1153,6 +1187,10 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
insideTryBlock=FALSE; insideTryBlock=FALSE;
BEGIN(TryFunctionBlock); BEGIN(TryFunctionBlock);
} }
// else if ( insidePHP && strcmp(yytext,"function")==0 )
// {
// BEGIN(
// }
else else
{ {
if (YY_START==FindMembers) if (YY_START==FindMembers)
...@@ -1180,11 +1218,15 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -1180,11 +1218,15 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
} }
QCString tmp=yytext; QCString tmp=yytext;
if (nameIsOperator(tmp)) if (nameIsOperator(tmp))
{
BEGIN( Operator ); BEGIN( Operator );
}
else else
{
BEGIN(FindMembers); BEGIN(FindMembers);
} }
} }
}
<FindMembers>"." { <FindMembers>"." {
if (insideJava) if (insideJava)
{ {
...@@ -1565,6 +1607,10 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -1565,6 +1607,10 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
{ {
current->bodyLine = yyLineNr; current->bodyLine = yyLineNr;
} }
if ( insidePHP && current->type.left(3) == "var" )
{
current->type = current->type.mid(3);
}
current->type=current->type.simplifyWhiteSpace(); current->type=current->type.simplifyWhiteSpace();
current->args=current->args.simplifyWhiteSpace(); current->args=current->args.simplifyWhiteSpace();
current->name=current->name.stripWhiteSpace(); current->name=current->name.stripWhiteSpace();
...@@ -2244,7 +2290,18 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -2244,7 +2290,18 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
BEGIN(SkipCPP); BEGIN(SkipCPP);
} }
*/ */
<FuncQual>[{:;,] { unput(*yytext); BEGIN( Function ); } <FuncQual>[{:;,] {
if ( strcmp(yytext,";")==0 && insidePHP && current->type.left(8) != "function" )
{
current->reset();
initEntry();
BEGIN( FindMembers );
}
else
{
unput(*yytext); BEGIN( Function );
}
}
<FuncQual>{BN}*"const"{BN}* { <FuncQual>{BN}*"const"{BN}* {
lineCount() ; lineCount() ;
current->args += " const "; current->args += " const ";
...@@ -2374,6 +2431,16 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -2374,6 +2431,16 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
} }
} }
//printf("Adding entry `%s'\n",current->name.data()); //printf("Adding entry `%s'\n",current->name.data());
if ( insidePHP && current->type.left(8) != "function" )
{
initEntry();
}
else
{
if ( insidePHP && current->type.left(8) == "function" )
{
current->type = current->type.mid(8);
}
previous = current; previous = current;
current_root->addSubEntry(current); current_root->addSubEntry(current);
current = new Entry ; current = new Entry ;
...@@ -2385,7 +2452,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -2385,7 +2452,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
} }
if ( *yytext == '{' ) if ( *yytext == '{' )
{ {
if (current_root->section & Entry::COMPOUND_MASK) if ( !insidePHP && (current_root->section & Entry::COMPOUND_MASK) )
previous->memSpec = previous->memSpec | Entry::Inline; previous->memSpec = previous->memSpec | Entry::Inline;
//addToBody(yytext); //addToBody(yytext);
curlyCount=0; curlyCount=0;
...@@ -2398,7 +2465,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -2398,7 +2465,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
BEGIN( FindMembers ) ; BEGIN( FindMembers ) ;
} }
} }
}
<SkipInits>"{" { <SkipInits>"{" {
//addToBody(yytext); //addToBody(yytext);
//lastCurlyContext = FindMembers; //lastCurlyContext = FindMembers;
...@@ -2592,6 +2659,14 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -2592,6 +2659,14 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
baseName.resize(0); baseName.resize(0);
BEGIN( BasesProt ) ; BEGIN( BasesProt ) ;
} }
else if (insidePHP && (strcmp(yytext,"extends")==0))
{
current->type.resize(0);
baseProt=Public;
baseVirt=Normal;
baseName.resize(0);
BEGIN( BasesProt ) ;
}
else else
{ {
//if (isTypedef) //if (isTypedef)
...@@ -2618,7 +2693,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -2618,7 +2693,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
} }
<ClassVar>":" { <ClassVar>":" {
current->type.resize(0); current->type.resize(0);
if (current->section == Entry::INTERFACE_SEC || current->section == Entry::STRUCT_SEC) if (current->section == Entry::INTERFACE_SEC || current->section == Entry::STRUCT_SEC || insidePHP)
baseProt=Public; baseProt=Public;
else else
baseProt=Private; baseProt=Private;
...@@ -2715,7 +2790,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -2715,7 +2790,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
current->extends->append( current->extends->append(
new BaseInfo(baseName,baseProt,baseVirt) new BaseInfo(baseName,baseProt,baseVirt)
); );
if (current->section == Entry::INTERFACE_SEC || insideJava) if (current->section == Entry::INTERFACE_SEC || insideJava || insidePHP)
baseProt=Public; baseProt=Public;
else else
baseProt=Private; baseProt=Private;
...@@ -4126,6 +4201,44 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -4126,6 +4201,44 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
current->doc+=yytext; current->doc+=yytext;
} }
<Doc,ClassDoc,PageDoc,ExampleDoc,AfterDoc,CopyArgComment>{CMD}[a-z_A-Z][a-z_A-Z0-9]* { <Doc,ClassDoc,PageDoc,ExampleDoc,AfterDoc,CopyArgComment>{CMD}[a-z_A-Z][a-z_A-Z0-9]* {
bool handled=FALSE;
if ( useOverrideCommands)
{
if ( strcmp(yytext+1,"static")==0 )
{
current->stat = TRUE; handled = TRUE;
}
else if ( strcmp(yytext+1,"pure")==0 )
{
current->virt = Pure; handled = TRUE;
}
else if ( strcmp(yytext+1,"private")==0 )
{
current->protection = Private; handled = TRUE;
}
else if ( strcmp(yytext+1,"privatesection")==0 )
{
current->protection = protection = Private; handled = TRUE;
}
else if ( strcmp(yytext+1,"protected")==0 )
{
current->protection = Protected; handled = TRUE;
}
else if ( strcmp(yytext+1,"protectedsection")==0 )
{
current->protection = protection = Protected ; handled = TRUE;
}
else if ( strcmp(yytext+1,"public")==0 )
{
current->protection = Public; handled = TRUE;
}
else if ( strcmp(yytext+1,"publicsection")==0 )
{
current->protection = protection = Public; handled = TRUE;
}
}
if (!handled)
{
QCString *pValue=Doxygen::aliasDict[yytext+1]; QCString *pValue=Doxygen::aliasDict[yytext+1];
if (pValue) if (pValue)
{ {
...@@ -4143,6 +4256,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) ...@@ -4143,6 +4256,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'"))
current->doc+=yytext; current->doc+=yytext;
} }
} }
}
<JavaDoc,LineDoc,ClassDocBrief,AfterDocBrief,AfterDocLine>"\\"[a-z_A-Z][a-z_A-Z0-9]*[\\] { // directory type of text <JavaDoc,LineDoc,ClassDocBrief,AfterDocBrief,AfterDocLine>"\\"[a-z_A-Z][a-z_A-Z0-9]*[\\] { // directory type of text
current->brief+=yytext; current->brief+=yytext;
} }
...@@ -4307,7 +4421,7 @@ static void parseCompounds(Entry *rt) ...@@ -4307,7 +4421,7 @@ static void parseCompounds(Entry *rt)
// set default protection based on the compound type // set default protection based on the compound type
if( ce->section==Entry::CLASS_SEC ) // class if( ce->section==Entry::CLASS_SEC ) // class
{ {
if (ce->fileName.right(5)==".java") if (ce->fileName.right(5)==".java" || ce->fileName.right(4)==".php")
current->protection = protection = Public ; // Actually this should be package scope! current->protection = protection = Public ; // Actually this should be package scope!
else else
current->protection = protection = Private ; current->protection = protection = Private ;
......
...@@ -1159,15 +1159,19 @@ void TagFileParser::addIncludes() ...@@ -1159,15 +1159,19 @@ void TagFileParser::addIncludes()
TagFileInfo *tfi = m_tagFileFiles.first(); TagFileInfo *tfi = m_tagFileFiles.first();
while (tfi) while (tfi)
{ {
//printf("tag file tagName=%s path=%s name=%s\n",m_tagName.data(),tfi->path.data(),tfi->name.data());
FileName *fn = Doxygen::inputNameDict->find(tfi->name); FileName *fn = Doxygen::inputNameDict->find(tfi->name);
if (fn) if (fn)
{ {
//printf("found\n");
FileNameIterator fni(*fn); FileNameIterator fni(*fn);
FileDef *fd; FileDef *fd;
for (;(fd=fni.current());++fni) for (;(fd=fni.current());++fni)
{ {
//printf("input file path=%s name=%s\n",fd->getPath().data(),fd->name().data());
if (fd->getPath()==QCString(m_tagName+":"+tfi->path)) if (fd->getPath()==QCString(m_tagName+":"+tfi->path))
{ {
//printf("found\n");
QListIterator<TagIncludeInfo> mii(tfi->includes); QListIterator<TagIncludeInfo> mii(tfi->includes);
TagIncludeInfo *ii; TagIncludeInfo *ii;
for (;(ii=mii.current());++mii) for (;(ii=mii.current());++mii)
...@@ -1213,3 +1217,4 @@ void parseTagFile(Entry *root,const char *fullName,const char *tagName) ...@@ -1213,3 +1217,4 @@ void parseTagFile(Entry *root,const char *fullName,const char *tagName)
handler.addIncludes(); handler.addIncludes();
} }
...@@ -29,6 +29,38 @@ ...@@ -29,6 +29,38 @@
#ifndef TRANSLATOR_JP_H #ifndef TRANSLATOR_JP_H
#define TRANSLATOR_JP_H #define TRANSLATOR_JP_H
class TranslatorJapaneseEn : public TranslatorEnglish
{
public:
virtual QCString idLanguage()
{ return "japanese"; }
virtual QCString latexLanguageSupportCommand()
{
return "";
}
/*! returns the name of the package that is included by LaTeX */
virtual QCString idLanguageCharset()
{
#ifdef _WIN32
return "Shift_JIS";
#else
return "euc-jp";
#endif
}
virtual QCString trRTFansicp()
{
return "932";
}
/*! Used as ansicpg for RTF fcharset
* \see trRTFansicp() for a table of possible values.
*/
virtual QCString trRTFCharSet()
{
return "128";
}
};
class TranslatorJapanese : public Translator class TranslatorJapanese : public Translator
{ {
private: private:
...@@ -64,7 +96,7 @@ class TranslatorJapanese : public Translator ...@@ -64,7 +96,7 @@ class TranslatorJapanese : public Translator
/*! subscript for the related functions. */ /*! subscript for the related functions. */
virtual QCString trRelatedSubscript() virtual QCString trRelatedSubscript()
{ return decode("(これらはメンバ関数でないことに注意)"); } { return decode("(これらはメソッドでないことに注意)"); }
/*! header that is put before the detailed description of files, classes and namespaces. */ /*! header that is put before the detailed description of files, classes and namespaces. */
virtual QCString trDetailedDescription() virtual QCString trDetailedDescription()
...@@ -72,15 +104,15 @@ class TranslatorJapanese : public Translator ...@@ -72,15 +104,15 @@ class TranslatorJapanese : public Translator
/*! header that is put before the list of typedefs. */ /*! header that is put before the list of typedefs. */
virtual QCString trMemberTypedefDocumentation() virtual QCString trMemberTypedefDocumentation()
{ return decode("Typedef メンバの解説"); } { return decode("Typedef の解説"); }
/*! header that is put before the list of enumerations. */ /*! header that is put before the list of enumerations. */
virtual QCString trMemberEnumerationDocumentation() virtual QCString trMemberEnumerationDocumentation()
{ return decode("Enum メンバの解説"); } { return decode("Enum の解説"); }
/*! header that is put before the list of member functions. */ /*! header that is put before the list of member functions. */
virtual QCString trMemberFunctionDocumentation() virtual QCString trMemberFunctionDocumentation()
{ return decode("関数メンバの解説"); } { return decode("メソッドの解説"); }
/*! header that is put before the list of member attributes. */ /*! header that is put before the list of member attributes. */
virtual QCString trMemberDataDocumentation() virtual QCString trMemberDataDocumentation()
...@@ -91,7 +123,7 @@ class TranslatorJapanese : public Translator ...@@ -91,7 +123,7 @@ class TranslatorJapanese : public Translator
} }
else else
{ {
return decode("メンバの解説"); return decode("変数の解説");
} }
} }
...@@ -258,7 +290,7 @@ class TranslatorJapanese : public Translator ...@@ -258,7 +290,7 @@ class TranslatorJapanese : public Translator
QCString result=decode("これは"); QCString result=decode("これは");
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C")) if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{ {
result+=decode("関数、変数、マクロ、列挙型、型定義の"); result+=decode("関数、変数、マクロ、Enum、Typedef の");
} }
else else
{ {
...@@ -389,13 +421,13 @@ class TranslatorJapanese : public Translator ...@@ -389,13 +421,13 @@ class TranslatorJapanese : public Translator
* list of typedefs * list of typedefs
*/ */
virtual QCString trTypedefs() virtual QCString trTypedefs()
{ return decode("型定義"); } { return decode("Typedef"); }
/*! This is used in the documentation of a file as a header before the /*! This is used in the documentation of a file as a header before the
* list of enumerations * list of enumerations
*/ */
virtual QCString trEnumerations() virtual QCString trEnumerations()
{ return decode("列挙型"); } { return decode("Enum"); }
/*! This is used in the documentation of a file as a header before the /*! This is used in the documentation of a file as a header before the
* list of (global) functions * list of (global) functions
...@@ -413,7 +445,7 @@ class TranslatorJapanese : public Translator ...@@ -413,7 +445,7 @@ class TranslatorJapanese : public Translator
* list of (global) variables * list of (global) variables
*/ */
virtual QCString trEnumerationValues() virtual QCString trEnumerationValues()
{ return decode("列挙値"); } { return decode("Enum 値"); }
/*! This is used in the documentation of a file before the list of /*! This is used in the documentation of a file before the list of
* documentation blocks for defines * documentation blocks for defines
*/ */
...@@ -430,19 +462,19 @@ class TranslatorJapanese : public Translator ...@@ -430,19 +462,19 @@ class TranslatorJapanese : public Translator
* of documentation blocks for typedefs * of documentation blocks for typedefs
*/ */
virtual QCString trTypedefDocumentation() virtual QCString trTypedefDocumentation()
{ return decode("型定義の解説"); } { return decode("Typedef の解説"); }
/*! This is used in the documentation of a file/namespace before the list /*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for enumeration types * of documentation blocks for enumeration types
*/ */
virtual QCString trEnumerationTypeDocumentation() virtual QCString trEnumerationTypeDocumentation()
{ return decode("列挙型の解説"); } { return decode("Enum の解説"); }
/*! This is used in the documentation of a file/namespace before the list /*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for enumeration values * of documentation blocks for enumeration values
*/ */
virtual QCString trEnumerationValueDocumentation() virtual QCString trEnumerationValueDocumentation()
{ return decode("列挙値の解説"); } { return decode("Enum 値の解説"); }
/*! This is used in the documentation of a file/namespace before the list /*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for functions * of documentation blocks for functions
...@@ -609,25 +641,25 @@ class TranslatorJapanese : public Translator ...@@ -609,25 +641,25 @@ class TranslatorJapanese : public Translator
/* these are for the member sections of a class, struct or union */ /* these are for the member sections of a class, struct or union */
virtual QCString trPublicMembers() virtual QCString trPublicMembers()
{ return decode("Public メンバ"); } { return decode("Public メソッド"); }
virtual QCString trPublicSlots() virtual QCString trPublicSlots()
{ return decode("Public スロット"); } { return decode("Public スロット"); }
virtual QCString trSignals() virtual QCString trSignals()
{ return decode("シグナル"); } { return decode("シグナル"); }
virtual QCString trStaticPublicMembers() virtual QCString trStaticPublicMembers()
{ return decode("Static Public メンバ"); } { return decode("Static Public メソッド"); }
virtual QCString trProtectedMembers() virtual QCString trProtectedMembers()
{ return decode("Protected メンバ"); } { return decode("Protected メソッド"); }
virtual QCString trProtectedSlots() virtual QCString trProtectedSlots()
{ return decode("Protected スロット"); } { return decode("Protected スロット"); }
virtual QCString trStaticProtectedMembers() virtual QCString trStaticProtectedMembers()
{ return decode("Static Protected メンバ"); } { return decode("Static Protected メソッド"); }
virtual QCString trPrivateMembers() virtual QCString trPrivateMembers()
{ return decode("Private メンバ"); } { return decode("Private メソッド"); }
virtual QCString trPrivateSlots() virtual QCString trPrivateSlots()
{ return decode("Private スロット"); } { return decode("Private スロット"); }
virtual QCString trStaticPrivateMembers() virtual QCString trStaticPrivateMembers()
{ return decode("Static Private メンバ"); } { return decode("Static Private メソッド"); }
/*! this function is used to produce a comma-separated list of items. /*! this function is used to produce a comma-separated list of items.
* use generateMarker(i) to indicate where item i should be put. * use generateMarker(i) to indicate where item i should be put.
...@@ -880,22 +912,22 @@ class TranslatorJapanese : public Translator ...@@ -880,22 +912,22 @@ class TranslatorJapanese : public Translator
} }
virtual QCString trPublicTypes() virtual QCString trPublicTypes()
{ {
return decode("公開型"); return decode("Public 型");
} }
virtual QCString trPublicAttribs() virtual QCString trPublicAttribs()
{ {
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C")) if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{ {
return decode("データフィールド"); return decode("変数");
} }
else else
{ {
return decode("Public 属性"); return decode("Public 変数");
} }
} }
virtual QCString trStaticPublicAttribs() virtual QCString trStaticPublicAttribs()
{ {
return decode("Static Public 属性"); return decode("Static Public 変数");
} }
virtual QCString trProtectedTypes() virtual QCString trProtectedTypes()
{ {
...@@ -903,11 +935,11 @@ class TranslatorJapanese : public Translator ...@@ -903,11 +935,11 @@ class TranslatorJapanese : public Translator
} }
virtual QCString trProtectedAttribs() virtual QCString trProtectedAttribs()
{ {
return decode("Protected 属性"); return decode("Protected 変数");
} }
virtual QCString trStaticProtectedAttribs() virtual QCString trStaticProtectedAttribs()
{ {
return decode("Static Protected 属性"); return decode("Static Protected 変数");
} }
virtual QCString trPrivateTypes() virtual QCString trPrivateTypes()
{ {
...@@ -915,11 +947,11 @@ class TranslatorJapanese : public Translator ...@@ -915,11 +947,11 @@ class TranslatorJapanese : public Translator
} }
virtual QCString trPrivateAttribs() virtual QCString trPrivateAttribs()
{ {
return decode("Private 属性"); return decode("Private 変数");
} }
virtual QCString trStaticPrivateAttribs() virtual QCString trStaticPrivateAttribs()
{ {
return decode("Static Private 属性"); return decode("Static Private 変数");
} }
////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////
...@@ -1334,4 +1366,5 @@ class TranslatorJapanese : public Translator ...@@ -1334,4 +1366,5 @@ class TranslatorJapanese : public Translator
} }
}; };
#endif #endif
/******************************************************************************
*
*
*
* Copyright (C) 1997-2002 by Dimitri van Heesch.
*
* Permission to use, copy, modify, and distribute this software and its
* documentation under the terms of the GNU General Public License is hereby
* granted. No representations are made about the suitability of this software
* for any purpose. It is provided "as is" without express or implied warranty.
* See the GNU General Public License for more details.
*
* Documents produced by Doxygen are derivative works derived from the
* input used in their production; they are not affected by this license.
*
*/
#ifndef TRANSLATOR_SR_H
#define TRANSLATOR_SR_H
// translation by Dejan D. M. Milosavljevic <dmilos@email.com>;<dmilosx@ptt.yu>
class TranslatorSerbian : public Translator
{
QCString decode(const QCString& sInput)
{
#ifdef _WIN32
return ISO88592ToWin1250(sInput);
#else
return sInput;
#endif
}
public:
// --- Language control methods -------------------
/*! Used for identification of the language. The identification
* should not be translated. It should be replaced by the name
* of the language in English using lower-case characters only
* (e.g. "czech", "japanese", "russian", etc.). It should be equal to
* the identification used in language.cpp.
*/
virtual QCString idLanguage()
{ return "serbian"; }
/*! Used to get the LaTeX command(s) for the language support.
* This method should return string with commands that switch
* LaTeX to the desired language. For example
* <pre>"\\usepackage[german]{babel}\n"
* </pre>
* or
* <pre>"\\usepackage{polski}\n"
* "\\usepackage[latin2]{inputenc}\n"
* "\\usepackage[T1]{fontenc}\n"
* </pre>
*
* The English LaTeX does not use such commands. Because of this
* the empty string is returned in this implementation.
*/
virtual QCString latexLanguageSupportCommand()
{
return "";
}
/*! return the language charset. This will be used for the HTML output */
virtual QCString idLanguageCharset()
{
#ifdef _WIN32
{ return "windows-1250"; }
#else
{ return "iso-8859-2"; }
#endif
}
// --- Language translation methods -------------------
/*! used in the compound documentation before a list of related functions. */
virtual QCString trRelatedFunctions()
{ return "Povezane funkcije"; }
/*! subscript for the related functions. */
virtual QCString trRelatedSubscript()
{ return decode( "(To nisu funkcije èlanice.)" ); }
/*! header that is put before the detailed description of files, classes and namespaces. */
virtual QCString trDetailedDescription()
{ return decode( "Detaljno obja¹njenje" ); }
/*! header that is put before the list of typedefs. */
virtual QCString trMemberTypedefDocumentation()
{ return decode( "Dokumentacija typedef èlanova" ); }
/*! header that is put before the list of enumerations. */
virtual QCString trMemberEnumerationDocumentation()
{ return decode( "Dokumentacija enum èlanova" ); }
/*! header that is put before the list of member functions. */
virtual QCString trMemberFunctionDocumentation()
{ return "Dokumentacija funkcija èlanica"; }
/*! header that is put before the list of member attributes. */
virtual QCString trMemberDataDocumentation()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Dokumentacija èlanova";
}
else
{
return "Documentacija javnoh èlanova";
}
}
/*! this is the text of a link put after brief descriptions. */
virtual QCString trMore()
{ return "Jo¹..."; }
/*! put in the class documentation */
virtual QCString trListOfAllMembers()
{ return "Spisak svih èlanova."; }
/*! used as the title of the "list of all members" page of a class */
virtual QCString trMemberList()
{ return "Spisak èlanova"; }
/*! this is the first part of a sentence that is followed by a class name */
virtual QCString trThisIsTheListOfAllMembers()
{ return "Ovo je spisak svih èlanova "; }
/*! this is the remainder of the sentence after the class name */
virtual QCString trIncludingInheritedMembers()
{ return ", ukljuèujuæi nasleðene èlanove."; }
/*! this is put at the author sections at the bottom of man pages.
* parameter s is name of the project name.
*/
virtual QCString trGeneratedAutomatically(const char *s)
{ QCString result="Napravljeno automatski Doxygen-om";
if (s) result+=(QCString)" za "+s;
result+=" od izvornog koda.";
return result;
}
/*! put after an enum name in the list of all members */
virtual QCString trEnumName()
{ return "ime enum-a "; }
/*! put after an enum value in the list of all members */
virtual QCString trEnumValue()
{ return "vrednost enum-a"; }
/*! put after an undocumented member in the list of all members */
virtual QCString trDefinedIn()
{ return "definisano u"; }
// quick reference sections
/*! This is put above each page as a link to the list of all groups of
* compounds or files (see the \\group command).
*/
virtual QCString trModules()
{ return "Moduli"; }
/*! This is put above each page as a link to the class hierarchy */
virtual QCString trClassHierarchy()
{ return "Stablo klasa"; }
/*! This is put above each page as a link to the list of annotated classes */
virtual QCString trCompoundList()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Sve strukture";
}
else
{
return "Sve klase";
}
}
/*! This is put above each page as a link to the list of documented files */
virtual QCString trFileList()
{ return "Spisak fajlova"; }
/*! This is put above each page as a link to the list of all verbatim headers */
virtual QCString trHeaderFiles()
{ return "Zaglavlja"; }
/*! This is put above each page as a link to all members of compounds. */
virtual QCString trCompoundMembers()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Svi èlanovi struktura";
}
else
{
return "Svi èlanovi klasa";
}
}
/*! This is put above each page as a link to all members of files. */
virtual QCString trFileMembers()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Globalni";
}
else
{
return "Lokalni";
}
}
/*! This is put above each page as a link to all related pages. */
virtual QCString trRelatedPages()
{ return "Stranice povezane s ovom"; }
/*! This is put above each page as a link to all examples. */
virtual QCString trExamples()
{ return "Primeri"; }
/*! This is put above each page as a link to the search engine. */
virtual QCString trSearch()
{ return "Tra¾i"; }
/*! This is an introduction to the class hierarchy. */
virtual QCString trClassHierarchyDescription()
{ return "Stablo nasleðivanja je slo¾eno ""pribli¾no po abecedi:"; }
/*! This is an introduction to the list with all files. */
virtual QCString trFileListDescription(bool extractAll)
{
QCString result="Spisak svih ";
if (!extractAll) result+="dokumetovanih ";
result+="fajlova, sa kratkim opisom:";
return result;
}
/*! This is an introduction to the annotated compound list. */
virtual QCString trCompoundListDescription()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Spisak struktura sa kratkim opisom:";
}
else
{
return "Spisak klasa, struktura, unija i interjfejsa sa kratkim opisom:";
}
}
/*! This is an introduction to the page with all class members. */
virtual QCString trCompoundMembersDescription(bool extractAll)
{
QCString result="Spisak svih ";
if (!extractAll)
{
result+="dokumentovanih ";
}
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
result+="èlanova struktura ili unija";
}
else
{
result+="èlanova klasa";
}
result+=" sa linkovima na ";
if (extractAll)
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
result+="dokumentaciju èlanova struktura/unija:";
}
else
{
result+="dokumentaciju svakog èlana klase:";
}
}
else
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
result+="strukture/uniije koje pripadaju:";
}
else
{
result+="klase koje pripadaju:";
}
}
return result;
}
/*! This is an introduction to the page with all file members. */
virtual QCString trFileMembersDescription(bool extractAll)
{
QCString result="Spisak svih ";
if (!extractAll) result+="dokumentovanih ";
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
result+="funkcija, promenjiva, makro zamena, enum-a, i typedef-va";
}
else
{
result+="èlanova";
}
result+=" sa linkovima na ";
if (extractAll)
result+="fajlove u kojima se nalaze:";
else
result+=" dokumentaciju:";
return decode( result );
}
/*! This is an introduction to the page with the list of all header files. */
virtual QCString trHeaderFilesDescription()
{ return decode( "Zaglavlja koje izgraðuju API:" ); }
/*! This is an introduction to the page with the list of all examples */
virtual QCString trExamplesDescription()
{ return "Spisak primera:"; }
/*! This is an introduction to the page with the list of related pages */
virtual QCString trRelatedPagesDescription()
{ return decode( "Spisak svih slèinih stranica:" ); }
/*! This is an introduction to the page with the list of class/file groups */
virtual QCString trModulesDescription()
{ return "Spisak svih modula:"; }
/*! This sentences is used in the annotated class/file lists if no brief
* description is given.
*/
virtual QCString trNoDescriptionAvailable()
{ return "Opis nije dostupan"; }
// index titles (the project name is prepended for these)
/*! This is used in HTML as the title of index.html. */
virtual QCString trDocumentation()
{ return "Dokumentacija"; }
/*! This is used in LaTeX as the title of the chapter with the
* index of all groups.
*/
virtual QCString trModuleIndex()
{ return "Index modula"; }
/*! This is used in LaTeX as the title of the chapter with the
* class hierarchy.
*/
virtual QCString trHierarchicalIndex()
{ return "Hijerarhijski sad¾raj"; }
/*! This is used in LaTeX as the title of the chapter with the
* annotated compound index.
*/
virtual QCString trCompoundIndex()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return decode( "Glavni sadr¾aj" );
}
else
{
return decode( "Glavni sadr¾aj" );
}
}
/*! This is used in LaTeX as the title of the chapter with the
* list of all files.
*/
virtual QCString trFileIndex()
{ return "Indeks fajlova"; }
/*! This is used in LaTeX as the title of the chapter containing
* the documentation of all groups.
*/
virtual QCString trModuleDocumentation()
{ return "Dokumentacija modula"; }
/*! This is used in LaTeX as the title of the chapter containing
* the documentation of all classes, structs and unions.
*/
virtual QCString trClassDocumentation()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Dokumentacija stuktura";
}
else
{
return "Dokumentacija klasa";
}
}
/*! This is used in LaTeX as the title of the chapter containing
* the documentation of all files.
*/
virtual QCString trFileDocumentation()
{ return "Dokumentacija fajla"; }
/*! This is used in LaTeX as the title of the chapter containing
* the documentation of all examples.
*/
virtual QCString trExampleDocumentation()
{ return "Dokumentacija primera"; }
/*! This is used in LaTeX as the title of the chapter containing
* the documentation of all related pages.
*/
virtual QCString trPageDocumentation()
{ return "Dokumentacija stranice"; }
/*! This is used in LaTeX as the title of the document */
virtual QCString trReferenceManual()
{ return decode("Priruènik"); }
/*! This is used in the documentation of a file as a header before the
* list of defines
*/
virtual QCString trDefines()
{ return "Makro zamene"; }
/*! This is used in the documentation of a file as a header before the
* list of function prototypes
*/
virtual QCString trFuncProtos()
{ return "Deklaracija funkcije"; }
/*! This is used in the documentation of a file as a header before the
* list of typedefs
*/
virtual QCString trTypedefs()
{ return "Typedef-ovi"; }
/*! This is used in the documentation of a file as a header before the
* list of enumerations
*/
virtual QCString trEnumerations()
{ return "Enum-ovi"; }
/*! This is used in the documentation of a file as a header before the
* list of (global) functions
*/
virtual QCString trFunctions()
{ return "Funkcije"; }
/*! This is used in the documentation of a file as a header before the
* list of (global) variables
*/
virtual QCString trVariables()
{ return "Promenjive"; }
/*! This is used in the documentation of a file as a header before the
* list of (global) variables
*/
virtual QCString trEnumerationValues()
{ return "Vrednosti enum-ova"; }
/*! This is used in the documentation of a file before the list of
* documentation blocks for defines
*/
virtual QCString trDefineDocumentation()
{ return "Dokumentacija makro zamene"; }
/*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for function prototypes
*/
virtual QCString trFunctionPrototypeDocumentation()
{ return "Dokumentacija deklaracije funkcije"; }
/*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for typedefs
*/
virtual QCString trTypedefDocumentation()
{ return "Dokumentacija typedef-a"; }
/*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for enumeration types
*/
virtual QCString trEnumerationTypeDocumentation()
{ return "Dokumetacija enum tipa"; }
/*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for enumeration values
*/
virtual QCString trEnumerationValueDocumentation()
{ return "Dokumentacija enum vrednosti"; }
/*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for functions
*/
virtual QCString trFunctionDocumentation()
{ return "Dokumentacija funkcije"; }
/*! This is used in the documentation of a file/namespace before the list
* of documentation blocks for variables
*/
virtual QCString trVariableDocumentation()
{ return "Dokumentacija promenjive"; }
/*! This is used in the documentation of a file/namespace/group before
* the list of links to documented compounds
*/
virtual QCString trCompounds()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Strukture";
}
else
{
return "Klase i strukture";
}
}
/*! This is used in the standard footer of each page and indicates when
* the page was generated
*/
virtual QCString trGeneratedAt(const char *date,const char *projName)
{
QCString result=(QCString)"Napravljeno "+date;
if (projName) result+=(QCString)" za "+projName;
result+=(QCString)" od";
return result;
}
/*! This is part of the sentence used in the standard footer of each page.
*/
virtual QCString trWrittenBy()
{
return "napisao";
}
/*! this text is put before a class diagram */
virtual QCString trClassDiagram(const char *clName)
{
return decode( QCString("Dijagram nasleðivanja za klasu ") + clName+":" );
}
/*! this text is generated when the \\internal command is used. */
virtual QCString trForInternalUseOnly()
{ return decode( "Samo za unutrasnju upotrebu." ); }
/*! this text is generated when the \\reimp command is used. */
virtual QCString trReimplementedForInternalReasons()
{ return decode("Preuraðeno zbog internih razloga; Nema uticaja na API." ); }
/*! this text is generated when the \\warning command is used. */
virtual QCString trWarning()
{ return "Upozorenje"; }
/*! this text is generated when the \\bug command is used. */
virtual QCString trBugsAndLimitations()
{ return decode("Gre¹ke i ogranièenja"); }
/*! this text is generated when the \\version command is used. */
virtual QCString trVersion()
{ return "Verzija"; }
/*! this text is generated when the \\date command is used. */
virtual QCString trDate()
{ return "Datum"; }
/*! this text is generated when the \\return command is used. */
virtual QCString trReturns()
{ return decode( "Vraæenene vrednosti" ); }
/*! this text is generated when the \\sa command is used. */
virtual QCString trSeeAlso()
{ return "Takoðe pogledati"; }
/*! this text is generated when the \\param command is used. */
virtual QCString trParameters()
{ return "Parametri"; }
/*! this text is generated when the \\exception command is used. */
virtual QCString trExceptions()
{ return "Izuzeci"; }
/*! this text is used in the title page of a LaTeX document. */
virtual QCString trGeneratedBy()
{ return "Napravio"; }
//////////////////////////////////////////////////////////////////////////
// new since 0.49-990307
//////////////////////////////////////////////////////////////////////////
/*! used as the title of page containing all the index of all namespaces. */
virtual QCString trNamespaceList()
{ return "Spisak prostora imena"; }
/*! used as an introduction to the namespace list */
virtual QCString trNamespaceListDescription(bool extractAll)
{
QCString result="Spisak svih ";
if (!extractAll) result+="dokumentovanih ";
result+="prostora imena sa kratkim opisom:";
return result;
}
/*! used in the class documentation as a header before the list of all
* friends of a class
*/
virtual QCString trFriends()
{ return "Prijatelji"; }
//////////////////////////////////////////////////////////////////////////
// new since 0.49-990405
//////////////////////////////////////////////////////////////////////////
/*! used in the class documentation as a header before the list of all
* related classes
*/
virtual QCString trRelatedFunctionDocumentation()
{ return "Dokumentacija prijateljskih funkcija ili klasa"; }
//////////////////////////////////////////////////////////////////////////
// new since 0.49-990425
//////////////////////////////////////////////////////////////////////////
/*! used as the title of the HTML page of a class/struct/union */
virtual QCString trCompoundReference(const char *clName,
ClassDef::CompoundType compType,
bool isTemplate)
{
QCString result( "Dokumentacija " );
switch(compType)
{
case ClassDef::Class: result+="klase "; break;
case ClassDef::Struct: result+="strukture "; break;
case ClassDef::Union: result+="unije "; break;
case ClassDef::Interface: result+="interfejsa "; break;
case ClassDef::Exception: result+="izuzetka "; break;
}
if (isTemplate) result+="¹vablona ";
result += clName;
return decode( result );
}
/*! used as the title of the HTML page of a file */
virtual QCString trFileReference(const char *fileName)
{
QCString result=fileName;
result+=" Opis fajla";
return result;
}
/*! used as the title of the HTML page of a namespace */
virtual QCString trNamespaceReference(const char *namespaceName)
{
QCString result=namespaceName;
result+=" Opis prostora imena";
return result;
}
virtual QCString trPublicMembers()
{ return decode("Javni èlanovi"); }
virtual QCString trPublicSlots()
{ return "Javni slotovi"; }
virtual QCString trSignals()
{ return "Signali"; }
virtual QCString trStaticPublicMembers()
{ return decode("Zajednièki javni èlanovi"); }
virtual QCString trProtectedMembers()
{ return decode("Zastiæeni èlanovi"); }
virtual QCString trProtectedSlots()
{ return decode("Zastiæeni slotovi"); }
virtual QCString trStaticProtectedMembers()
{ return decode("Zajednièki za¹tiæeni èlanovi"); }
virtual QCString trPrivateMembers()
{ return decode("Privani èlanovi"); }
virtual QCString trPrivateSlots()
{ return decode("Privatni slotovi"); }
virtual QCString trStaticPrivateMembers()
{ return decode("Zajednièki privatni èlanovi"); }
/*! this function is used to produce a comma-separated list of items.
* use generateMarker(i) to indicate where item i should be put.
*/
virtual QCString trWriteList(int numEntries)
{
QCString result;
int i;
// the inherits list contain `numEntries' classes
for (i=0;i<numEntries;i++)
{
// use generateMarker to generate placeholders for the class links!
result+=generateMarker(i); // generate marker for entry i in the list
// (order is left to right)
if (i!=numEntries-1) // not the last entry, so we need a separator
{
if (i<numEntries-2) // not the fore last entry
result+=", ";
else // the fore last entry
result+=" i ";
}
}
return result;
}
/*! used in class documentation to produce a list of base classes,
* if class diagrams are disabled.
*/
virtual QCString trInheritsList(int numEntries)
{
return decode("Nasleðeno od "+trWriteList(numEntries)+".");
}
/*! used in class documentation to produce a list of super classes,
* if class diagrams are disabled.
*/
virtual QCString trInheritedByList(int numEntries)
{
return decode( "Nasleðeno u "+trWriteList(numEntries)+"." );
}
/*! used in member documentation blocks to produce a list of
* members that are hidden by this one.
*/
virtual QCString trReimplementedFromList(int numEntries)
{
return decode("Preuraðeno od "+trWriteList(numEntries)+"." );
}
/*! used in member documentation blocks to produce a list of
* all member that overwrite the implementation of this member.
*/
virtual QCString trReimplementedInList(int numEntries)
{
return decode("Preuraðeno u "+trWriteList(numEntries)+"." );
}
/*! This is put above each page as a link to all members of namespaces. */
virtual QCString trNamespaceMembers()
{ return decode("Èlanovi prostora imena"); }
/*! This is an introduction to the page with all namespace members */
virtual QCString trNamespaceMemberDescription(bool extractAll)
{
QCString result="Spisak svih ";
if (!extractAll) result+="dokumentovanih ";
result+="èlanova prostora imena sa linkovima na ";
if (extractAll)
result+="dokumentaciju svakog èlana prostora imena: ";
else
result+="prostor imena kojima pripadaju: ";
return result;
}
/*! This is used in LaTeX as the title of the chapter with the
* index of all namespaces.
*/
virtual QCString trNamespaceIndex()
{ return "Index prostora imena"; }
/*! This is used in LaTeX as the title of the chapter containing
* the documentation of all namespaces.
*/
virtual QCString trNamespaceDocumentation()
{ return "Dokumentacija prostora imena"; }
//////////////////////////////////////////////////////////////////////////
// new since 0.49-990522
//////////////////////////////////////////////////////////////////////////
/*! This is used in the documentation before the list of all
* namespaces in a file.
*/
virtual QCString trNamespaces()
{ return "Prostori imena"; }
//////////////////////////////////////////////////////////////////////////
// new since 0.49-990728
//////////////////////////////////////////////////////////////////////////
/*! This is put at the bottom of a class documentation page and is
* followed by a list of files that were used to generate the page.
*/
virtual QCString trGeneratedFromFiles(ClassDef::CompoundType compType,
bool single)
{ // here s is one of " Class", " Struct" or " Union"
// single is true implies a single file
QCString result=(QCString)"Dokumentacija ove ";
switch(compType)
{
case ClassDef::Class: result+="klase"; break;
case ClassDef::Struct: result+="strukture"; break;
case ClassDef::Union: result+="unije"; break;
case ClassDef::Interface: result+="interfejsa"; break;
case ClassDef::Exception: result+="izuzetka"; break;
}
result+=" je napravljen iz ";
if (single) result+=":"; else result+=":";
return result;
}
/*! This is in the (quick) index as a link to the alphabetical compound
* list.
*/
virtual QCString trAlphabeticalList()
{ return "Abecedni spisak"; }
//////////////////////////////////////////////////////////////////////////
// new since 0.49-990901
//////////////////////////////////////////////////////////////////////////
/*! This is used as the heading text for the retval command. */
virtual QCString trReturnValues()
{ return "Vraæena vrednost"; }
/*! This is in the (quick) index as a link to the main page (index.html)
*/
virtual QCString trMainPage()
{ return "Glavna strana"; }
/*! This is used in references to page that are put in the LaTeX
* documentation. It should be an abbreviation of the word page.
*/
virtual QCString trPageAbbreviation()
{ return "str."; }
//////////////////////////////////////////////////////////////////////////
// new since 0.49-991003
//////////////////////////////////////////////////////////////////////////
virtual QCString trSources()
{
return "Izvorni fajlovi";
}
virtual QCString trDefinedAtLineInSourceFile()
{
return "Definisano u redu @0 fajla @1.";
}
virtual QCString trDefinedInSourceFile()
{
return "Definisano u fajlu @0.";
}
//////////////////////////////////////////////////////////////////////////
// new since 0.49-991205
//////////////////////////////////////////////////////////////////////////
virtual QCString trDeprecated()
{
return "Matoro";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.0.0
//////////////////////////////////////////////////////////////////////////
/*! this text is put before a collaboration diagram */
virtual QCString trCollaborationDiagram(const char *clName)
{
return decode( (QCString)"Dijagram nasleðenih èlanova za "+clName+":" );
}
/*! this text is put before an include dependency graph */
virtual QCString trInclDepGraph(const char *fName)
{
return decode( (QCString)"Graf zavisnosti fajlova za "+fName+":" );
}
/*! header that is put before the list of constructor/destructors. */
virtual QCString trConstructorDocumentation()
{
return "Dokumentacija konstruktora i destruktora";
}
/*! Used in the file documentation to point to the corresponding sources. */
virtual QCString trGotoSourceCode()
{
return "Izvorni kod.";
}
/*! Used in the file sources to point to the corresponding documentation. */
virtual QCString trGotoDocumentation()
{
return "Dokumentacija.";
}
/*! Text for the \\pre command */
virtual QCString trPrecondition()
{
return "Preduslovi";
}
/*! Text for the \\post command */
virtual QCString trPostcondition()
{
return "Postuslovi";
}
/*! Text for the \\invariant command */
virtual QCString trInvariant()
{
return "Invarijanta";
}
/*! Text shown before a multi-line variable/enum initialization */
virtual QCString trInitialValue()
{
return decode("Poèetna vriednost:");
}
/*! Text used the source code in the file index */
virtual QCString trCode()
{
return "kod";
}
virtual QCString trGraphicalHierarchy()
{
return decode("Grafièko prikaz stablo klasa");
}
virtual QCString trGotoGraphicalHierarchy()
{
return decode("Prika¾i grafièko stablo klasa");
}
virtual QCString trGotoTextualHierarchy()
{
return decode( "Prika¾i tekstualno stablo klasa" );
}
virtual QCString trPageIndex()
{
return "Indeks stranice";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.1.0
//////////////////////////////////////////////////////////////////////////
virtual QCString trNote()
{
return "Primedba";
}
virtual QCString trPublicTypes()
{
return "Javni tipovi";
}
virtual QCString trPublicAttribs()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Èlan";
}
else
{
return "Javni èlan";
}
}
virtual QCString trStaticPublicAttribs()
{
return decode( "Zajednièki javni èlanovi");
}
virtual QCString trProtectedTypes()
{
return decode( "Za¹tiæeni tipovi" );
}
virtual QCString trProtectedAttribs()
{
return decode( "Za¹tiæeni èlanovi" );
}
virtual QCString trStaticProtectedAttribs()
{
return decode( "Zajednièki za¹tiæeni èlanovi" );
}
virtual QCString trPrivateTypes()
{
return "Privatni tipovi";
}
virtual QCString trPrivateAttribs()
{
return "Privatni èlanovi";
}
virtual QCString trStaticPrivateAttribs()
{
return decode("Zajednièki privatni èlanovi");
}
//////////////////////////////////////////////////////////////////////////
// new since 1.1.3
//////////////////////////////////////////////////////////////////////////
/*! Used as a marker that is put before a \\todo item */
virtual QCString trTodo()
{
return decode( "Neuraðeno" );
}
/*! Used as the header of the todo list */
virtual QCString trTodoList()
{
return decode("Spisak neuraðenog");
}
//////////////////////////////////////////////////////////////////////////
// new since 1.1.4
//////////////////////////////////////////////////////////////////////////
virtual QCString trReferencedBy()
{
return decode( "Kori¹æno od" );
}
virtual QCString trRemarks()
{
return decode( "Zapa¾anja" );
}
virtual QCString trAttention()
{
return decode("Pa¾nja");;
}
virtual QCString trInclByDepGraph()
{
return decode("Ovaj graf pokazuje koji fajl direktno "
"ili indirektno ukljuèuju ovaj fajl: ");
}
virtual QCString trSince()
{
return "Od";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.1.5
//////////////////////////////////////////////////////////////////////////
/*! title of the graph legend page */
virtual QCString trLegendTitle()
{
return decode( "Objasnjenje koriscenih simbola" );
}
/*! page explaining how the dot graph's should be interpreted
* The %A in the text below are to prevent link to classes called "A".
*/
virtual QCString trLegendDocs()
{
return decode(
"Ova stranica obja¹njava kako tumaèiti grafikone koje je napravio "
"doxygen.<p>\n"
"Na primer:\n"
"\\code\n"
"/*! Nevidljiva klasa ( nemo¾e stati na graf zbog zadatih ogranièenja ) */\n"
"class Invisible { };\n\n"
"/*! Odseèena klasa, neke osnovne klase su sakrivene */\n"
"class Truncated : public Invisible { };\n\n"
"/* Nedokumentovana klasa */\n"
"class Undocumented { };\n\n"
"/*! Javno nasleðena klasa */\n"
"class PublicBase : public Truncated { };\n\n"
"/*! Sablon klasa */\n"
"template<class T> class Templ { };\n\n"
"/*! Za¹tiæeno nasleðena klasa */\n"
"class ProtectedBase { };\n\n"
"/*! Privatno nasleðena klasa */\n"
"class PrivateBase { };\n\n"
"/*! Klasa koja je kori¹æena od drugih klasa*/\n"
"class Used { };\n\n"
"/*! Super klasa koja naslijeðuje/koristi ostale */\n"
"class Inherited : public PublicBase,\n"
" protected ProtectedBase,\n"
" private PrivateBase,\n"
" public Undocumented\n"
" public Templ<int>\n"
"{\n"
" private:\n"
" Used *m_usedClass;\n"
"};\n"
"\\endcode\n"
"Ako je \\c MAX_DOT_GRAPH_HEIGHT tag u konfiguracionom fajlu "
"postavljen na 200 gornje veze æe izgledati:"
"<p><center><img src=\"graph_legend."+Config_getEnum("DOT_IMAGE_FORMAT")+"\"></center>\n"
"<p>\n"
"Pravougaonici imaju sledeæa znaèenja:\n"
"<ul>\n"
"<li>Puni crni predstavlja strukturu ili klasu za koju je graf napravljen.\n"
"<li>Sa crnom ivicom predstavlja dokumentovanu strukturu ili klasu.\n"
"<li>Sa sivom icivom predstavlja nedokumentovanu strukturu ili klasu.\n"
"<li>Sa crvenom ivicom predstavlja dokumentovanu strukturu ili klasu\n"
"za koju nije prikazan graf naslijeðivanja/kori¹æenja. Graf je odseèen "
"ako ne stane unutar odreðenih granica."
"Strelice imaju sledeæa znaèenja:\n"
"<ul>\n"
"<li>Tamnoplava strelica oznaèava javno nasleðivanje.\n"
"<li>Tamnozelena strelica oznaèava za¹tiæeno nasleðivanje.\n"
"<li>Tamnocrvena strelica oznaèava privatno nasleðivanje.\n"
"<li>Ljubièasta isprekidana strelica ako je klasa koristi ili je njen èlan. "
"Strelica je oznaèena imenom èlana.\n"
"<li>Zuta strelica oznaèava vezu izmeðu primerka ¹ablona"
" i ¹ablon klase od koje je napravljena. "
"Strelica je oznaèena imenom prarametra ¹ablona.\n"
"</ul>\n"
);
}
/*! text for the link to the legend page */
virtual QCString trLegend()
{
return decode( "Objaènjenje korièæenih simbola" );
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.0
//////////////////////////////////////////////////////////////////////////
/*! Used as a marker that is put before a test item */
virtual QCString trTest()
{
return "Test";
}
/*! Used as the header of the test list */
virtual QCString trTestList()
{
return "Spisak testova";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.1
//////////////////////////////////////////////////////////////////////////
/*! Used as a section header for KDE-2 IDL methods */
virtual QCString trDCOPMethods()
{
return "DCOP metode";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.2
//////////////////////////////////////////////////////////////////////////
/*! Used as a section header for IDL properties */
virtual QCString trProperties()
{
return "Osobine";
}
/*! Used as a section header for IDL property documentation */
virtual QCString trPropertyDocumentation()
{
return "Dokumentacija osobina";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.4
//////////////////////////////////////////////////////////////////////////
/*! Used for Java interfaces in the summary section of Java packages */
virtual QCString trInterfaces()
{
return "Interfejsi";
}
/*! Used for Java classes in the summary section of Java packages */
virtual QCString trClasses()
{
if (Config_getBool("OPTIMIZE_OUTPUT_FOR_C"))
{
return "Strikture";
}
else
{
return "Klase";
}
}
/*! Used as the title of a Java package */
virtual QCString trPackage(const char *name)
{
return (QCString)"Paket "+name;
}
/*! Title of the package index page */
virtual QCString trPackageList()
{
return "Spisak paketa";
}
/*! The description of the package index page */
virtual QCString trPackageListDescription()
{
return "Paketi s kratkim opisom (ukoliko postoji):";
}
/*! The link name in the Quick links header for each page */
virtual QCString trPackages()
{
return "Paketi";
}
/*! Used as a chapter title for Latex & RTF output */
virtual QCString trPackageDocumentation()
{
return "Dokumentacija paketa";
}
/*! Text shown before a multi-line define */
virtual QCString trDefineValue()
{
return "Vrednost:";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.5
//////////////////////////////////////////////////////////////////////////
/*! Used as a marker that is put before a \\bug item */
virtual QCString trBug()
{
return decode("Gre¹ka");;
}
/*! Used as the header of the bug list */
virtual QCString trBugList()
{
return decode("Spisak gre¹aka");;
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.6
//////////////////////////////////////////////////////////////////////////
/*! Used as ansicpg for RTF file
*
* The following table shows the correlation of Charset name, Charset Value and
* <pre>
* Codepage number:
* Charset Name Charset Value(hex) Codepage number
* ------------------------------------------------------
* DEFAULT_CHARSET 1 (x01)
* SYMBOL_CHARSET 2 (x02)
* OEM_CHARSET 255 (xFF)
* ANSI_CHARSET 0 (x00) 1252
* RUSSIAN_CHARSET 204 (xCC) 1251
* EE_CHARSET 238 (xEE) 1250
* GREEK_CHARSET 161 (xA1) 1253
* TURKISH_CHARSET 162 (xA2) 1254
* BALTIC_CHARSET 186 (xBA) 1257
* HEBREW_CHARSET 177 (xB1) 1255
* ARABIC _CHARSET 178 (xB2) 1256
* SHIFTJIS_CHARSET 128 (x80) 932
* HANGEUL_CHARSET 129 (x81) 949
* GB2313_CHARSET 134 (x86) 936
* CHINESEBIG5_CHARSET 136 (x88) 950
* </pre>
*
*/
virtual QCString trRTFansicp()
{
return "1252";
}
/*! Used as ansicpg for RTF fcharset
* \see trRTFansicp() for a table of possible values.
*/
virtual QCString trRTFCharSet()
{
return "238";
}
/*! Used as header RTF general index */
virtual QCString trRTFGeneralIndex()
{
return decode("Sadr¾aj");;
}
/*! 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 trClass(bool first_capital, bool singular)
{
QCString result((first_capital ? "Klas" : "klas"));
result+= (singular ? "a" : "e");
return 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 trFile(bool first_capital, bool singular)
{
QCString result((first_capital ? "Fajl" : "fajl"));
result+= (singular ? "" : "ovi");
return 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 trNamespace(bool first_capital, bool singular)
{
QCString result((first_capital ? "Prostor" : "prostor"));
result += (singular ? "" : "i");
result += " imena";
return 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 trGroup(bool first_capital, bool singular)
{
QCString result((first_capital ? "Grup" : "grup"));
result+= (singular ? "a" : "e");
return 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 trPage(bool first_capital, bool singular)
{
QCString result((first_capital ? "Stran" : "stran"));
result+= (singular ? "a" : "e");
return 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 trMember(bool first_capital, bool singular)
{
QCString result((first_capital ? "Èlan" : "èlan"));
result+= (singular ? "" : "ovi");
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
* be followed by a single name or by a list of names
* of the category.
*/
virtual QCString trGlobal(bool first_capital, bool singular)
{
QCString result((first_capital ? "Global" : "global"));
result+= (singular ? "no" : "ni");
return result;
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.7
//////////////////////////////////////////////////////////////////////////
/*! This text is generated when the \\author command is used and
* for the author section in man pages. */
virtual QCString trAuthor(bool first_capital, bool singular)
{
QCString result((first_capital ? "Autor" : "autor"));
result+= (singular ? "" : "i");
return result;
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.11
//////////////////////////////////////////////////////////////////////////
/*! This text is put before the list of members referenced by a member
*/
virtual QCString trReferences()
{
return "Pogledati";
}
//////////////////////////////////////////////////////////////////////////
// new since 1.2.13
//////////////////////////////////////////////////////////////////////////
/*! used in member documentation blocks to produce a list of
* members that are implemented by this one.
*/
virtual QCString trImplementedFromList(int numEntries)
{
return "Defini¹e "+trWriteList(numEntries)+".";
}
/*! used in member documentation blocks to produce a list of
* all members that implement this abstract member.
*/
virtual QCString trImplementedInList(int numEntries)
{
return "Definisano u "+trWriteList(numEntries)+".";
}
};
#endif
// sh - ¹
// dj - ð
// ch - è - chasha
// cc - æ - vicc
// zz - ¾
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment