Annotation of freem/src/cmd_ksubscripts.c, revision 1.1.1.1
1.1 snw 1: /*
2: * *
3: * * *
4: * * *
5: * ***************
6: * * * * *
7: * * MUMPS *
8: * * * * *
9: * ***************
10: * * *
11: * * *
12: * *
13: *
14: * cmd_ksubscripts.c
15: * Implementation of the KSUBSCRIPTS command
16: *
17: *
18: * Author: Serena Willis <jpw@coherent-logic.com>
19: * Copyright (C) 1998 MUG Deutschland
20: * Copyright (C) 2023 Coherent Logic Development LLC
21: *
22: *
23: * This file is part of FreeM.
24: *
25: * FreeM is free software: you can redistribute it and/or modify
26: * it under the terms of the GNU Affero Public License as published by
27: * the Free Software Foundation, either version 3 of the License, or
28: * (at your option) any later version.
29: *
30: * FreeM is distributed in the hope that it will be useful,
31: * but WITHOUT ANY WARRANTY; without even the implied warranty of
32: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
33: * GNU Affero Public License for more details.
34: *
35: * You should have received a copy of the GNU Affero Public License
36: * along with FreeM. If not, see <https://www.gnu.org/licenses/>.
37: *
38: **/
39:
40: #include <string.h>
41: #include <stdlib.h>
42: #include "mpsdef.h"
43: #include "mcommand.h"
44: #include "consttbl.h"
45:
46: MRESULT cmd_ksubscripts(MACTION *ra)
47: {
48: register char ch;
49: char vn[255];
50: char *old_value;
51:
52: if ((rtn_dialect () != D_FREEM) &&
53: (rtn_dialect () != D_MDS)) {
54: return NOSTAND;
55: }
56:
57: if ((old_value = (char *) malloc (STRLEN * sizeof (char))) == NULL) {
58: return MEMOV;
59: }
60:
61: /* argumentless: KSUBSCRIPTS nukleurrr winturr */
62: if (((ch = *codptr) == SP) || ch == EOL) {
63: write_m ("Argumentless KSUBSCRIPTS not yet implemented.\201");
64:
65: free (old_value);
66:
67: *ra = RA_NEXTCMND;
68: return OK;
69: }
70:
71:
72: if (ch != '(') { /* inclusive KSUBSCRIPTS */
73:
74: for (;;) {
75: expr (NAME); /* try to interpret an mname */
76:
77: if (merr ()) return merr ();
78:
79: stcpy (vn, varnam);
80:
81: if (vn[0] != '^') {
82: symtab (get_sym, vn, old_value);
83: symtab (kill_sym, vn, NULL);
84: symtab (set_sym, vn, old_value);
85: }
86: else {
87: if (vn[1] == '$') {
88: ssvn (get_sym, vn, old_value);
89: ssvn (kill_sym, vn, NULL);
90: ssvn (set_sym, vn, old_value);
91: }
92: else {
93: global (get_sym, vn, old_value);
94: global (kill_sym, vn, NULL);
95: global (set_sym, vn, old_value);
96: }
97: }
98:
99: free (old_value);
100:
101: if (merr ()) return merr ();
102:
103: if ((ch = *(codptr + 1)) == EOL) {
104: codptr++;
105: break;
106: }
107: else if (ch == ',') {
108: codptr += 2;
109: }
110: else {
111: return CMMND;
112: }
113: }
114:
115: }
116: else { /* exclusive KSUBSCRIPTS */
117:
118: write_m ("Exclusive KSUBSCRIPTS not yet implemented.\201");
119:
120: while ((ch = *(codptr++)) != SP && ch != EOL) ; /* skip to the end of the command */
121:
122: }
123:
124: *ra = RA_NEXTCMND;
125: return OK;
126:
127: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>