ref: 81e3671bc0195954d80cb3a212009b94f33cf49f
parent: 6ac8cd278169f186325f03e7c0947da6318b8e19
author: Roberto E. Vargas Caballero <[email protected]>
date: Thu Jan 25 11:45:27 EST 2018
[as-z80] Change [] to () Zilog and AT&T use (), only Intel uses []. So the decision is clear.
--- a/as/expr.c
+++ b/as/expr.c
@@ -318,10 +318,7 @@
case '\'':
c = character();
break;
- case '$':
- case '.':
case '_':
- case '%':
c = iden();
break;
default:
@@ -350,27 +347,29 @@
next();
}
+static Node *expr(void);
+
Node *
-content(Node *np)
+zilog(void)
{
int op;
+ Node *np = expr();
switch (np->addr) {
case AREG:
op = AINDIR;
- goto new_node;
+ break;
case AREG_OFF:
op = AINDEX;
- goto new_node;
+ break;
case ANUMBER:
op = ADIRECT;
- new_node:
- np = node(op, np, NULL);
- np->addr = op;
break;
default:
abort();
}
+ np = node(op, np, NULL);
+ np->addr = op;
return np;
}
@@ -378,8 +377,6 @@
/* grammar functions */
/*************************************************************************/
-static Node *expr(void);
-
static Node *
primary(void)
{
@@ -406,12 +403,6 @@
np = expr();
expect(')');
break;
- case '[':
- next();
- np = expr();
- expect(']');
- np = content(np);
- break;
default:
unexpected();
}
@@ -426,6 +417,10 @@
Node *np;
switch (tok = yytoken) {
+ case '%':
+ case '$':
+ case '.':
+ /* TODO: implement identifiers with %, $ and . */
case '!':
case '-':
case '+':
@@ -539,29 +534,34 @@
{
int imm = 0;
Node *np;
- char *s = *strp;
- while (isspace(*s))
- ++s;
- textp = s;
-
- switch (*s) {
- case '\0':
+ textp = *strp;
+ switch (next()) {
+ case EOS:
np = NULL;
break;
+ case '(':
+ next();
+ np = zilog();
+ expect(')');
+ break;
+ case REG:
+ np = node(yytoken, NULL, NULL);
+ np->sym = yylval.sym;
+ np->addr = AREG;
+ next();
+ break;
case '$':
+ next();
imm = 1;
- textp++;
default:
- next();
np = expr();
if (imm)
np->addr = AIMM;
- if (yytoken != ',' && yytoken != EOS)
- error("trailing characters in expression '%s'", textp);
- s = endp;
}
+ if (yytoken != ',' && yytoken != EOS)
+ error("trailing characters in expression '%s'", textp);
+ *strp = endp;
- *strp = s;
return np;
}