Annotation of freem/src/cmd_map.c, revision 1.3

1.1       snw         1: /*
1.3     ! snw         2:  *   $Id$
1.1       snw         3:  *    Implementation of the MAP command
                      4:  *
                      5:  *  
1.2       snw         6:  *   Author: Serena Willis <snw@coherent-logic.com>
1.1       snw         7:  *    Copyright (C) 1998 MUG Deutschland
                      8:  *    Copyright (C) 2023 Coherent Logic Development LLC
                      9:  *
                     10:  *
                     11:  *   This file is part of FreeM.
                     12:  *
                     13:  *   FreeM is free software: you can redistribute it and/or modify
                     14:  *   it under the terms of the GNU Affero Public License as published by
                     15:  *   the Free Software Foundation, either version 3 of the License, or
                     16:  *   (at your option) any later version.
                     17:  *
                     18:  *   FreeM is distributed in the hope that it will be useful,
                     19:  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
                     20:  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     21:  *   GNU Affero Public License for more details.
                     22:  *
                     23:  *   You should have received a copy of the GNU Affero Public License
                     24:  *   along with FreeM.  If not, see <https://www.gnu.org/licenses/>.
                     25:  *
1.3     ! snw        26:  *   $Log$
        !            27:  *
        !            28:  * SPDX-FileCopyrightText:  (C) 2025 Coherent Logic Development LLC
        !            29:  * SPDX-License-Identifier: AGPL-3.0-or-later 
1.1       snw        30:  **/
                     31: 
                     32: #include <string.h>
                     33: #include <stdlib.h>
                     34: #include "mpsdef.h"
                     35: #include "mcommand.h"
                     36: 
                     37: MRESULT cmd_map(MACTION *ra)
                     38: {
                     39:     char mapping_type;
                     40:     char mapping_obj[256];
                     41:     char mapping_ns[256];
                     42:     char tmp_key[256];
                     43:     
                     44:     if (rtn_dialect () != D_FREEM) {
                     45:         return NOSTAND;
                     46:     }
                     47:     
                     48:     if (is_standard ()) {
                     49:         return NOSTAND;
                     50:     }
                     51:     
                     52:     expr (NAME);    
                     53:     
                     54:     if (stcmp (varnam, "GLOBAL\201") == 0 || stcmp (varnam, "global\201") == 0) {
                     55:         mapping_type = 'g';
                     56:     }
                     57:     else if (stcmp (varnam, "ROUTINE\201") == 0 ||  stcmp (varnam, "routine\201") == 0) {
                     58:         mapping_type = 'r';
                     59:         return ARGLIST;
                     60:     }
                     61:     else {
                     62:         return ARGLIST;
                     63:     }
                     64:     
                     65:     codptr += 2;
                     66:     
                     67:     expr (NAME);
                     68:     if (merr ()) return merr ();
                     69:     
                     70:     stcpy (mapping_obj, varnam);
                     71:     stcnv_m2c (mapping_obj);
                     72:     
                     73:     codptr++;
                     74:     
                     75:     if (*codptr != '=') {
                     76:         return ASSIGNER;       
                     77:     }
                     78:     
                     79:     codptr++;
                     80:         
                     81:     expr (STRING);
                     82:     if (merr ()) return merr ();
                     83:     
                     84:     stcpy (mapping_ns, argptr);               
                     85:     
                     86:     snprintf (tmp_key, 255, "^$SYSTEM\202MAPPINGS\202GLOBAL\202%s\201", mapping_obj);
                     87:     global (set_sym, tmp_key, mapping_ns);
                     88: 
                     89:     *ra = RA_CONTINUE;
                     90:     return OK;
                     91:     
                     92: }

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