libpq.h 8.9 KB
Newer Older
1 2 3
/*-------------------------------------------------------------------------
 *
 * libpq.h--
4
 *	  POSTGRES LIBPQ buffer structure definitions.
5 6 7 8
 *
 *
 * Copyright (c) 1994, Regents of the University of California
 *
9
 * $Id: libpq.h,v 1.16 1998/06/16 07:29:41 momjian Exp $
10 11 12 13 14 15
 *
 *-------------------------------------------------------------------------
 */
#ifndef LIBPQ_H
#define LIBPQ_H

16 17
#include <sys/types.h>

18 19 20 21 22 23
#include <netinet/in.h>

#include "libpq/libpq-be.h"
#include "access/htup.h"
#include "access/tupdesc.h"

24

25 26
/* ----------------
 * PQArgBlock --
27 28
 *		Information (pointer to array of this structure) required
 *		for the PQfn() call.
29 30
 * ----------------
 */
31 32
typedef struct
{
33 34
	int			len;
	int			isint;
35 36
	union
	{
37 38 39
		int		   *ptr;		/* can't use void (dec compiler barfs)	 */
		int			integer;
	}			u;
40
} PQArgBlock;
41 42 43

/* ----------------
 * TypeBlock --
44
 *		Information about an attribute.
45 46 47 48
 * ----------------
 */
#define NameLength 16

49 50
typedef struct TypeBlock
{
51 52 53
	char		name[NAMEDATALEN];		/* name of the attribute */
	int			adtid;			/* adtid of the type */
	int			adtsize;		/* adtsize of the type */
54
} TypeBlock;
55 56 57

/* ----------------
 * TupleBlock --
58
 *		Data of a tuple.
59 60 61 62
 * ----------------
 */
#define TupleBlockSize 100

63 64
typedef struct TupleBlock
{
65 66
	char	  **values[TupleBlockSize]; /* an array of tuples */
	int		   *lengths[TupleBlockSize];		/* an array of length vec.
67 68
												 * foreach tuple */
	struct TupleBlock *next;	/* next tuple block */
69
	int			tuple_index;	/* current tuple index */
70
} TupleBlock;
71 72 73

/* ----------------
 * GroupBuffer --
74
 *		A group of tuples with the same attributes.
75 76
 * ----------------
 */
77 78
typedef struct GroupBuffer
{
79 80 81 82
	int			no_tuples;		/* number of tuples in this group */
	int			no_fields;		/* number of attributes */
	TypeBlock  *types;			/* types of the attributes */
	TupleBlock *tuples;			/* tuples in this group */
83
	struct GroupBuffer *next;	/* next group */
84
} GroupBuffer;
85 86 87

/* ----------------
 * PortalBuffer --
88
 *		Data structure of a portal buffer.
89 90
 * ----------------
 */
91 92
typedef struct PortalBuffer
{
93 94 95 96
	int			rule_p;			/* 1 if this is an asynchronized portal. */
	int			no_tuples;		/* number of tuples in this portal buffer */
	int			no_groups;		/* number of tuple groups */
	GroupBuffer *groups;		/* linked list of tuple groups */
97
} PortalBuffer;
98 99 100

/* ----------------
 * PortalEntry --
101
 *		an entry in the global portal table
102 103
 *
 * Note: the portalcxt is only meaningful for PQcalls made from
104
 *		 within a postgres backend.  frontend apps should ignore it.
105 106 107 108
 * ----------------
 */
#define PortalNameLength 32

109 110
typedef struct PortalEntry
{
111 112 113 114
	char		name[PortalNameLength]; /* name of this portal */
	PortalBuffer *portal;		/* tuples contained in this portal */
	Pointer		portalcxt;		/* memory context (for backend) */
	Pointer		result;			/* result for PQexec */
115
} PortalEntry;
116 117

#define PORTALS_INITIAL_SIZE 32
118
#define PORTALS_GROW_BY		 32
119 120

/* in portalbuf.c */
121
extern PortalEntry **portals;
122
extern size_t portals_array_size;
123 124

