Annotation of 43BSD/contrib/icon/functions/center.c, revision 1.1.1.1

1.1       root        1: #include "../h/rt.h"
                      2: 
                      3: /*
                      4:  * center(s1,n,s2) - pad s1 on left and right with s2 to length n.
                      5:  */
                      6: 
                      7: Xcenter(nargs, arg3, arg2, arg1, arg0)
                      8: int nargs;
                      9: struct descrip arg3, arg2, arg1, arg0;
                     10:    {
                     11:    register char *s, *st;
                     12:    int cnt, slen, hcnt;
                     13:    char *sbuf, *s3;
                     14:    char sbuf1[MAXSTRING], sbuf2[MAXSTRING];
                     15:    extern char *alcstr();
                     16: 
                     17:    /*
                     18:     * s1 must be a string.  n must be a non-negative integer and defaults
                     19:     *  to 1.  s2 must be a string and defaults to a blank.
                     20:     */
                     21:    if (cvstr(&arg1, sbuf1) == NULL)
                     22:       runerr(103, &arg1);
                     23:    defshort(&arg2, 1);
                     24:    if ((cnt = INTVAL(arg2)) < 0)
                     25:       runerr(205, &arg2);
                     26:    defstr(&arg3, sbuf2, &blank);
                     27: 
                     28:    sneed(cnt);
                     29: 
                     30:    if (STRLEN(arg3) == 0) {
                     31:       /*
                     32:        * The padding string is null, make it a blank.
                     33:        */
                     34:       slen = 1;
                     35:       s3 = " ";
                     36:       }
                     37:    else {
                     38:       slen = STRLEN(arg3);
                     39:       s3 = STRLOC(arg3);
                     40:       }
                     41: 
                     42:    /*
                     43:     * Get n bytes of string space for the new string.  Start at the right
                     44:     *  of the new string and copy s2 into it from right to left as
                     45:     *  many times as will fit in the right half of the new string.
                     46:     */
                     47:    sbuf = alcstr(NULL, cnt);
                     48:    hcnt = cnt / 2;
                     49:    s = sbuf + cnt;
                     50:    while (s > sbuf + hcnt) {
                     51:       st = s3 + slen;
                     52:       while (st > s3 && s > sbuf + hcnt)
                     53:          *--s = *--st;
                     54:       }
                     55: 
                     56:    /*
                     57:     * Start at the left end of the new string and copy s1 into it from
                     58:     *  left to right as many time as will fit in the left half of the
                     59:     *  new string.
                     60:     */
                     61:    s = sbuf;
                     62:    while (s < sbuf + hcnt) {
                     63:       st = s3;
                     64:       while (st < s3 + slen && s < sbuf + hcnt)
                     65:          *s++ = *st++;
                     66:       }
                     67: 
                     68:    slen = STRLEN(arg1);
                     69:    if (cnt < slen) {
                     70:       /*  
                     71:        * s1 is larger than the field to center it in.  The source for the
                     72:        *  copy starts at the appropriate point in s1 and the destination
                     73:        *  starts at the left end of of the new string.
                     74:        */
                     75:       s = sbuf;
                     76:       st = STRLOC(arg1) + slen/2 - hcnt + (~cnt&slen&1);
                     77:       }
                     78:    else {
                     79:       /*
                     80:        * s1 is smaller than the field to center it in.  The source for the
                     81:        *  copy starts at the left end of s1 and the destination starts at
                     82:        *  the appropriate point in the new string.
                     83:        */
                     84:       s = sbuf + hcnt - slen/2 - (~cnt&slen&1);
                     85:       st = STRLOC(arg1);
                     86:       }
                     87:    /*
                     88:     * Perform the copy, moving min(*s1,n) bytes from st to s.
                     89:     */
                     90:    if (slen > cnt)
                     91:       slen = cnt;
                     92:    while (slen-- > 0)
                     93:       *s++ = *st++;
                     94: 
                     95:    /*
                     96:     * Return the new string.
                     97:     */
                     98:    STRLEN(arg0) = cnt;
                     99:    STRLOC(arg0) = sbuf;
                    100:    }
                    101: 
                    102: Procblock(center,3)

unix.superglobalmegacorp.com

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