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;
1091 prev = pstatus, pstatus = pstatus->
next)
1093 if (strcmp(pstatus->
name,
name) == 0)
1114 pstatus->
name = ptr;
1116 ptr += strlen(
name) + 1;
1117 pstatus->
value = ptr;
1130 if (strcmp(
name,
"client_encoding") == 0)
1138 else if (strcmp(
name,
"standard_conforming_strings") == 0)
1143 else if (strcmp(
name,
"server_version") == 0)
1151 cnt = sscanf(
value,
"%d.%d.%d", &vmaj, &vmin, &vrev);
1179 else if (strcmp(
name,
"default_transaction_read_only") == 0)
1184 else if (strcmp(
name,
"in_hot_standby") == 0)
1189 else if (strcmp(
name,
"scram_iterations") == 0)
1251 for (
i = 0;
i < nfields;
i++)
1253 int clen = columns[
i].
len;
1325 entry->
query = NULL;
1397 entry->
query = NULL;
1467 entry->
query = strdup(query);
1493 const char *command,
1495 const Oid *paramTypes,
1496 const char *
const *paramValues,
1497 const int *paramLengths,
1498 const int *paramFormats,
1537 const char *stmtName,
const char *query,
1538 int nParams,
const Oid *paramTypes)
1573 if (nParams > 0 && paramTypes)
1579 for (
i = 0;
i < nParams;
i++)
1606 entry->
query = strdup(query);
1634 const char *stmtName,
1636 const char *
const *paramValues,
1637 const int *paramLengths,
1638 const int *paramFormats,
1758 const char *command,
1759 const char *stmtName,
1761 const Oid *paramTypes,
1762 const char *
const *paramValues,
1763 const int *paramLengths,
1764 const int *paramFormats,
1787 if (nParams > 0 && paramTypes)
1791 for (
i = 0;
i < nParams;
i++)
1813 if (nParams > 0 && paramFormats)
1817 for (
i = 0;
i < nParams;
i++)
1833 for (
i = 0;
i < nParams;
i++)
1835 if (paramValues && paramValues[
i])
1839 if (paramFormats && paramFormats[
i] != 0)
1843 nbytes = paramLengths[
i];
1853 nbytes = strlen(paramValues[
i]);
1900 entry->
query = strdup(command);
2277 const char *command,
2279 const Oid *paramTypes,
2280 const char *
const *paramValues,
2281 const int *paramLengths,
2282 const int *paramFormats,
2288 nParams, paramTypes, paramValues, paramLengths,
2289 paramFormats, resultFormat))
2307 const char *stmtName,
const char *query,
2308 int nParams,
const Oid *paramTypes)
2324 const char *stmtName,
2326 const char *
const *paramValues,
2327 const int *paramLengths,
2328 const int *paramFormats,
2334 nParams, paramValues, paramLengths,
2335 paramFormats, resultFormat))
2430 lastResult = result;
2856 if (!buffer || length <= 0)
3015 result_buf, result_len,
3171 prevquery->
next = NULL;
3314 "internal error: cannot send pipeline while in COPY\n");
3330 entry->
query = NULL;
3343 if (immediate_flush)
3429 if (!res || !res->
errMsg)
3449 return strdup(
libpq_gettext(
"PGresult is not an error result\n"));
3462 return workBuf.
data;
3472 for (pfield = res->
errFields; pfield != NULL; pfield = pfield->
next)
3474 if (pfield->
code == fieldcode)
3517 "column number %d is out of range 0..%d",
3526 int tup_num,
int field_num)
3530 if (tup_num < 0 || tup_num >= res->
ntups)
3533 "row number %d is out of range 0..%d",
3534 tup_num, res->
ntups - 1);
3540 "column number %d is out of range 0..%d",
3555 "parameter number %d is out of range 0..%d",
3593 bool all_lower =
true;
3605 if (field_name == NULL ||
3606 field_name[0] ==
'\0' ||
3614 for (iptr = field_name; *iptr; iptr++)
3637 field_case = strdup(field_name);
3638 if (field_case == NULL)
3643 for (iptr = field_case; *iptr; iptr++)
3771 static char buf[24];
3775 if (!res || strncmp(res->
cmdStatus,
"INSERT ", 7) != 0)
3779 if (
len >
sizeof(
buf) - 1)
3795 char *endptr = NULL;
3796 unsigned long result;
3799 strncmp(res->
cmdStatus,
"INSERT ", 7) != 0 ||
3804 result = strtoul(res->
cmdStatus + 7, &endptr, 10);
3806 if (!endptr || (*endptr !=
' ' && *endptr !=
'\0'))
3809 return (
Oid) result;
3830 if (strncmp(res->
cmdStatus,
"INSERT ", 7) == 0)
3834 while (*p && *p !=
' ')
3837 goto interpret_error;
3840 else if (strncmp(res->
cmdStatus,
"SELECT ", 7) == 0 ||
3841 strncmp(res->
cmdStatus,
"DELETE ", 7) == 0 ||
3842 strncmp(res->
cmdStatus,
"UPDATE ", 7) == 0)
3844 else if (strncmp(res->
cmdStatus,
"FETCH ", 6) == 0 ||
3845 strncmp(res->
cmdStatus,
"MERGE ", 6) == 0)
3847 else if (strncmp(res->
cmdStatus,
"MOVE ", 5) == 0 ||
3848 strncmp(res->
cmdStatus,
"COPY ", 5) == 0)
3854 for (
c = p; *
c;
c++)
3856 if (!isdigit((
unsigned char) *
c))
3857 goto interpret_error;
3860 goto interpret_error;
3866 "could not interpret result from server: %s",
3892 return res->
tuples[tup_num][field_num].
len;
4072 char *to,
const char *from,
size_t length,
4076 const char *
source = from;
4079 bool already_complained =
false;
4137 if (
conn && !already_complained)
4144 already_complained =
true;
4161 for (
i = 0;
i < charlen;
i++)
4177 char *to,
const char *from,
size_t length,
4219 int num_backslashes = 0;
4222 char quote_char = as_ident ?
'"' :
'\'';
4223 bool validated_mb =
false;
4239 if (*s == quote_char)
4241 else if (*s ==
'\\')
4275 validated_mb =
true;
4285 result_size = input_len + num_quotes + 3;
4286 if (!as_ident && num_backslashes > 0)
4287 result_size += num_backslashes + 2;
4288 result = rp = (
char *)
malloc(result_size);
4302 if (!as_ident && num_backslashes > 0)
4322 if (num_quotes == 0 && (num_backslashes == 0 || as_ident))
4324 memcpy(rp,
str, input_len);
4332 if (*s == quote_char || (!as_ident && *s ==
'\\'))
4375static const char hextbl[] =
"0123456789abcdef";
4378 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4379 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4380 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4381 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, -1, -1, -1, -1, -1, -1,
4382 -1, 10, 11, 12, 13, 14, 15, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4383 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4384 -1, 10, 11, 12, 13, 14, 15, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4385 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
4393 if (
c > 0 &&
c < 127)
4415static unsigned char *
4417 const unsigned char *from,
size_t from_length,
4418 size_t *to_length,
bool std_strings,
bool use_hex)
4420 const unsigned char *vp;
4422 unsigned char *result;
4425 size_t bslash_len = (std_strings ? 1 : 2);
4434 len += bslash_len + 1 + 2 * from_length;
4439 for (
i = from_length;
i > 0;
i--, vp++)
4441 if (*vp < 0x20 || *vp > 0x7e)
4442 len += bslash_len + 3;
4443 else if (*vp ==
'\'')
4445 else if (*vp ==
'\\')
4446 len += bslash_len + bslash_len;
4453 rp = result = (
unsigned char *)
malloc(
len);
4470 for (
i = from_length;
i > 0;
i--, vp++)
4472 unsigned char c = *vp;
4476 *rp++ =
hextbl[(
c >> 4) & 0xF];
4484 *rp++ = (
c >> 6) +
'0';
4485 *rp++ = ((
c >> 3) & 07) +
'0';
4486 *rp++ = (
c & 07) +
'0';
4513 const unsigned char *from,
size_t from_length,
4536#define ISFIRSTOCTDIGIT(CH) ((CH) >= '0' && (CH) <= '3')
4537#define ISOCTDIGIT(CH) ((CH) >= '0' && (CH) <= '7')
4538#define OCTVAL(CH) ((CH) - '0')
4557 unsigned char *buffer,
4562 if (strtext == NULL)
4565 strtextlen = strlen((
const char *) strtext);
4567 if (strtext[0] ==
'\\' && strtext[1] ==
'x')
4569 const unsigned char *s;
4572 buflen = (strtextlen - 2) / 2;
4574 buffer = (
unsigned char *)
malloc(buflen > 0 ? buflen : 1);
4590 if (!*s || v1 == (
char) -1)
4593 if (v2 != (
char) -1)
4594 *p++ = (v1 << 4) | v2;
4597 buflen = p - buffer;
4605 buffer = (
unsigned char *)
malloc(strtextlen + 1);
4609 for (
i =
j = 0;
i < strtextlen;)
4615 if (strtext[
i] ==
'\\')
4616 buffer[
j++] = strtext[
i++];
4626 byte = (
byte << 3) +
OCTVAL(strtext[
i++]);
4627 byte = (
byte << 3) +
OCTVAL(strtext[
i++]);
4642 buffer[
j++] = strtext[
i++];
4660 *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)
void pqSaveParameterStatus(PGconn *conn, const char *name, const char *value)
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 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 char *s, size_t len, PGconn *conn)
int pqPuts(const char *s, PGconn *conn)
void libpq_append_conn_error(PGconn *conn, const char *fmt,...)
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)
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_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)