handling of C++ names.

This commit is contained in:
rsc 2005-11-29 05:12:48 +00:00
parent e3de25fea4
commit 62faed57a5
3 changed files with 27 additions and 6 deletions

View file

@ -4,7 +4,7 @@
enum
{
Eof = -1,
Strsize = 4096,
Strsize = 65536,
Hashsize = 128,
Maxarg = 512,
NFD = 100,

View file

@ -348,7 +348,6 @@ bqsymbol(void)
char *p;
Lsym *s;
symbol[0] = 0;
p = symbol;
while((c = lexc()) != '`'){
if(c == Eof)
@ -361,6 +360,7 @@ bqsymbol(void)
sysfatal("overflow in bqsymbol");
*p = 0;
fprint(2, "bq: %s\n", symbol);
s = look(symbol);
if(s == 0)
s = enter(symbol, Tid);
@ -601,7 +601,19 @@ numsym(char first)
error("%d <eof> eating symbols", line);
if(c == '\n')
line++;
if(c != '_' && c != '$' && c <= '~' && !isalnum(c)) { /* checking against ~ lets UTF names through */
/* allow :: in name */
if(c == ':'){
c = lexc();
if(c == ':'){
*p++ = ':';
*p++ = ':';
continue;
}
unlexc(c);
unlexc(':');
break;
}
if(c != '_' && c != '$' && c < Runeself && !isalnum(c)) {
unlexc(c);
break;
}

View file

@ -16,7 +16,7 @@ unique(char *buf, Symbol *s)
int i, renamed;
renamed = 0;
strcpy(buf, s->name);
strcpy(buf, s->xname);
for(;;) {
l = look(buf);
if(l == 0 || (l->lexval == Tid && l->v->set == 0))
@ -36,9 +36,10 @@ unique(char *buf, Symbol *s)
}
}
if(renamed && !quiet)
print("\t%s=%s %c/%L\n", s->name, buf, s->type, s->loc);
print("\t%s=%s %c/%L\n", s->xname, buf, s->type, s->loc);
if(l == 0)
l = enter(buf, Tid);
s->aux = l;
return l;
}
@ -116,23 +117,31 @@ addvarsym(Fhdr *fp)
if(l->v->store.comt == 0)
l->v->store.fmt = 'X';
/* Enter as list of { name, type, value, file } */
/* Enter as list of { name, type, value, file, xname } */
list = al(TSTRING);
tl->store.u.l = list;
list->store.u.string = strnode(buf);
list->store.fmt = 's';
list->next = al(TINT);
list = list->next;
list->store.fmt = 'c';
list->store.u.ival = s.type;
list->next = al(TINT);
list = list->next;
list->store.fmt = 'X';
list->store.u.ival = v;
list->next = al(TSTRING);
list = list->next;
list->store.fmt = 's';
list->store.u.string = file;
list->next = al(TSTRING);
list = list->next;
list->store.fmt = 's';
list->store.u.string = strnode(s.xname);
}
}
*tail = nil;