Annotation of freem/src/mcommand.c, revision 1.1

1.1     ! snw         1: /*
        !             2:  *                            *
        !             3:  *                           * *
        !             4:  *                          *   *
        !             5:  *                     ***************
        !             6:  *                      * *       * *
        !             7:  *                       *  MUMPS  *
        !             8:  *                      * *       * *
        !             9:  *                     ***************
        !            10:  *                          *   *
        !            11:  *                           * *
        !            12:  *                            *
        !            13:  *
        !            14:  *   mcommand.c
        !            15:  *    M command utility functions
        !            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: 
        !            45: MRESULT mcmd_tokenize(MACTION *ra, char *tmp3, char *deferrable_codptr, char *deferrable_code, int *j)
        !            46: {
        !            47:     tmp3[0] = SP;
        !            48:     tmp3[1] = mcmnd;
        !            49:     tmp3[++(*j)] = SP;
        !            50:     tmp3[++(*j)] = EOL;
        !            51:     
        !            52:     if (mcmnd != 'z') {
        !            53:         
        !            54:         if (find (" ab ablock assert assign asta astart asto astop aunb aunblock \
        !            55:             break co const close do else esta estart esto estop etr etrigger for goto hang halt \
        !            56:             if job kill ks ksubscripts kv kvalue lock ma map merge new open quit read rl rload \
        !            57:             rs rsave set tc tcommit th then thr throw tro trollback ts tstart use \
        !            58:             un unmap usi using view wa watch write wi with xecute ", tmp3) == FALSE) {
        !            59:             return CMMND;
        !            60:         }
        !            61: 
        !            62:         switch (mcmnd)
        !            63:         {
        !            64:             
        !            65:             case 'a':
        !            66:                 
        !            67:                 if (tmp3[2] == 'b') {
        !            68:                     mcmnd = ABLOCK;
        !            69:                 }
        !            70:                 else if (tmp3[2] == 'u') {
        !            71:                     mcmnd = AUNBLOCK;
        !            72:                 }
        !            73:                 else if (tmp3[2] == 's') {
        !            74:                     
        !            75:                     if (tmp3[4] == 'a') {
        !            76:                         mcmnd = ASTART;
        !            77:                     }                 
        !            78:                     else if (tmp3[4] == 'o') {
        !            79:                         mcmnd = ASTOP;
        !            80:                     }
        !            81:                     else if (tmp3[4] == 'e') {
        !            82:                         mcmnd = ASSERT_TKN;
        !            83:                     }
        !            84:                     
        !            85:                 }
        !            86:                
        !            87:                 break;
        !            88:                 
        !            89:             case 'c':
        !            90:                 
        !            91:                 if (tmp3[2] == 'l') {
        !            92:                     mcmnd = CLOSE;
        !            93:                 }
        !            94:                 else {
        !            95:                     mcmnd = CONST;
        !            96:                 }
        !            97:                
        !            98:             case 'e':
        !            99:                 if (tmp3[2] == 't') mcmnd = ETRIGGER;
        !           100:                 else if (tmp3[4] == 'a') mcmnd = ESTART;
        !           101:                 else if (tmp3[4] == 'o') mcmnd = ESTOP;
        !           102:                 break;
        !           103:                
        !           104:             case 'h':
        !           105:                 mcmnd = tmp3[4] == 't' ? HALT : HANG;
        !           106:                 break;
        !           107:                
        !           108:             case 'k':
        !           109:                 if (tmp3[2] == 'v') mcmnd = KVALUE;
        !           110:                 else if (tmp3[2] == 's') mcmnd = KSUBSC;
        !           111:                 break;
        !           112:                
        !           113:             case 'm':
        !           114:                 
        !           115:                 if (tmp3[2] == 'e') {
        !           116:                     
        !           117:                     /* save off pre-parse codptr and code for commands implemented in M routines */
        !           118:                     deferrable_codptr = codptr;
        !           119:                     stcpy (deferrable_code, "MERGE\201");
        !           120:                     stcat (deferrable_code, deferrable_codptr);
        !           121:                    
        !           122:                     break;
        !           123:                     
        !           124:                 }
        !           125:                 else if (tmp3[2] == 'a') {
        !           126:                     mcmnd = MAP;
        !           127:                     break;
        !           128:                 }
        !           129:                
        !           130:             case 'r':
        !           131:                 if (tmp3[2] == 'l') mcmnd = RLOAD;
        !           132:                 else if (tmp3[2] == 's') mcmnd = RSAVE;
        !           133:                 break;
        !           134:                
        !           135:             case 't':
        !           136:                 if (tmp3[2] == 'c') mcmnd = TCOMMIT;
        !           137:                 else if (tmp3[2] == 'h') {
        !           138:                     if (tmp3[3] == 'e') {
        !           139:                         mcmnd = THEN;
        !           140:                     }
        !           141:                     else if (tmp3[3] == 'r') {
        !           142:                         mcmnd = THROW;
        !           143:                     }
        !           144:                 }
        !           145:                 else if (tmp3[3] == 'o') mcmnd = TROLLBACK;
        !           146:                 else if (tmp3[2] == 's') mcmnd = TSTART;
        !           147:                 break;
        !           148:                
        !           149:             case 'w':
        !           150:                 
        !           151:                 switch (tmp3[2]) {
        !           152:                     
        !           153:                     
        !           154:                     case 'a':
        !           155:                         mcmnd = WATCH;
        !           156:                         break;
        !           157:                         
        !           158:                     case 'i':
        !           159:                         mcmnd = OO_WITH;
        !           160:                         break;
        !           161:                        
        !           162:                     case 'r':
        !           163:                         mcmnd = WRITE;
        !           164:                         break;
        !           165:                         
        !           166:                        
        !           167:                 }                  
        !           168:                 
        !           169:                 break;
        !           170:                 
        !           171:             case 'u':
        !           172:                 
        !           173:                 if (tmp3[2] == 'n') {
        !           174:                     mcmnd = UNMAP;
        !           175:                     break;
        !           176:                 }
        !           177:                 
        !           178:                 switch (tmp3[3]) {
        !           179:                     
        !           180:                     case 'e':
        !           181:                         mcmnd = USE;
        !           182:                         break;
        !           183:                         
        !           184:                     case 'i':
        !           185:                         mcmnd = OO_USING;
        !           186:                         break;
        !           187:                         
        !           188:                 }
        !           189:                 
        !           190:                
        !           191:         }           /* end of switch(mcmnd) */
        !           192:         
        !           193:     }
        !           194:     else {
        !           195:         
        !           196:         mcmnd = tmp3[2] - 32;   /* z_command select */
        !           197:         
        !           198:         if (find (zcommds, tmp3) == FALSE) mcmnd = PRIVATE;
        !           199:     }
        !           200: 
        !           201:     *ra = RA_CONTINUE;
        !           202:     return OK;
        !           203: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>