aboutsummaryrefslogtreecommitdiff
path: root/src/include/utils/varbit.h
blob: e6106331b9aaa6f26dd1ef7f8087e83e2f1cc65e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
#ifndef VARBIT_H
#define VARBIT_H

#include <math.h>

#include "postgres.h"
#ifdef HAVE_LIMITS_H
#include <limits.h>
#ifndef MAXINT
#define MAXINT INT_MAX
#endif
#else
#ifdef HAVE_VALUES_H
#include <values.h>
#endif
#endif
#include "utils/builtins.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	   *zpbit_in(char *s, int dummy, int32 atttypmod);
char	   *zpbit_out(bits8 *s);
char	   *zpbits_out(bits8 *s);
bits8	   *varbit_in(char *s, int dummy, int32 atttypmod);
char	   *varbit_out(bits8 *s);
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);

bool		varbiteq(bits8 *arg1, bits8 *arg2);
bool		varbitne(bits8 *arg1, bits8 *arg2);
bool		varbitge(bits8 *arg1, bits8 *arg2);
bool		varbitgt(bits8 *arg1, bits8 *arg2);
bool		varbitle(bits8 *arg1, bits8 *arg2);
bool		varbitlt(bits8 *arg1, bits8 *arg2);
int			varbitcmp(bits8 *arg1, bits8 *arg2);
bits8	   *varbitand(bits8 *arg1, bits8 *arg2);
bits8	   *varbitor(bits8 *arg1, bits8 *arg2);
bits8	   *varbitxor(bits8 *arg1, bits8 *arg2);
bits8	   *varbitnot(bits8 *arg);
bits8	   *varbitshiftright(bits8 *arg, int shft);
bits8	   *varbitshiftleft(bits8 *arg, int shft);
bits8	   *varbitcat(bits8 *arg1, bits8 *arg2);
bits8	   *varbitsubstr(bits8 *arg, int32 s, int32 l);

#endif