X-Git-Url: https://secure.softndesign.org/git/?a=blobdiff_plain;f=parser.c;h=395e2aea1e90642757ab4cf6fb2d891058d479a1;hb=c7cbb833c65805634f6e9832b49e4a4680a4a4a6;hp=a1602a0f3b05360e8a34bfb29b7f25f5582e4b86;hpb=9b759869476fd697c534a6c3b126c0ee34a88778;p=calc.git diff --git a/parser.c b/parser.c index a1602a0..395e2ae 100644 --- a/parser.c +++ b/parser.c @@ -21,6 +21,8 @@ double *storage = NULL; char *format = NULL; char *minform = NULL; +workspace_t *programs = NULL; + /* compare codes */ int codecmp (char *ref, char *str) @@ -122,7 +124,7 @@ keyword_t operators[NB_OPERATORS] = { { "|", Or, 2, 1, -2} }; -#define NB_FUNCTIONS 25 +#define NB_FUNCTIONS 31 keyword_t functions[NB_FUNCTIONS] = { { "sqrt", Sqr, 1, 4, 5}, { "pow", Pow, 2, 3, 5}, @@ -143,12 +145,18 @@ keyword_t functions[NB_FUNCTIONS] = { { "dec", Dec, 1, 3, 5}, { "disp", Disp, 0, 4, 9}, { "mem", Mem, 1, 3, 9}, + { "clr", Clear, 0, 3, 9}, { "quit", Quit, 0, 4, 9}, { "help", Help, 0, 4, 9}, { "!", Not, 1, 1, 6}, { "cond", Cond, 3, 4, 5}, { "while", While, 2, 5, 5}, - { "print", Print, 1, 5, 5} + { "print", Print, 1, 5, 5}, + { "prog", Prog, 3, 4, 9}, + { "call", Call, 10, 4, 5}, + { "ls", List, 0, 2, 9}, + { "edit", Edit, 1, 4, 9}, + { "del", Del, 1, 3, 9} }; #define NB_CONSTANTS 3 @@ -507,6 +515,7 @@ void print_element (element_t *root, int level) case Dec: func = "Decrease"; break; case Disp: func = "Display"; break; case Mem: func = "Memory"; break; + case Clear: func = "Clear"; break; case Quit: func = "Quit"; break; case Help: func = "Help"; break; case Ans: func = "Ans"; break; @@ -525,6 +534,11 @@ void print_element (element_t *root, int level) case While: func = "While"; break; case Prog: func = "Program"; break; case Print: func = "Print"; break; + case Prog: func = "Program"; break; + case Call: func = "Call"; break; + case List: func = "List"; break; + case Edit: func = "Edit"; break; + case Del: func = "Del"; break; } fprintf (stdout, "Function: %s\n", func); @@ -631,6 +645,14 @@ void display (void) fprintf (stdout, "\n"); } +void clear () +{ + int i; + for (i = 0; i < storage_size; i++) { + storage[i] = 0; + } +} + /* While do function */ double while_do (element_t *cond, element_t *action) @@ -709,6 +731,25 @@ void quit (void) exit (0); } +/* program function */ + +void prog (int id, int nbmems, element_t *root) +{ } + +double call (int id, int nbobs, element_t **ops) +{ + return 0; +} + +void list () +{ } + +void edit (int id) +{ } + +void del (int id) +{ } + /* help message */ void help (void) @@ -791,6 +832,7 @@ double evaluate_element (element_t *root, char mask) case Lt: case And: case Or: + case Prog: if (root->ops[1]) { op1 = evaluate_element (root->ops[1], nextmask); } else if (root->func != Store) { @@ -816,6 +858,10 @@ double evaluate_element (element_t *root, char mask) case Not: case Mem: case Cond: + case Call: + case List: + case Edit: + case Del: if (root->ops[0]) { op0 = evaluate_element (root->ops[0], 0); } else { @@ -824,6 +870,7 @@ double evaluate_element (element_t *root, char mask) } break; case Disp: + case Clear: case Quit: case Help: case Ans: @@ -869,6 +916,7 @@ double evaluate_element (element_t *root, char mask) case Dec: return decrease ((int)op0); case Disp: display (); break; case Mem: memory ((int)op0); break; + case Clear: clear (); break; case Quit: quit (); break; case Help: help (); break; case Ans: return answer; @@ -894,6 +942,11 @@ double evaluate_element (element_t *root, char mask) case While: return while_do (root->ops[0], root->ops[1]); case Prog: return program_do (root->ops, root->nbops); case Print: return print (op0); + case Prog: prog ((int)op0, (int)op1, root->ops[2]); break; + case Call: return call ((int)op0, root->nbops + 1, root->ops + 1); + case List: list (); break; + case Edit: edit ((int)op0); break; + case Del: del (int (op0)); break; } return 0;