LCOV - differential code coverage report
Current view: top level - src/include/utils - varbit.h (source / functions) Coverage Total Hit CBC
Current: Differential Code Coverage 16@8cea358b128 vs 17@8cea358b128 Lines: 100.0 % 4 4 4
Current Date: 2024-04-14 14:21:10 Functions: 100.0 % 2 2 2
Baseline: 16@8cea358b128 Branches: - 0 0
Baseline Date: 2024-04-14 14:21:09 Line coverage date bins:
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed (240..) days: 100.0 % 4 4 4
Function coverage date bins:
(240..) days: 100.0 % 2 2 2

 Age         Owner                    Branch data    TLA  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-2024, 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 postgres.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 *
  565 peter@eisentraut.org       45                 :CBC       52174 : DatumGetVarBitP(Datum X)
                                 46                 :                : {
                                 47                 :          52174 :     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                 :           8343 : VarBitPGetDatum(const VarBit *X)
                                 58                 :                : {
                                 59                 :           8343 :     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.1-beta2-3-g6141622