| 
									
										
										
										
											2008-02-12 18:19:55 -05:00
										 |  |  | ! Copyright (C) 2007, 2008 Doug Coleman. | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-02-03 16:06:31 -05:00
										 |  |  | ! tested on debian linux with postgresql 8.1 | 
					
						
							| 
									
										
										
										
											2009-09-27 16:11:21 -04:00
										 |  |  | USING: alien alien.c-types alien.syntax combinators system | 
					
						
							|  |  |  | alien.libraries ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | IN: db.postgresql.ffi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-12 18:19:55 -05:00
										 |  |  | << "postgresql" { | 
					
						
							| 
									
										
										
										
											2008-04-02 19:53:24 -04:00
										 |  |  |     { [ os winnt? ]  [ "libpq.dll" ] } | 
					
						
							| 
									
										
										
										
											2008-04-08 20:43:54 -04:00
										 |  |  |     { [ os macosx? ] [ "libpq.dylib" ] } | 
					
						
							| 
									
										
										
										
											2008-04-02 19:25:33 -04:00
										 |  |  |     { [ os unix?  ]  [ "libpq.so" ] } | 
					
						
							| 
									
										
										
										
											2010-03-31 22:20:35 -04:00
										 |  |  | } cond cdecl add-library >> | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! ConnSatusType | 
					
						
							| 
									
										
										
										
											2009-02-12 17:36:29 -05:00
										 |  |  | CONSTANT: CONNECTION_OK                     HEX: 0
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_BAD                    HEX: 1
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_STARTED                HEX: 2
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_MADE                   HEX: 3
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_AWAITING_RESPONSE      HEX: 4
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_AUTH_OK                HEX: 5
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_SETENV                 HEX: 6
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_SSL_STARTUP            HEX: 7
 | 
					
						
							|  |  |  | CONSTANT: CONNECTION_NEEDED                 HEX: 8
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! PostgresPollingStatusType | 
					
						
							| 
									
										
										
										
											2009-02-12 17:36:29 -05:00
										 |  |  | CONSTANT: PGRES_POLLING_FAILED              HEX: 0
 | 
					
						
							|  |  |  | CONSTANT: PGRES_POLLING_READING             HEX: 1
 | 
					
						
							|  |  |  | CONSTANT: PGRES_POLLING_WRITING             HEX: 2
 | 
					
						
							|  |  |  | CONSTANT: PGRES_POLLING_OK                  HEX: 3
 | 
					
						
							|  |  |  | CONSTANT: PGRES_POLLING_ACTIVE              HEX: 4
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! ExecStatusType; | 
					
						
							| 
									
										
										
										
											2009-02-12 17:36:29 -05:00
										 |  |  | CONSTANT: PGRES_EMPTY_QUERY                 HEX: 0
 | 
					
						
							|  |  |  | CONSTANT: PGRES_COMMAND_OK                  HEX: 1
 | 
					
						
							|  |  |  | CONSTANT: PGRES_TUPLES_OK                   HEX: 2
 | 
					
						
							|  |  |  | CONSTANT: PGRES_COPY_OUT                    HEX: 3
 | 
					
						
							|  |  |  | CONSTANT: PGRES_COPY_IN                     HEX: 4
 | 
					
						
							|  |  |  | CONSTANT: PGRES_BAD_RESPONSE                HEX: 5
 | 
					
						
							|  |  |  | CONSTANT: PGRES_NONFATAL_ERROR              HEX: 6
 | 
					
						
							|  |  |  | CONSTANT: PGRES_FATAL_ERROR                 HEX: 7
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! PGTransactionStatusType; | 
					
						
							| 
									
										
										
										
											2009-02-12 17:36:29 -05:00
										 |  |  | CONSTANT: PQTRANS_IDLE                      HEX: 0
 | 
					
						
							|  |  |  | CONSTANT: PQTRANS_ACTIVE                    HEX: 1
 | 
					
						
							|  |  |  | CONSTANT: PQTRANS_INTRANS                   HEX: 2
 | 
					
						
							|  |  |  | CONSTANT: PQTRANS_INERROR                   HEX: 3
 | 
					
						
							|  |  |  | CONSTANT: PQTRANS_UNKNOWN                   HEX: 4
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! PGVerbosity; | 
					
						
							| 
									
										
										
										
											2009-02-12 17:36:29 -05:00
										 |  |  | CONSTANT: PQERRORS_TERSE                    HEX: 0
 | 
					
						
							|  |  |  | CONSTANT: PQERRORS_DEFAULT                  HEX: 1
 | 
					
						
							|  |  |  | CONSTANT: PQERRORS_VERBOSE                  HEX: 2
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-12 17:36:29 -05:00
										 |  |  | CONSTANT: InvalidOid 0
 | 
					
						
							| 
									
										
										
										
											2008-02-13 17:51:16 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | TYPEDEF: int ConnStatusType | 
					
						
							|  |  |  | TYPEDEF: int ExecStatusType  | 
					
						
							|  |  |  | TYPEDEF: int PostgresPollingStatusType | 
					
						
							|  |  |  | TYPEDEF: int PGTransactionStatusType  | 
					
						
							|  |  |  | TYPEDEF: int PGVerbosity  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 23:21:24 -04:00
										 |  |  | C-TYPE: PGconn | 
					
						
							|  |  |  | C-TYPE: PGresult | 
					
						
							|  |  |  | C-TYPE: PGcancel | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | TYPEDEF: uint Oid | 
					
						
							|  |  |  | TYPEDEF: char pqbool | 
					
						
							| 
									
										
										
										
											2009-09-27 23:21:24 -04:00
										 |  |  | C-TYPE: PQconninfoOption | 
					
						
							|  |  |  | C-TYPE: PGnotify | 
					
						
							|  |  |  | C-TYPE: PQArgBlock | 
					
						
							|  |  |  | C-TYPE: PQprintOpt | 
					
						
							|  |  |  | C-TYPE: SSL | 
					
						
							|  |  |  | C-TYPE: FILE | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | LIBRARY: postgresql | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Exported functions of libpq | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! make a new client connection to the backend | 
					
						
							|  |  |  | ! Asynchronous (non-blocking) | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: PGconn* PQconnectStart ( c-string conninfo ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: PostgresPollingStatusType PQconnectPoll ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Synchronous (blocking) | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: PGconn* PQconnectdb ( c-string conninfo ) ;
 | 
					
						
							|  |  |  | FUNCTION: PGconn* PQsetdbLogin ( c-string pghost, c-string pgport, | 
					
						
							|  |  |  |              c-string pgoptions, c-string pgtty, | 
					
						
							|  |  |  |              c-string dbName, | 
					
						
							|  |  |  |              c-string login, c-string pwd ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : PQsetdb ( M_PGHOST M_PGPORT M_PGOPT M_PGTTY M_DBNAME -- PGconn* )
 | 
					
						
							|  |  |  |     f f PQsetdbLogin ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! close the current connection and free the PGconn data structure | 
					
						
							|  |  |  | FUNCTION: void PQfinish ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! get info about connection options known to PQconnectdb | 
					
						
							|  |  |  | FUNCTION: PQconninfoOption* PQconndefaults ( ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! free the data structure returned by PQconndefaults() | 
					
						
							|  |  |  | FUNCTION: void PQconninfoFree ( PQconninfoOption* connOptions ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Asynchronous (non-blocking) | 
					
						
							|  |  |  | FUNCTION: int    PQresetStart ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: PostgresPollingStatusType PQresetPoll ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Synchronous (blocking) | 
					
						
							|  |  |  | FUNCTION: void PQreset ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! request a cancel structure | 
					
						
							|  |  |  | FUNCTION: PGcancel* PQgetCancel ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! free a cancel structure | 
					
						
							|  |  |  | FUNCTION: void PQfreeCancel ( PGcancel* cancel ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! issue a cancel request | 
					
						
							|  |  |  | FUNCTION: int    PQrequestCancel ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Accessor functions for PGconn objects | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQdb ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQuser ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQpass ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQhost ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQport ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQtty ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQoptions ( PGconn* conn ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: ConnStatusType PQstatus ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: PGTransactionStatusType PQtransactionStatus ( PGconn* conn ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQparameterStatus ( PGconn* conn, | 
					
						
							|  |  |  |                   c-string paramName ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: int PQprotocolVersion ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | ! FUNCTION: int PQServerVersion ( PGconn* conn ) ; | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQerrorMessage ( PGconn* conn ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: int PQsocket ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: int PQbackendPID ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: int PQclientEncoding ( PGconn* conn ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: int PQsetClientEncoding ( PGconn* conn, c-string encoding ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! May not be compiled into libpq | 
					
						
							|  |  |  | ! Get the SSL structure associated with a connection | 
					
						
							|  |  |  | FUNCTION: SSL* PQgetssl ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Tell libpq whether it needs to initialize OpenSSL | 
					
						
							|  |  |  | FUNCTION: void PQinitSSL ( int do_init ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Set verbosity for PQerrorMessage and PQresultErrorMessage | 
					
						
							|  |  |  | FUNCTION: PGVerbosity PQsetErrorVerbosity ( PGconn* conn, | 
					
						
							|  |  |  |     PGVerbosity verbosity ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Enable/disable tracing | 
					
						
							|  |  |  | FUNCTION: void PQtrace ( PGconn* conn, FILE* debug_port ) ;
 | 
					
						
							|  |  |  | FUNCTION: void PQuntrace ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! BROKEN | 
					
						
							|  |  |  | ! Function types for notice-handling callbacks | 
					
						
							|  |  |  | ! typedef void (*PQnoticeReceiver) (void *arg, PGresult *res); | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | ! typedef void (*PQnoticeProcessor) (void *arg, c-string message); | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | ! ALIAS: void* PQnoticeReceiver | 
					
						
							|  |  |  | ! ALIAS: void* PQnoticeProcessor | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Override default notice handling routines | 
					
						
							|  |  |  | ! FUNCTION: PQnoticeReceiver PQsetNoticeReceiver ( PGconn* conn, | 
					
						
							|  |  |  |                     ! PQnoticeReceiver proc, | 
					
						
							|  |  |  |                     ! void* arg ) ; | 
					
						
							|  |  |  | ! FUNCTION: PQnoticeProcessor PQsetNoticeProcessor ( PGconn* conn, | 
					
						
							|  |  |  |                     ! PQnoticeProcessor proc, | 
					
						
							|  |  |  |                     ! void* arg ) ; | 
					
						
							|  |  |  | ! END BROKEN | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! === in fe-exec.c === | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Simple synchronous query | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: PGresult* PQexec ( PGconn* conn, c-string query ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: PGresult* PQexecParams ( PGconn* conn, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |              c-string command, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |              int nParams, | 
					
						
							|  |  |  |              Oid* paramTypes, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |              c-string* paramValues, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |              int* paramLengths, | 
					
						
							|  |  |  |              int* paramFormats, | 
					
						
							|  |  |  |              int resultFormat ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: PGresult* PQprepare ( PGconn* conn, c-string stmtName, | 
					
						
							|  |  |  |         c-string query, int nParams, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |         Oid* paramTypes ) ;
 | 
					
						
							|  |  |  | FUNCTION: PGresult* PQexecPrepared ( PGconn* conn, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |              c-string stmtName, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |              int nParams, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |              c-string* paramValues, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |              int* paramLengths, | 
					
						
							|  |  |  |              int* paramFormats, | 
					
						
							|  |  |  |              int resultFormat ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Interface for multiple-result or asynchronous queries | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: int PQsendQuery ( PGconn* conn, c-string query ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: int PQsendQueryParams ( PGconn* conn, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |                   c-string command, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |                   int nParams, | 
					
						
							|  |  |  |                   Oid* paramTypes, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |                   c-string* paramValues, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |                   int* paramLengths, | 
					
						
							|  |  |  |                   int* paramFormats, | 
					
						
							|  |  |  |                   int resultFormat ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: PGresult* PQsendPrepare ( PGconn* conn, c-string stmtName, | 
					
						
							|  |  |  |             c-string query, int nParams, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |             Oid* paramTypes ) ;
 | 
					
						
							|  |  |  | FUNCTION: int PQsendQueryPrepared ( PGconn* conn, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |                   c-string stmtName, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |                   int nParams, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |                   c-string* paramValues, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |                   int *paramLengths, | 
					
						
							|  |  |  |                   int *paramFormats, | 
					
						
							|  |  |  |                   int resultFormat ) ;
 | 
					
						
							|  |  |  | FUNCTION: PGresult* PQgetResult ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Routines for managing an asynchronous query | 
					
						
							|  |  |  | FUNCTION: int    PQisBusy ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    PQconsumeInput ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! LISTEN/NOTIFY support | 
					
						
							|  |  |  | FUNCTION: PGnotify* PQnotifies ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Routines for copy in/out | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: int    PQputCopyData ( PGconn* conn, c-string buffer, int nbytes ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    PQputCopyEnd ( PGconn* conn, c-string errormsg ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    PQgetCopyData ( PGconn* conn, c-string* buffer, int async ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Deprecated routines for copy in/out | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: int    PQgetline ( PGconn* conn, c-string string, int length ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    PQputline ( PGconn* conn, c-string string ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    PQgetlineAsync ( PGconn* conn, c-string buffer, int bufsize ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    PQputnbytes ( PGconn* conn, c-string buffer, int nbytes ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: int    PQendcopy ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Set blocking/nonblocking connection to the backend | 
					
						
							|  |  |  | FUNCTION: int    PQsetnonblocking ( PGconn* conn, int arg ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    PQisnonblocking ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Force the write buffer to be written (or at least try) | 
					
						
							|  |  |  | FUNCTION: int    PQflush ( PGconn* conn ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! 
 | 
					
						
							|  |  |  | ! * "Fast path" interface --- not really recommended for application | 
					
						
							|  |  |  | ! * use | 
					
						
							|  |  |  | !
 | 
					
						
							|  |  |  | FUNCTION: PGresult* PQfn ( PGconn* conn, | 
					
						
							|  |  |  |      int fnid, | 
					
						
							|  |  |  |      int* result_buf, | 
					
						
							|  |  |  |      int* result_len, | 
					
						
							|  |  |  |      int result_is_int, | 
					
						
							|  |  |  |      PQArgBlock* args, | 
					
						
							|  |  |  |      int nargs ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Accessor functions for PGresult objects | 
					
						
							|  |  |  | FUNCTION: ExecStatusType PQresultStatus ( PGresult* res ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQresStatus ( ExecStatusType status ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQresultErrorMessage ( PGresult* res ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQresultErrorField ( PGresult* res, int fieldcode ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: int   PQntuples ( PGresult* res ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQnfields ( PGresult* res ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQbinaryTuples ( PGresult* res ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQfname ( PGresult* res, int field_num ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQfnumber ( PGresult* res, c-string field_name ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: Oid   PQftable ( PGresult* res, int field_num ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQftablecol ( PGresult* res, int field_num ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQfformat ( PGresult* res, int field_num ) ;
 | 
					
						
							|  |  |  | FUNCTION: Oid   PQftype ( PGresult* res, int field_num ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQfsize ( PGresult* res, int field_num ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQfmod ( PGresult* res, int field_num ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQcmdStatus ( PGresult* res ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQoidStatus ( PGresult* res ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: Oid   PQoidValue ( PGresult* res ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQcmdTuples ( PGresult* res ) ;
 | 
					
						
							|  |  |  | ! FUNCTION: c-string PQgetvalue ( PGresult* res, int tup_num, int field_num ) ; | 
					
						
							| 
									
										
										
										
											2008-03-10 18:00:28 -04:00
										 |  |  | FUNCTION: void* PQgetvalue ( PGresult* res, int tup_num, int field_num ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: int   PQgetlength ( PGresult* res, int tup_num, int field_num ) ;
 | 
					
						
							|  |  |  | FUNCTION: int   PQgetisnull ( PGresult* res, int tup_num, int field_num ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Delete a PGresult | 
					
						
							|  |  |  | FUNCTION: void PQclear ( PGresult* res ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! For freeing other alloc'd results, such as PGnotify structs | 
					
						
							|  |  |  | FUNCTION: void PQfreemem ( void* ptr ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Exists for backward compatibility. | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : PQfreeNotify ( ptr -- ) PQfreemem ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | !
 | 
					
						
							|  |  |  | ! Make an empty PGresult with given status (some apps find this | 
					
						
							|  |  |  | ! useful). If conn is not NULL and status indicates an error, the | 
					
						
							|  |  |  | ! conn's errorMessage is copied. | 
					
						
							|  |  |  | !
 | 
					
						
							|  |  |  | FUNCTION: PGresult* PQmakeEmptyPGresult ( PGconn* conn, ExecStatusType status ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Quoting strings before inclusion in queries. | 
					
						
							|  |  |  | FUNCTION: size_t PQescapeStringConn ( PGconn* conn, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |                                     c-string to, c-string from, size_t length, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |                                     int* error ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string PQescapeByteaConn ( PGconn* conn, | 
					
						
							|  |  |  |                                     c-string from, size_t length, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |                                     size_t* to_length ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: void* PQunescapeBytea ( c-string strtext, size_t* retbuflen ) ;
 | 
					
						
							|  |  |  | ! FUNCTION: c-string PQunescapeBytea ( c-string strtext, size_t* retbuflen ) ; | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | ! These forms are deprecated! | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: size_t PQescapeString ( void* to, c-string from, size_t length ) ;
 | 
					
						
							|  |  |  | FUNCTION: c-string PQescapeBytea ( c-string bintext, size_t binlen, | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  |               size_t* bytealen ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! === in fe-print.c === | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | FUNCTION: void PQprint ( FILE* fout, PGresult* res, PQprintOpt* ps ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! really old printing routines | 
					
						
							|  |  |  | FUNCTION: void PQdisplayTuples ( PGresult* res, | 
					
						
							| 
									
										
										
										
											2008-02-02 01:29:47 -05:00
										 |  |  |                                 FILE* fp,                | 
					
						
							|  |  |  |                                 int fillAlign, | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  |                                 c-string fieldSep, | 
					
						
							| 
									
										
										
										
											2008-02-02 01:29:47 -05:00
										 |  |  |                                 int printHeader, | 
					
						
							|  |  |  |                                 int quiet ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | FUNCTION: void PQprintTuples ( PGresult* res, | 
					
						
							| 
									
										
										
										
											2008-02-02 01:29:47 -05:00
										 |  |  |                           FILE* fout,            | 
					
						
							|  |  |  |                           int printAttName, | 
					
						
							|  |  |  |                           int terseOutput,       | 
					
						
							|  |  |  |                           int width ) ;  | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | ! === in fe-lobj.c === | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Large-object access routines | 
					
						
							|  |  |  | FUNCTION: int    lo_open ( PGconn* conn, Oid lobjId, int mode ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    lo_close ( PGconn* conn, int fd ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: int    lo_read ( PGconn* conn, int fd, c-string buf, size_t len ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    lo_write ( PGconn* conn, int fd, c-string buf, size_t len ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | FUNCTION: int    lo_lseek ( PGconn* conn, int fd, int offset, int whence ) ;
 | 
					
						
							|  |  |  | FUNCTION: Oid    lo_creat ( PGconn* conn, int mode ) ;
 | 
					
						
							|  |  |  | ! FUNCTION: Oid    lo_creat ( PGconn* conn, Oid lobjId ) ; | 
					
						
							|  |  |  | FUNCTION: int    lo_tell ( PGconn* conn, int fd ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    lo_unlink ( PGconn* conn, Oid lobjId ) ;
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: Oid    lo_import ( PGconn* conn, c-string filename ) ;
 | 
					
						
							|  |  |  | FUNCTION: int    lo_export ( PGconn* conn, Oid lobjId, c-string filename ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! === in fe-misc.c === | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Determine length of multibyte encoded char at *s | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: int    PQmblen ( c-string s, int encoding ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Determine display length of multibyte encoded char at *s | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: int    PQdsplen ( c-string s, int encoding ) ;
 | 
					
						
							| 
									
										
										
										
											2008-02-01 18:43:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Get encoding id from environment variable PGCLIENTENCODING | 
					
						
							|  |  |  | FUNCTION: int    PQenv2encoding ( ) ;
 | 
					
						
							| 
									
										
										
										
											2008-03-11 01:05:22 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! From git, include/catalog/pg_type.h | 
					
						
							| 
									
										
										
										
											2009-02-12 17:36:29 -05:00
										 |  |  | CONSTANT: BOOL-OID 16
 | 
					
						
							|  |  |  | CONSTANT: BYTEA-OID 17
 | 
					
						
							|  |  |  | CONSTANT: CHAR-OID 18
 | 
					
						
							|  |  |  | CONSTANT: NAME-OID 19
 | 
					
						
							|  |  |  | CONSTANT: INT8-OID 20
 | 
					
						
							|  |  |  | CONSTANT: INT2-OID 21
 | 
					
						
							|  |  |  | CONSTANT: INT4-OID 23
 | 
					
						
							|  |  |  | CONSTANT: TEXT-OID 23
 | 
					
						
							|  |  |  | CONSTANT: OID-OID 26
 | 
					
						
							|  |  |  | CONSTANT: FLOAT4-OID 700
 | 
					
						
							|  |  |  | CONSTANT: FLOAT8-OID 701
 | 
					
						
							|  |  |  | CONSTANT: VARCHAR-OID 1043
 | 
					
						
							|  |  |  | CONSTANT: DATE-OID 1082
 | 
					
						
							|  |  |  | CONSTANT: TIME-OID 1083
 | 
					
						
							|  |  |  | CONSTANT: TIMESTAMP-OID 1114
 | 
					
						
							|  |  |  | CONSTANT: TIMESTAMPTZ-OID 1184
 | 
					
						
							|  |  |  | CONSTANT: INTERVAL-OID 1186
 | 
					
						
							|  |  |  | CONSTANT: NUMERIC-OID 1700
 |