1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-10 19:29:45 +00:00

isequal: add --wildcards option

This commit is contained in:
Spiro Trikaliotis 2022-06-21 22:23:10 +02:00
parent c738c94935
commit a7b2a92fc2
3 changed files with 281 additions and 17 deletions

View File

@ -79,7 +79,7 @@ ifneq ($(wildcard ref/$1.ld65err-ref),)
-diff -u ref/$1.ld65err-ref $$(@:.bin=.ld65-err) -diff -u ref/$1.ld65err-ref $$(@:.bin=.ld65-err)
@echo @echo
@echo @echo
$(ISEQUAL) ref/$1.ld65err-ref $$(@:.bin=.ld65-err) $(ISEQUAL) --wildcards ref/$1.ld65err-ref $$(@:.bin=.ld65-err)
else else
ifneq ($(wildcard $(WORKDIR)/$1.ld65-err),) ifneq ($(wildcard $(WORKDIR)/$1.ld65-err),)
$(ISEQUAL) --empty $$(@:.bin=.ld65-err) $(ISEQUAL) --empty $$(@:.bin=.ld65-err)
@ -106,7 +106,7 @@ else
endif endif
ifneq ($(wildcard ref/$1.ld65err-ref),) ifneq ($(wildcard ref/$1.ld65err-ref),)
$(ISEQUAL) ref/$1.ld65err-ref $$(@:.bin=.list-ld65-err) $(ISEQUAL) --wildcards ref/$1.ld65err-ref $$(@:.bin=.list-ld65-err)
else else
ifneq ($(wildcard $(WORKDIR)/$1.list-ld65-err),) ifneq ($(wildcard $(WORKDIR)/$1.list-ld65-err),)
$(ISEQUAL) --empty $$(@:.bin=.list-ld65-err) $(ISEQUAL) --empty $$(@:.bin=.list-ld65-err)

View File

@ -1 +1 @@
ld65: Warning: /home/spiro/Work/tmp/cc65.spiro.testcases-ca65/cfg/none.cfg:18: Segment 'CODE' isn't aligned properly; the resulting executable might not be functional. ld65: Warning: <<<#PATH#>>>:<<<#INTEGER#>>>: Segment 'CODE' isn't aligned properly; the resulting executable might not be functional.

View File

