Added assembly header detection.

This commit is contained in:
Johanne Schock 2020-03-14 14:36:47 +01:00 committed by patacongo
parent 23db3b2a48
commit cdf615855a

View File

@ -116,6 +116,10 @@ enum pptype_e
{ {
PPLINE_NONE = 0, PPLINE_NONE = 0,
PPLINE_DEFINE, PPLINE_DEFINE,
PPLINE_IF,
PPLINE_ELIF,
PPLINE_ELSE,
PPLINE_ENDIF,
PPLINE_OTHER PPLINE_OTHER
}; };
@ -526,6 +530,8 @@ int main(int argc, char **argv, char **envp)
int dnest; /* Data declaration nesting level on this line */ int dnest; /* Data declaration nesting level on this line */
int prevdnest; /* Data declaration nesting level on the previous line */ int prevdnest; /* Data declaration nesting level on the previous line */
int pnest; /* Parenthesis nesting level on this line */ int pnest; /* Parenthesis nesting level on this line */
int ppifnest; /* #if nesting level on this line */
int inasm; /* > 0: Within #ifdef __ASSEMBLY__ */
int comment_lineno; /* Line on which the last comment was closed */ int comment_lineno; /* Line on which the last comment was closed */
int blank_lineno; /* Line number of the last blank line */ int blank_lineno; /* Line number of the last blank line */
int noblank_lineno; /* A blank line is not needed after this line */ int noblank_lineno; /* A blank line is not needed after this line */
@ -643,6 +649,8 @@ int main(int argc, char **argv, char **envp)
bnest = 0; /* Brace nesting level on this line */ bnest = 0; /* Brace nesting level on this line */
dnest = 0; /* Data declaration nesting level on this line */ dnest = 0; /* Data declaration nesting level on this line */
pnest = 0; /* Parenthesis nesting level on this line */ pnest = 0; /* Parenthesis nesting level on this line */
ppifnest = 0; /* #if nesting level on this line */
inasm = 0; /* > 0: Within #ifdef __ASSEMBLY__ */
comment_lineno = -1; /* Line on which the last comment was closed */ comment_lineno = -1; /* Line on which the last comment was closed */
blank_lineno = -1; /* Line number of the last blank line */ blank_lineno = -1; /* Line number of the last blank line */
noblank_lineno = -1; /* A blank line is not needed after this line */ noblank_lineno = -1; /* A blank line is not needed after this line */
@ -851,14 +859,15 @@ int main(int argc, char **argv, char **envp)
* line. * line.
*/ */
ii = indent + 1;
if (ppline == PPLINE_NONE) if (ppline == PPLINE_NONE)
{ {
/* Skip to the pre-processor command following the '#' */ /* Skip to the pre-processor command following the '#' */
for (ii = indent + 1; while (line[ii] != '\0' && isspace(line[ii]))
line[ii] != '\0' && isspace(line[ii]);
ii++)
{ {
ii++;
} }
if (line[ii] != '\0') if (line[ii] != '\0')
@ -915,6 +924,81 @@ int main(int argc, char **argv, char **envp)
lineno, ii); lineno, ii);
} }
} }
else if (strncmp(&line[ii], "if", 2) == 0)
{
ppifnest++;
ppline = PPLINE_IF;
ii += 2;
}
else if (strncmp(&line[ii], "elif", 4) == 0)
{
if (ppifnest == inasm)
{
inasm = 0;
}
ppline = PPLINE_ELIF;
ii += 4;
}
else if (strncmp(&line[ii], "else", 4) == 0)
{
if (ppifnest == inasm)
{
inasm = 0;
}
ppline = PPLINE_ELSE;
}
else if (strncmp(&line[ii], "endif", 4) == 0)
{
if (ppifnest == inasm)
{
inasm = 0;
}
ppifnest--;
ppline = PPLINE_ENDIF;
}
}
}
if (ppline == PPLINE_IF || ppline == PPLINE_ELIF)
{
int bdef = 0;
if (strncmp(&line[ii], "def", 3) == 0)
{
bdef = 1;
ii += 3;
}
else
{
while (line[ii] != '\0' && isspace(line[ii]))
{
ii++;
}
if (strncmp(&line[ii], "defined", 7) == 0)
{
bdef = 1;
ii += 7;
}
}
if (bdef)
{
while (line[ii] != '\0' &&
(isspace(line[ii]) || line[ii] == '('))
{
ii++;
}
if (strncmp(&line[ii], "__ASSEMBLY__", 12) == 0)
{
inasm = ppifnest;
}
} }
} }
@ -968,10 +1052,12 @@ int main(int argc, char **argv, char **envp)
rhcomment = -1; rhcomment = -1;
if (ncomment > 0 && (strncmp(&line[ii], "if", 2) == 0 || if (ncomment > 0 &&
strncmp(&line[ii], "el", 2) == 0)) (ppline == PPLINE_IF ||
ppline == PPLINE_ELSE ||
ppline == PPLINE_ELIF))
{ {
/* in #if... and #el.. */ /* in #if... and #el... */
ERROR("No multiline comment right of code allowed here", ERROR("No multiline comment right of code allowed here",
lineno, n); lineno, n);
@ -1047,7 +1133,9 @@ int main(int argc, char **argv, char **envp)
* example. * example.
*/ */
else if (strncmp(&line[indent], "auto ", 5) == 0 || else if (inasm == 0)
{
if (strncmp(&line[indent], "auto ", 5) == 0 ||
strncmp(&line[indent], "bool ", 5) == 0 || strncmp(&line[indent], "bool ", 5) == 0 ||
strncmp(&line[indent], "char ", 5) == 0 || strncmp(&line[indent], "char ", 5) == 0 ||
strncmp(&line[indent], "CODE ", 5) == 0 || strncmp(&line[indent], "CODE ", 5) == 0 ||
@ -1082,8 +1170,8 @@ int main(int argc, char **argv, char **envp)
strncmp(&line[indent], "void ", 5) == 0 || strncmp(&line[indent], "void ", 5) == 0 ||
strncmp(&line[indent], "volatile ", 9) == 0) strncmp(&line[indent], "volatile ", 9) == 0)
{ {
/* Check if this is extern "C"; We don't typically indent following /* Check if this is extern "C"; We don't typically indent
* this. * following this.
*/ */
if (strncmp(&line[indent], "extern \"C\"", 10) == 0) if (strncmp(&line[indent], "extern \"C\"", 10) == 0)
@ -1164,22 +1252,22 @@ int main(int argc, char **argv, char **envp)
else if (strncmp(&line[indent], "break ", 6) == 0 || else if (strncmp(&line[indent], "break ", 6) == 0 ||
strncmp(&line[indent], "case ", 5) == 0 || strncmp(&line[indent], "case ", 5) == 0 ||
#if 0 /* Part of switch */ #if 0 /* Part of switch */
strncmp(&line[indent], "case ", 5) == 0 || strncmp(&line[indent], "case ", 5) == 0 ||
#endif #endif
strncmp(&line[indent], "continue ", 9) == 0 || strncmp(&line[indent], "continue ", 9) == 0 ||
#if 0 /* Part of switch */ #if 0 /* Part of switch */
strncmp(&line[indent], "default ", 8) == 0 || strncmp(&line[indent], "default ", 8) == 0 ||
#endif #endif
strncmp(&line[indent], "do ", 3) == 0 || strncmp(&line[indent], "do ", 3) == 0 ||
strncmp(&line[indent], "else ", 5) == 0 || strncmp(&line[indent], "else ", 5) == 0 ||
strncmp(&line[indent], "goto ", 5) == 0 || strncmp(&line[indent], "goto ", 5) == 0 ||
strncmp(&line[indent], "if ", 3) == 0 || strncmp(&line[indent], "if ", 3) == 0 ||
strncmp(&line[indent], "return ", 7) == 0 || strncmp(&line[indent], "return ", 7) == 0 ||
#if 0 /* Doesn't follow pattern */ #if 0 /* Doesn't follow pattern */
strncmp(&line[indent], "switch ", 7) == 0 || strncmp(&line[indent], "switch ", 7) == 0 ||
#endif #endif
strncmp(&line[indent], "while ", 6) == 0) strncmp(&line[indent], "while ", 6) == 0)
{ {
bstatm = true; bstatm = true;
@ -1217,6 +1305,7 @@ int main(int argc, char **argv, char **envp)
ERROR("Missing whitespace after keyword", lineno, n); ERROR("Missing whitespace after keyword", lineno, n);
bswitch = true; bswitch = true;
} }
}
/* STEP 3: Parse each character on the line */ /* STEP 3: Parse each character on the line */
@ -1590,14 +1679,14 @@ int main(int argc, char **argv, char **envp)
bquote = false; bquote = false;
} }
/* The reset of the line is only examined of we are not in a comment /* The rest of the line is only examined of we are not in a comment,
* or a string. * in a string or in assembly.
* *
* REVISIT: Should still check for whitespace at the end of the * REVISIT: Should still check for whitespace at the end of the
* line. * line.
*/ */
if (ncomment == 0 && !bstring) if (ncomment == 0 && !bstring && inasm == 0)
{ {
switch (line[n]) switch (line[n])
{ {