LCOV - code coverage report
Current view: top level - src/bin/pg_waldump - logicalmsgdesc.c (source / functions) Hit Total Coverage
Test: PostgreSQL 18devel Lines: 17 18 94.4 %
Date: 2024-12-12 18:14:58 Functions: 2 2 100.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /*-------------------------------------------------------------------------
       2             :  *
       3             :  * logicalmsgdesc.c
       4             :  *    rmgr descriptor routines for replication/logical/message.c
       5             :  *
       6             :  * Portions Copyright (c) 2015-2024, PostgreSQL Global Development Group
       7             :  *
       8             :  *
       9             :  * IDENTIFICATION
      10             :  *    src/backend/access/rmgrdesc/logicalmsgdesc.c
      11             :  *
      12             :  *-------------------------------------------------------------------------
      13             :  */
      14             : #include "postgres.h"
      15             : 
      16             : #include "replication/message.h"
      17             : 
      18             : void
      19          12 : logicalmsg_desc(StringInfo buf, XLogReaderState *record)
      20             : {
      21          12 :     char       *rec = XLogRecGetData(record);
      22          12 :     uint8       info = XLogRecGetInfo(record) & ~XLR_INFO_MASK;
      23             : 
      24          12 :     if (info == XLOG_LOGICAL_MESSAGE)
      25             :     {
      26          12 :         xl_logical_message *xlrec = (xl_logical_message *) rec;
      27          12 :         char       *prefix = xlrec->message;
      28          12 :         char       *message = xlrec->message + xlrec->prefix_size;
      29          12 :         char       *sep = "";
      30             : 
      31             :         Assert(prefix[xlrec->prefix_size - 1] == '\0');
      32             : 
      33          12 :         appendStringInfo(buf, "%s, prefix \"%s\"; payload (%zu bytes): ",
      34          12 :                          xlrec->transactional ? "transactional" : "non-transactional",
      35             :                          prefix, xlrec->message_size);
      36             :         /* Write message payload as a series of hex bytes */
      37          48 :         for (int cnt = 0; cnt < xlrec->message_size; cnt++)
      38             :         {
      39          36 :             appendStringInfo(buf, "%s%02X", sep, (unsigned char) message[cnt]);
      40          36 :             sep = " ";
      41             :         }
      42             :     }
      43          12 : }
      44             : 
      45             : const char *
      46          14 : logicalmsg_identify(uint8 info)
      47             : {
      48          14 :     if ((info & ~XLR_INFO_MASK) == XLOG_LOGICAL_MESSAGE)
      49          14 :         return "MESSAGE";
      50             : 
      51           0 :     return NULL;
      52             : }

Generated by: LCOV version 1.14