diff options
author | dimitri <dimitri@afe2bf4a-e733-0410-8a33-86f594647bc7> | 2002-03-24 20:06:51 (GMT) |
---|---|---|
committer | dimitri <dimitri@afe2bf4a-e733-0410-8a33-86f594647bc7> | 2002-03-24 20:06:51 (GMT) |
commit | 21587da40824d8609575284f0ee0fac90c972f27 (patch) | |
tree | 797740a23dd652f609fa100db4f0c862df4692ed /src/scanner.l | |
parent | ca3fb0a6df32b732c6b390b937f3ada001cb1e7a (diff) | |
download | Doxygen-21587da40824d8609575284f0ee0fac90c972f27.zip Doxygen-21587da40824d8609575284f0ee0fac90c972f27.tar.gz Doxygen-21587da40824d8609575284f0ee0fac90c972f27.tar.bz2 |
Release-1.2.14-20020324
Diffstat (limited to 'src/scanner.l')
-rw-r--r-- | src/scanner.l | 40 |
1 files changed, 33 insertions, 7 deletions
diff --git a/src/scanner.l b/src/scanner.l index ab08498..049dc9b 100644 --- a/src/scanner.l +++ b/src/scanner.l @@ -753,15 +753,32 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) <FindMembers>{B}*"package"{BN}+ { // Java package lineCount(); BEGIN(PackageName); + } <PackageName>{ID}("."{ID})* { - current->name = yytext; - current->fileName = yyFileName; - current->startLine = yyLineNr; - current->section=Entry::PACKAGE_SEC; + //current->name = yytext; + //current->fileName = yyFileName; + //current->startLine = yyLineNr; + //current->section=Entry::PACKAGE_SEC; + //current_root->addSubEntry(current); + //current = new Entry ; + //initEntry(); + + isTypedef=FALSE; + current->name = yytext; + current->name = substitute(current->name,".","::"); + current->section = Entry::NAMESPACE_SEC; + current->type = "namespace" ; + current->fileName = yyFileName; + current->startLine = yyLineNr; + current->bodyLine = yyLineNr; + lineCount(); + curlyCount=0; current_root->addSubEntry(current); - current = new Entry ; + current_root = current ; + current = new Entry ; initEntry(); + BEGIN( FindMembers ) ; } <PackageName>";" { BEGIN(FindMembers); @@ -2222,6 +2239,7 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) <FuncQual,FuncRound,FuncFunc>. { current->args += *yytext; } <FuncQual>{BN}*"try"{BN}+ { /* try-function-block */ insideTryBlock=TRUE; + lineCount(); } <FuncQual>{BN}*"throw"{BN}*"(" { // C++ style throw clause current->exception = " throw (" ; @@ -2255,8 +2273,12 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) <ExcpList>"{" { unput('{'); BEGIN( FuncQual ); } +<ExcpList>";" { + unput(';'); BEGIN( FuncQual ); + } <ExcpList>"\n" { current->exception += ' '; + yyLineNr++; } <ExcpList>. { current->exception += *yytext; @@ -2579,7 +2601,8 @@ CHARLIT (("'"\\[0-7]{1,3}"'")|("'"\\."'")|("'"[^'\\\n]{1,4}"'")) } BEGIN( FindMembers ); } -<CompoundName,ClassVar>{B}*"{"{B}* { current->fileName = yyFileName ; +<CompoundName,ClassVar>{B}*"{"{B}* { + current->fileName = yyFileName ; current->startLine = yyLineNr ; current->name = removeRedundantWhiteSpace(current->name); if (current->name.isEmpty() && !isTypedef) // anonymous compound @@ -4244,7 +4267,10 @@ static void parseCompounds(Entry *rt) // set default protection based on the compound type if( ce->section==Entry::CLASS_SEC ) // class { - current->protection = protection = Private ; + if (ce->fileName.right(5)==".java") + current->protection = protection = Public ; // Actually this should be package scope! + else + current->protection = protection = Private ; } else if (ce->section == Entry::ENUM_SEC ) // enum { |