X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?p=ypp-sc-tools.db-test.git;a=blobdiff_plain;f=pctb%2Fconvert.h;h=07c3a6ffaf366759da1e8fbf9bf5dd2e7b6271ce;hp=354a6f12467b10755a8eddc02513496dea54eb45;hb=9c4e6ae34ea06c776ebbf5410f7bc1ce78edad2f;hpb=6a3c0962283d32bc6e5f6c47c929baf37ddc642f diff --git a/pctb/convert.h b/pctb/convert.h index 354a6f1..07c3a6f 100644 --- a/pctb/convert.h +++ b/pctb/convert.h @@ -51,17 +51,28 @@ typedef struct RgbImage { */ } RgbImage; +typedef unsigned long Rgb; + void identify_rgbimage(const RgbImage *base, Rect portion, char result[MAXIMGIDENT], const char *what); RgbImage *alloc_rgb_image(int w, int h); +void fwrite_ppmraw(FILE *f, const RgbImage *ri); #define RI_PIXEL(ri,x,y) ((ri)->data + ((y)*(ri)->w + (x)) * 3) +static inline Rgb ri_rgb(const RgbImage *ri, int x, int y) { + const unsigned char *rip= RI_PIXEL(ri,x,y); + return (rip[0] << 16) | + (rip[1] << 8) | + (rip[2] ); +} + /*----- from structure.c -----*/ -void find_structure(const CanonImage *im, int *max_relevant_y_r); +void find_structure(CanonImage *im, int *max_relevant_y_r); +Rect find_sunshine_widget(void); -void find_islandname(void); +void find_islandname(RgbImage *ri); void check_correct_commodities(void); void read_screenshots(void); void read_one_screenshot(void); @@ -85,20 +96,30 @@ void vprogress_spinner(const char *fmt, va_list) FMT(1,0); void progress_spinner(const char *fmt, ...) FMT(1,2); enum flags { - ff_editcharset= 00001, - ff_singlepage= 00002, + ff_singlepage= 000002, + ff_testservers= 000004, + + ff_charset_edit= 000010, + ff_charset_allowedit= 000020, + ff_charset_havelocal= 000040, + ffm_charset= 000070, - ff_dict_fetch= 00010, - ff_dict_submit= 00020, - ff_dict_pirate= 00040, - ffs_dict= 00070, - - ff_needisland= 00100, - ff_upload= 00200, - ffs_upload= 00300, + ff_dict_fetch= 000100, + ff_dict_submit= 000200, + ff_dict_pirate= 000400, + ffs_dict= 000700, + + ff_needisland= 001000, + ff_printisland= 002000, + ff_upload= 004000, + ffs_printisland= 003000, + ffs_upload= 005000, }; extern enum flags o_flags; +extern const char *o_ocean, *o_pirate; +extern int o_quiet; + /*----- from pages.c -----*/ void screenshot_startup(void); @@ -110,9 +131,9 @@ void take_one_screenshot(void); #define MAX_PAGES 100 extern CanonImage *page_images[MAX_PAGES]; extern int npages; -RgbImage *page0_rgbimage; -extern char *ocean, *pirate; +extern const char *ocean, *pirate; +extern char *archipelago, *island; #endif /*CONVERT_H*/