Annotation of freem/src/cmd_tstart.c, revision 1.1
1.1 ! snw 1: /*
! 2: * *
! 3: * * *
! 4: * * *
! 5: * ***************
! 6: * * * * *
! 7: * * MUMPS *
! 8: * * * * *
! 9: * ***************
! 10: * * *
! 11: * * *
! 12: * *
! 13: *
! 14: * cmd_tstart.c
! 15: * Implementation of the TSTART 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 <ctype.h>
! 43: #include "mpsdef.h"
! 44: #include "mcommand.h"
! 45: #include "consttbl.h"
! 46: #include "transact.h"
! 47:
! 48: MRESULT cmd_tstart(MACTION *ra)
! 49: {
! 50: register char ch;
! 51: short serial = FALSE;
! 52: short restartable = FALSE;
! 53: char tran_ident[50];
! 54: char tre_offset[50];
! 55: short parct = 0;
! 56:
! 57: if ((rtn_dialect () != D_M95) &&
! 58: (rtn_dialect () != D_MDS) &&
! 59: (rtn_dialect () != D_M5) &&
! 60: (rtn_dialect () != D_FREEM)) {
! 61: return NOSTAND;
! 62: }
! 63:
! 64: uuid_v4 (tran_ident);
! 65:
! 66: if (((ch = *codptr) == SP) || ch == EOL) {
! 67:
! 68: serial = FALSE;
! 69: restartable = FALSE;
! 70:
! 71: goto exec_tstart;
! 72:
! 73: }
! 74:
! 75: restartable = TRUE;
! 76: getraddress (tre_offset, nstx);
! 77:
! 78: //printf ("tre_offset = '%s'\r\n", tre_offset);
! 79:
! 80: if (ch == ':') {
! 81: restartable = FALSE;
! 82: goto tstart_param;
! 83: }
! 84: else if (ch == '(') {
! 85: ch = *codptr++;
! 86:
! 87: if (ch == ')') goto tstart_param;
! 88: }
! 89: else if (ch == '*') {
! 90: printf ("all varnames\r\n");
! 91: }
! 92: else if ((ch >= 'a' && ch <= 'z') || (ch >= 'A' && ch <= 'Z')) {
! 93: printf ("one varname\r\n");
! 94: }
! 95:
! 96:
! 97: tstart_param:
! 98:
! 99: codptr++;
! 100: ch = *codptr;
! 101:
! 102: switch (ch) {
! 103:
! 104: case ':':
! 105: goto tstart_param;
! 106:
! 107: case 's':
! 108: case 'S':
! 109:
! 110: expr (NAME);
! 111: if (merr ()) return merr ();
! 112:
! 113: stcnv_m2c (varnam);
! 114: {
! 115: int stct;
! 116: for (stct = 0; stct < strlen (varnam); stct++) {
! 117: varnam[stct] = toupper (varnam[stct]);
! 118: }
! 119: }
! 120:
! 121: if ((strcmp (varnam, "S") == 0) ||
! 122: (strcmp (varnam, "SERIAL") == 0)) {
! 123: serial = TRUE;
! 124: }
! 125: else {
! 126: return SYNTERR;
! 127: }
! 128:
! 129: goto tstart_param;
! 130:
! 131: case 't':
! 132: case 'T':
! 133:
! 134: expr (NAME);
! 135: if (merr ()) return merr ();
! 136:
! 137: stcnv_m2c (varnam);
! 138: {
! 139: int stct;
! 140: for (stct = 0; stct < strlen (varnam); stct++) {
! 141: varnam[stct] = toupper (varnam[stct]);
! 142: }
! 143: }
! 144:
! 145: if ((strcmp (varnam, "T") == 0) ||
! 146: (strcmp (varnam, "TRANSACTIONID") == 0)) {
! 147:
! 148: codptr++;
! 149:
! 150: if ((ch = *codptr) != '=') {
! 151: return ASSIGNER;
! 152: }
! 153:
! 154: codptr++;
! 155:
! 156: expr (STRING);
! 157: if (merr () == BRAER) merr_clear ();
! 158: if (merr () > OK) {
! 159: return merr ();
! 160: }
! 161:
! 162: stcnv_m2c (argptr);
! 163: strcpy (tran_ident, argptr);
! 164:
! 165: codptr--;
! 166:
! 167: goto tstart_param;
! 168:
! 169: }
! 170: break;
! 171:
! 172: case '(':
! 173:
! 174: parct++;
! 175:
! 176: if (parct > 1) {
! 177: return SYNTERR;
! 178: }
! 179:
! 180: goto tstart_param;
! 181:
! 182: break;
! 183:
! 184: case ')':
! 185:
! 186: parct--;
! 187:
! 188: if (parct < 0) {
! 189: return SYNTERR;
! 190: }
! 191:
! 192: goto exec_tstart;
! 193:
! 194: case SP:
! 195: case EOL:
! 196:
! 197: if (parct > 0) {
! 198: return BRAER;
! 199: }
! 200:
! 201: goto exec_tstart;
! 202:
! 203: default:
! 204:
! 205: return SYNTERR;
! 206:
! 207: }
! 208:
! 209:
! 210: exec_tstart:
! 211: tp_tstart (tran_ident, serial, restartable, NULL);
! 212:
! 213: while ((ch = *(codptr++)) != SP && ch != EOL) ; /* skip to the end of the command */
! 214: *ra = RA_NEXTCMND;
! 215: return OK;
! 216: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>