Annotation of researchv10no/cmd/basic/bite/src/avars.c, revision 1.1

1.1     ! root        1: /* Copyright Bell Telephone Laboratories Whippany, N.J.
        !             2: 
        !             3:  *     /////////////////////////////////////
        !             4:  *     /////////////////////////////////////
        !             5:  *     ////////////// avars.c //////////////
        !             6:  *     /// J. P. Hawkins WH X4610 8C-001 ///
        !             7:  *     ///// Fri Aug 24 17:11:02 1979 //////
        !             8:  *     /////////////////////////////////////
        !             9:  *     /////////////////////////////////////
        !            10: 
        !            11:  *
        !            12:  * Process ARRAY (subscripted) VARABLES
        !            13:  * STORAGE & FETCH ROUTINES
        !            14:  */
        !            15: /*   "@(#) avars.c:  V 1.2  3/4/81" */
        !            16: #include       "bas.h"
        !            17: char * asymtab[26][11];        /* symbol table */
        !            18: /*
        !            19:  * STORE ARRAY VARIABLE
        !            20:  */
        !            21: aputvar(vstr, value)
        !            22: char   vstr[];
        !            23: double value;
        !            24: {
        !            25:        char    *addr;  /* address of data */
        !            26:        char    *putflot();
        !            27: 
        !            28:        if(getaddr(vstr, &addr) < 0)
        !            29:                return(-1);
        !            30: 
        !            31:        putflot(value, addr);   /* store the number in the array location */
        !            32:        return(0);
        !            33: }
        !            34: 
        !            35: /*
        !            36:  * FETCH ARRAY VARIABLE
        !            37:  */
        !            38: agetvar(vstr, value)
        !            39: char   vstr[];
        !            40: double *value;
        !            41: {
        !            42:        char *  addr;
        !            43:        char    *getflot();
        !            44: 
        !            45:        if(getaddr(vstr, &addr) < 0)
        !            46:                return(-1);
        !            47: 
        !            48:        getflot(value, addr);
        !            49:        return(0);
        !            50: }
        !            51: /*
        !            52:  *
        !            53:  * ////// CALCULATE ARRAY VARIABLE ADDRESS //////
        !            54:  *
        !            55:  *
        !            56:  */
        !            57: getaddr(vstr, addr)
        !            58: char   vstr[];         /* subscripted variable string */
        !            59: char   **addr;         /* addres of subscripted variable */
        !            60: {
        !            61:        char    arname[3];      /* array name */
        !            62:        char    *ptr;           /* location pointer */
        !            63:        char    *getflot(),*putflot();
        !            64:        int     offset;         /* offset to data point */
        !            65:        int     asize;          /* actual number of dims stored */
        !            66:        double  dasize;         /* actual number of dims stored */
        !            67:        double  rsize;          /* number of dims in request */
        !            68:        double  adims[MAXDIM];  /* actual dims */
        !            69:        double  rdims[MAXDIM];  /* requested dims */
        !            70:        double  acons[MAXDIM-1];        /* actual constants */
        !            71:        register i;             /* counter */
        !            72:        int     j,k;
        !            73:        int     amax;           /* integer form of size */
        !            74: 
        !            75:        /*
        !            76:         * GET REQUESTED PARAMS
        !            77:         */
        !            78:        if(getdims(vstr, arname, &rsize, rdims) < 0)
        !            79:                return(-1);     /* error in spec */
        !            80: 
        !            81:        j = arname[0] - 'a';
        !            82:        /*
        !            83:         * compute k subscript
        !            84:         */
        !            85:        if(arname[1] == '\0')
        !            86:                k = 0;
        !            87:        else
        !            88:                k = arname [1] - '0' + 1;
        !            89: 
        !            90:        if(asymtab[j][k] == 0)  /* If not dimensioned, complain */
        !            91:        {
        !            92:                error(inst.thing.linno, 25); /* NOT DIMENSIONED */
        !            93:                return(-1);
        !            94:        }
        !            95: 
        !            96:        ptr = asymtab[j][k];    /* get pointer to header */
        !            97:        ptr = getflot(&dasize, ptr);    /* get actual size */
        !            98: 
        !            99:        if(dasize != rsize)     /* error if mismatch in actual to
        !           100:                                        requested size */
        !           101:        {
        !           102:                error(inst.thing.linno, 26); /* WRONG NUMBER OF DIMS */
        !           103:                return(-1);
        !           104:        }
        !           105:        amax = asize = dasize;          /* convert size to integer */
        !           106:        for(i=0; i<amax; i++)
        !           107:        {
        !           108:                ptr = getflot(&adims[i], ptr);
        !           109:                if((rdims[i] ) > adims[i]) /* make spec start with 1 */
        !           110:                {
        !           111:                        error(inst.thing.linno, 27); /* DIM LARGER THAN ACTUAL */
        !           112:                        return(-1);
        !           113:                }
        !           114:                rdims[i] -= 1;  /* actual number used starts at 0 */
        !           115:        }
        !           116:        /*
        !           117:         * GET CONSTANTS
        !           118:         */
        !           119:        for(i=0; i<(amax-1); i++)
        !           120:                ptr = getflot(&acons[i], ptr);
        !           121:        acons[i] = 0.0; /* null terminate */
        !           122: 
        !           123:        /*
        !           124:         * CALCULATE BYTE OFFSET IN A POSITIVE SENSE
        !           125:         */
        !           126:        for(i=0, offset = 0; acons[i] != 0.0; i++)
        !           127:        {
        !           128:                offset += acons[i] * rdims[i];
        !           129:        }
        !           130:        offset += rdims[i] + 2 * asize;
        !           131:        offset *= PREC;
        !           132:        *addr = asymtab[j][k] - offset;
        !           133:        return(0);
        !           134: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.