@ -5,14 +5,67 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#define ARRAYSIZE(_x) (sizeof _x / sizeof _x[0])
typedef int wildcardfunc(FILE * f2);
struct wildcardtype {
char * name;
wildcardfunc * func;
};
static int wildcard_path(FILE * f1);
static int wildcard_integer(FILE * f1);
struct wildcardtype wildcards[] = {
{ "PATH", wildcard_path },
{ "INTEGER", wildcard_integer }
};
static wildcardfunc * currentwildcardfunc = 0;
static int binary = 0; static int binary = 0;
static int empty = 0; static int empty = 0;
static int skiplines_left = 0; static int skiplines_left = 0;
static int skiplines_right = 0; static int skiplines_right = 0;
static int use_wildcards = 0;
static char * filename_left = 0; static char * filename_left = 0;
static char * filename_right = 0; static char * filename_right = 0;
int handleargparameter(int offset, char * parameter) /* LOOKAHEADBUFFERSIZE must be a power of 2, because the wrap-around for the
indices requires this!
*/
#define LOOKAHEADBUFFERSIZE 0x80
#define WILDCARDCHAR_OPEN '<'
#define WILDCARDCHAR_INTERNAL '#'
#define WILDCARDCHAR_CLOSE '>'
#define WILDCARDCHAR_OPEN_CLOSE_COUNT 3
#define WILDCARDNAME_MAXLENGTH 20
static char lookaheadbuffer[LOOKAHEADBUFFERSIZE] = { 0 };
static int lookaheadindexread = 0;
static int lookaheadindexwrite = 0;
static int wildcardendchar;
wildcardfunc * findwildcardfunc(char * wildcardname)
{
wildcardfunc * func = NULL;
unsigned int i;
for (i = 0; i < ARRAYSIZE(wildcards); ++i) {
if (strcmp(wildcards[i].name, wildcardname) == 0) {
func = wildcards[i].func;
}
}
return func;
}
static int handleargparameter(int offset, char * parameter)
{ {
long number = -1; long number = -1;
char * endptr = NULL; char * endptr = NULL;
@ -30,13 +83,14 @@ int handleargparameter(int offset, char * parameter)
return number; return number;
} }
int handleparameter(int argc, char *argv[]) static int handleparameter(int argc, char *argv[])
{ {
static const char opt_binary[] = "--binary"; static const char opt_binary[] = "--binary";
static const char opt_empty[] = "--empty"; static const char opt_empty[] = "--empty";
static const char opt_skipleft[] = "--skipleft"; static const char opt_skipleft[] = "--skipleft";
static const char opt_skipright[] = "--skipright"; static const char opt_skipright[] = "--skipright";
static const char opt_skip[] = "--skip"; static const char opt_skip[] = "--skip";
static const char opt_wildcards[] = "--wildcards";
static const char len_skipleft = sizeof opt_skipleft - 1; static const char len_skipleft = sizeof opt_skipleft - 1;
static const char len_skipright = sizeof opt_skipright - 1; static const char len_skipright = sizeof opt_skipright - 1;
@ -57,7 +111,7 @@ int handleparameter(int argc, char *argv[])
binary = 1; binary = 1;
} }
else if (strcmp(argv[argindex], opt_empty) == 0) { else if (strcmp(argv[argindex], opt_empty) == 0) {
if (binary || skiplines_left || skiplines_right) { if (binary || skiplines_left || skiplines_right || use_wildcards) {
fprintf(stderr, "--binary cannot go with other options.\n"); fprintf(stderr, "--binary cannot go with other options.\n");
exit(1); exit(1);
} }
@ -93,6 +147,13 @@ int handleparameter(int argc, char *argv[])
fprintf(stderr, "%s: you must specify the number of lines\n", opt_skip); fprintf(stderr, "%s: you must specify the number of lines\n", opt_skip);
} }
} }
else if (strcmp(argv[argindex], opt_wildcards) == 0) {
if (binary) {
fprintf(stderr, "--wildcards cannot go with --binary.\n");
exit(1);
}
use_wildcards = 1;
}
++argindex; ++argindex;
} }
@ -117,7 +178,7 @@ int handleparameter(int argc, char *argv[])
0x0d (CR) classic MacOS 0x0d (CR) classic MacOS
*/ */
int getnext(FILE *f) static int getnext(FILE *f)
{ {
int c = fgetc(f); int c = fgetc(f);
if (!binary && c == 0x0d) { if (!binary && c == 0x0d) {
@ -133,7 +194,7 @@ int getnext(FILE *f)
return c; return c;
} }
void skiplines(FILE *f, int skipcount) static void skiplines(FILE *f, int skipcount)
{ {
int c; int c;
@ -149,6 +210,213 @@ void skiplines(FILE *f, int skipcount)
} }
} }
static int comparefiles(FILE *f1, FILE *f2)
{
for(;;) {
if (feof(f1) && feof(f2)) {
return EXIT_SUCCESS;
} else if (feof(f1) || feof(f2)) {
return EXIT_FAILURE;
}
if (getnext(f1) != getnext(f2)) {
return EXIT_FAILURE;
}
}
}
static int lookaheadbufferisempty(void)
{
return lookaheadindexread == lookaheadindexwrite;
}
static char lookaheadbufferread(void)
{
char ch;
if (lookaheadbufferisempty()) {
fprintf(stderr, "### want to take from lookahead buffer, but it is empty --> aborting!\n");
exit(EXIT_FAILURE);
}
ch = lookaheadbuffer[lookaheadindexread];
/* advance read pointer, with wrap-around */
lookaheadindexread = (lookaheadindexread + 1) & (sizeof lookaheadbuffer - 1);
return ch;
}
static void lookaheadbufferwrite(char ch)
{
lookaheadbuffer[lookaheadindexwrite] = ch;
/* advance write pointer, with wrap-around */
lookaheadindexwrite = (lookaheadindexwrite + 1) & (sizeof lookaheadbuffer - 1);
if (lookaheadbufferisempty()) {
fprintf(stderr, "### lookahead buffer ovrrun, aborting!\n");
exit(EXIT_FAILURE);
}
}
static int processwildcardchar(FILE *f1)
{
int countwildcardchar = 1;
int foundwildcard = 0;
int ch;
static char wildcardname[WILDCARDNAME_MAXLENGTH + 1];
unsigned int wildcardnamenextindex;
while ((ch = getnext(f1)) == WILDCARDCHAR_OPEN) {
++countwildcardchar;
if (feof(f1)) {
break;
}
}
if (countwildcardchar == WILDCARDCHAR_OPEN_CLOSE_COUNT) {
if (ch == WILDCARDCHAR_INTERNAL) {
/* we found a wildcard! */
foundwildcard = 1;
}
}
else {
if (ch == WILDCARDCHAR_OPEN) {
ch = -1;
}
}
if (foundwildcard) {
char c;
/* we found a wildcard init sequence; now check which wildcard it is */
wildcardnamenextindex = 0;
wildcardname[WILDCARDNAME_MAXLENGTH] = 0;
c = getnext(f1);
while (c != WILDCARDCHAR_INTERNAL && c != 0x0a && !feof(f1)) {
wildcardname[wildcardnamenextindex] = c;
if (++wildcardnamenextindex >= WILDCARDNAME_MAXLENGTH) {
wildcardname[WILDCARDNAME_MAXLENGTH] = 0;
fprintf(stderr, "wildcard '%s' is too long!\n", wildcardname);
exit(EXIT_FAILURE);
}
c = getnext(f1);
}
wildcardname[wildcardnamenextindex] = 0;
if (c == WILDCARDCHAR_INTERNAL) {
int countwildcardcharclose = 0;
fprintf(stderr, "Found wildcard '%s'\n", wildcardname);
while ((c = getnext(f1)) == WILDCARDCHAR_CLOSE && !feof(f1)) {
++countwildcardcharclose;
}
wildcardendchar = c; /* remember next char */
currentwildcardfunc = findwildcardfunc(wildcardname);
if (currentwildcardfunc == NULL) {
fprintf(stderr, "Wildcard '%s' is unknown!\n", wildcardname);
exit(EXIT_FAILURE);
}
}
else {
fprintf(stderr, "Thought I found wildcard '%s', but it does not end.\n", wildcardname);
}
}
if (!foundwildcard) {
int i;
/* no wildcard; restore the chars */
for (i = 0; i < countwildcardchar; ++i) {
lookaheadbufferwrite(WILDCARDCHAR_OPEN);
}
if (ch >= 0) {
lookaheadbufferwrite(ch);
}
}
return foundwildcard;
}
static int wildcard_path(FILE * f2)
{
int isstillwildcard = 1;
int ch = getnext(f2);
if ((ch == wildcardendchar) || ch < ' ' || ch > 126) {
/* this is not a path char anymore, abort the wildcard processing */
isstillwildcard = 0;
if (ch != wildcardendchar) {
exit(EXIT_FAILURE);
}
}
return isstillwildcard;
}
static int wildcard_integer(FILE * f2)
{
int isstillwildcard = 1;
int ch = getnext(f2);
if ((ch == wildcardendchar) || ch < '0' || ch > '9') {
/* this is not a digit anymore, abort the wildcard processing */
isstillwildcard = 0;
if (ch != wildcardendchar) {
exit(EXIT_FAILURE);
}
}
return isstillwildcard;
}
static int comparefileswithwildcards(FILE *f1, FILE *f2)
{
static int iswildcard = 0;
for(;;) {
int c1;
if (lookaheadbufferisempty() && !iswildcard && feof(f1) && feof(f2)) {
return EXIT_SUCCESS;
} else if (((lookaheadbufferisempty() && !iswildcard && feof(f1))) || feof(f2)) {
return EXIT_FAILURE;
}
if (iswildcard) {
/* f1 has a wildcard; process that */
iswildcard = currentwildcardfunc(f2);
}
else {
/* f1 does not have a wildcard; process the next char (unless it starts a wildcard) */
if (lookaheadbufferisempty()) {
c1 = getnext(f1);
if (c1 == WILDCARDCHAR_OPEN) {
iswildcard = processwildcardchar(f1);
continue;
}
}
else {
c1 = lookaheadbufferread();
}
if (c1 != getnext(f2)) {
return EXIT_FAILURE;
}
}
}
}
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
FILE *f1, *f2; FILE *f1, *f2;
@ -183,15 +451,11 @@ int main(int argc, char *argv[])
if (skiplines_right) { if (skiplines_right) {
skiplines(f2, skiplines_right); skiplines(f2, skiplines_right);
} }
for(;;) { if (use_wildcards) {
if (feof(f1) && feof(f2)) { return comparefileswithwildcards(f1, f2);
return EXIT_SUCCESS;
} else if (feof(f1) || feof(f2)) {
return EXIT_FAILURE;
}
if (getnext(f1) != getnext(f2)) {
return EXIT_FAILURE;
} }
else {
return comparefiles(f1, f2);
} }
} }
} }