shithub: rgbds

Download patch

ref: 7bb6f71f0b51afd06446fe5138f5e90f996af7e4
parent: 10e3f1a02b01b7a4c5b94d121f80284fb321c723
author: Rangi <[email protected]>
date: Fri Jan 1 13:46:26 EST 2021

Change `FOREACH` to `FOR` (#680)


--- a/include/asm/fstack.h
+++ b/include/asm/fstack.h
@@ -73,7 +73,7 @@
 void fstk_RunInclude(char const *path);
 void fstk_RunMacro(char const *macroName, struct MacroArgs *args);
 void fstk_RunRept(uint32_t count, int32_t nReptLineNo, char *body, size_t size);
-void fstk_RunForeach(char const *symName, int32_t start, int32_t stop, int32_t step,
+void fstk_RunFor(char const *symName, int32_t start, int32_t stop, int32_t step,
 		     int32_t reptLineNo, char *body, size_t size);
 
 void fstk_Init(char const *mainPath, size_t maxRecursionDepth);
--- a/src/asm/fstack.c
+++ b/src/asm/fstack.c
@@ -34,9 +34,9 @@
 	uint32_t uniqueID;
 	struct MacroArgs *macroArgs; /* Macro args are *saved* here */
 	uint32_t nbReptIters;
-	int32_t foreachValue;
-	int32_t foreachStep;
-	char *foreachName;
+	int32_t forValue;
+	int32_t forStep;
+	char *forName;
 };
 
 static struct Context *contextStack;
@@ -220,14 +220,14 @@
 		}
 
 		fileInfo->iters[0]++;
