Cache value before entering spacer macro
This commit is contained in:
parent
a512cb2888
commit
c25561c650
14
src/modal.c
14
src/modal.c
|
@ -25,7 +25,7 @@ walk(char *s)
|
||||||
if(!depth) return s;
|
if(!depth) return s;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while(!spacer(s[0]) && *s++)
|
while((c = *s) && !spacer(c) && *s++)
|
||||||
;
|
;
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
@ -63,7 +63,8 @@ match(char *p, Rule *r)
|
||||||
if(*a != *b) return NULL;
|
if(*a != *b) return NULL;
|
||||||
a++, b++;
|
a++, b++;
|
||||||
}
|
}
|
||||||
return spacer(*b) ? b : NULL;
|
c = *b;
|
||||||
|
return spacer(c) ? b : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *
|
static char *
|
||||||
|
@ -81,8 +82,8 @@ plode(char *s)
|
||||||
} else { /* explode */
|
} else { /* explode */
|
||||||
*outp_++ = *s++, *outp_++ = ' ';
|
*outp_++ = *s++, *outp_++ = ' ';
|
||||||
while((c = *s++) && !spacer(c)) {
|
while((c = *s++) && !spacer(c)) {
|
||||||
*outp_++ = '(', *outp_++ = c, depth++;
|
*outp_++ = '(', *outp_++ = c, depth++, c = *s;
|
||||||
if(!spacer(*s))
|
if(!spacer(c))
|
||||||
*outp_++ = ' ';
|
*outp_++ = ' ';
|
||||||
}
|
}
|
||||||
for(i = 0; i < depth; i++)
|
for(i = 0; i < depth; i++)
|
||||||
|
@ -135,7 +136,7 @@ parse_rule(char *s)
|
||||||
static int
|
static int
|
||||||
rewrite(void)
|
rewrite(void)
|
||||||
{
|
{
|
||||||
char c, last = 0, *p = direction ? bank_b : bank_a, *o = p;
|
char c, c_ = 0, last = 0, *p = direction ? bank_b : bank_a, *o = p;
|
||||||
while((c = *p) && c <= ' ') p++;
|
while((c = *p) && c <= ' ') p++;
|
||||||
while((c = *p)) {
|
while((c = *p)) {
|
||||||
int i;
|
int i;
|
||||||
|
@ -148,7 +149,8 @@ rewrite(void)
|
||||||
r->b = parse_rule(p), p = walk(p);
|
r->b = parse_rule(p), p = walk(p);
|
||||||
return save(-1, p);
|
return save(-1, p);
|
||||||
}
|
}
|
||||||
if(p == o || spacer(*(p - 1))) {
|
if(p != o) c_ = *(p - 1);
|
||||||
|
if(p == o || spacer(c_)) {
|
||||||
for(i = 0; i < rules_len; i++) {
|
for(i = 0; i < rules_len; i++) {
|
||||||
Rule *r = &rules[i];
|
Rule *r = &rules[i];
|
||||||
char *res = match(p, r);
|
char *res = match(p, r);
|
||||||
|
|
Loading…
Reference in New Issue