LCOV - code coverage report
Current view: top level - src/include/utils - varbit.h (source / functions) Coverage Total Hit
Test: Code coverage Lines: 100.0 % 4 4
Test Date: 2026-01-26 10:56:24 Functions: 100.0 % 2 2
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /*-------------------------------------------------------------------------
       2              :  *
       3              :  * varbit.h
       4              :  *        Functions for the SQL datatypes BIT() and BIT VARYING().
       5              :  *
       6              :  * Code originally contributed by Adriaan Joubert.
       7              :  *
       8              :  * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
       9              :  * Portions Copyright (c) 1994, Regents of the University of California
      10              :  *
      11              :  * src/include/utils/varbit.h
      12              :  *
      13              :  *-------------------------------------------------------------------------
      14              :  */
      15              : #ifndef VARBIT_H
      16              : #define VARBIT_H
      17              : 
      18              : #include <limits.h>
      19              : 
      20              : #include "fmgr.h"
      21              : 
      22              : /*
      23              :  * Modeled on struct varlena from c.h, but data type is bits8.
      24              :  *
      25              :  * Caution: if bit_len is not a multiple of BITS_PER_BYTE, the low-order
      26              :  * bits of the last byte of bit_dat[] are unused and MUST be zeroes.
      27              :  * (This allows bit_cmp() to not bother masking the last byte.)
      28              :  * Also, there should not be any excess bytes counted in the header length.
      29              :  */
      30              : typedef struct
      31              : {
      32              :         int32           vl_len_;                /* varlena header (do not touch directly!) */
      33              :         int32           bit_len;                /* number of valid bits */
      34              :         bits8           bit_dat[FLEXIBLE_ARRAY_MEMBER]; /* bit string, most sig. byte
      35              :                                                                                                  * first */
      36              : } VarBit;
      37              : 
      38              : /*
      39              :  * fmgr interface macros
      40              :  *
      41              :  * BIT and BIT VARYING are toastable varlena types.  They are the same
      42              :  * as far as representation goes, so we just have one set of macros.
      43              :  */
      44              : static inline VarBit *
      45        10782 : DatumGetVarBitP(Datum X)
      46              : {
      47        10782 :         return (VarBit *) PG_DETOAST_DATUM(X);
      48              : }
      49              : 
      50              : static inline VarBit *
      51              : DatumGetVarBitPCopy(Datum X)
      52              : {
      53              :         return (VarBit *) PG_DETOAST_DATUM_COPY(X);
      54              : }
      55              : 
      56              : static inline Datum
      57         2330 : VarBitPGetDatum(const VarBit *X)
      58              : {
      59         2330 :         return PointerGetDatum(X);
      60              : }
      61              : 
      62              : #define PG_GETARG_VARBIT_P(n)      DatumGetVarBitP(PG_GETARG_DATUM(n))
      63              : #define PG_GETARG_VARBIT_P_COPY(n) DatumGetVarBitPCopy(PG_GETARG_DATUM(n))
      64              : #define PG_RETURN_VARBIT_P(x)      return VarBitPGetDatum(x)
      65              : 
      66              : /* Header overhead *in addition to* VARHDRSZ */
      67              : #define VARBITHDRSZ                     sizeof(int32)
      68              : /* Number of bits in this bit string */
      69              : #define VARBITLEN(PTR)          (((VarBit *) (PTR))->bit_len)
      70              : /* Pointer to the first byte containing bit string data */
      71              : #define VARBITS(PTR)            (((VarBit *) (PTR))->bit_dat)
      72              : /* Number of bytes in the data section of a bit string */
      73              : #define VARBITBYTES(PTR)        (VARSIZE(PTR) - VARHDRSZ - VARBITHDRSZ)
      74              : /* Padding of the bit string at the end (in bits) */
      75              : #define VARBITPAD(PTR)          (VARBITBYTES(PTR)*BITS_PER_BYTE - VARBITLEN(PTR))
      76              : /* Number of bytes needed to store a bit string of a given length */
      77              : #define VARBITTOTALLEN(BITLEN)  (((BITLEN) + BITS_PER_BYTE-1)/BITS_PER_BYTE + \
      78              :                                                                  VARHDRSZ + VARBITHDRSZ)
      79              : /*
      80              :  * Maximum number of bits.  Several code sites assume no overflow from
      81              :  * computing bitlen + X; VARBITTOTALLEN() has the largest such X.
      82              :  */
      83              : #define VARBITMAXLEN            (INT_MAX - BITS_PER_BYTE + 1)
      84              : /* pointer beyond the end of the bit string (like end() in STL containers) */
      85              : #define VARBITEND(PTR)          (((bits8 *) (PTR)) + VARSIZE(PTR))
      86              : /* Mask that will cover exactly one byte, i.e. BITS_PER_BYTE bits */
      87              : #define BITMASK 0xFF
      88              : 
      89              : #endif
        

Generated by: LCOV version 2.3.2-1