Annotation of researchv9/cmd/cfront/libC/stream/out.c, revision 1.1

1.1     ! root        1: /*
        !             2:        C++ stream i/o source
        !             3: 
        !             4:        out.c
        !             5: */
        !             6: strlen(const char*);
        !             7: #include "stream.h"
        !             8: #include <common.h>
        !             9: 
        !            10: 
        !            11: #define MAXOSTREAMS 20
        !            12: 
        !            13: char cout_buf[BUFSIZE];
        !            14: filebuf cout_file(stdout);     // UNIX output stream 1
        !            15: ostream cout(&cout_file);
        !            16: 
        !            17: char cerr_buf[1];
        !            18: filebuf cerr_file(stderr);     // UNIX output stream 2
        !            19: ostream cerr(&cerr_file);
        !            20: 
        !            21: const  cb_size = 1024;
        !            22: const  fld_size = 256;
        !            23: 
        !            24: /* a circular formating buffer */
        !            25: static char    formbuf[cb_size];       // some slob for form overflow
        !            26: static char*   bfree=formbuf;
        !            27: static char*   max = &formbuf[cb_size-1];
        !            28: 
        !            29: char* chr(register i, register int w)  /* note: chr(0) is "" */
        !            30: {
        !            31:        register char* buf = bfree;
        !            32: 
        !            33:        if (w<=0 || fld_size<w) w = 1;
        !            34:        w++;                            /* space for trailing 0 */
        !            35:        if (max < buf+w) buf = formbuf;
        !            36:        bfree = buf+w;
        !            37:        char * res = buf;
        !            38: 
        !            39:        w -= 2;                         /* pad */
        !            40:        while (w--) *buf++ = ' ';
        !            41:        if (i<0 || 127<i) i = ' ';
        !            42:        *buf++ = i;
        !            43:        *buf = 0;
        !            44:        return res;
        !            45: }
        !            46: 
        !            47: char* str(const char* s, register int w)
        !            48: {
        !            49:        register char* buf = bfree;
        !            50:        int ll = strlen(s);
        !            51:        if (w<=0 || fld_size<w) w = ll;
        !            52:        if (w < ll) ll = w;
        !            53:        w++;                            /* space for traling 0 */
        !            54:        if (max < buf+w) buf = formbuf;
        !            55:        bfree = buf+w;
        !            56:        char* res = buf;
        !            57: 
        !            58:        w -= (ll+1);                    /* pad */
        !            59:        while (w--) *buf++ = ' ';
        !            60:        while (*s) *buf++ = *s++;
        !            61:        *buf = 0;
        !            62:        return res;
        !            63: }
        !            64: 
        !            65: char* form(const char* format ...)
        !            66: {
        !            67:        register* ap = (int*)((char*)&format+sizeof(char*));    // not completely general
        !            68:        register char* buf = bfree;
        !            69:        if (max < buf+fld_size) buf = formbuf;
        !            70: 
        !            71:        register ll = sprintf(buf,format,ap[0],ap[1],ap[2],ap[3],ap[4],ap[5],ap[6],ap[7],ap[8],ap[9]);  // too few words copied
        !            72:        if (0<ll && ll<cb_size)                         // length
        !            73:                ;
        !            74:        else if (buf<(char*)ll && (char*)ll<buf+cb_size)// pointer to trailing 0
        !            75:                ll = (char*)ll - buf;
        !            76:        else
        !            77:                ll = strlen(buf);
        !            78:        if (fld_size < ll) exit(10);
        !            79:        bfree = buf+ll+1;
        !            80:        return buf;
        !            81: }
        !            82: 
        !            83: const char a10 = 'a'-10;
        !            84: 
        !            85: char* hex(long ii, register w)
        !            86: {
        !            87:        int m = sizeof(long)*2;         // maximum hex digits for a long
        !            88:        if (w<0 || fld_size<w) w = 0;
        !            89:        int sz = (w?w:m)+1;
        !            90:        register char* buf = bfree;
        !            91:        if (max < buf+sz) buf = formbuf;
        !            92:        register char* p = buf+sz;
        !            93:        bfree = p+1;
        !            94:        *p-- = 0;                       // trailing 0
        !            95:        register unsigned long i = ii;
        !            96: 
        !            97:        if (w) {
        !            98:                do {
        !            99:                        register h = i&0xf;
        !           100:                        *p-- = (h < 10) ? h+'0' : h+a10;
        !           101:                } while (--w && (i>>=4));
        !           102:                while (0<w--) *p-- = ' ';
        !           103:        }
        !           104:        else {
        !           105:                do {
        !           106:                        register h = i&0xf;
        !           107:                        *p-- = (h < 10) ? h+'0' : h+a10;
        !           108:                } while (i>>=4);
        !           109:        }
        !           110:        return p+1;
        !           111: }
        !           112: 
        !           113: char* oct(long ii, int w)
        !           114: {
        !           115:        int m = sizeof(long)*3;         // maximum oct digits for a long
        !           116:        if (w<0 || fld_size<w) w = 0;
        !           117:        int sz = (w?w:m)+1;
        !           118:        register char* buf = bfree;
        !           119:        if (max < buf+sz) buf = formbuf;
        !           120:        register char* p = buf+sz;
        !           121:        bfree = p+1;
        !           122:        *p-- = 0;                       // trailing 0
        !           123:        register unsigned long i = ii;
        !           124: 
        !           125:        if (w) {
        !           126:                do {
        !           127:                        register h = i&07;
        !           128:                        *p-- = h + '0';
        !           129:                } while (--w && (i>>=3));
        !           130:                while (0<w--) *p-- = ' ';
        !           131:        }
        !           132:        else {
        !           133:                do {
        !           134:                        register h = i&07;
        !           135:                        *p-- = h+'0';
        !           136:                } while (i>>=3);
        !           137:        }
        !           138: 
        !           139:        return p+1;
        !           140: }
        !           141: 
        !           142: char* dec(long i, int w)
        !           143: {
        !           144:        int sign = 0;
        !           145:        if (i < 0) {
        !           146:                sign = 1;
        !           147:                i = -i;
        !           148:        }       
        !           149:        int m = sizeof(long)*3;         /* maximum dec digits for a long */
        !           150:        if (w<0 || fld_size<w) w = 0;
        !           151:        int sz = (w?w:m)+1;
        !           152:        register char* buf = bfree;
        !           153:        if (max < buf+sz) buf = formbuf;
        !           154:        register char* p = buf+sz;
        !           155:        bfree = p+1;
        !           156:        *p-- = 0;                       /* trailing 0 */
        !           157: 
        !           158:        if (w) {
        !           159:                do {
        !           160:                        register h = i%10;
        !           161:                        *p-- = h + '0';
        !           162:                } while (--w && (i/=10));
        !           163:                if (sign && 0<w) {
        !           164:                        w--;
        !           165:                        *p-- = '-';
        !           166:                }
        !           167:                while (0<w--) *p-- = ' ';
        !           168:        }
        !           169:        else {
        !           170:                do {
        !           171:                        register h = i%10;
        !           172:                        *p-- = h + '0';
        !           173:                } while (i/=10);
        !           174:                if (sign) *p-- = '-';
        !           175:        }
        !           176: 
        !           177:        return p+1;
        !           178: }
        !           179: 
        !           180: 
        !           181: ostream& ostream.operator<<(const char* s)
        !           182: {
        !           183:        register streambuf* nbp = bp;
        !           184: 
        !           185:        if (state || s==0 || *s==0) return *this;
        !           186: 
        !           187:        do
        !           188:                if (nbp->sputc(*s++) == EOF) {
        !           189:                        state |= _eof|_fail;
        !           190:                        break;
        !           191:                }
        !           192:        while (*s);
        !           193: 
        !           194:        return *this;
        !           195: }
        !           196: 
        !           197: ostream& ostream.operator<<(long i)
        !           198: {
        !           199:        register streambuf* nbp = bp;
        !           200:        register long j;
        !           201:        char buf[32];
        !           202:        register char *p = buf;
        !           203: 
        !           204:        if (state) return *this;
        !           205: 
        !           206:        if (i < 0) {
        !           207:                nbp->sputc('-');
        !           208:                j = -i;
        !           209:        } else
        !           210:                j = i;
        !           211: 
        !           212:        do {
        !           213:                *p++ = '0' + j%10;
        !           214:                j = j/10;
        !           215:        } while (j > 0);
        !           216: 
        !           217:        do {
        !           218:                if (nbp->sputc(*--p) == EOF) {
        !           219:                        state |= _fail | _eof;
        !           220:                        break;
        !           221:                }
        !           222:        } while (p != buf);
        !           223: 
        !           224:        return *this;
        !           225: }
        !           226: 
        !           227: ostream& ostream.put(char c)
        !           228: {
        !           229:        if (state) return *this;
        !           230: 
        !           231:        if (bp->sputc(c) == EOF) state |= _eof|_fail;
        !           232: 
        !           233:        return *this;
        !           234: }
        !           235: 
        !           236: ostream& ostream.operator<<(double d)
        !           237: {
        !           238:        register streambuf* nbp = bp;
        !           239:        char buf[32];
        !           240:        register char *p = buf;
        !           241: 
        !           242:        if (state) return *this;
        !           243: 
        !           244:        sprintf(buf,"%g",d);
        !           245:        while (*p != '\0')
        !           246:                if (nbp->sputc(*p++) == EOF) {
        !           247:                        state |= _eof|_fail;
        !           248:                        break;
        !           249:                }
        !           250:        return *this;
        !           251: }
        !           252: 
        !           253: ostream& ostream.operator<<(const streambuf& b)
        !           254: {
        !           255:        register streambuf* nbp = bp;
        !           256:        register int c;
        !           257: 
        !           258:        if (state) return *this;
        !           259: 
        !           260:        c = b.sgetc();
        !           261:        while (c != EOF) {
        !           262:                if (nbp->sputc(c) == EOF) {
        !           263:                        state |= _eof|_fail;
        !           264:                        break;
        !           265:                }
        !           266:                c = b.snextc();
        !           267:        }
        !           268:                
        !           269:        return *this;
        !           270: }
        !           271: 
        !           272: 

unix.superglobalmegacorp.com

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