-		/* If this is a FOREACH, update the symbol value */
-		if (contextStack->foreachName) {
-			contextStack->foreachValue += contextStack->foreachStep;
-			struct Symbol *sym = sym_AddSet(contextStack->foreachName,
-				contextStack->foreachValue);
+		/* If this is a FOR, update the symbol value */
+		if (contextStack->forName) {
+			contextStack->forValue += contextStack->forStep;
+			struct Symbol *sym = sym_AddSet(contextStack->forName,
+				contextStack->forValue);
 
 			if (sym->type != SYM_SET)
-				fatalerror("Failed to update FOREACH symbol value\n");
+				fatalerror("Failed to update FOR symbol value\n");
 		}
 		/* If this wasn't the last iteration, wrap instead of popping */
 		if (fileInfo->iters[0] <= contextStack->nbReptIters) {
@@ -254,8 +254,8 @@
 	/* Free the file stack node */
 	if (!context->fileInfo->referenced)
 		free(context->fileInfo);
-	/* Free the FOREACH symbol name */
-	free(context->foreachName);
+	/* Free the FOR symbol name */
+	free(context->forName);
 	/* Free the entry and make its parent the current entry */
 	free(context);
 
@@ -281,7 +281,7 @@
 	fileInfo->referenced = false;
 	fileInfo->lineNo = lexer_GetLineNo();
 	context->fileInfo = fileInfo;
-	context->foreachName = NULL;
+	context->forName = NULL;
 	/*
 	 * Link new entry to its parent so it's reachable later
 	 * ERRORS SHOULD NOT OCCUR AFTER THIS!!
@@ -443,13 +443,13 @@
 		return;
 
 	contextStack->nbReptIters = count;
-	contextStack->foreachName = NULL;
+	contextStack->forName = NULL;
 }
 
-void fstk_RunForeach(char const *symName, int32_t start, int32_t stop, int32_t step,
+void fstk_RunFor(char const *symName, int32_t start, int32_t stop, int32_t step,
 		     int32_t reptLineNo, char *body, size_t size)
 {
-	dbgPrint("Running FOREACH(\"%s\", %" PRId32 ", %" PRId32 ", %" PRId32 ")\n",
+	dbgPrint("Running FOR(\"%s\", %" PRId32 ", %" PRId32 ", %" PRId32 ")\n",
 		 symName, start, stop, step);
 
 	struct Symbol *sym = sym_AddSet(symName, start);
@@ -464,7 +464,7 @@
 	else if (step < 0 && stop < start)
 		count = (start - stop - 1) / -step + 1;
 	else if (step == 0)
-		error("FOREACH cannot have a step value of 0\n");
+		error("FOR cannot have a step value of 0\n");
 
 	if (count == 0)
 		return;
@@ -472,11 +472,11 @@
 		return;
 
 	contextStack->nbReptIters = count;
-	contextStack->foreachValue = start;
-	contextStack->foreachStep = step;
-	contextStack->foreachName = strdup(symName);
-	if (!contextStack->foreachName)
-		fatalerror("Not enough memory for FOREACH name: %s\n", strerror(errno));
+	contextStack->forValue = start;
+	contextStack->forStep = step;
+	contextStack->forName = strdup(symName);
+	if (!contextStack->forName)
+		fatalerror("Not enough memory for FOR symbol name: %s\n", strerror(errno));
 }
 
 void fstk_Init(char const *mainPath, size_t maxRecursionDepth)
@@ -508,9 +508,9 @@
 	context->uniqueID = 0;
 	macro_SetUniqueID(0);
 	context->nbReptIters = 0;
-	context->foreachValue = 0;
-	context->foreachStep = 0;
-	context->foreachName = NULL;
+	context->forValue = 0;
+	context->forStep = 0;
+	context->forName = NULL;
 
 	/* Now that it's set up properly, register the context */
 	contextStack = context;
--- a/src/asm/lexer.c
+++ b/src/asm/lexer.c
@@ -240,7 +240,7 @@
 	{"SHIFT", T_POP_SHIFT},
 
 	{"REPT", T_POP_REPT},
-	{"FOREACH", T_POP_FOREACH},
+	{"FOR", T_POP_FOR},
 	{"ENDR", T_POP_ENDR},
 
 	{"LOAD", T_POP_LOAD},
@@ -462,7 +462,7 @@
 
 void lexer_RestartRept(uint32_t lineNo)
 {
-	dbgPrint("Restarting REPT/FOREACH\n");
+	dbgPrint("Restarting REPT/FOR\n");
 	lexerState->offset = 0;
 	initState(lexerState);
 	lexerState->lineNo = lineNo;
@@ -2123,11 +2123,11 @@
 		do { /* Discard initial whitespace */
 			c = nextChar();
 		} while (isWhitespace(c));
-		/* Now, try to match `REPT`, `FOREACH` or `ENDR` as a **whole** identifier */
+		/* Now, try to match `REPT`, `FOR` or `ENDR` as a **whole** identifier */
 		if (startsIdentifier(c)) {
 			switch (readIdentifier(c)) {
 			case T_POP_REPT:
-			case T_POP_FOREACH:
+			case T_POP_FOR:
 				level++;
 				/* Ignore the rest of that line */
 				break;
@@ -2156,7 +2156,7 @@
 		/* Just consume characters until EOL or EOF */
 		for (;;) {
 			if (c == EOF) {
-				error("Unterminated REPT/FOREACH block\n");
+				error("Unterminated REPT/FOR block\n");
 				lexerState->capturing = false;
 				goto finish;
 			} else if (c == '\n' || c == '\r') {
--- a/src/asm/parser.y
+++ b/src/asm/parser.y
@@ -310,7 +310,7 @@
 		int32_t start;
 		int32_t stop;
 		int32_t step;
-	} foreachArgs;
+	} forArgs;
 	struct StrFmtArgList strfmtArgs;
 }
 
@@ -406,7 +406,7 @@
 %token	T_POP_ENDM
 %token	T_POP_RSRESET T_POP_RSSET
 %token	T_POP_UNION T_POP_NEXTU T_POP_ENDU
-%token	T_POP_INCBIN T_POP_REPT T_POP_FOREACH
+%token	T_POP_INCBIN T_POP_REPT T_POP_FOR
 %token	T_POP_CHARMAP
 %token	T_POP_NEWCHARMAP
 %token	T_POP_SETCHARMAP
@@ -431,7 +431,7 @@
 %type	<sectMod> sectmod
 %type	<macroArg> macroargs
 
-%type	<foreachArgs> foreach_args
+%type	<forArgs> for_args
 
 %token	T_Z80_ADC T_Z80_ADD T_Z80_AND
 %token	T_Z80_BIT
@@ -634,7 +634,7 @@
 		| popc
 		| load
 		| rept
-		| foreach
+		| for
 		| shift
 		| fail
 		| warn
@@ -758,15 +758,15 @@
 		}
 ;
 
-foreach		: T_POP_FOREACH T_ID T_COMMA foreach_args {
+for		: T_POP_FOR T_ID T_COMMA for_args {
 			uint32_t nDefinitionLineNo = lexer_GetLineNo();
 			char *body;
 			size_t size;
 			lexer_CaptureRept(&body, &size);
-			fstk_RunForeach($2, $4.start, $4.stop, $4.step, nDefinitionLineNo, body, size);
+			fstk_RunFor($2, $4.start, $4.stop, $4.step, nDefinitionLineNo, body, size);
 		}
 
-foreach_args	: const {
+for_args	: const {
 			$$.start = 0;
 			$$.stop = $1;
 			$$.step = 1;
--- a/src/asm/rgbasm.5
+++ b/src/asm/rgbasm.5
@@ -1533,18 +1533,18 @@
 blocks can be nested.
 .Pp
 A common pattern is to repeat a block for each value in some range.
-.Ic FOREACH
+.Ic FOR
 is simpler than
 .Ic REPT
 for that purpose.
 Everything between
-.Ic FOREACH
+.Ic FOR
 and the matching
 .Ic ENDR
 will be repeated for each value of a given symbol.
 For example, this code will produce a table of squared values from 0 to 255:
 .Bd -literal -offset indent
-FOREACH N, 256
+FOR N, 256
       dw N * N
 ENDR
 .Ed
@@ -1564,17 +1564,17 @@
 .Ed
 .Pp
 You can customize the range of
-.Ic FOREACH
+.Ic FOR
 values:
-.Bl -column "FOREACH V, start, stop, step"
+.Bl -column "FOR V, start, stop, step"
 .It Sy Code Ta Sy Range
-.It Ic FOREACH Ar V , stop Ta Ar V No increments from 0 to Ar stop No
-.It Ic FOREACH Ar V , start , stop Ta Ar V No increments from Ar start No to Ar stop No
-.It Ic FOREACH Ar V , start , stop , step Ta Ar V No goes from Ar start No to Ar stop No by Ar step No
+.It Ic FOR Ar V , stop Ta Ar V No increments from 0 to Ar stop No
+.It Ic FOR Ar V , start , stop Ta Ar V No increments from Ar start No to Ar stop No
+.It Ic FOR Ar V , start , stop , step Ta Ar V No goes from Ar start No to Ar stop No by Ar step No
 .El
 .Pp
 The
-.Ic FOREACH
+.Ic FOR
 value will be updated by
 .Ar step
 until it reaches or exceeds
@@ -1581,7 +1581,7 @@
 .Ar stop.
 For example:
 .Bd -literal -offset indent
-FOREACH V, 4, 25, 5
+FOR V, 4, 25, 5
       PRINTT "{d:V} "
 ENDR
       PRINTT "done {d:V}\n"
@@ -1596,7 +1596,7 @@
 blocks, you can use the escape sequence
 .Ic \[rs]@
 inside of
-.Ic FOREACH
+.Ic FOR
 blocks, and they can be nested.
 .Ss Aborting the assembly process
 .Ic FAIL
--- /dev/null
+++ b/test/asm/for.asm
@@ -1,0 +1,48 @@
+for n, 10
+	printt "{d:n} "
+endr
+	printt "-> {d:n}\n"
+
+for v, 0
+	printt "unreached"
+endr
+
+for v, 2, 1
+	printt "unreached"
+endr
+
+for v, 1, 2, 0
+	printt "unreached"
+endr
+
+for x, 1, 5+1
+	printt "{d:x} "
+endr
+	printt "-> {d:x}\n"
+
+for v, 10, -1, -1
+	printt "{d:v} "
+v = 42
+endr
+	printt "-> {d:v}\n"
+
+for q, 5, 21, 5
+	printt "{d:q} "
+purge q
+endr
+	printt "-> {d:q}\n"
+
+s EQUS "x"
+for s, 3, 30, 3
+	printt "{d:x} "
+endr
+	printt "-> {d:x}\n"
+
+for v, 10
+	printt "{d:v}\n"
+if v == 3
+purge v
+v equ 42 ; causes a fatal error
+endc
+endr
+	printt "-> {d:v}\n"
--- /dev/null
+++ b/test/asm/for.err
@@ -1,0 +1,6 @@
+ERROR: for.asm(16):
+    FOR cannot have a step value of 0
+ERROR: for.asm(41) -> for.asm::REPT~5(47):
+    'v' already defined as constant at for.asm(41) -> for.asm::REPT~4(45)
+FATAL: for.asm(41) -> for.asm::REPT~5(47):
+    Failed to update FOR symbol value
--- /dev/null
+++ b/test/asm/for.out
@@ -1,0 +1,9 @@
+0 1 2 3 4 5 6 7 8 9 -> 10
+1 2 3 4 5 -> 6
+10 9 8 7 6 5 4 3 2 1 0 -> -1
+5 10 15 20 -> 25
+3 6 9 12 15 18 21 24 27 -> 30
+0
+1
+2
+3
--- a/test/asm/foreach.asm
+++ /dev/null
@@ -1,48 +1,0 @@
-foreach n, 10
-	printt "{d:n} "
-endr
-	printt "-> {d:n}\n"
-
-foreach v, 0
-	printt "unreached"
-endr
-
-foreach v, 2, 1
-	printt "unreached"
-endr
-
-foreach v, 1, 2, 0
-	printt "unreached"
-endr
-
-foreach x, 1, 5+1
-	printt "{d:x} "
-endr
-	printt "-> {d:x}\n"
-
-foreach v, 10, -1, -1
-	printt "{d:v} "
-v = 42
-endr
-	printt "-> {d:v}\n"
-
-foreach q, 5, 21, 5
-	printt "{d:q} "
-purge q
-endr
-	printt "-> {d:q}\n"
-
-s EQUS "x"
-foreach s, 3, 30, 3
-	printt "{d:x} "
-endr
-	printt "-> {d:x}\n"
-
-foreach v, 10
-	printt "{d:v}\n"
-if v == 3
-purge v
-v equ 42 ; causes a fatal error
-endc
-endr
-	printt "-> {d:v}\n"
--- a/test/asm/foreach.err
+++ /dev/null
@@ -1,6 +1,0 @@
-ERROR: foreach.asm(16):
-    FOREACH cannot have a step value of 0
-ERROR: foreach.asm(41) -> foreach.asm::REPT~5(47):
-    'v' already defined as constant at foreach.asm(41) -> foreach.asm::REPT~4(45)
-FATAL: foreach.asm(41) -> foreach.asm::REPT~5(47):
-    Failed to update FOREACH symbol value
--- a/test/asm/foreach.out
+++ /dev/null
@@ -1,9 +1,0 @@
-0 1 2 3 4 5 6 7 8 9 -> 10
-1 2 3 4 5 -> 6
-10 9 8 7 6 5 4 3 2 1 0 -> -1
-5 10 15 20 -> 25
-3 6 9 12 15 18 21 24 27 -> 30
-0
-1
-2
-3