X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?a=blobdiff_plain;f=pctb%2Frgbimage.c;h=dc9fa68996069fbc3518b5d445f6b1766622cf20;hb=34c9aa9031897dada3450d014de96d68a5834039;hp=0e89892306605d0b9f5e14773125197f7445e234;hpb=dd9f2514793939f2197d0376b5ce8e01ec7edb05;p=ypp-sc-tools.main.git diff --git a/pctb/rgbimage.c b/pctb/rgbimage.c index 0e89892..dc9fa68 100644 --- a/pctb/rgbimage.c +++ b/pctb/rgbimage.c @@ -50,9 +50,9 @@ static int identify1(const RgbImage *base, Rect portion, char result[MAXIMGIDENT], const char *what, - const char *which) { - char *dbfile_name= masprintf("#%s-pixmap#.txt",which); - if (!dbfile_open(dbfile_name)) + const char *which, int (*opener)(const char *fn)) { + char *dbfile_name= masprintf("_%s-pixmap.txt",which); + if (!opener(dbfile_name)) goto not_found; #define FGETSLINE (dbfile_getsline(result,MAXIMGIDENT,__FILE__,__LINE__)) @@ -85,14 +85,16 @@ static int identify1(const RgbImage *base, Rect portion, int x,y,i; for (y=0; y=0 && c<=255); - int px= portion.tl.x + x, py= portion.tl.y + y; - diff |= px > portion.br.x || py > portion.br.y || - (c != RI_PIXEL(base,px,py)[i]); + rgb |= (Rgb)c << (i*8); } + int px= portion.tl.x + x, py= portion.tl.y + y; + diff |= px > portion.br.x || py > portion.br.y || + rgb != ri_rgb(base,px,py); } } if (!diff) { @@ -111,17 +113,22 @@ static int identify1(const RgbImage *base, Rect portion, static int identify(const RgbImage *base, Rect portion, char result[MAXIMGIDENT], const char *what) { - return identify1(base,portion,result,what, "master") || - identify1(base,portion,result,what, "local"); + return identify1(base,portion,result,what, "master", dbfile_gzopen) || + identify1(base,portion,result,what, "local", dbfile_open); } void fwrite_ppmraw(FILE *f, const RgbImage *ri) { + int i; fprintf(f, "P6\n" "%d %d\n" "255\n", ri->w, ri->h); - int count= ri->w * ri->h * 3; - sysassert( fwrite(ri->data, 1, count, f) == count ); + for (i=0; i < ri->w * ri->h; i++) { + Rgb rgb= ri->data[i]; + fputc_unlocked(rgb >> 0, f); + fputc_unlocked(rgb >> 8, f); + fputc_unlocked(rgb >> 16, f); + } sysassert(!ferror(f)); sysassert(!fflush(f)); } @@ -132,8 +139,9 @@ static void fwrite_ppm(FILE *f, const RgbImage *base, Rect portion) { for (y=portion.tl.y; y<=portion.br.y; y++) { for (x=portion.tl.x; x<=portion.br.x; x++) { putc(' ',f); + Rgb rgb= ri_rgb(base,x,y); for (i=0; i<3; i++) - fprintf(f," %3d", RI_PIXEL(base,x,y)[i]); + fprintf(f," %3d", (rgb>>(i*8)) & 0xff); } putc('\n',f); } @@ -147,7 +155,7 @@ void identify_rgbimage(const RgbImage *base, Rect portion, if (!synced) { if (o_flags & ff_dict_fetch) - fetch_with_rsync("pixmap"); + fetch_with_rsync_gz("pixmap"); synced++; } @@ -173,7 +181,7 @@ void identify_rgbimage(const RgbImage *base, Rect portion, RgbImage *alloc_rgb_image(int w, int h) { RgbImage *ri; - ri= mmalloc(sizeof(*ri) + w*h*3); + ri= mmalloc(sizeof(*ri) + w*h*sizeof(ri->data[0])); ri->w= w; ri->h= h; return ri;