*/
} 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);
#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(RgbImage *ri);
void progress_spinner(const char *fmt, ...) FMT(1,2);
enum flags {
- ff_editcharset= 00001,
- ff_singlepage= 00002,
- ff_testservers= 00004,
+ 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_printisland= 00200,
- ff_upload= 00400,
- ffs_printisland= 00300,
- ffs_upload= 00500,
+ 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;