Annotation of freem/src/cmd_write.c, revision 1.1
1.1 ! snw 1: /*
! 2: * *
! 3: * * *
! 4: * * *
! 5: * ***************
! 6: * * * * *
! 7: * * MUMPS *
! 8: * * * * *
! 9: * ***************
! 10: * * *
! 11: * * *
! 12: * *
! 13: *
! 14: * cmd_write.c
! 15: * Implementation of the WRITE 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: #if !defined(MSDOS)
! 45: # include "io_socket.h"
! 46: #endif
! 47:
! 48: MRESULT cmd_write(MACTION *ra, int *i)
! 49: {
! 50: char vn[255];
! 51: char *wr_terminator = (char *) malloc (STRLEN * sizeof (char));
! 52: char *sw_buf = (char *) malloc (STRLEN * sizeof (char));
! 53:
! 54: NULLPTRCHK(wr_terminator,"cmd_write");
! 55: NULLPTRCHK(sw_buf,"cmd_write");
! 56:
! 57: if (io > FIRSTSCK) msck_get_terminator (io, wr_terminator);
! 58:
! 59: if (io != HOME && devopen[io] == 'r' && io < FIRSTSCK) {
! 60: free (sw_buf);
! 61: return NOWRITE;
! 62: }
! 63:
! 64: if ((*i = (*codptr)) == SP || *i == EOL) {
! 65: return ARGLIST;
! 66: }
! 67:
! 68: writeproc:
! 69:
! 70: switch (*i)
! 71: {
! 72:
! 73: case '!':
! 74:
! 75: if (io < FIRSTSCK) {
! 76:
! 77: if (crlf[io]) {
! 78: write_m ("\012\201");
! 79: }
! 80: else {
! 81: write_m ("\015\012\201");
! 82: }
! 83:
! 84: }
! 85: else {
! 86: /* WRITE ! for sockets */
! 87: strcat (sw_buf, wr_terminator);
! 88: }
! 89:
! 90: break;
! 91:
! 92: case '#':
! 93:
! 94: if (io < FIRSTSCK) {
! 95: write_m ("\015\014\201");
! 96: }
! 97: else {
! 98: return SYNTERR;
! 99: }
! 100:
! 101: break;
! 102:
! 103: case '?':
! 104:
! 105: codptr++;
! 106:
! 107: expr (STRING);
! 108:
! 109: if (merr ()) return merr ();
! 110:
! 111: if (io < FIRSTSCK) {
! 112: write_t ((short) intexpr (argptr));
! 113: }
! 114: else {
! 115: return SYNTERR;
! 116: }
! 117:
! 118: break;
! 119:
! 120: case '/':
! 121: codptr++;
! 122:
! 123: expr (NAME);
! 124: if (merr ()) return merr ();
! 125:
! 126: if (io < FIRSTSCK) {
! 127: write_f (varnam);
! 128: }
! 129: else {
! 130: return SYNTERR;
! 131: }
! 132:
! 133: codptr++;
! 134:
! 135: break;
! 136:
! 137: case '*':
! 138: codptr++;
! 139:
! 140: expr (STRING);
! 141: if (merr ()) return merr ();
! 142:
! 143: argptr[0] = (char) UNSIGN (intexpr (argptr));
! 144: argptr[1] = EOL;
! 145:
! 146: /* special treatment for EOL as long as we don't have 8 bit */
! 147: if (argptr[0] == EOL) {
! 148:
! 149: mcmnd = '*';
! 150:
! 151: if (io < FIRSTSCK) {
! 152: m_output (argptr);
! 153: }
! 154: else {
! 155: /* EOL handling for socket devices */
! 156: }
! 157: mcmnd = WRITE;
! 158:
! 159: }
! 160: else {
! 161:
! 162: if (io < FIRSTSCK) {
! 163: write_m (argptr);
! 164: }
! 165: else {
! 166: /* non-EOL char-code handling for sockets */
! 167: }
! 168:
! 169: }
! 170:
! 171: break;
! 172:
! 173: default:
! 174: expr (STRING);
! 175: if (merr ()) return merr ();
! 176:
! 177: if (io < FIRSTSCK) {
! 178: write_m (argptr);
! 179: }
! 180: else {
! 181: /* regular output for socket devices */
! 182: stcpy (vn, argptr);
! 183: stcnv_m2c (vn);
! 184: strcat (sw_buf, vn);
! 185: }
! 186: }
! 187:
! 188: if ((*i == '!') || (*i == '#')) {
! 189: if ((*i = *++codptr) == '!' || *i == '#' || *i == '?') goto writeproc;
! 190: }
! 191:
! 192: if (io >= FIRSTSCK) {
! 193: msck_write (io, sw_buf, strlen (sw_buf));
! 194: }
! 195:
! 196: free (sw_buf);
! 197: free (wr_terminator);
! 198:
! 199: *ra = RA_CONTINUE;
! 200: return OK;
! 201: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>