Annotation of freem/src/datatypes.c, revision 1.1
1.1 ! snw 1: /*
! 2: * *
! 3: * * *
! 4: * * *
! 5: * ***************
! 6: * * * * *
! 7: * * MUMPS *
! 8: * * * * *
! 9: * ***************
! 10: * * *
! 11: * * *
! 12: * *
! 13: *
! 14: * datatypes.c
! 15: * supports the type system
! 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 <stdio.h>
! 43: #include <unistd.h>
! 44: #include <ctype.h>
! 45:
! 46: #include "mpsdef.h"
! 47: #include "datatypes.h"
! 48:
! 49: short dt_get_type(char *type_string)
! 50: {
! 51: register int i;
! 52:
! 53: for (i = 0; i < strlen (type_string); i++) {
! 54: type_string[i] = toupper (type_string[i]);
! 55: }
! 56:
! 57: if ((strcmp (type_string, "STRING")) == 0) {
! 58: return DT_STRING;
! 59: }
! 60: else if ((strcmp (type_string, "BOOLEAN")) == 0) {
! 61: return DT_BOOLEAN;
! 62: }
! 63: else if ((strcmp (type_string, "COMPLEX")) == 0) {
! 64: return DT_COMPLEX;
! 65: }
! 66: else if ((strcmp (type_string, "INTEGER")) == 0) {
! 67: return DT_INTEGER;
! 68: }
! 69: else if ((strcmp (type_string, "MATRIX")) == 0) {
! 70: return DT_MATRIX;
! 71: }
! 72: else if ((strcmp (type_string, "NAME")) == 0) {
! 73: return DT_NAME;
! 74: }
! 75: else if ((strcmp (type_string, "REAL")) == 0) {
! 76: return DT_REAL;
! 77: }
! 78: else {
! 79: return DT_INVALID;
! 80: }
! 81: }
! 82:
! 83: void dt_get_typestr (char *buf, short datatype)
! 84: {
! 85: switch (datatype) {
! 86:
! 87: case DT_AUTO:
! 88: sprintf (buf, "AUTO");
! 89: break;
! 90:
! 91: case DT_STRING:
! 92: sprintf (buf, "STRING");
! 93: break;
! 94:
! 95: case DT_BOOLEAN:
! 96: sprintf (buf, "BOOLEAN");
! 97: break;
! 98:
! 99: case DT_INTEGER:
! 100: sprintf (buf, "INTEGER");
! 101: break;
! 102:
! 103: case DT_REAL:
! 104: sprintf (buf, "REAL");
! 105: break;
! 106:
! 107: case DT_NAME:
! 108: sprintf (buf, "NAME");
! 109: break;
! 110:
! 111: case DT_COMPLEX:
! 112: sprintf (buf, "COMPLEX");
! 113: break;
! 114:
! 115: case DT_MATRIX:
! 116: sprintf (buf, "MATRIX");
! 117: break;
! 118:
! 119: }
! 120: }
! 121:
! 122: short dt_check(short datatype, char *data, int arg_num)
! 123: {
! 124: short res;
! 125: char dtc_temp[10];
! 126:
! 127: switch (datatype) {
! 128:
! 129: case DT_AUTO:
! 130: case DT_STRING:
! 131: case DT_BOOLEAN:
! 132: res = TRUE;
! 133: break;
! 134:
! 135: case DT_COMPLEX:
! 136: res = dt_check_complex (data);
! 137: break;
! 138:
! 139: case DT_MATRIX:
! 140: res = dt_check_matrix (data);
! 141: break;
! 142:
! 143: case DT_INTEGER:
! 144: res = dt_check_integer (data);
! 145: break;
! 146:
! 147: case DT_REAL:
! 148: res = dt_check_real (data);
! 149: break;
! 150:
! 151: default:
! 152: res = FALSE;
! 153:
! 154: }
! 155:
! 156: if (res == FALSE) {
! 157: dt_get_typestr (dtc_temp, datatype);
! 158:
! 159: if (arg_num == 0) {
! 160: sprintf (err_suppl, "%s expected for extrinsic function return value\201", dtc_temp);
! 161: }
! 162: else {
! 163: sprintf (err_suppl, "%s expected in argument %d\201", dtc_temp, arg_num);
! 164: }
! 165: }
! 166:
! 167: return res;
! 168:
! 169: }
! 170:
! 171: short dt_check_complex(char *data)
! 172: {
! 173: register char ch;
! 174: register int i;
! 175:
! 176: char *cpx_real;
! 177: char *cpx_imaginary;
! 178:
! 179: int pctct = 0;
! 180:
! 181: while ((ch = *data++) != EOL) {
! 182: if (ch == '%') {
! 183: pctct++;
! 184: if (pctct > 1) return FALSE;
! 185: }
! 186: }
! 187:
! 188: cpx_real = strtok (data, "%");
! 189: cpx_imaginary = strtok (NULL, "%");
! 190:
! 191: if ((dt_check_real (cpx_real) == FALSE) || (dt_check_real (cpx_imaginary) == FALSE)) {
! 192: return FALSE;
! 193: }
! 194:
! 195: return TRUE;
! 196: }
! 197:
! 198: short dt_check_integer(char *data)
! 199: {
! 200: register char ch;
! 201: register int i;
! 202:
! 203: i = 0;
! 204:
! 205: while ((ch = *data++) != EOL) {
! 206:
! 207: if (((ch == '+') || (ch == '-')) && i > 0) return FALSE;
! 208:
! 209: if (!isdigit (ch)) return FALSE;
! 210:
! 211: i++;
! 212:
! 213: }
! 214:
! 215: return TRUE;
! 216: }
! 217:
! 218: short dt_check_matrix(char *data)
! 219: {
! 220: return FALSE;
! 221: }
! 222:
! 223: short dt_check_name(char *data)
! 224: {
! 225: return FALSE;
! 226: }
! 227:
! 228: short dt_check_real(char *data)
! 229: {
! 230: register char ch;
! 231: register int i;
! 232: int ptct;
! 233:
! 234: i = 0;
! 235: ptct = 0;
! 236:
! 237: while ((ch = *data++) != EOL) {
! 238:
! 239: if (((ch == '+') || (ch == '-')) && i > 0) return FALSE;
! 240:
! 241: if ((ch == '.') && (++ptct > 1)) return FALSE;
! 242:
! 243: if (!isdigit (ch)) return FALSE;
! 244:
! 245: i++;
! 246:
! 247: }
! 248:
! 249: return TRUE;
! 250: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>