Annotation of researchv10no/cmd/qsnap/qsnap.c, revision 1.1

1.1     ! root        1: #include       <fb.h>
        !             2: #include       <stdio.h>
        !             3: #include       <sys/types.h>
        !             4: #include       <sys/stat.h>
        !             5: #include       "defines.h"
        !             6: 
        !             7: #define XTIMES         Times
        !             8: #define YTIMES         Times
        !             9: #define Min(a,b)       ((a)>(b)?(b):(a))
        !            10: #define Max(a,b)       ((a)<(b)?(b):(a))
        !            11: 
        !            12: int Dither=0, BW=1, Times=3, Bright=0;
        !            13: int Film = 0;
        !            14: int Filter = GREEN;
        !            15: int Reso;
        !            16: int redonly = 0;
        !            17: int mustrot = 0;
        !            18: int settimes= 0;
        !            19: int setbright=0;
        !            20: int skip = 0;
        !            21: 
        !            22: unsigned char nq[9];
        !            23: char *malloc();
        !            24: unsigned char *rgb;
        !            25: 
        !            26: Usage(str)
        !            27:        char *str;
        !            28: {      fprintf(stderr, "qsnap: %s\n", str);
        !            29:        fprintf(stderr, "usage: qsnap -bcdfmnrRF [N ...] file\n");
        !            30:        fprintf(stderr, "b  brightness  [0-8,9], defaults to 0 (2k) or 2 (4k)\n");
        !            31:        fprintf(stderr, "c  td format n-channel color image\n");
        !            32:        fprintf(stderr, "d  dither image +- N [2-255]\n");
        !            33:        fprintf(stderr, "f  filmtype [0-2], defaults to 0 (custom,lin,pola)\n");
        !            34:        fprintf(stderr, "m  enlargement [1- ], defaults to 3(2k) or 6(4k)\n");
        !            35:        fprintf(stderr, "n  headerless square b&w image (default)\n");
        !            36:        fprintf(stderr, "r  expose red only, when combined with 'c'\n");
        !            37:        fprintf(stderr, "F  bwfilter [0-3], defaults to 2 (n,r,g,b)\n");
        !            38:        fprintf(stderr, "R  rotate image 90o clockwise\n");
        !            39:        fprintf(stderr, "s  skip the first N pictures\n");
        !            40:        exit(1);
        !            41: }
        !            42: 
        !            43: main(argc, argv)
        !            44:        char **argv;
        !            45: {
        !            46:        int i=1, base=2;        /* base of option arguments */
        !            47:        int x, y;
        !            48:        char c;
        !            49: 
        !            50:        if (argc > 1 && argv[1][0] == '-')
        !            51:        {       base++;
        !            52:                while ((c = argv[1][i++]) != '\0')
        !            53:                        switch (c) {
        !            54:        /* neutral  */  case 'n': BW = 1; break;
        !            55:        /* color    */  case 'c': BW = 0; break;
        !            56:        /* bright   */  case 'b': if (argc >= base)
        !            57:                                  {     sscanf(argv[base-1], "%d", &Bright);
        !            58:                                        base++;
        !            59:                                        Bright = Bright%10;
        !            60:                                        setbright = 1;
        !            61:                                        break;
        !            62:                                  } else
        !            63:                                        Usage("missing argument for `b' flag");
        !            64:        /* dither   */  case 'd': if (argc >= base)
        !            65:                                  {     sscanf(argv[base-1], "%d", &Dither);
        !            66:                                        base++;
        !            67:                                        if (Dither < 0) Dither = -Dither;
        !            68:                                        break;
        !            69:                                  } else
        !            70:                                        Usage("missing argument for `d' flag");
        !            71: 
        !            72:        /* filmtype */  case 'f': if (argc >= base)
        !            73:                                  {     sscanf(argv[base-1], "%d", &Film);
        !            74:                                        Film = Film%8;
        !            75:                                        base++;
        !            76:                                        if (Film == 6)
        !            77:                                                Usage("unknown film type");
        !            78:                                        break;
        !            79:                                  } else
        !            80:                                        Usage("missing argument for `f' flag");
        !            81:        /* multiply */  case 'm': if (argc >= base)
        !            82:                                  {     sscanf(argv[base-1], "%d", &Times);
        !            83:                                        base++;
        !            84:                                        settimes = 1;
        !            85:                                        break;
        !            86:                                  } else
        !            87:                                        Usage("missing argument for `m' flag");
        !            88:        /* filter */    case 'F': if (argc >= base)
        !            89:                                  {     sscanf(argv[base-1], "%d", &Filter);
        !            90:                                        Filter = Filter%4;
        !            91:                                        base++;
        !            92:                                        break;
        !            93:                                  } else
        !            94:                                        Usage("missing argument for `F' flag");
        !            95:                        case 'R': mustrot = 1; break;
        !            96:                        case 'r': redonly = 1; break;
        !            97:                        case 's': if (argc >= base)
        !            98:                                  {     sscanf(argv[base-1], "%d", &skip);
        !            99:                                        base++;
        !           100:                                        break;
        !           101:                                  } else
        !           102:                                        Usage("missing argument for `s' flag");
        !           103:                        default : Usage("unknown option");
        !           104:                        }
        !           105:        }
        !           106:        if (base > argc)
        !           107:                Usage("bad arglist");
        !           108:        qreset();
        !           109:        nocalibs();
        !           110:        Reso = resolution();
        !           111:        if (Reso == 4)
        !           112:        {       if (!settimes)  Times = 6;
        !           113:                if (!setbright) Bright = 2;
        !           114:        }
        !           115: 
        !           116:        rotate(mustrot);
        !           117:        filmtype(Film);
        !           118:        if (Bright != 9)
        !           119:        {       getbright(nq);
        !           120:                brightness(Bright, Bright, Bright, Bright);
        !           121:                printf("brightness %d (%d)\n", Bright, nq[Bright]);
        !           122:        }
        !           123: 
        !           124:        handshake(1);
        !           125: 
        !           126:        for (x = -512*Reso, y = 384*Reso; base <= argc; base++)
        !           127:        {       if (skip-- > 0)
        !           128:                        continue;
        !           129:                i = snap(argv[base-1], x, y);
        !           130:                x += i;
        !           131:                if (x+i >= 512*Reso)
        !           132:                {       y -= i;
        !           133:                        x = -512*Reso;
        !           134:                }
        !           135:                if (y-i < -384*Reso)
        !           136:                {       fprintf(stderr, "picture %s doesn't fit\n", argv[base-1]);
        !           137:                        break;
        !           138:                }
        !           139:                qreset();
        !           140:                brightness(Bright, Bright, Bright, Bright);
        !           141:                handshake(1);
        !           142:        }
        !           143:        exit(0);
        !           144: }
        !           145: 
        !           146: snap(name, Xmin, Ymin)
        !           147:        char *name;
        !           148: {
        !           149:        PICFILE *f;
        !           150:        register i, fd;
        !           151:        register unsigned char *p;
        !           152:        int h, w, nchan=1;
        !           153:        int Xmax = 1024*Reso, Ymax = 768*Reso;
        !           154: 
        !           155:        if (BW)
        !           156:        {       if ((fd = open(name, 0)) == -1)
        !           157:                {       perror(name);
        !           158:                        exit(1);
        !           159:                }
        !           160:                w = dimension(fd);
        !           161:                if (w*XTIMES > Xmax)
        !           162:                {       fprintf(stderr, "width is too large\n");
        !           163:                        fprintf(stderr, "you have: %dx%d=%d\n",w,XTIMES,w*XTIMES);
        !           164:                        exit(1);
        !           165:                }
        !           166:                h = Min(Ymax/YTIMES, w);
        !           167:                printf("%s: %dx%d\n", name, w, h);
        !           168:                if (!(rgb = (unsigned char *) malloc(w*h* sizeof(unsigned char))))
        !           169:                {       fprintf(stderr, "sorry, not enough memory\n");
        !           170:                        exit(1);
        !           171:                }
        !           172:                read(fd, (char *)rgb, w*h);
        !           173:                close(fd);
        !           174:        } else
        !           175:        {       if ((f = openpicr(name)) == NULL)
        !           176:                {       perror(name);
        !           177:                        exit(1);
        !           178:                }
        !           179:                w = f->r.co.x-f->r.or.x;
        !           180:                h = f->r.co.y-f->r.or.y;
        !           181:                nchan = f->nchan;
        !           182:                if (w*XTIMES > Xmax)
        !           183:                {       fprintf(stderr, "width too large\n");
        !           184:                        fprintf(stderr, "you have: %dx%d=%d\n",w,XTIMES,w*XTIMES);
        !           185:                        exit(1);
        !           186:                }
        !           187:                h = Min(Ymax/YTIMES, h);
        !           188:                printf("%s: %dx%d\n", name, w, h);
        !           189:                if (!(rgb = (unsigned char *)
        !           190:                                malloc(w*h*nchan* sizeof(unsigned char))))
        !           191:                {       fprintf(stderr, "sorry, not enough memory\n");
        !           192:                        exit(1);
        !           193:                }
        !           194:                for (p = rgb, i = 0; i < h; i++)
        !           195:                {       readpic(f, p);
        !           196:                        p += w*nchan;
        !           197:                }
        !           198:                closepic(f);
        !           199:        }
        !           200:        window(Xmin, Ymin, w*XTIMES, h*YTIMES);
        !           201: 
        !           202:        if (BW)
        !           203:        {       singlepass(Filter);
        !           204:                onechannel(rgb, h, w, 1);
        !           205:        } else
        !           206:        {       threepass();
        !           207:                printf("red\n"); onechannel(rgb  , h, w, nchan);
        !           208: if (!redonly) {
        !           209:                printf("grn\n"); onechannel(rgb+1, h, w, nchan);
        !           210:                printf("blu\n"); onechannel(rgb+2, h, w, nchan);
        !           211: }
        !           212:        }
        !           213:        printf("done\n");
        !           214:        return w*XTIMES;
        !           215: }
        !           216: 
        !           217: onechannel(from, h, w, n)
        !           218:        unsigned char *from;
        !           219: {
        !           220:        if (Dither)
        !           221:        {       prerand();
        !           222:                onedither(from, h, w, n);
        !           223:        } else
        !           224:                 straight(from, h, w, n);
        !           225: }
        !           226: 
        !           227: straight(from, h, w, n)
        !           228:        unsigned char *from;
        !           229: {
        !           230:        register i, j, k;
        !           231:        register unsigned char *p, *q;
        !           232:        unsigned char obuf[8192];
        !           233:        int chunk = w*XTIMES;
        !           234: 
        !           235:        for (i = 0, p = from; i < h; i++)
        !           236:        {       q = obuf;
        !           237:                for (j = 0; j < w; j++, p += n)
        !           238:                for (k = 0; k < XTIMES; k++)
        !           239:                        *q++ = *p;
        !           240:                for (k = 0; k < YTIMES; k++)
        !           241:                {       qwrite(obuf, chunk);
        !           242:                        if (chunk > 2048) qwait(200);
        !           243:        }       }
        !           244: }
        !           245: 
        !           246: short Nrand[5000];
        !           247: 
        !           248: prerand()
        !           249: {      register int i, D1=Dither, D2=Dither/2;
        !           250: 
        !           251:        for (i = 0; i < 5000; i++)
        !           252:                Nrand[i] = (short) (nrand(D1) - D2);
        !           253: }
        !           254: 
        !           255: /*onedither(from, h, w, n)
        !           256:        unsigned char *from;
        !           257: {
        !           258:        register short c, m, kk;
        !           259:        register unsigned char *op, *q;
        !           260:        register int D1 = Dither;
        !           261:        unsigned char *p, obuf[8192];
        !           262:        int i, j, k;
        !           263:        int chunk = w*XTIMES;
        !           264: 
        !           265:        for (i = 0, p = from; i < h; i++, p = op)
        !           266:        for (k = 0; k < YTIMES; k++)
        !           267:        {       q = obuf;
        !           268:                op = p;
        !           269:                for (j = 0; j < w; j++, op += n)
        !           270:                for (m = 0; m < XTIMES; m++)
        !           271:                {       c = (short) *op + Nrand[kk];
        !           272:                        if (++kk >= 5000) kk = 0;
        !           273:                        if(c<0)
        !           274:                                c=0;
        !           275:                        if(c>255)
        !           276:                                c=255;
        !           277:                        *q++ = (unsigned char) c;
        !           278:                }
        !           279:                qwrite(obuf, chunk);
        !           280:        }
        !           281: }*/
        !           282: onedither(from, h, w, n)
        !           283:        unsigned char *from;
        !           284: {
        !           285:        register int c, m, kk=0;
        !           286:        register unsigned char *op, *q;
        !           287:        register int D1 = Dither;
        !           288:        unsigned char *p, obuf[8192];
        !           289:        int i, j, k;
        !           290:        int chunk = w*XTIMES;
        !           291: 
        !           292:        if (w <= 0 || XTIMES <= 0) abort();
        !           293:        for (i = 0, p = from; i < h; i++, p = op)
        !           294:        for (k = 0; k < YTIMES; k++)
        !           295:        {       q = obuf;
        !           296:                op = p;
        !           297:                j = w;
        !           298:                do{
        !           299:                        m = XTIMES;
        !           300:                        do{
        !           301:                                c = *op + Nrand[kk];
        !           302:                                if (++kk >= 5000) kk = 0;
        !           303:                                if(c<0)
        !           304:                                        c=0;
        !           305:                                if(c>255)
        !           306:                                        c=255;
        !           307:                                *q++ = c;
        !           308:                        }while(--m);
        !           309:                        op += n;
        !           310:                }while(--j);
        !           311:                qwrite(obuf, chunk);
        !           312:        }
        !           313: }
        !           314: 
        !           315: qwait(n)
        !           316: {      int i;
        !           317:        for (i=0; i < n; i++) ;
        !           318: }
        !           319: 
        !           320: dimension(fd)
        !           321: {      struct stat bam;
        !           322:        int N;
        !           323:        extern float fsqrt();
        !           324: 
        !           325:        if (fstat(fd, &bam)==0)
        !           326:        {       N = bam.st_size;
        !           327:                N = (int) fsqrt((double)N+1.0);
        !           328:                return N;
        !           329:        }
        !           330:        return 0;
        !           331: }

unix.superglobalmegacorp.com

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