Get rid of writefmt functions
This commit is contained in:
112
user/tb/interp.c
112
user/tb/interp.c
@ -17,7 +17,8 @@ void tz_init(Tokenizer *tz, char *str) {
|
||||
void tz_free(Tokenizer *tz) {
|
||||
Token *tk, *tktmp;
|
||||
LL_FOREACH_SAFE(tz->tokens, tk, tktmp) {
|
||||
dlfree(tk);
|
||||
ufree(tk->str);
|
||||
ufree(tk);
|
||||
}
|
||||
tz->tokens = NULL;
|
||||
}
|
||||
@ -54,50 +55,44 @@ void tz_tokenize(Tokenizer *tz) {
|
||||
}
|
||||
}
|
||||
|
||||
/* void tz_classify(Tokenizer *tz) { */
|
||||
/* const int tmpbufsz = 256; */
|
||||
/* char *tmpbuf = dlmalloc(tmpbufsz); */
|
||||
void tz_classify(Tokenizer *tz) {
|
||||
Token *tk, *tktmp;
|
||||
LL_FOREACH_SAFE(tz->tokens, tk, tktmp) {
|
||||
if (tk->str[0] == '"') {
|
||||
tk->type = TOK_STRING;
|
||||
} else if (tk->str[0] == '%') {
|
||||
RtCmd *cmd, *cmdtmp;
|
||||
LL_FOREACH_SAFE(RTCMDS, cmd, cmdtmp) {
|
||||
if (string_strcmp(tk->str, cmd->cmdname) == 0) {
|
||||
tk->type = TOK_CMD;
|
||||
tk->cmd = cmd;
|
||||
break;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
tk->type = TOK_MISC;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* Token *tk, *tktmp; */
|
||||
/* LL_FOREACH_SAFE(tz->tokens, tk, tktmp) { */
|
||||
/* if (tk->ptr[0] == '"' && tk->ptr[tk->len - 1] == '"') { */
|
||||
/* tk->type = TOK_STRING; */
|
||||
/* } else if (tk->ptr[0] == '%') { */
|
||||
/* RtCmd *cmd, *cmdtmp; */
|
||||
/* LL_FOREACH_SAFE(RTCMDS, cmd, cmdtmp) { */
|
||||
/* string_memset(tmpbuf, 0, tmpbufsz); */
|
||||
/* string_memcpy(tmpbuf, tk->ptr, MIN(tk->len, tmpbufsz)); */
|
||||
/* if (string_strcmp(tmpbuf, cmd->cmdname) == 0) { */
|
||||
/* tk->type = TOK_CMD; */
|
||||
/* tk->cmd = cmd; */
|
||||
/* break; */
|
||||
/* } */
|
||||
/* } */
|
||||
/* } else { */
|
||||
/* tk->type = TOK_MISC; */
|
||||
/* } */
|
||||
/* } */
|
||||
/* dlfree(tmpbuf); */
|
||||
/* } */
|
||||
|
||||
/* void tz_expandspecial(Tokenizer *tz) { */
|
||||
/* Token *tk, *tktmp; */
|
||||
/* LL_FOREACH_SAFE(tz->tokens, tk, tktmp) { */
|
||||
/* if (tk->ptr[0] == '$' && tk->len > 1) { */
|
||||
/* char aliasbuf[RTALIAS_NAMEBUF_MAX]; */
|
||||
/* string_memset(aliasbuf, 0, sizeof(aliasbuf)); */
|
||||
/* string_memcpy(aliasbuf, &tk->ptr[1], MIN(tk->len - 1, RTALIAS_NAMEBUF_MAX)); */
|
||||
/* RtAlias *alias, *aliastmp; */
|
||||
/* LL_FOREACH_SAFE(RTALIASES, alias, aliastmp) { */
|
||||
/* if (string_strcmp(alias->namebuf, aliasbuf) == 0) { */
|
||||
/* tk->ptr = alias->valbuf; */
|
||||
/* tk->len = string_len(alias->valbuf); */
|
||||
/* break; */
|
||||
/* } */
|
||||
/* } */
|
||||
/* } */
|
||||
/* } */
|
||||
/* } */
|
||||
void tz_expandspecial(Tokenizer *tz) {
|
||||
Token *tk, *tktmp;
|
||||
LL_FOREACH_SAFE(tz->tokens, tk, tktmp) {
|
||||
/* if (tk->ptr[0] == '$' && tk->len > 1) { */
|
||||
/* char aliasbuf[RTALIAS_NAMEBUF_MAX]; */
|
||||
/* string_memset(aliasbuf, 0, sizeof(aliasbuf)); */
|
||||
/* string_memcpy(aliasbuf, &tk->ptr[1], MIN(tk->len - 1, RTALIAS_NAMEBUF_MAX)); */
|
||||
/* RtAlias *alias, *aliastmp; */
|
||||
/* LL_FOREACH_SAFE(RTALIASES, alias, aliastmp) { */
|
||||
/* if (string_strcmp(alias->namebuf, aliasbuf) == 0) { */
|
||||
/* tk->ptr = alias->valbuf; */
|
||||
/* tk->len = string_len(alias->valbuf); */
|
||||
/* break; */
|
||||
/* } */
|
||||
/* } */
|
||||
/* } */
|
||||
}
|
||||
}
|
||||
|
||||
#define LINE_MAX 1024
|
||||
|
||||
@ -110,27 +105,32 @@ bool interp_runstring(char *string, InterpResult **res, bool logcmds, bool inter
|
||||
|
||||
char *line = string_tokenizealloc(string, "\n");
|
||||
while (line != NULL) {
|
||||
|
||||
if (logcmds) {
|
||||
writefmt("+{s}\n", line);
|
||||
uprintf("+%s\n", line);
|
||||
}
|
||||
|
||||
Tokenizer tz; ZERO(&tz);
|
||||
tz_init(&tz, line);
|
||||
|
||||
tz_tokenize(&tz);
|
||||
/* Token tktmp; ZERO(&tktmp); */
|
||||
/* while (tz_next(&tz, &tktmp)) { */
|
||||
/* Token *tk = dlmalloc(sizeof(*tk)); */
|
||||
/* tk->ptr = tktmp.ptr; */
|
||||
/* tk->len = tktmp.len; */
|
||||
/* LL_APPEND(tz.tokens, tk); */
|
||||
/* } */
|
||||
|
||||
/* tz_classify(&tz); */
|
||||
/* tz_expandspecial(&tz); */
|
||||
tz_classify(&tz);
|
||||
tz_expandspecial(&tz);
|
||||
|
||||
/* dlfree((void *)line); */
|
||||
Token *cmdtk = tz.tokens;
|
||||
if (cmdtk->type == TOK_CMD) {
|
||||
ok = cmdtk->cmd->fn(cmdtk->next);
|
||||
if (!ok) {
|
||||
usprintf(RES.errmsg, "cmd %s failed", cmdtk->str);
|
||||
goto next;
|
||||
}
|
||||
} else if (cmdtk->type == TOK_MISC) {
|
||||
|
||||
}
|
||||
|
||||
next:
|
||||
tz_free(&tz);
|
||||
ufree(line);
|
||||
line = string_tokenizealloc(NULL, "\n");
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user