--- ray/src/cal/calc.c 2013/12/19 16:56:31 1.8 +++ ray/src/cal/calc.c 2023/09/26 18:09:08 1.10 @@ -1,5 +1,5 @@ #ifndef lint -static const char RCSid[] = "$Id: calc.c,v 1.8 2013/12/19 16:56:31 greg Exp $"; +static const char RCSid[] = "$Id: calc.c,v 1.10 2023/09/26 18:09:08 greg Exp $"; #endif /* * calc.c - simple algebraic desk calculator program. @@ -25,9 +25,7 @@ int recover = 0; int -main(argc, argv) -int argc; -char *argv[]; +main(int argc, char *argv[]) { char expr[2048]; char *epos; @@ -65,6 +63,8 @@ char *argv[]; epos[-1] = ' '; continue; /* escaped newline */ } + while (epos > expr && isspace(epos[-1])) + epos--; /* eliminate end spaces */ *epos = '\0'; epos = expr; switch (expr[0]) { @@ -73,6 +73,8 @@ char *argv[]; case '?': for (cp = expr+1; isspace(*cp); cp++) ; + if (*calcontext(NULL)) + printf("context is: %s\n", calcontext(NULL)); if (*cp) dprint(cp, stdout); else @@ -108,6 +110,22 @@ char *argv[]; fcompile(cp); eclock++; continue; + case '[': + for (cp = expr+1; isspace(*cp); cp++) + ; + if (!isalpha(*cp)) { + eputs("context name required\n"); + continue; + } + printf("context now: %s\n", pushcontext(cp)); + continue; + case ']': + cp = popcontext(); + if (*cp) + printf("context now: %s\n", cp); + else + printf("at global context\n"); + continue; } if ((cp = strchr(expr, '=')) != NULL || (cp = strchr(expr, ':')) != NULL) { @@ -155,24 +173,21 @@ int n; void -eputs(msg) -char *msg; +eputs(const char *msg) { fputs(msg, stderr); } void -wputs(msg) -char *msg; +wputs(const char *msg) { eputs(msg); } void -quit(code) -int code; +quit(int code) { if (recover) /* a cavalier approach */ longjmp(env, 1);