39 "PGRES_NONFATAL_ERROR",
43 "PGRES_PIPELINE_SYNC",
44 "PGRES_PIPELINE_ABORTED",
52 .errMsg =
"out of memory\n",
65 const char **errmsgp);
72 const Oid *paramTypes,
73 const char *
const *paramValues,
74 const int *paramLengths,
75 const int *paramFormats,
142#define PGRESULT_DATA_BLOCKSIZE 2048
143#define PGRESULT_ALIGN_BOUNDARY MAXIMUM_ALIGNOF
144#define PGRESULT_BLOCK_OVERHEAD Max(sizeof(PGresult_data), PGRESULT_ALIGN_BOUNDARY)
145#define PGRESULT_SEP_ALLOC_THRESHOLD (PGRESULT_DATA_BLOCKSIZE / 2)
262 if (numAttributes <= 0 || !attDescs)
350 for (tup = 0; tup < src->
ntups; tup++)
383 for (
i = 0;
i <
dest->nEvents;
i++)
393 dest->events[
i].passThrough))
394 dest->events[
i].resultInitialized =
true;
414 if (!events || count <= 0)
417 msize = count *
sizeof(
PGEvent);
422 for (
i = 0;
i < count;
i++)
426 newEvents[
i].
data = NULL;
429 if (!newEvents[
i].
name)
436 msize += strlen(events[
i].
name) + 1;
455 const char *
errmsg = NULL;
466 if (tup_num < 0 || tup_num > res->
ntups)
469 "row number %d is out of range 0..%d",
470 tup_num, res->
ntups);
475 if (tup_num == res->
ntups)
499 attval = &res->
tuples[tup_num][field_num];
751 while ((block = res->
curBlock) != NULL)
951 msgBuf[
sizeof(msgBuf) - 1] =
'\0';
1021 *errmsgp =
libpq_gettext(
"PGresult cannot support more than INT_MAX tuples");
1030#if INT_MAX >= (SIZE_MAX / 2)
1071 pfield->
code = code;
1095 prev = pstatus, pstatus = pstatus->
next)
1097 if (strcmp(pstatus->
name,
name) == 0)
1118 pstatus->
name = ptr;
1120 ptr += strlen(
name) + 1;
1121 pstatus->
value = ptr;
1139 if (strcmp(
name,
"client_encoding") == 0)
1147 else if (strcmp(
name,
"standard_conforming_strings") == 0)
1152 else if (strcmp(
name,
"server_version") == 0)
1160 cnt = sscanf(
value,
"%d.%d.%d", &vmaj, &vmin, &vrev);
1188 else if (strcmp(
name,
"default_transaction_read_only") == 0)
1193 else if (strcmp(
name,
"in_hot_standby") == 0)
1198 else if (strcmp(
name,
"scram_iterations") == 0)
1262 for (
i = 0;
i < nfields;
i++)
1264 int clen = columns[
i].
len;
1336 entry->
query = NULL;
1408 entry->
query = NULL;
1478 entry->
query = strdup(query);
1504 const char *command,
1506 const Oid *paramTypes,
1507 const char *
const *paramValues,
1508 const int *paramLengths,
1509 const int *paramFormats,
1548 const char *stmtName,
const char *query,
1549 int nParams,
const Oid *paramTypes)
1584 if (nParams > 0 && paramTypes)
1590 for (
i = 0;
i < nParams;
i++)
1617 entry->
query = strdup(query);
1645 const char *stmtName,
1647 const char *
const *paramValues,
1648 const int *paramLengths,
1649 const int *paramFormats,
1769 const char *command,
1770 const char *stmtName,
1772 const Oid *paramTypes,
1773 const char *
const *paramValues,
1774 const int *paramLengths,
1775 const int *paramFormats,
1798 if (nParams > 0 && paramTypes)
1802 for (
i = 0;
i < nParams;
i++)
1824 if (nParams > 0 && paramFormats)
1828 for (
i = 0;
i < nParams;
i++)
1844 for (
i = 0;
i < nParams;
i++)
1846 if (paramValues && paramValues[
i])
1850 if (paramFormats && paramFormats[
i] != 0)
1854 nbytes = paramLengths[
i];
1864 nbytes = strlen(paramValues[
i]);
1911 entry->
query = strdup(command);
2288 const char *command,
2290 const Oid *paramTypes,
2291 const char *
const *paramValues,
2292 const int *paramLengths,
2293 const int *paramFormats,
2299 nParams, paramTypes, paramValues, paramLengths,
2300 paramFormats, resultFormat))
2318 const char *stmtName,
const char *query,
2319 int nParams,
const Oid *paramTypes)
2335 const char *stmtName,
2337 const char *
const *paramValues,
2338 const int *paramLengths,
2339 const int *paramFormats,
2345 nParams, paramValues, paramLengths,
2346 paramFormats, resultFormat))
2441 lastResult = result;
2867 if (!buffer || length <= 0)
3026 result_buf, result_len,
3182 prevquery->
next = NULL;
3325 "internal error: cannot send pipeline while in COPY\n");
3341 entry->
query = NULL;
3354 if (immediate_flush)
3440 if (!res || !res->
errMsg)
3460 return strdup(
libpq_gettext(
"PGresult is not an error result\n"));
3473 return workBuf.
data;
3483 for (pfield = res->
errFields; pfield != NULL; pfield = pfield->
next)
3485 if (pfield->
code == fieldcode)
3528 "column number %d is out of range 0..%d",
3537 int tup_num,
int field_num)
3541 if (tup_num < 0 || tup_num >= res->
ntups)
3544 "row number %d is out of range 0..%d",
3545 tup_num, res->
ntups - 1);
3551 "column number %d is out of range 0..%d",
3566 "parameter number %d is out of range 0..%d",
3604 bool all_lower =
true;
3616 if (field_name == NULL ||
3617 field_name[0] ==
'\0' ||
3625 for (iptr = field_name; *iptr; iptr++)
3648 field_case = strdup(field_name);
3649 if (field_case == NULL)
3654 for (iptr = field_case; *iptr; iptr++)
3782 static char buf[24];
3786 if (!res || strncmp(res->
cmdStatus,
"INSERT ", 7) != 0)
3790 if (
len >
sizeof(
buf) - 1)
3806 char *endptr = NULL;
3807 unsigned long result;
3810 strncmp(res->
cmdStatus,
"INSERT ", 7) != 0 ||
3815 result = strtoul(res->
cmdStatus + 7, &endptr, 10);
3817 if (!endptr || (*endptr !=
' ' && *endptr !=
'\0'))
3820 return (
Oid) result;
3841 if (strncmp(res->
cmdStatus,
"INSERT ", 7) == 0)
3845 while (*p && *p !=
' ')
3848 goto interpret_error;
3851 else if (strncmp(res->
cmdStatus,
"SELECT ", 7) == 0 ||
3852 strncmp(res->
cmdStatus,
"DELETE ", 7) == 0 ||
3853 strncmp(res->
cmdStatus,
"UPDATE ", 7) == 0)
3855 else if (strncmp(res->
cmdStatus,
"FETCH ", 6) == 0 ||
3856 strncmp(res->
cmdStatus,
"MERGE ", 6) == 0)
3858 else if (strncmp(res->
cmdStatus,
"MOVE ", 5) == 0 ||
3859 strncmp(res->
cmdStatus,
"COPY ", 5) == 0)
3865 for (
c = p; *
c;
c++)
3867 if (!isdigit((
unsigned char) *
c))
3868 goto interpret_error;
3871 goto interpret_error;
3877 "could not interpret result from server: %s",
3903 return res->
tuples[tup_num][field_num].
len;
4083 char *to,
const char *from,
size_t length,
4087 const char *
source = from;
4090 bool already_complained =
false;
4149 if (
conn && !already_complained)
4156 already_complained =
true;
4173 for (
i = 0;
i < charlen;
i++)
4189 char *to,
const char *from,
size_t length,
4231 int num_backslashes = 0;
4234 char quote_char = as_ident ?
'"' :
'\'';
4235 bool validated_mb =
false;
4251 if (*s == quote_char)
4253 else if (*s ==
'\\')
4288 validated_mb =
true;
4298 result_size = input_len + num_quotes + 3;
4299 if (!as_ident && num_backslashes > 0)
4300 result_size += num_backslashes + 2;
4301 result = rp = (
char *)
malloc(result_size);
4315 if (!as_ident && num_backslashes > 0)
4335 if (num_quotes == 0 && (num_backslashes == 0 || as_ident))
4337 memcpy(rp,
str, input_len);
4345 if (*s == quote_char || (!as_ident && *s ==
'\\'))
4388static const char hextbl[] =
"0123456789abcdef";
4391 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4392 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4393 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4394 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, -1, -1, -1, -1, -1, -1,
4395 -1, 10, 11, 12, 13, 14, 15, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4396 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4397 -1, 10, 11, 12, 13, 14, 15, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4398 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4406 if (
c > 0 &&
c < 127)
4428static unsigned char *
4430 const unsigned char *from,
size_t from_length,
4431 size_t *to_length,
bool std_strings,
bool use_hex)
4433 const unsigned char *vp;
4435 unsigned char *result;
4438 size_t bslash_len = (std_strings ? 1 : 2);
4447 len += bslash_len + 1 + 2 * from_length;
4452 for (
i = from_length;
i > 0;
i--, vp++)
4454 if (*vp < 0x20 || *vp > 0x7e)
4455 len += bslash_len + 3;
4456 else if (*vp ==
'\'')
4458 else if (*vp ==
'\\')
4459 len += bslash_len + bslash_len;
4466 rp = result = (
unsigned char *)
malloc(
len);
4483 for (
i = from_length;
i > 0;
i--, vp++)
4485 unsigned char c = *vp;
4489 *rp++ =
hextbl[(
c >> 4) & 0xF];
4497 *rp++ = (
c >> 6) +
'0';
4498 *rp++ = ((
c >> 3) & 07) +
'0';
4499 *rp++ = (
c & 07) +
'0';
4526 const unsigned char *from,
size_t from_length,
4549#define ISFIRSTOCTDIGIT(CH) ((CH) >= '0' && (CH) <= '3')
4550#define ISOCTDIGIT(CH) ((CH) >= '0' && (CH) <= '7')
4551#define OCTVAL(CH) ((CH) - '0')
4570 unsigned char *buffer,
4575 if (strtext == NULL)
4578 strtextlen = strlen((
const char *) strtext);
4580 if (strtext[0] ==
'\\' && strtext[1] ==
'x')
4582 const unsigned char *s;
4585 buflen = (strtextlen - 2) / 2;
4587 buffer = (
unsigned char *)
malloc(buflen > 0 ? buflen : 1);
4603 if (!*s || v1 == (
char) -1)
4606 if (v2 != (
char) -1)
4607 *p++ = (v1 << 4) | v2;
4610 buflen = p - buffer;
4618 buffer = (
unsigned char *)
malloc(strtextlen + 1);
4622 for (
i =
j = 0;
i < strtextlen;)
4628 if (strtext[
i] ==
'\\')
4629 buffer[
j++] = strtext[
i++];
4639 byte = (
byte << 3) +
OCTVAL(strtext[
i++]);
4640 byte = (
byte << 3) +
OCTVAL(strtext[
i++]);
4655 buffer[
j++] = strtext[
i++];
4673 *retbuflen = buflen;
#define unconstify(underlying_type, expr)
#define IS_HIGHBIT_SET(ch)
#define SQL_STR_DOUBLE(ch, escape_backslash)
int errmsg(const char *fmt,...)
static int PQsendQueryInternal(PGconn *conn, const char *query, bool newQuery)
int PQsendQueryParams(PGconn *conn, const char *command, int nParams, const Oid *paramTypes, const char *const *paramValues, const int *paramLengths, const int *paramFormats, int resultFormat)
int PQsendQueryContinue(PGconn *conn, const char *query)
int PQgetlength(const PGresult *res, int tup_num, int field_num)
int PQsetSingleRowMode(PGconn *conn)
static char get_hex(char c)
int PQbinaryTuples(const PGresult *res)
int PQflush(PGconn *conn)
PGresult * PQcopyResult(const PGresult *src, int flags)
void PQfreemem(void *ptr)
static unsigned char * PQescapeByteaInternal(PGconn *conn, const unsigned char *from, size_t from_length, size_t *to_length, bool std_strings, bool use_hex)
int PQgetline(PGconn *conn, char *buffer, int length)
void * pqResultAlloc(PGresult *res, size_t nBytes, bool isBinary)
static bool canChangeResultMode(PGconn *conn)
static size_t PQescapeStringInternal(PGconn *conn, char *to, const char *from, size_t length, int *error, int encoding, bool std_strings)
Oid PQftype(const PGresult *res, int field_num)
char * PQresultVerboseErrorMessage(const PGresult *res, PGVerbosity verbosity, PGContextVisibility show_context)
PGresult * PQdescribePrepared(PGconn *conn, const char *stmt)
PGresult * PQexecParams(PGconn *conn, const char *command, int nParams, const Oid *paramTypes, const char *const *paramValues, const int *paramLengths, const int *paramFormats, int resultFormat)
int PQexitPipelineMode(PGconn *conn)
PGresult * PQexecPrepared(PGconn *conn, const char *stmtName, int nParams, const char *const *paramValues, const int *paramLengths, const int *paramFormats, int resultFormat)
int PQsendClosePortal(PGconn *conn, const char *portal)
static PGcmdQueueEntry * pqAllocCmdQueueEntry(PGconn *conn)
int PQsetResultAttrs(PGresult *res, int numAttributes, PGresAttDesc *attDescs)
unsigned char * PQunescapeBytea(const unsigned char *strtext, size_t *retbuflen)
void pqSaveMessageField(PGresult *res, char code, const char *value)
static int check_tuple_field_number(const PGresult *res, int tup_num, int field_num)
PGresult * pqPrepareAsyncResult(PGconn *conn)
static void pqSaveWriteError(PGconn *conn)
int PQenterPipelineMode(PGconn *conn)
void pqCommandQueueAdvance(PGconn *conn, bool isReadyForQuery, bool gotSync)
void pqSetResultError(PGresult *res, PQExpBuffer errorMessage, int offset)
size_t PQescapeStringConn(PGconn *conn, char *to, const char *from, size_t length, int *error)
void pqSaveErrorResult(PGconn *conn)
PGresult * PQclosePrepared(PGconn *conn, const char *stmt)
char *const pgresStatus[]
char * PQgetvalue(const PGresult *res, int tup_num, int field_num)
#define PGRESULT_DATA_BLOCKSIZE
PGresult * PQclosePortal(PGconn *conn, const char *portal)
static int pqPipelineSyncInternal(PGconn *conn, bool immediate_flush)
PGresult * PQgetResult(PGconn *conn)
ExecStatusType PQresultStatus(const PGresult *res)
Oid PQparamtype(const PGresult *res, int param_num)
static int check_param_number(const PGresult *res, int param_num)
int pqRowProcessor(PGconn *conn, const char **errmsgp)
int PQnparams(const PGresult *res)
void PQclear(PGresult *res)
int PQsendClosePrepared(PGconn *conn, const char *stmt)
char * PQcmdTuples(PGresult *res)
static PGresult * PQexecFinish(PGconn *conn)
int PQfformat(const PGresult *res, int field_num)
static void pqAppendCmdQueueEntry(PGconn *conn, PGcmdQueueEntry *entry)
static int PQsendQueryGuts(PGconn *conn, const char *command, const char *stmtName, int nParams, const Oid *paramTypes, const char *const *paramValues, const int *paramLengths, const int *paramFormats, int resultFormat)
int PQendcopy(PGconn *conn)
static int pqPipelineFlush(PGconn *conn)
int PQputCopyEnd(PGconn *conn, const char *errormsg)
static int PQsendTypedCommand(PGconn *conn, char command, char type, const char *target)
int PQsendPipelineSync(PGconn *conn)
int PQntuples(const PGresult *res)
int PQputnbytes(PGconn *conn, const char *buffer, int nbytes)
int PQputline(PGconn *conn, const char *string)
int PQgetlineAsync(PGconn *conn, char *buffer, int bufsize)
static const PGresult OOM_result
#define PGRESULT_BLOCK_OVERHEAD
int PQputCopyData(PGconn *conn, const char *buffer, int nbytes)
static PGresult * getCopyResult(PGconn *conn, ExecStatusType copytype)
PGresult * PQmakeEmptyPGresult(PGconn *conn, ExecStatusType status)
static PGEvent * dupEvents(PGEvent *events, int count, size_t *memSize)
PGresult * PQprepare(PGconn *conn, const char *stmtName, const char *query, int nParams, const Oid *paramTypes)
static bool static_std_strings
char * PQresultErrorMessage(const PGresult *res)
void pqInternalNotice(const PGNoticeHooks *hooks, const char *fmt,...)
int PQsendDescribePrepared(PGconn *conn, const char *stmt)
char * PQfname(const PGresult *res, int field_num)
static const char hextbl[]
static bool PQexecStart(PGconn *conn)
size_t PQescapeString(char *to, const char *from, size_t length)
int PQconsumeInput(PGconn *conn)
static char * PQescapeInternal(PGconn *conn, const char *str, size_t len, bool as_ident)
#define ISFIRSTOCTDIGIT(CH)
static void parseInput(PGconn *conn)
Oid PQftable(const PGresult *res, int field_num)
int PQfnumber(const PGresult *res, const char *field_name)
unsigned char * PQescapeBytea(const unsigned char *from, size_t from_length, size_t *to_length)
int PQsetnonblocking(PGconn *conn, int arg)
char * PQescapeLiteral(PGconn *conn, const char *str, size_t len)
PGresult * PQfn(PGconn *conn, int fnid, int *result_buf, int *result_len, int result_is_int, const PQArgBlock *args, int nargs)
int PQsendPrepare(PGconn *conn, const char *stmtName, const char *query, int nParams, const Oid *paramTypes)
#define PGRESULT_SEP_ALLOC_THRESHOLD
PGresult * PQdescribePortal(PGconn *conn, const char *portal)
int PQfmod(const PGresult *res, int field_num)
void pqClearAsyncResult(PGconn *conn)
int PQgetisnull(const PGresult *res, int tup_num, int field_num)
int PQftablecol(const PGresult *res, int field_num)
int PQsetChunkedRowsMode(PGconn *conn, int chunkSize)
static int static_client_encoding
char * PQresultErrorField(const PGresult *res, int fieldcode)
int PQsetvalue(PGresult *res, int tup_num, int field_num, char *value, int len)
int PQsendQuery(PGconn *conn, const char *query)
char * PQcmdStatus(PGresult *res)
int PQpipelineSync(PGconn *conn)
char * PQoidStatus(const PGresult *res)
int PQsendDescribePortal(PGconn *conn, const char *portal)
char * PQresStatus(ExecStatusType status)
size_t PQresultMemorySize(const PGresult *res)
void * PQresultAlloc(PGresult *res, size_t nBytes)
int PQisBusy(PGconn *conn)
PGresult * PQexec(PGconn *conn, const char *query)
unsigned char * PQescapeByteaConn(PGconn *conn, const unsigned char *from, size_t from_length, size_t *to_length)
int PQsendQueryPrepared(PGconn *conn, const char *stmtName, int nParams, const char *const *paramValues, const int *paramLengths, const int *paramFormats, int resultFormat)
static void pqPipelineProcessQueue(PGconn *conn)
char * PQescapeIdentifier(PGconn *conn, const char *str, size_t len)
int PQsendFlushRequest(PGconn *conn)
int pqSaveParameterStatus(PGconn *conn, const char *name, const char *value)
int PQisnonblocking(const PGconn *conn)
char * pqResultStrdup(PGresult *res, const char *str)
Oid PQoidValue(const PGresult *res)
static bool pqAddTuple(PGresult *res, PGresAttValue *tup, const char **errmsgp)
#define PGRESULT_ALIGN_BOUNDARY
int PQnfields(const PGresult *res)
static int check_field_number(const PGresult *res, int field_num)
int PQfsize(const PGresult *res, int field_num)
PGnotify * PQnotifies(PGconn *conn)
static bool PQsendQueryStart(PGconn *conn, bool newQuery)
static const int8 hexlookup[128]
int PQgetCopyData(PGconn *conn, char **buffer, int async)
static void pqRecycleCmdQueueEntry(PGconn *conn, PGcmdQueueEntry *entry)
void PQfreeNotify(PGnotify *notify)
int pqPutc(char c, PGconn *conn)
int pqReadData(PGconn *conn)
int pqPutInt(int value, size_t bytes, PGconn *conn)
int pqCheckOutBufferSpace(size_t bytes_needed, PGconn *conn)
int pqFlush(PGconn *conn)
int pqPutMsgStart(char msg_type, PGconn *conn)
int pqWait(int forRead, int forWrite, PGconn *conn)
int pqPutnchar(const void *s, size_t len, PGconn *conn)
int pqPuts(const char *s, PGconn *conn)
int pqPutMsgEnd(PGconn *conn)
void pqBuildErrorMessage3(PQExpBuffer msg, const PGresult *res, PGVerbosity verbosity, PGContextVisibility show_context)
void pqParseInput3(PGconn *conn)
int pqEndcopy3(PGconn *conn)
PGresult * pqFunctionCall3(PGconn *conn, Oid fnid, int *result_buf, int *actual_result_len, int result_is_int, const PQArgBlock *args, int nargs)
int pqGetlineAsync3(PGconn *conn, char *buffer, int bufsize)
int pqGetCopyData3(PGconn *conn, char **buffer, int async)
int pqGetline3(PGconn *conn, char *s, int maxlen)
Assert(PointerIsAligned(start, uint64))
if(TABLE==NULL||TABLE_index==NULL)
int PQfireResultCreateEvents(PGconn *conn, PGresult *res)
#define PG_COPYRES_TUPLES
struct pg_result PGresult
#define PG_COPYRES_EVENTS
#define PG_COPYRES_NOTICEHOOKS
#define PQ_QUERY_PARAM_MAX_LIMIT
struct pgParameterStatus pgParameterStatus
#define pqClearConnErrorState(conn)
union pgresult_data PGresult_data
#define pqIsnonblocking(conn)
#define OUTBUFFER_THRESHOLD
#define pgHavePendingResult(conn)
void libpq_append_conn_error(PGconn *conn, const char *fmt,...)
static rewind_source * source
#define pg_char_to_encoding
unsigned char pg_tolower(unsigned char ch)
size_t strnlen(const char *str, size_t maxlen)
#define PG_DIAG_SEVERITY_NONLOCALIZED
#define PG_DIAG_MESSAGE_PRIMARY
void initPQExpBuffer(PQExpBuffer str)
void appendPQExpBufferStr(PQExpBuffer str, const char *data)
void termPQExpBuffer(PQExpBuffer str)
#define PQExpBufferBroken(str)
#define PQExpBufferDataBroken(buf)
PQnoticeReceiver noticeRec
PQnoticeProcessor noticeProc
struct PGcmdQueueEntry * next
struct pgMessageField * next
char contents[FLEXIBLE_ARRAY_MEMBER]
struct pgParameterStatus * next
PGTernaryBool in_hot_standby
PGcmdQueueEntry * cmd_queue_recycle
PGcmdQueueEntry * cmd_queue_tail
PGTernaryBool default_transaction_read_only
pgParameterStatus * pstatus
PQExpBufferData errorMessage
PGAsyncStatusType asyncStatus
int scram_sha_256_iterations
PGpipelineStatus pipelineStatus
PGNoticeHooks noticeHooks
PGcmdQueueEntry * cmd_queue_head
PGNoticeHooks noticeHooks
char cmdStatus[CMDSTATUS_LEN]
PGMessageField * errFields
PGresParamDesc * paramDescs
ExecStatusType resultStatus
static StringInfoData tmpbuf
void pg_encoding_set_invalid(int encoding, char *dst)
int pg_encoding_mblen_or_incomplete(int encoding, const char *mbstr, size_t remaining)
int pg_encoding_verifymbstr(int encoding, const char *mbstr, int len)
int pg_encoding_mblen(int encoding, const char *mbstr)
int pg_encoding_verifymbchar(int encoding, const char *mbstr, int len)