Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
D
doxverilog
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
Elphel
doxverilog
Commits
b5f4e547
Commit
b5f4e547
authored
Feb 03, 2014
by
Dimitri van Heesch
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #101 from albert-github/feature/bug_commentcnv
Add line numbers in case comment is not closed properly.
parents
ae7007a4
b1d513b2
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
1 deletion
+40
-1
commentcnv.l
src/commentcnv.l
+40
-1
No files found.
src/commentcnv.l
View file @
b5f4e547
...
@@ -52,6 +52,13 @@ struct CondCtx
...
@@ -52,6 +52,13 @@ struct CondCtx
bool skip;
bool skip;
};
};
struct CommentCtx
{
CommentCtx(int line)
: lineNr(line) {}
int lineNr;
};
static BufStr * g_inBuf;
static BufStr * g_inBuf;
static BufStr * g_outBuf;
static BufStr * g_outBuf;
static int g_inBufPos;
static int g_inBufPos;
...
@@ -64,6 +71,7 @@ static QCString g_fileName;
...
@@ -64,6 +71,7 @@ static QCString g_fileName;
static int g_lineNr;
static int g_lineNr;
static int g_condCtx;
static int g_condCtx;
static QStack<CondCtx> g_condStack;
static QStack<CondCtx> g_condStack;
static QStack<CommentCtx> g_commentStack;
static QCString g_blockName;
static QCString g_blockName;
static int g_lastCommentContext;
static int g_lastCommentContext;
static bool g_inSpecialComment;
static bool g_inSpecialComment;
...
@@ -256,8 +264,10 @@ void replaceComment(int offset);
...
@@ -256,8 +264,10 @@ void replaceComment(int offset);
{
{
g_pythonDocString = TRUE;
g_pythonDocString = TRUE;
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
}
}
<Scan>![><!]/.*\n {
<Scan>![><!]/.*\n {
...
@@ -269,7 +279,9 @@ void replaceComment(int offset);
...
@@ -269,7 +279,9 @@ void replaceComment(int offset);
{
{
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
}
}
<Scan>[Cc\*][><!]/.*\n {
<Scan>[Cc\*][><!]/.*\n {
...
@@ -284,7 +296,9 @@ void replaceComment(int offset);
...
@@ -284,7 +296,9 @@ void replaceComment(int offset);
{
{
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
else
else
{
{
...
@@ -378,8 +392,10 @@ void replaceComment(int offset);
...
@@ -378,8 +392,10 @@ void replaceComment(int offset);
<Scan>"/*"[*!]? { /* start of a C comment */
<Scan>"/*"[*!]? { /* start of a C comment */
g_specialComment=(int)yyleng==3;
g_specialComment=(int)yyleng==3;
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
<Scan>"#"("#")? {
<Scan>"#"("#")? {
if (g_lang!=SrcLangExt_Python)
if (g_lang!=SrcLangExt_Python)
...
@@ -390,7 +406,9 @@ void replaceComment(int offset);
...
@@ -390,7 +406,9 @@ void replaceComment(int offset);
{
{
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
}
}
<Scan>"--!" {
<Scan>"--!" {
...
@@ -402,7 +420,9 @@ void replaceComment(int offset);
...
@@ -402,7 +420,9 @@ void replaceComment(int offset);
{
{
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
}
}
<Scan>![><!] {
<Scan>![><!] {
...
@@ -414,7 +434,9 @@ void replaceComment(int offset);
...
@@ -414,7 +434,9 @@ void replaceComment(int offset);
{
{
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
}
}
<CComment>"{@code"/[ \t\n] {
<CComment>"{@code"/[ \t\n] {
...
@@ -606,6 +628,7 @@ void replaceComment(int offset);
...
@@ -606,6 +628,7 @@ void replaceComment(int offset);
}
}
<CComment>"/"+"*" { /* nested C comment */
<CComment>"/"+"*" { /* nested C comment */
g_nestingCount++;
g_nestingCount++;
g_commentStack.push(new CommentCtx(g_lineNr));
copyToOutput(yytext,(int)yyleng);
copyToOutput(yytext,(int)yyleng);
}
}
<CComment>"*"+"/" { /* end of C comment */
<CComment>"*"+"/" { /* end of C comment */
...
@@ -623,6 +646,7 @@ void replaceComment(int offset);
...
@@ -623,6 +646,7 @@ void replaceComment(int offset);
else
else
{
{
g_nestingCount--;
g_nestingCount--;
CommentCtx *ctx = g_commentStack.pop();
}
}
}
}
}
}
...
@@ -951,6 +975,8 @@ void convertCppComments(BufStr *inBuf,BufStr *outBuf,const char *fileName)
...
@@ -951,6 +975,8 @@ void convertCppComments(BufStr *inBuf,BufStr *outBuf,const char *fileName)
g_lineNr = 1;
g_lineNr = 1;
g_condStack.clear();
g_condStack.clear();
g_condStack.setAutoDelete(TRUE);
g_condStack.setAutoDelete(TRUE);
g_commentStack.clear();
g_commentStack.setAutoDelete(TRUE);
printlex(yy_flex_debug, TRUE, __FILE__, fileName);
printlex(yy_flex_debug, TRUE, __FILE__, fileName);
isFixedForm = FALSE;
isFixedForm = FALSE;
...
@@ -962,7 +988,9 @@ void convertCppComments(BufStr *inBuf,BufStr *outBuf,const char *fileName)
...
@@ -962,7 +988,9 @@ void convertCppComments(BufStr *inBuf,BufStr *outBuf,const char *fileName)
if (g_lang==SrcLangExt_Markdown)
if (g_lang==SrcLangExt_Markdown)
{
{
g_nestingCount=0;
g_nestingCount=0;
g_commentStack.clear(); /* to be on the save side */
BEGIN(CComment);
BEGIN(CComment);
g_commentStack.push(new CommentCtx(g_lineNr));
}
}
else
else
{
{
...
@@ -979,9 +1007,20 @@ void convertCppComments(BufStr *inBuf,BufStr *outBuf,const char *fileName)
...
@@ -979,9 +1007,20 @@ void convertCppComments(BufStr *inBuf,BufStr *outBuf,const char *fileName)
}
}
if (g_nestingCount>0 || (YY_START==CComment && g_lang!=SrcLangExt_Markdown))
if (g_nestingCount>0 || (YY_START==CComment && g_lang!=SrcLangExt_Markdown))
{
{
QString tmp= "(probable line reference: ";
bool first = TRUE;
while (!g_commentStack.isEmpty())
{
CommentCtx *ctx = g_commentStack.pop();
if (!first) tmp += ", ";
tmp += QString::number(ctx->lineNr);
first = FALSE;
}
tmp += ")";
warn(g_fileName,g_lineNr,"Reached end of file while still inside a (nested) comment. "
warn(g_fileName,g_lineNr,"Reached end of file while still inside a (nested) comment. "
"Nesting level %d
",g_nestingCount+1
); // add one for "normal" expected end of comment
"Nesting level %d
%s",g_nestingCount+1,tmp.data()
); // add one for "normal" expected end of comment
}
}
g_commentStack.clear();
if (Debug::isFlagSet(Debug::CommentCnv))
if (Debug::isFlagSet(Debug::CommentCnv))
{
{
g_outBuf->at(g_outBuf->curPos())='\0';
g_outBuf->at(g_outBuf->curPos())='\0';
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment