PostgreSQL Source Code git master
fe-trace.c File Reference
#include "postgres_fe.h"
#include <ctype.h>
#include <limits.h>
#include <sys/time.h>
#include <unistd.h>
#include "libpq-fe.h"
#include "libpq-int.h"
#include "port/pg_bswap.h"
Include dependency graph for fe-trace.c:

Go to the source code of this file.

Functions

void PQtrace (PGconn *conn, FILE *debug_port)
 
void PQuntrace (PGconn *conn)
 
void PQsetTraceFlags (PGconn *conn, int flags)
 
static void pqTraceFormatTimestamp (char *timestr, size_t ts_len)
 
static void pqTraceOutputByte1 (FILE *pfdebug, const char *data, int *cursor)
 
static int pqTraceOutputInt16 (FILE *pfdebug, const char *data, int *cursor)
 
static int pqTraceOutputInt32 (FILE *pfdebug, const char *data, int *cursor, bool suppress)
 
static void pqTraceOutputString (FILE *pfdebug, const char *data, int *cursor, bool suppress)
 
static void pqTraceOutputNchar (FILE *pfdebug, int len, const char *data, int *cursor, bool suppress)
 
static void pqTraceOutput_NotificationResponse (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_Bind (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_Close (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_CommandComplete (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_CopyData (FILE *f, const char *message, int *cursor, int length, bool suppress)
 
static void pqTraceOutput_DataRow (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_Describe (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutputNR (FILE *f, const char *type, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_ErrorResponse (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_NoticeResponse (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_Execute (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_CopyFail (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_GSSResponse (FILE *f, const char *message, int *cursor, int length, bool regress)
 
static void pqTraceOutput_PasswordMessage (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_SASLInitialResponse (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_SASLResponse (FILE *f, const char *message, int *cursor, int length, bool regress)
 
static void pqTraceOutput_FunctionCall (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_CopyInResponse (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_CopyOutResponse (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_BackendKeyData (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_Parse (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_Query (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_Authentication (FILE *f, const char *message, int *cursor, int length, bool suppress)
 
static void pqTraceOutput_ParameterStatus (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_ParameterDescription (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_RowDescription (FILE *f, const char *message, int *cursor, bool regress)
 
static void pqTraceOutput_NegotiateProtocolVersion (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_FunctionCallResponse (FILE *f, const char *message, int *cursor)
 
static void pqTraceOutput_CopyBothResponse (FILE *f, const char *message, int *cursor, int length)
 
static void pqTraceOutput_ReadyForQuery (FILE *f, const char *message, int *cursor)
 
void pqTraceOutputMessage (PGconn *conn, const char *message, bool toServer)
 
void pqTraceOutputNoTypeByteMessage (PGconn *conn, const char *message)
 
void pqTraceOutputCharResponse (PGconn *conn, const char *responseType, char response)
 

Function Documentation

◆ PQsetTraceFlags()

void PQsetTraceFlags ( PGconn conn,
int  flags 
)

Definition at line 64 of file fe-trace.c.

65{
66 if (conn == NULL)
67 return;
68 /* If PQtrace() failed, do nothing. */
69 if (conn->Pfdebug == NULL)
70 return;
71 conn->traceFlags = flags;
72}
PGconn * conn
Definition: streamutil.c:53
FILE * Pfdebug
Definition: libpq-int.h:441
int traceFlags
Definition: libpq-int.h:442

References conn, pg_conn::Pfdebug, and pg_conn::traceFlags.

Referenced by main().

◆ PQtrace()

void PQtrace ( PGconn conn,
FILE *  debug_port 
)

Definition at line 35 of file fe-trace.c.

36{
37 if (conn == NULL)
38 return;
40 if (debug_port == NULL)
41 return;
42
43 conn->Pfdebug = debug_port;
44 conn->traceFlags = 0;
45}
void PQuntrace(PGconn *conn)
Definition: fe-trace.c:49

References conn, pg_conn::Pfdebug, PQuntrace(), and pg_conn::traceFlags.

Referenced by main().

◆ pqTraceFormatTimestamp()

static void pqTraceFormatTimestamp ( char *  timestr,
size_t  ts_len 
)
static

Definition at line 80 of file fe-trace.c.

81{
82 struct timeval tval;
83 time_t now;
84 struct tm tmbuf;
85
86 gettimeofday(&tval, NULL);
87
88 /*
89 * MSVC's implementation of timeval uses a long for tv_sec, however,
90 * localtime() expects a time_t pointer. Here we'll assign tv_sec to a
91 * local time_t variable so that we pass localtime() the correct pointer
92 * type.
93 */
94 now = tval.tv_sec;
95 strftime(timestr, ts_len,
96 "%Y-%m-%d %H:%M:%S",
97 localtime_r(&now, &tmbuf));
98 /* append microseconds */
99 snprintf(timestr + strlen(timestr), ts_len - strlen(timestr),
100 ".%06u", (unsigned int) (tval.tv_usec));
101}
Datum now(PG_FUNCTION_ARGS)
Definition: timestamp.c:1608
static struct pg_tm tm
Definition: localtime.c:104
#define snprintf
Definition: port.h:238
int gettimeofday(struct timeval *tp, void *tzp)

References gettimeofday(), now(), snprintf, and tm.

Referenced by pqTraceOutputCharResponse(), pqTraceOutputMessage(), and pqTraceOutputNoTypeByteMessage().

◆ pqTraceOutput_Authentication()

static void pqTraceOutput_Authentication ( FILE *  f,
const char *  message,
int *  cursor,
int  length,
bool  suppress 
)
static

Definition at line 484 of file fe-trace.c.

486{
487 int authType = 0;
488
489 memcpy(&authType, message + *cursor, 4);
490 authType = (int) pg_ntoh32(authType);
491 *cursor += 4;
492 switch (authType)
493 {
494 case AUTH_REQ_OK:
495 fprintf(f, "AuthenticationOk");
496 break;
497 /* AUTH_REQ_KRB4 not supported */
498 /* AUTH_REQ_KRB5 not supported */
500 fprintf(f, "AuthenticationCleartextPassword");
501 break;
502 /* AUTH_REQ_CRYPT not supported */
503 case AUTH_REQ_MD5:
504 fprintf(f, "AuthenticationMD5Password");
505 break;
506 case AUTH_REQ_GSS:
507 fprintf(f, "AuthenticationGSS");
508 break;
510 fprintf(f, "AuthenticationGSSContinue\t");
511 pqTraceOutputNchar(f, length - *cursor + 1, message, cursor,
512 suppress);
513 break;
514 case AUTH_REQ_SSPI:
515 fprintf(f, "AuthenticationSSPI");
516 break;
517 case AUTH_REQ_SASL:
518 fprintf(f, "AuthenticationSASL\t");
519 while (message[*cursor] != '\0')
520 pqTraceOutputString(f, message, cursor, false);
521 pqTraceOutputString(f, message, cursor, false);
522 break;
524 fprintf(f, "AuthenticationSASLContinue\t");
525 pqTraceOutputNchar(f, length - *cursor + 1, message, cursor,
526 suppress);
527 break;
529 fprintf(f, "AuthenticationSASLFinal\t");
530 pqTraceOutputNchar(f, length - *cursor + 1, message, cursor,
531 suppress);
532 break;
533 default:
534 fprintf(f, "Unknown authentication message %d", authType);
535 }
536}
#define fprintf(file, fmt, msg)
Definition: cubescan.l:21
static void pqTraceOutputString(FILE *pfdebug, const char *data, int *cursor, bool suppress)
Definition: fe-trace.c:166
static void pqTraceOutputNchar(FILE *pfdebug, int len, const char *data, int *cursor, bool suppress)
Definition: fe-trace.c:193
#define pg_ntoh32(x)
Definition: pg_bswap.h:125
#define AUTH_REQ_SSPI
Definition: protocol.h:83
#define AUTH_REQ_SASL_CONT
Definition: protocol.h:85
#define AUTH_REQ_GSS
Definition: protocol.h:81
#define AUTH_REQ_MD5
Definition: protocol.h:79
#define AUTH_REQ_OK
Definition: protocol.h:74
#define AUTH_REQ_PASSWORD
Definition: protocol.h:77
#define AUTH_REQ_GSS_CONT
Definition: protocol.h:82
#define AUTH_REQ_SASL
Definition: protocol.h:84
#define AUTH_REQ_SASL_FIN
Definition: protocol.h:86
Definition: type.h:138

References AUTH_REQ_GSS, AUTH_REQ_GSS_CONT, AUTH_REQ_MD5, AUTH_REQ_OK, AUTH_REQ_PASSWORD, AUTH_REQ_SASL, AUTH_REQ_SASL_CONT, AUTH_REQ_SASL_FIN, AUTH_REQ_SSPI, fprintf, pg_ntoh32, pqTraceOutputNchar(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_BackendKeyData()

static void pqTraceOutput_BackendKeyData ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 455 of file fe-trace.c.

456{
457 fprintf(f, "BackendKeyData\t");
458 pqTraceOutputInt32(f, message, cursor, regress);
459 pqTraceOutputInt32(f, message, cursor, regress);
460}
static int pqTraceOutputInt32(FILE *pfdebug, const char *data, int *cursor, bool suppress)
Definition: fe-trace.c:145

References fprintf, and pqTraceOutputInt32().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_Bind()

static void pqTraceOutput_Bind ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 240 of file fe-trace.c.

241{
242 int nparams;
243
244 fprintf(f, "Bind\t");
245 pqTraceOutputString(f, message, cursor, false);
246 pqTraceOutputString(f, message, cursor, false);
247 nparams = pqTraceOutputInt16(f, message, cursor);
248
249 for (int i = 0; i < nparams; i++)
250 pqTraceOutputInt16(f, message, cursor);
251
252 nparams = pqTraceOutputInt16(f, message, cursor);
253
254 for (int i = 0; i < nparams; i++)
255 {
256 int nbytes;
257
258 nbytes = pqTraceOutputInt32(f, message, cursor, false);
259 if (nbytes == -1)
260 continue;
261 pqTraceOutputNchar(f, nbytes, message, cursor, false);
262 }
263
264 nparams = pqTraceOutputInt16(f, message, cursor);
265 for (int i = 0; i < nparams; i++)
266 pqTraceOutputInt16(f, message, cursor);
267}
static int pqTraceOutputInt16(FILE *pfdebug, const char *data, int *cursor)
Definition: fe-trace.c:126
int i
Definition: isn.c:72

References fprintf, i, pqTraceOutputInt16(), pqTraceOutputInt32(), pqTraceOutputNchar(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_Close()

static void pqTraceOutput_Close ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 270 of file fe-trace.c.

271{
272 fprintf(f, "Close\t");
273 pqTraceOutputByte1(f, message, cursor);
274 pqTraceOutputString(f, message, cursor, false);
275}
static void pqTraceOutputByte1(FILE *pfdebug, const char *data, int *cursor)
Definition: fe-trace.c:107

References fprintf, pqTraceOutputByte1(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_CommandComplete()

static void pqTraceOutput_CommandComplete ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 278 of file fe-trace.c.

279{
280 fprintf(f, "CommandComplete\t");
281 pqTraceOutputString(f, message, cursor, false);
282}

References fprintf, and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_CopyBothResponse()

static void pqTraceOutput_CopyBothResponse ( FILE *  f,
const char *  message,
int *  cursor,
int  length 
)
static

Definition at line 598 of file fe-trace.c.

599{
600 fprintf(f, "CopyBothResponse\t");
601 pqTraceOutputByte1(f, message, cursor);
602
603 while (length > *cursor)
604 pqTraceOutputInt16(f, message, cursor);
605}

References fprintf, pqTraceOutputByte1(), and pqTraceOutputInt16().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_CopyData()

static void pqTraceOutput_CopyData ( FILE *  f,
const char *  message,
int *  cursor,
int  length,
bool  suppress 
)
static

Definition at line 285 of file fe-trace.c.

287{
288 fprintf(f, "CopyData\t");
289 pqTraceOutputNchar(f, length - *cursor + 1, message, cursor, suppress);
290}

References fprintf, and pqTraceOutputNchar().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_CopyFail()

static void pqTraceOutput_CopyFail ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 360 of file fe-trace.c.

361{
362 fprintf(f, "CopyFail\t");
363 pqTraceOutputString(f, message, cursor, false);
364}

References fprintf, and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_CopyInResponse()

static void pqTraceOutput_CopyInResponse ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 429 of file fe-trace.c.

430{
431 int nfields;
432
433 fprintf(f, "CopyInResponse\t");
434 pqTraceOutputByte1(f, message, cursor);
435 nfields = pqTraceOutputInt16(f, message, cursor);
436
437 for (int i = 0; i < nfields; i++)
438 pqTraceOutputInt16(f, message, cursor);
439}

References fprintf, i, pqTraceOutputByte1(), and pqTraceOutputInt16().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_CopyOutResponse()

static void pqTraceOutput_CopyOutResponse ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 442 of file fe-trace.c.

443{
444 int nfields;
445
446 fprintf(f, "CopyOutResponse\t");
447 pqTraceOutputByte1(f, message, cursor);
448 nfields = pqTraceOutputInt16(f, message, cursor);
449
450 for (int i = 0; i < nfields; i++)
451 pqTraceOutputInt16(f, message, cursor);
452}

References fprintf, i, pqTraceOutputByte1(), and pqTraceOutputInt16().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_DataRow()

static void pqTraceOutput_DataRow ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 293 of file fe-trace.c.

294{
295 int nfields;
296 int len;
297 int i;
298
299 fprintf(f, "DataRow\t");
300 nfields = pqTraceOutputInt16(f, message, cursor);
301 for (i = 0; i < nfields; i++)
302 {
303 len = pqTraceOutputInt32(f, message, cursor, false);
304 if (len == -1)
305 continue;
306 pqTraceOutputNchar(f, len, message, cursor, false);
307 }
308}
const void size_t len

References fprintf, i, len, pqTraceOutputInt16(), pqTraceOutputInt32(), and pqTraceOutputNchar().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_Describe()

static void pqTraceOutput_Describe ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 311 of file fe-trace.c.

312{
313 fprintf(f, "Describe\t");
314 pqTraceOutputByte1(f, message, cursor);
315 pqTraceOutputString(f, message, cursor, false);
316}

References fprintf, pqTraceOutputByte1(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_ErrorResponse()

static void pqTraceOutput_ErrorResponse ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 340 of file fe-trace.c.

341{
342 pqTraceOutputNR(f, "ErrorResponse", message, cursor, regress);
343}
static void pqTraceOutputNR(FILE *f, const char *type, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:320

References pqTraceOutputNR().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_Execute()

static void pqTraceOutput_Execute ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 352 of file fe-trace.c.

353{
354 fprintf(f, "Execute\t");
355 pqTraceOutputString(f, message, cursor, false);
356 pqTraceOutputInt32(f, message, cursor, false);
357}

References fprintf, pqTraceOutputInt32(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_FunctionCall()

static void pqTraceOutput_FunctionCall ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 403 of file fe-trace.c.

404{
405 int nfields;
406 int nbytes;
407
408 fprintf(f, "FunctionCall\t");
409 pqTraceOutputInt32(f, message, cursor, regress);
410 nfields = pqTraceOutputInt16(f, message, cursor);
411
412 for (int i = 0; i < nfields; i++)
413 pqTraceOutputInt16(f, message, cursor);
414
415 nfields = pqTraceOutputInt16(f, message, cursor);
416
417 for (int i = 0; i < nfields; i++)
418 {
419 nbytes = pqTraceOutputInt32(f, message, cursor, false);
420 if (nbytes == -1)
421 continue;
422 pqTraceOutputNchar(f, nbytes, message, cursor, false);
423 }
424
425 pqTraceOutputInt16(f, message, cursor);
426}

References fprintf, i, pqTraceOutputInt16(), pqTraceOutputInt32(), and pqTraceOutputNchar().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_FunctionCallResponse()

static void pqTraceOutput_FunctionCallResponse ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 587 of file fe-trace.c.

588{
589 int len;
590
591 fprintf(f, "FunctionCallResponse\t");
592 len = pqTraceOutputInt32(f, message, cursor, false);
593 if (len != -1)
594 pqTraceOutputNchar(f, len, message, cursor, false);
595}

References fprintf, len, pqTraceOutputInt32(), and pqTraceOutputNchar().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_GSSResponse()

static void pqTraceOutput_GSSResponse ( FILE *  f,
const char *  message,
int *  cursor,
int  length,
bool  regress 
)
static

Definition at line 367 of file fe-trace.c.

369{
370 fprintf(f, "GSSResponse\t");
371 pqTraceOutputNchar(f, length - *cursor + 1, message, cursor, regress);
372}

References fprintf, and pqTraceOutputNchar().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_NegotiateProtocolVersion()

static void pqTraceOutput_NegotiateProtocolVersion ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 579 of file fe-trace.c.

580{
581 fprintf(f, "NegotiateProtocolVersion\t");
582 pqTraceOutputInt32(f, message, cursor, false);
583 pqTraceOutputInt32(f, message, cursor, false);
584}

References fprintf, and pqTraceOutputInt32().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_NoticeResponse()

static void pqTraceOutput_NoticeResponse ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 346 of file fe-trace.c.

347{
348 pqTraceOutputNR(f, "NoticeResponse", message, cursor, regress);
349}

References pqTraceOutputNR().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_NotificationResponse()

static void pqTraceOutput_NotificationResponse ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 231 of file fe-trace.c.

232{
233 fprintf(f, "NotificationResponse\t");
234 pqTraceOutputInt32(f, message, cursor, regress);
235 pqTraceOutputString(f, message, cursor, false);
236 pqTraceOutputString(f, message, cursor, false);
237}

References fprintf, pqTraceOutputInt32(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_ParameterDescription()

static void pqTraceOutput_ParameterDescription ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 547 of file fe-trace.c.

548{
549 int nfields;
550
551 fprintf(f, "ParameterDescription\t");
552 nfields = pqTraceOutputInt16(f, message, cursor);
553
554 for (int i = 0; i < nfields; i++)
555 pqTraceOutputInt32(f, message, cursor, regress);
556}

References fprintf, i, pqTraceOutputInt16(), and pqTraceOutputInt32().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_ParameterStatus()

static void pqTraceOutput_ParameterStatus ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 539 of file fe-trace.c.

540{
541 fprintf(f, "ParameterStatus\t");
542 pqTraceOutputString(f, message, cursor, false);
543 pqTraceOutputString(f, message, cursor, false);
544}

References fprintf, and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_Parse()

static void pqTraceOutput_Parse ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 463 of file fe-trace.c.

464{
465 int nparams;
466
467 fprintf(f, "Parse\t");
468 pqTraceOutputString(f, message, cursor, false);
469 pqTraceOutputString(f, message, cursor, false);
470 nparams = pqTraceOutputInt16(f, message, cursor);
471
472 for (int i = 0; i < nparams; i++)
473 pqTraceOutputInt32(f, message, cursor, regress);
474}

References fprintf, i, pqTraceOutputInt16(), pqTraceOutputInt32(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_PasswordMessage()

static void pqTraceOutput_PasswordMessage ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 375 of file fe-trace.c.

376{
377 fprintf(f, "PasswordMessage\t");
378 pqTraceOutputString(f, message, cursor, false);
379}

References fprintf, and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_Query()

static void pqTraceOutput_Query ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 477 of file fe-trace.c.

478{
479 fprintf(f, "Query\t");
480 pqTraceOutputString(f, message, cursor, false);
481}

References fprintf, and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_ReadyForQuery()

static void pqTraceOutput_ReadyForQuery ( FILE *  f,
const char *  message,
int *  cursor 
)
static

Definition at line 608 of file fe-trace.c.

609{
610 fprintf(f, "ReadyForQuery\t");
611 pqTraceOutputByte1(f, message, cursor);
612}

References fprintf, and pqTraceOutputByte1().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_RowDescription()

static void pqTraceOutput_RowDescription ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 559 of file fe-trace.c.

560{
561 int nfields;
562
563 fprintf(f, "RowDescription\t");
564 nfields = pqTraceOutputInt16(f, message, cursor);
565
566 for (int i = 0; i < nfields; i++)
567 {
568 pqTraceOutputString(f, message, cursor, false);
569 pqTraceOutputInt32(f, message, cursor, regress);
570 pqTraceOutputInt16(f, message, cursor);
571 pqTraceOutputInt32(f, message, cursor, regress);
572 pqTraceOutputInt16(f, message, cursor);
573 pqTraceOutputInt32(f, message, cursor, false);
574 pqTraceOutputInt16(f, message, cursor);
575 }
576}

References fprintf, i, pqTraceOutputInt16(), pqTraceOutputInt32(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_SASLInitialResponse()

static void pqTraceOutput_SASLInitialResponse ( FILE *  f,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 382 of file fe-trace.c.

384{
385 int initialResponse;
386
387 fprintf(f, "SASLInitialResponse\t");
388 pqTraceOutputString(f, message, cursor, false);
389 initialResponse = pqTraceOutputInt32(f, message, cursor, false);
390 if (initialResponse != -1)
391 pqTraceOutputNchar(f, initialResponse, message, cursor, regress);
392}

References fprintf, pqTraceOutputInt32(), pqTraceOutputNchar(), and pqTraceOutputString().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutput_SASLResponse()

static void pqTraceOutput_SASLResponse ( FILE *  f,
const char *  message,
int *  cursor,
int  length,
bool  regress 
)
static

Definition at line 395 of file fe-trace.c.

397{
398 fprintf(f, "SASLResponse\t");
399 pqTraceOutputNchar(f, length - *cursor + 1, message, cursor, regress);
400}

References fprintf, and pqTraceOutputNchar().

Referenced by pqTraceOutputMessage().

◆ pqTraceOutputByte1()

static void pqTraceOutputByte1 ( FILE *  pfdebug,
const char *  data,
int *  cursor 
)
static

Definition at line 107 of file fe-trace.c.

108{
109 const char *v = data + *cursor;
110
111 /*
112 * Show non-printable data in hex format, including the terminating \0
113 * that completes ErrorResponse and NoticeResponse messages.
114 */
115 if (!isprint((unsigned char) *v))
116 fprintf(pfdebug, " \\x%02x", *v);
117 else
118 fprintf(pfdebug, " %c", *v);
119 *cursor += 1;
120}
const void * data

References data, and fprintf.

Referenced by pqTraceOutput_Close(), pqTraceOutput_CopyBothResponse(), pqTraceOutput_CopyInResponse(), pqTraceOutput_CopyOutResponse(), pqTraceOutput_Describe(), pqTraceOutput_ReadyForQuery(), and pqTraceOutputNR().

◆ pqTraceOutputCharResponse()

void pqTraceOutputCharResponse ( PGconn conn,
const char *  responseType,
char  response 
)

Definition at line 909 of file fe-trace.c.

911{
913 {
914 char timestr[128];
915
916 pqTraceFormatTimestamp(timestr, sizeof(timestr));
917 fprintf(conn->Pfdebug, "%s\t", timestr);
918 }
919
920 fprintf(conn->Pfdebug, "B\t1\t%s\t %c\n", responseType, response);
921}
static void pqTraceFormatTimestamp(char *timestr, size_t ts_len)
Definition: fe-trace.c:80
#define PQTRACE_SUPPRESS_TIMESTAMPS
Definition: libpq-fe.h:467

References conn, fprintf, pg_conn::Pfdebug, PQTRACE_SUPPRESS_TIMESTAMPS, pqTraceFormatTimestamp(), and pg_conn::traceFlags.

Referenced by PQconnectPoll().

◆ pqTraceOutputInt16()

static int pqTraceOutputInt16 ( FILE *  pfdebug,
const char *  data,
int *  cursor 
)
static

Definition at line 126 of file fe-trace.c.

127{
128 uint16 tmp;
129 int result;
130
131 memcpy(&tmp, data + *cursor, 2);
132 *cursor += 2;
133 result = (int) pg_ntoh16(tmp);
134 fprintf(pfdebug, " %d", result);
135
136 return result;
137}
uint16_t uint16
Definition: c.h:487
#define pg_ntoh16(x)
Definition: pg_bswap.h:124

References data, fprintf, and pg_ntoh16.

Referenced by pqTraceOutput_Bind(), pqTraceOutput_CopyBothResponse(), pqTraceOutput_CopyInResponse(), pqTraceOutput_CopyOutResponse(), pqTraceOutput_DataRow(), pqTraceOutput_FunctionCall(), pqTraceOutput_ParameterDescription(), pqTraceOutput_Parse(), pqTraceOutput_RowDescription(), and pqTraceOutputNoTypeByteMessage().

◆ pqTraceOutputInt32()

static int pqTraceOutputInt32 ( FILE *  pfdebug,
const char *  data,
int *  cursor,
bool  suppress 
)
static

◆ pqTraceOutputMessage()

void pqTraceOutputMessage ( PGconn conn,
const char *  message,
bool  toServer 
)

Definition at line 618 of file fe-trace.c.

619{
620 char id;
621 int length;
622 char *prefix = toServer ? "F" : "B";
623 int logCursor = 0;
624 bool regress;
625
627 {
628 char timestr[128];
629
630 pqTraceFormatTimestamp(timestr, sizeof(timestr));
631 fprintf(conn->Pfdebug, "%s\t", timestr);
632 }
633 regress = (conn->traceFlags & PQTRACE_REGRESS_MODE) != 0;
634
635 id = message[logCursor++];
636
637 memcpy(&length, message + logCursor, 4);
638 length = (int) pg_ntoh32(length);
639 logCursor += 4;
640
641 /*
642 * In regress mode, suppress the length of ErrorResponse and
643 * NoticeResponse. The F (file name), L (line number) and R (routine
644 * name) fields can change as server code is modified, and if their
645 * lengths differ from the originals, that would break tests.
646 */
647 if (regress && !toServer && (id == PqMsg_ErrorResponse || id == PqMsg_NoticeResponse))
648 fprintf(conn->Pfdebug, "%s\tNN\t", prefix);
649 else
650 fprintf(conn->Pfdebug, "%s\t%d\t", prefix, length);
651
652 switch (id)
653 {
655 fprintf(conn->Pfdebug, "ParseComplete");
656 /* No message content */
657 break;
659 fprintf(conn->Pfdebug, "BindComplete");
660 /* No message content */
661 break;
663 fprintf(conn->Pfdebug, "CloseComplete");
664 /* No message content */
665 break;
667 pqTraceOutput_NotificationResponse(conn->Pfdebug, message, &logCursor, regress);
668 break;
669 case PqMsg_Bind:
670 pqTraceOutput_Bind(conn->Pfdebug, message, &logCursor);
671 break;
672 case PqMsg_CopyDone:
673 fprintf(conn->Pfdebug, "CopyDone");
674 /* No message content */
675 break;
677 /* Close(F) and CommandComplete(B) use the same identifier. */
679 if (toServer)
680 pqTraceOutput_Close(conn->Pfdebug, message, &logCursor);
681 else
682 pqTraceOutput_CommandComplete(conn->Pfdebug, message, &logCursor);
683 break;
684 case PqMsg_CopyData:
685 pqTraceOutput_CopyData(conn->Pfdebug, message, &logCursor,
686 length, regress);
687 break;
688 case PqMsg_Describe:
689 /* Describe(F) and DataRow(B) use the same identifier. */
691 if (toServer)
692 pqTraceOutput_Describe(conn->Pfdebug, message, &logCursor);
693 else
694 pqTraceOutput_DataRow(conn->Pfdebug, message, &logCursor);
695 break;
696 case PqMsg_Execute:
697 /* Execute(F) and ErrorResponse(B) use the same identifier. */
699 if (toServer)
700 pqTraceOutput_Execute(conn->Pfdebug, message, &logCursor, regress);
701 else
702 pqTraceOutput_ErrorResponse(conn->Pfdebug, message, &logCursor, regress);
703 break;
704 case PqMsg_CopyFail:
705 pqTraceOutput_CopyFail(conn->Pfdebug, message, &logCursor);
706 break;
711
712 /*
713 * These messages share a common type byte, so we discriminate by
714 * having the code store the auth type separately.
715 */
717 {
720 &logCursor, length, regress);
721 break;
724 &logCursor);
725 break;
728 &logCursor, regress);
729 break;
732 &logCursor, length, regress);
733 break;
734 default:
735 fprintf(conn->Pfdebug, "UnknownAuthenticationResponse");
736 break;
737 }
739 break;
741 pqTraceOutput_FunctionCall(conn->Pfdebug, message, &logCursor, regress);
742 break;
744 pqTraceOutput_CopyInResponse(conn->Pfdebug, message, &logCursor);
745 break;
746 case PqMsg_Flush:
747 /* Flush(F) and CopyOutResponse(B) use the same identifier */
749 if (toServer)
750 fprintf(conn->Pfdebug, "Flush"); /* no message content */
751 else
752 pqTraceOutput_CopyOutResponse(conn->Pfdebug, message, &logCursor);
753 break;
755 fprintf(conn->Pfdebug, "EmptyQueryResponse");
756 /* No message content */
757 break;
759 pqTraceOutput_BackendKeyData(conn->Pfdebug, message, &logCursor, regress);
760 break;
761 case PqMsg_NoData:
762 fprintf(conn->Pfdebug, "NoData");
763 /* No message content */
764 break;
766 pqTraceOutput_NoticeResponse(conn->Pfdebug, message, &logCursor, regress);
767 break;
768 case PqMsg_Parse:
769 pqTraceOutput_Parse(conn->Pfdebug, message, &logCursor, regress);
770 break;
771 case PqMsg_Query:
772 pqTraceOutput_Query(conn->Pfdebug, message, &logCursor);
773 break;
775 pqTraceOutput_Authentication(conn->Pfdebug, message, &logCursor,
776 length, regress);
777 break;
779 fprintf(conn->Pfdebug, "PortalSuspended");
780 /* No message content */
781 break;
782 case PqMsg_Sync:
783 /* ParameterStatus(B) and Sync(F) use the same identifier */
785 if (toServer)
786 fprintf(conn->Pfdebug, "Sync"); /* no message content */
787 else
788 pqTraceOutput_ParameterStatus(conn->Pfdebug, message, &logCursor);
789 break;
791 pqTraceOutput_ParameterDescription(conn->Pfdebug, message, &logCursor, regress);
792 break;
794 pqTraceOutput_RowDescription(conn->Pfdebug, message, &logCursor, regress);
795 break;
798 break;
800 pqTraceOutput_FunctionCallResponse(conn->Pfdebug, message, &logCursor);
801 break;
803 pqTraceOutput_CopyBothResponse(conn->Pfdebug, message, &logCursor, length);
804 break;
805 case PqMsg_Terminate:
806 fprintf(conn->Pfdebug, "Terminate");
807 /* No message content */
808 break;
810 pqTraceOutput_ReadyForQuery(conn->Pfdebug, message, &logCursor);
811 break;
812 default:
813 fprintf(conn->Pfdebug, "Unknown message: %02x", id);
814 break;
815 }
816
817 fputc('\n', conn->Pfdebug);
818
819 /*
820 * Verify the printing routine did it right. Note that the one-byte
821 * message identifier is not included in the length, but our cursor does
822 * include it.
823 */
824 if (logCursor - 1 != length)
826 "mismatched message length: consumed %d, expected %d\n",
827 logCursor - 1, length);
828}
#define Assert(condition)
Definition: c.h:815
static void pqTraceOutput_RowDescription(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:559
static void pqTraceOutput_GSSResponse(FILE *f, const char *message, int *cursor, int length, bool regress)
Definition: fe-trace.c:367
static void pqTraceOutput_FunctionCall(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:403
static void pqTraceOutput_CopyInResponse(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:429
static void pqTraceOutput_BackendKeyData(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:455
static void pqTraceOutput_Authentication(FILE *f, const char *message, int *cursor, int length, bool suppress)
Definition: fe-trace.c:484
static void pqTraceOutput_Parse(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:463
static void pqTraceOutput_NoticeResponse(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:346
static void pqTraceOutput_ParameterDescription(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:547
static void pqTraceOutput_DataRow(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:293
static void pqTraceOutput_SASLResponse(FILE *f, const char *message, int *cursor, int length, bool regress)
Definition: fe-trace.c:395
static void pqTraceOutput_Query(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:477
static void pqTraceOutput_CopyData(FILE *f, const char *message, int *cursor, int length, bool suppress)
Definition: fe-trace.c:285
static void pqTraceOutput_SASLInitialResponse(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:382
static void pqTraceOutput_NegotiateProtocolVersion(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:579
static void pqTraceOutput_CopyBothResponse(FILE *f, const char *message, int *cursor, int length)
Definition: fe-trace.c:598
static void pqTraceOutput_Bind(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:240
static void pqTraceOutput_ErrorResponse(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:340
static void pqTraceOutput_Close(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:270
static void pqTraceOutput_Describe(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:311
static void pqTraceOutput_NotificationResponse(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:231
static void pqTraceOutput_CommandComplete(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:278
static void pqTraceOutput_ParameterStatus(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:539
static void pqTraceOutput_Execute(FILE *f, const char *message, int *cursor, bool regress)
Definition: fe-trace.c:352
static void pqTraceOutput_CopyOutResponse(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:442
static void pqTraceOutput_ReadyForQuery(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:608
static void pqTraceOutput_CopyFail(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:360
static void pqTraceOutput_PasswordMessage(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:375
static void pqTraceOutput_FunctionCallResponse(FILE *f, const char *message, int *cursor)
Definition: fe-trace.c:587
#define PQTRACE_REGRESS_MODE
Definition: libpq-fe.h:469
#define AUTH_RESPONSE_PASSWORD
Definition: libpq-int.h:344
#define AUTH_RESPONSE_SASL
Definition: libpq-int.h:346
#define AUTH_RESPONSE_SASL_INITIAL
Definition: libpq-int.h:345
#define AUTH_RESPONSE_GSS
Definition: libpq-int.h:343
#define PqMsg_CloseComplete
Definition: protocol.h:40
#define PqMsg_CopyDone
Definition: protocol.h:64
#define PqMsg_NotificationResponse
Definition: protocol.h:41
#define PqMsg_BindComplete
Definition: protocol.h:39
#define PqMsg_CopyData
Definition: protocol.h:65
#define PqMsg_ParameterDescription
Definition: protocol.h:58
#define PqMsg_FunctionCall
Definition: protocol.h:23
#define PqMsg_GSSResponse
Definition: protocol.h:30
#define PqMsg_SASLResponse
Definition: protocol.h:33
#define PqMsg_Describe
Definition: protocol.h:21
#define PqMsg_FunctionCallResponse
Definition: protocol.h:53
#define PqMsg_SASLInitialResponse
Definition: protocol.h:32
#define PqMsg_ReadyForQuery
Definition: protocol.h:55
#define PqMsg_AuthenticationRequest
Definition: protocol.h:50
#define PqMsg_CopyInResponse
Definition: protocol.h:45
#define PqMsg_EmptyQueryResponse
Definition: protocol.h:47
#define PqMsg_RowDescription
Definition: protocol.h:52
#define PqMsg_CopyBothResponse
Definition: protocol.h:54
#define PqMsg_ParameterStatus
Definition: protocol.h:51
#define PqMsg_NoData
Definition: protocol.h:56
#define PqMsg_NegotiateProtocolVersion
Definition: protocol.h:59
#define PqMsg_PortalSuspended
Definition: protocol.h:57
#define PqMsg_Parse
Definition: protocol.h:25
#define PqMsg_Bind
Definition: protocol.h:19
#define PqMsg_PasswordMessage
Definition: protocol.h:31
#define PqMsg_Sync
Definition: protocol.h:27
#define PqMsg_CopyFail
Definition: protocol.h:29
#define PqMsg_Flush
Definition: protocol.h:24
#define PqMsg_BackendKeyData
Definition: protocol.h:48
#define PqMsg_CommandComplete
Definition: protocol.h:42
#define PqMsg_Query
Definition: protocol.h:26
#define PqMsg_ErrorResponse
Definition: protocol.h:44
#define PqMsg_DataRow
Definition: protocol.h:43
#define PqMsg_NoticeResponse
Definition: protocol.h:49
#define PqMsg_Terminate
Definition: protocol.h:28
#define PqMsg_Execute
Definition: protocol.h:22
#define PqMsg_Close
Definition: protocol.h:20
#define PqMsg_CopyOutResponse
Definition: protocol.h:46
#define PqMsg_ParseComplete
Definition: protocol.h:38
char current_auth_response
Definition: libpq-int.h:510

References Assert, AUTH_RESPONSE_GSS, AUTH_RESPONSE_PASSWORD, AUTH_RESPONSE_SASL, AUTH_RESPONSE_SASL_INITIAL, conn, pg_conn::current_auth_response, fprintf, pg_conn::Pfdebug, pg_ntoh32, PqMsg_AuthenticationRequest, PqMsg_BackendKeyData, PqMsg_Bind, PqMsg_BindComplete, PqMsg_Close, PqMsg_CloseComplete, PqMsg_CommandComplete, PqMsg_CopyBothResponse, PqMsg_CopyData, PqMsg_CopyDone, PqMsg_CopyFail, PqMsg_CopyInResponse, PqMsg_CopyOutResponse, PqMsg_DataRow, PqMsg_Describe, PqMsg_EmptyQueryResponse, PqMsg_ErrorResponse, PqMsg_Execute, PqMsg_Flush, PqMsg_FunctionCall, PqMsg_FunctionCallResponse, PqMsg_GSSResponse, PqMsg_NegotiateProtocolVersion, PqMsg_NoData, PqMsg_NoticeResponse, PqMsg_NotificationResponse, PqMsg_ParameterDescription, PqMsg_ParameterStatus, PqMsg_Parse, PqMsg_ParseComplete, PqMsg_PasswordMessage, PqMsg_PortalSuspended, PqMsg_Query, PqMsg_ReadyForQuery, PqMsg_RowDescription, PqMsg_SASLInitialResponse, PqMsg_SASLResponse, PqMsg_Sync, PqMsg_Terminate, PQTRACE_REGRESS_MODE, PQTRACE_SUPPRESS_TIMESTAMPS, pqTraceFormatTimestamp(), pqTraceOutput_Authentication(), pqTraceOutput_BackendKeyData(), pqTraceOutput_Bind(), pqTraceOutput_Close(), pqTraceOutput_CommandComplete(), pqTraceOutput_CopyBothResponse(), pqTraceOutput_CopyData(), pqTraceOutput_CopyFail(), pqTraceOutput_CopyInResponse(), pqTraceOutput_CopyOutResponse(), pqTraceOutput_DataRow(), pqTraceOutput_Describe(), pqTraceOutput_ErrorResponse(), pqTraceOutput_Execute(), pqTraceOutput_FunctionCall(), pqTraceOutput_FunctionCallResponse(), pqTraceOutput_GSSResponse(), pqTraceOutput_NegotiateProtocolVersion(), pqTraceOutput_NoticeResponse(), pqTraceOutput_NotificationResponse(), pqTraceOutput_ParameterDescription(), pqTraceOutput_ParameterStatus(), pqTraceOutput_Parse(), pqTraceOutput_PasswordMessage(), pqTraceOutput_Query(), pqTraceOutput_ReadyForQuery(), pqTraceOutput_RowDescription(), pqTraceOutput_SASLInitialResponse(), pqTraceOutput_SASLResponse(), and pg_conn::traceFlags.

Referenced by pg_password_sendauth(), pg_SASL_continue(), pg_SASL_init(), pqParseDone(), and pqPutMsgEnd().

◆ pqTraceOutputNchar()

static void pqTraceOutputNchar ( FILE *  pfdebug,
int  len,
const char *  data,
int *  cursor,
bool  suppress 
)
static

Definition at line 193 of file fe-trace.c.

194{
195 int i,
196 next; /* first char not yet printed */
197 const char *v = data + *cursor;
198
199 if (suppress)
200 {
201 fprintf(pfdebug, " 'BBBB'");
202 *cursor += len;
203 return;
204 }
205
206 fprintf(pfdebug, " \'");
207
208 for (next = i = 0; i < len; ++i)
209 {
210 if (isprint((unsigned char) v[i]))
211 continue;
212 else
213 {
214 fwrite(v + next, 1, i - next, pfdebug);
215 fprintf(pfdebug, "\\x%02x", v[i]);
216 next = i + 1;
217 }
218 }
219 if (next < len)
220 fwrite(v + next, 1, len - next, pfdebug);
221
222 fprintf(pfdebug, "\'");
223 *cursor += len;
224}
static int32 next
Definition: blutils.c:219

References data, fprintf, i, len, and next.

Referenced by pqTraceOutput_Authentication(), pqTraceOutput_Bind(), pqTraceOutput_CopyData(), pqTraceOutput_DataRow(), pqTraceOutput_FunctionCall(), pqTraceOutput_FunctionCallResponse(), pqTraceOutput_GSSResponse(), pqTraceOutput_SASLInitialResponse(), and pqTraceOutput_SASLResponse().

◆ pqTraceOutputNoTypeByteMessage()

void pqTraceOutputNoTypeByteMessage ( PGconn conn,
const char *  message 
)

Definition at line 835 of file fe-trace.c.

836{
837 int length;
838 int version;
839 bool regress;
840 int logCursor = 0;
841
842 regress = (conn->traceFlags & PQTRACE_REGRESS_MODE) != 0;
843
845 {
846 char timestr[128];
847
848 pqTraceFormatTimestamp(timestr, sizeof(timestr));
849 fprintf(conn->Pfdebug, "%s\t", timestr);
850 }
851
852 memcpy(&length, message + logCursor, 4);
853 length = (int) pg_ntoh32(length);
854 logCursor += 4;
855
856 fprintf(conn->Pfdebug, "F\t%d\t", length);
857
858 if (length < 8)
859 {
860 fprintf(conn->Pfdebug, "Unknown message\n");
861 return;
862 }
863
864 memcpy(&version, message + logCursor, 4);
865 version = (int) pg_ntoh32(version);
866
867 if (version == CANCEL_REQUEST_CODE && length >= 16)
868 {
869 fprintf(conn->Pfdebug, "CancelRequest\t");
870 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
871 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
872 pqTraceOutputInt32(conn->Pfdebug, message, &logCursor, regress);
873 pqTraceOutputInt32(conn->Pfdebug, message, &logCursor, regress);
874 }
875 else if (version == NEGOTIATE_SSL_CODE)
876 {
877 fprintf(conn->Pfdebug, "SSLRequest\t");
878 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
879 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
880 }
881 else if (version == NEGOTIATE_GSS_CODE)
882 {
883 fprintf(conn->Pfdebug, "GSSENCRequest\t");
884 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
885 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
886 }
887 else
888 {
889 fprintf(conn->Pfdebug, "StartupMessage\t");
890 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
891 pqTraceOutputInt16(conn->Pfdebug, message, &logCursor);
892 while (message[logCursor] != '\0')
893 {
894 /* XXX should we suppress anything in regress mode? */
895 pqTraceOutputString(conn->Pfdebug, message, &logCursor, false);
896 pqTraceOutputString(conn->Pfdebug, message, &logCursor, false);
897 }
898 }
899
900 fputc('\n', conn->Pfdebug);
901}
#define CANCEL_REQUEST_CODE
Definition: pqcomm.h:133
#define NEGOTIATE_GSS_CODE
Definition: pqcomm.h:168
#define NEGOTIATE_SSL_CODE
Definition: pqcomm.h:167

References CANCEL_REQUEST_CODE, conn, fprintf, NEGOTIATE_GSS_CODE, NEGOTIATE_SSL_CODE, pg_conn::Pfdebug, pg_ntoh32, PQTRACE_REGRESS_MODE, PQTRACE_SUPPRESS_TIMESTAMPS, pqTraceFormatTimestamp(), pqTraceOutputInt16(), pqTraceOutputInt32(), pqTraceOutputString(), and pg_conn::traceFlags.

Referenced by pqPutMsgEnd().

◆ pqTraceOutputNR()

static void pqTraceOutputNR ( FILE *  f,
const char *  type,
const char *  message,
int *  cursor,
bool  regress 
)
static

Definition at line 320 of file fe-trace.c.

322{
323 fprintf(f, "%s\t", type);
324 for (;;)
325 {
326 char field;
327 bool suppress;
328
329 pqTraceOutputByte1(f, message, cursor);
330 field = message[*cursor - 1];
331 if (field == '\0')
332 break;
333
334 suppress = regress && (field == 'L' || field == 'F' || field == 'R');
335 pqTraceOutputString(f, message, cursor, suppress);
336 }
337}
const char * type

References fprintf, pqTraceOutputByte1(), pqTraceOutputString(), and type.

Referenced by pqTraceOutput_ErrorResponse(), and pqTraceOutput_NoticeResponse().

◆ pqTraceOutputString()

static void pqTraceOutputString ( FILE *  pfdebug,
const char *  data,
int *  cursor,
bool  suppress 
)
static

Definition at line 166 of file fe-trace.c.

167{
168 int len;
169
170 if (suppress)
171 {
172 fprintf(pfdebug, " \"SSSS\"");
173 *cursor += strlen(data + *cursor) + 1;
174 }
175 else
176 {
177 len = fprintf(pfdebug, " \"%s\"", data + *cursor);
178
179 /*
180 * This is a null-terminated string. So add 1 after subtracting 3
181 * which is the double quotes and space length from len.
182 */
183 *cursor += (len - 3 + 1);
184 }
185}

References data, fprintf, and len.

Referenced by pqTraceOutput_Authentication(), pqTraceOutput_Bind(), pqTraceOutput_Close(), pqTraceOutput_CommandComplete(), pqTraceOutput_CopyFail(), pqTraceOutput_Describe(), pqTraceOutput_Execute(), pqTraceOutput_NotificationResponse(), pqTraceOutput_ParameterStatus(), pqTraceOutput_Parse(), pqTraceOutput_PasswordMessage(), pqTraceOutput_Query(), pqTraceOutput_RowDescription(), pqTraceOutput_SASLInitialResponse(), pqTraceOutputNoTypeByteMessage(), and pqTraceOutputNR().

◆ PQuntrace()

void PQuntrace ( PGconn conn)

Definition at line 49 of file fe-trace.c.

50{
51 if (conn == NULL)
52 return;
53 if (conn->Pfdebug)
54 {
56 conn->Pfdebug = NULL;
57 }
58
59 conn->traceFlags = 0;
60}
static void const char fflush(stdout)

References conn, fflush(), pg_conn::Pfdebug, and pg_conn::traceFlags.

Referenced by PQtrace().