X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?p=ypp-sc-tools.db-test.git;a=blobdiff_plain;f=pctb%2Fcommon.h;h=52f57d699c4cefd959d300bc44349038d7e4e5a8;hp=47f898f06fecd31519d3bc0f717e0e024c1e41cf;hb=b1f4b728760aaa2cba8e19dca85b93d248f6db12;hpb=8360f12a6a457b73ebb18dbeedbb15e6ed91318b diff --git a/pctb/common.h b/pctb/common.h index 47f898f..52f57d6 100644 --- a/pctb/common.h +++ b/pctb/common.h @@ -30,7 +30,9 @@ #define _GNU_SOURCE +#include #include +#include #include #include #include @@ -38,6 +40,8 @@ #include #include #include +#include +#include #include #include @@ -45,6 +49,7 @@ typedef struct { int w,h; + struct RgbImage *rgb; char d[]; } CanonImage; @@ -72,6 +77,8 @@ typedef struct { /* both inclusive */ DF(pixmap) \ DF(struct) \ DF(ocr) \ + DF(rsync) \ + DF(structcolon) \ DF(callout) enum { @@ -93,6 +100,7 @@ void debug_flush(void); #define debug stderr const char *get_vardir(void); +const char *get_libdir(void); #define FMT(f,a) __attribute__((format(printf,f,a))) #define SCANFMT(f,a) __attribute__((format(scanf,f,a))) @@ -144,4 +152,21 @@ int dbfile_scanf(const char *fmt, ...) SCANFMT(1,2); int dbfile_vscanf(const char *fmt, va_list al) SCANFMT(1,0); +char *masprintf(const char *fmt, ...) FMT(1,2); + +#define EXECLP_HELPER(helper, ...) do{ \ + char *helper_path= masprintf("%s/%s",get_libdir(),helper); \ + execlp(helper_path,helper, __VA_ARGS__); \ + sysassert(errno==ENOENT); \ + fatal("Failed to find helper program %s.\n" \ + "(Are you in the correct directory?)", helper); \ + }while(0) + + +#define ARRAYSIZE(a) ((sizeof((a)) / sizeof((a)[0]))) +#define FILLZERO(obj) (memset(&(obj),0,sizeof((obj)))) + +#define STRING2(x) #x +#define STRING(x) STRING2(x) + #endif /*COMMON_H*/