/*
125
 *	Asynchronous notification
126
 */
127 128
typedef struct PQNotifyList
{
129 130 131 132
	char		relname[NAMEDATALEN];	/* name of relation containing
										 * data */
	int			be_pid;			/* process id of backend */
	int			valid;			/* has this already been handled by user. */
133
/*	  SLNode Node; */
134
} PQNotifyList;
135 136 137 138 139 140

/*
 * Exceptions.
 */

#define libpq_raise(X, Y) ExcRaise((Exception *)(X), (ExcDetail) (Y),\
141
								   (ExcData)0, (ExcMessage) 0)
142 143

/* in portal.c */
144
extern Exception MemoryError,
145 146 147
			PortalError,
			PostquelError,
			ProtocolError;
148

149 150
/*
 * POSTGRES backend dependent Constants.
151 152 153 154 155 156 157
 */

/* ERROR_MSG_LENGTH should really be the same as ELOG_MAXLEN in utils/elog.h*/
#define ERROR_MSG_LENGTH 4096
#define COMMAND_LENGTH 20
#define REMARK_LENGTH 80

158
extern char PQerrormsg[ERROR_MSG_LENGTH];		/* in portal.c */
159 160 161 162 163

/*
 * External functions.
 */

164 165
/*
 * prototypes for functions in portal.c
166
 */
167 168 169 170 171 172
extern void pqdebug(char *target, char *msg);
extern void pqdebug2(char *target, char *msg1, char *msg2);
extern void PQtrace(void);
extern void PQuntrace(void);
extern int	PQnportals(int rule_p);
extern void PQpnames(char **pnames, int rule_p);
173
extern PortalBuffer *PQparray(char *pname);
174 175 176 177 178 179 180 181 182
extern int	PQrulep(PortalBuffer *portal);
extern int	PQntuples(PortalBuffer *portal);
extern int	PQninstances(PortalBuffer *portal);
extern int	PQngroups(PortalBuffer *portal);
extern int	PQntuplesGroup(PortalBuffer *portal, int group_index);
extern int	PQninstancesGroup(PortalBuffer *portal, int group_index);
extern int	PQnfieldsGroup(PortalBuffer *portal, int group_index);
extern int	PQfnumberGroup(PortalBuffer *portal, int group_index, char *field_name);
extern char *PQfnameGroup(PortalBuffer *portal, int group_index, int field_number);
183 184
extern int
PQftypeGroup(PortalBuffer *portal, int group_index,
185
			 int field_number);
186 187
extern int
PQfsizeGroup(PortalBuffer *portal, int group_index,
188
			 int field_number);
189 190 191 192 193 194 195 196 197 198 199
extern GroupBuffer *PQgroup(PortalBuffer *portal, int tuple_index);
extern int	PQgetgroup(PortalBuffer *portal, int tuple_index);
extern int	PQnfields(PortalBuffer *portal, int tuple_index);
extern int	PQfnumber(PortalBuffer *portal, int tuple_index, char *field_name);
extern char *PQfname(PortalBuffer *portal, int tuple_index, int field_number);
extern int	PQftype(PortalBuffer *portal, int tuple_index, int field_number);
extern int	PQfsize(PortalBuffer *portal, int tuple_index, int field_number);
extern int	PQsametype(PortalBuffer *portal, int tuple_index1, int tuple_index2);
extern char *PQgetvalue(PortalBuffer *portal, int tuple_index, int field_number);
extern char *PQgetAttr(PortalBuffer *portal, int tuple_index, int field_number);
extern int	PQgetlength(PortalBuffer *portal, int tuple_index, int field_number);
200 201 202
extern void PQclear(char *pname);
extern void PQcleanNotify(void);
extern void PQnotifies_init(void);
203
extern PQNotifyList *PQnotifies(void);
204
extern void PQremoveNotify(PQNotifyList *nPtr);
205
extern void PQappendNotify(char *relname, int pid);
206 207 208

/*
 * prototypes for functions in portalbuf.c
209
 */
