Display original source file location for errors
This commit is contained in:
parent
49afce6095
commit
3cd2d96611
@ -4,6 +4,7 @@
|
|||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
extern FILE * yyin;
|
extern FILE * yyin;
|
||||||
|
|
||||||
@ -59,6 +60,80 @@ static char * read_file(const char * filename, size_t * length)
|
|||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int orig_line = -1;
|
||||||
|
const char * orig_file = NULL;
|
||||||
|
|
||||||
|
static void scan_source_line_for_orig_location(char * source_line, int max_length)
|
||||||
|
{
|
||||||
|
int state = 0;
|
||||||
|
char * orig_file_build = NULL;
|
||||||
|
for (int i = 0;
|
||||||
|
(i < max_length) && (source_line[i] != '\n');
|
||||||
|
i++)
|
||||||
|
{
|
||||||
|
char c = source_line[i];
|
||||||
|
switch (state)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
if (c == '#')
|
||||||
|
{
|
||||||
|
state++;
|
||||||
|
}
|
||||||
|
else if (c != ' ')
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
if (('0' <= c) && (c <= '9'))
|
||||||
|
{
|
||||||
|
orig_line = c - '0';
|
||||||
|
state++;
|
||||||
|
}
|
||||||
|
else if (c != ' ')
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
if (('0' <= c) && (c <= '9'))
|
||||||
|
{
|
||||||
|
orig_line *= 10;
|
||||||
|
orig_line += c - '0';
|
||||||
|
}
|
||||||
|
else if (c == ' ')
|
||||||
|
{
|
||||||
|
state++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
if (c == '"')
|
||||||
|
{
|
||||||
|
orig_line--;
|
||||||
|
orig_file_build = &source_line[i + 1];
|
||||||
|
state++;
|
||||||
|
}
|
||||||
|
else if (c != ' ')
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
if (c == '"')
|
||||||
|
{
|
||||||
|
source_line[i] = '\0';
|
||||||
|
orig_file = orig_file_build;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void display_error_source(int line, int column)
|
static void display_error_source(int line, int column)
|
||||||
{
|
{
|
||||||
if (line < 0)
|
if (line < 0)
|
||||||
@ -72,6 +147,7 @@ static void display_error_source(int line, int column)
|
|||||||
|
|
||||||
int search_line = 1;
|
int search_line = 1;
|
||||||
const char * line_begin = NULL;
|
const char * line_begin = NULL;
|
||||||
|
bool scan_for_location = true;
|
||||||
for (size_t i = 0u; i < length; i++)
|
for (size_t i = 0u; i < length; i++)
|
||||||
{
|
{
|
||||||
if (search_line == line)
|
if (search_line == line)
|
||||||
@ -79,6 +155,11 @@ static void display_error_source(int line, int column)
|
|||||||
line_begin = &file[i];
|
line_begin = &file[i];
|
||||||
search_line++;
|
search_line++;
|
||||||
}
|
}
|
||||||
|
if (scan_for_location)
|
||||||
|
{
|
||||||
|
scan_source_line_for_orig_location(&file[i], length - i);
|
||||||
|
scan_for_location = false;
|
||||||
|
}
|
||||||
if (file[i] == '\n')
|
if (file[i] == '\n')
|
||||||
{
|
{
|
||||||
if (line_begin != NULL)
|
if (line_begin != NULL)
|
||||||
@ -90,9 +171,15 @@ static void display_error_source(int line, int column)
|
|||||||
fprintf(stderr, " ");
|
fprintf(stderr, " ");
|
||||||
}
|
}
|
||||||
fprintf(stderr, "^\n");
|
fprintf(stderr, "^\n");
|
||||||
|
if (orig_file != NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "Originally from %s:%d\n", orig_file, orig_line);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
search_line++;
|
search_line++;
|
||||||
|
orig_line++;
|
||||||
|
scan_for_location = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user