#include "c.h" #include "postgres.h" #define HEXDIG(z) (z)<10 ? ((z)+'0') : ((z)-10+'A') /* Modeled on struct varlena from postgres.h, bu data type is bits8 */ struct varbita { int32 vl_len; bits8 vl_dat[1]; }; #define BITSPERBYTE 8 #define VARBITHDRSZ sizeof(int32) /* Number of bits in this bit string */ #define VARBITLEN(PTR) (((struct varbita *)VARDATA(PTR))->vl_len) /* Pointer tp the first byte containing bit string data */ #define VARBITS(PTR) (((struct varbita *)VARDATA(PTR))->vl_dat) /* Number of bytes in the data section of a bit string */ #define VARBITBYTES(PTR) (VARSIZE(PTR) - VARHDRSZ - VARBITHDRSZ) /* Padding of the bit string at the end */ #define VARBITPAD(PTR) (VARBITBYTES(PTR)*BITSPERBYTE - VARBITLEN(PTR)) /* Number of bytes needed to store a bit string of a given length */ #define VARBITDATALEN(BITLEN) (BITLEN/BITSPERBYTE + \ (BITLEN%BITSPERBYTE > 0 ? 1 : 0) + \ VARHDRSZ + VARBITHDRSZ) /* pointer beyond the end of the bit string (like end() in STL containers) */ #define VARBITEND(PTR) ((bits8 *) (PTR + VARSIZE(PTR))) /* Mask that will cover exactly one byte, i.e. BITSPERBYTE bits */ #define BITMASK 0xFF #define BITHIGH 0x80 bits8 * zpbitin(char *s, int dummy, int32 atttypmod); char * zpbitout(bits8 *s); char * zpbitsout(bits8 *s); bits8 * varbitin(char *s, int dummy, int32 atttypmod); bool biteq (bits8 *arg1, bits8 *arg2); bool bitne (bits8 *arg1, bits8 *arg2); bool bitge (bits8 *arg1, bits8 *arg2); bool bitgt (bits8 *arg1, bits8 *arg2); bool bitle (bits8 *arg1, bits8 *arg2); bool bitlt (bits8 *arg1, bits8 *arg2); int bitcmp (bits8 *arg1, bits8 *arg2); bits8 * bitand (bits8 * arg1, bits8 * arg2); bits8 * bitor (bits8 * arg1, bits8 * arg2); bits8 * bitxor (bits8 * arg1, bits8 * arg2); bits8 * bitnot (bits8 * arg); bits8 * bitshiftright (bits8 * arg, int shft); bits8 * bitshiftleft (bits8 * arg, int shft); bits8 * bitcat (bits8 *arg1, bits8 *arg2); bits8 * bitsubstr (bits8 *arg, int32 s, int32 l);