210 211
extern caddr_t pbuf_alloc(size_t size);
extern void pbuf_free(caddr_t pointer);
212
extern PortalBuffer *pbuf_addPortal(void);
213
extern GroupBuffer *pbuf_addGroup(PortalBuffer *portal);
214 215
extern TypeBlock *pbuf_addTypes(int n);
extern TupleBlock *pbuf_addTuples(void);
216 217 218
extern char **pbuf_addTuple(int n);
extern int *pbuf_addTupleValueLengths(int n);
extern char *pbuf_addValues(int n);
219
extern PortalEntry *pbuf_addEntry(void);
220
extern void pbuf_freeEntry(int i);
221 222 223 224
extern void pbuf_freeTypes(TypeBlock *types);
extern void pbuf_freeTuples(TupleBlock *tuples, int no_tuples, int no_fields);
extern void pbuf_freeGroup(GroupBuffer *group);
extern void pbuf_freePortal(PortalBuffer *portal);
225
extern int	pbuf_getIndex(char *pname);
226
extern void pbuf_setportalinfo(PortalEntry *entry, char *pname);
227
extern PortalEntry *pbuf_setup(char *pname);
228
extern void pbuf_close(char *pname);
229 230 231 232
extern GroupBuffer *pbuf_findGroup(PortalBuffer *portal, int group_index);
extern int	pbuf_findFnumber(GroupBuffer *group, char *field_name);
extern void pbuf_checkFnumber(GroupBuffer *group, int field_number);
extern char *pbuf_findFname(GroupBuffer *group, int field_number);
233

234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254
/* in be-dumpdata.c */
extern void be_portalinit(void);
extern void be_portalpush(PortalEntry *entry);
extern PortalEntry *be_portalpop(void);
extern PortalEntry *be_currentportal(void);
extern PortalEntry *be_newportal(void);
extern void
be_typeinit(PortalEntry *entry, TupleDesc attrs,
			int natts);
extern void be_printtup(HeapTuple tuple, TupleDesc typeinfo);


/* in be-pqexec.c */
extern char *
PQfn(int fnid, int *result_buf, int result_len, int result_is_int,
	 PQArgBlock *args, int nargs);
extern char *PQexec(char *query);
extern int	pqtest_PQexec(char *q);
extern int	pqtest_PQfn(char *q);
extern int32 pqtest(struct varlena * vlena);

255 256
/*
 * prototypes for functions in pqcomm.c
257
 */
258 259 260 261 262 263 264 265 266 267 268 269 270 271
extern void pq_init(int fd);
extern void pq_gettty(char *tp);
extern int	pq_getport(void);
extern void pq_close(void);
extern void pq_flush(void);
extern int	pq_getstr(char *s, int maxlen);
extern int	PQgetline(char *s, int maxlen);
extern int	PQputline(char *s);
extern int	pq_getnchar(char *s, int off, int maxlen);
extern int	pq_getint(int b);
extern void pq_putstr(char *s);
extern void pq_putnchar(char *s, int n);
extern void pq_putint(int i, int b);
extern int	pq_sendoob(char *msg, int len);
272
extern int	pq_recvoob(char *msgPtr, int len);
273 274
extern int	pq_getinaddr(struct sockaddr_in * sin, char *host, int port);
extern int	pq_getinserv(struct sockaddr_in * sin, char *host, char *serv);
275 276 277 278 279

#ifdef MB
extern void	pq_putncharlen(char *s, int n);
#endif

280 281
extern int
pq_connect(char *dbname, char *user, char *args, char *hostName,
282
		   char *debugTty, char *execFile, short portName);
283
extern int	StreamOpen(char *hostName, short portName, Port *port);
284 285 286
extern void pq_regoob(void (*fptr) ());
extern void pq_unregoob(void);
extern void pq_async_notify(void);
287 288 289
extern void StreamDoUnlink();
extern int StreamServerPort(char *hostName, short portName, int *fdP);
extern int StreamConnection(int server_fd, Port *port);
290
extern void StreamClose(int sock);
291 292

#endif							/* LIBPQ_H */