LCOV - code coverage report
Current view: top level - disco/topo - fd_pod_format.h (source / functions) Hit Total Coverage
Test: cov.lcov Lines: 38 60 63.3 %
Date: 2025-01-08 12:08:44 Functions: 4 245 1.6 %

          Line data    Source code
       1             : #ifndef HEADER_fd_src_disco_topo_fd_pod_format_h
       2             : #define HEADER_fd_src_disco_topo_fd_pod_format_h
       3             : 
       4             : #include "../../util/pod/fd_pod.h"
       5             : 
       6             : #include <stdarg.h>
       7             : #include <stdio.h>
       8             : 
       9             : /* fd_pod_insertf_[type] inserts the [type] val into the pod at the
      10             :    given path.  The path is constructed from the given format string.
      11             :    Returns offset where val was inserted, 0 on failure.  The inserted
      12             :    representation might be compressed.  This offset is valid for the
      13             :    pod's lifetime or an invalidating operation is done on the pod.
      14             : 
      15             :    IMPORTANT!  THIS IS AN INVALIDATING OPERATION */
      16             : 
      17             : #define FD_POD_IMPL(type,TYPE)                                                  \
      18             : __attribute__ ((format (printf, 3, 4)))                                         \
      19             : static inline ulong                                                             \
      20             : fd_pod_insertf_##type( uchar      * FD_RESTRICT pod,                            \
      21             :                        type                     val,                            \
      22         411 :                        char const * FD_RESTRICT fmt, ... ) {                    \
      23         411 :   va_list ap;                                                                   \
      24         411 :   va_start( ap, fmt );                                                          \
      25         411 :   char buf[ 128UL ];                                                            \
      26         411 :   int   ret = vsnprintf( buf, 128UL, fmt, ap );                                 \
      27         411 :   ulong len = fd_ulong_if( ret<0, 0UL, fd_ulong_min( (ulong)ret, 128UL-1UL ) ); \
      28         411 :   buf[ len ] = '\0';                                                            \
      29         411 :   va_end( ap );                                                                 \
      30         411 :   if( FD_UNLIKELY( ret<0 || (ulong)ret>=128UL ) ) return 0UL;                   \
      31         411 :   return fd_pod_insert_##type( pod, buf, val );                                 \
      32         411 : }
      33             : 
      34             : FD_POD_IMPL( ushort, USHORT )
      35             : FD_POD_IMPL( uint,   UINT   )
      36             : FD_POD_IMPL( ulong,  ULONG  )
      37             : FD_POD_IMPL( short,  SHORT )
      38             : FD_POD_IMPL( int,    INT   )
      39             : FD_POD_IMPL( long,   LONG  )
      40             : FD_POD_IMPL( char,   CHAR   )
      41             : FD_POD_IMPL( schar,  SCHAR  )
      42             : FD_POD_IMPL( uchar,  UCHAR  )
      43             : FD_POD_IMPL( float,  FLOAT  )
      44             : #if FD_HAS_DOUBLE
      45             : FD_POD_IMPL( double, DOUBLE )
      46             : #endif
      47             : 
      48             : #undef FD_POD_IMPL
      49             : 
      50             : __attribute__ ((format (printf, 3, 4)))
      51             : static inline ulong
      52             : fd_pod_insertf_cstr( uchar      * FD_RESTRICT pod,
      53             :                      char const * FD_RESTRICT str,
      54           0 :                      char const * FD_RESTRICT fmt, ... ) {
      55           0 :   va_list ap;
      56           0 :   va_start( ap, fmt );
      57           0 :   char buf[ 128UL ];
      58           0 :   int   ret = vsnprintf( buf, 128UL, fmt, ap );
      59           0 :   ulong len = fd_ulong_if( ret<0, 0UL, fd_ulong_min( (ulong)ret, 128UL-1UL ) );
      60           0 :   buf[ len ] = '\0';
      61           0 :   va_end( ap );
      62           0 :   if( FD_UNLIKELY( ret<0 || (ulong)ret>=128UL ) ) return 0UL;
      63           0 :   return fd_pod_insert_cstr( pod, buf, str );
      64           0 : }
      65             : 
      66             : /* fd_pod_replacef_[type] replaces the [type] val into the pod at the
      67             :    given path.  The path is constructed from the given format string.
      68             :    If the path does not exist, it is created.  Returns FD_POD_SUCCESS
      69             :    on success, or FD_POD_ERR_* on failure.
      70             : 
      71             :    IMPORTANT!  THIS IS AN INVALIDATING OPERATION */
      72             : 
      73             : #define FD_POD_IMPL(type,TYPE)                                                  \
      74             : __attribute__ ((format (printf, 3, 4)))                                         \
      75             : static inline int                                                               \
      76             : fd_pod_replacef_##type( uchar      * FD_RESTRICT pod,                           \
      77             :                         type                     val,                           \
      78         138 :                         char const * FD_RESTRICT fmt, ... ) {                   \
      79         138 :   va_list ap;                                                                   \
      80         138 :   va_start( ap, fmt );                                                          \
      81         138 :   char buf[ 128UL ];                                                            \
      82         138 :   int   ret = vsnprintf( buf, 128UL, fmt, ap );                                 \
      83         138 :   ulong len = fd_ulong_if( ret<0, 0UL, fd_ulong_min( (ulong)ret, 128UL-1UL ) ); \
      84         138 :   buf[ len ] = '\0';                                                            \
      85         138 :   va_end( ap );                                                                 \
      86         138 :   if( FD_UNLIKELY( ret<0 || (ulong)ret>=128UL ) ) return 0UL;                   \
      87         138 :   int result = fd_pod_remove( pod, buf );                                       \
      88         138 :   if( FD_UNLIKELY( result!=FD_POD_SUCCESS && result!=FD_POD_ERR_RESOLVE ) )     \
      89         138 :     return result;                                                              \
      90         138 :   if( FD_UNLIKELY( !fd_pod_insert_##type( pod, buf, val ) ) )                   \
      91         138 :     return FD_POD_ERR_FULL;                                                     \
      92         138 :   return FD_POD_SUCCESS;                                                        \
      93         138 : }
      94             : 
      95             : FD_POD_IMPL( ushort, USHORT )
      96             : FD_POD_IMPL( uint,   UINT   )
      97             : FD_POD_IMPL( ulong,  ULONG  )
      98             : FD_POD_IMPL( short,  SHORT )
      99             : FD_POD_IMPL( int,    INT   )
     100             : FD_POD_IMPL( long,   LONG  )
     101             : FD_POD_IMPL( char,   CHAR   )
     102             : FD_POD_IMPL( schar,  SCHAR  )
     103             : FD_POD_IMPL( uchar,  UCHAR  )
     104             : FD_POD_IMPL( float,  FLOAT  )
     105             : #if FD_HAS_DOUBLE
     106             : FD_POD_IMPL( double, DOUBLE )
     107             : #endif
     108             : 
     109             : #undef FD_POD_IMPL
     110             : 
     111             : /* fd_pod_queryf_[type] queries for the [type] in pod at path.  The path
     112             :    is constructed from the given format string.  Returns the query
     113             :    result on success or def on failure. */
     114             : 
     115             : #define FD_POD_IMPL(type,TYPE)                                                  \
     116             : __attribute__ ((format (printf, 3, 4)))                                         \
     117             : static inline type                                                              \
     118             : fd_pod_queryf_##type( uchar const * FD_RESTRICT  pod,                           \
     119             :                       type                       def,                           \
     120        1029 :                       char const   * FD_RESTRICT fmt, ... ) {                   \
     121        1029 :   va_list ap;                                                                   \
     122        1029 :   va_start( ap, fmt );                                                          \
     123        1029 :   char buf[ 128UL ];                                                            \
     124        1029 :   int   ret = vsnprintf( buf, 128UL, fmt, ap );                                 \
     125        1029 :   ulong len = fd_ulong_if( ret<0, 0UL, fd_ulong_min( (ulong)ret, 128UL-1UL ) ); \
     126        1029 :   buf[ len ] = '\0';                                                            \
     127        1029 :   va_end( ap );                                                                 \
     128        1029 :   if( FD_UNLIKELY( ret<0 || (ulong)ret>=128UL ) ) return 0UL;                   \
     129        1029 :   return fd_pod_query_##type( pod, buf, def );                                  \
     130        1029 : }
     131             : 
     132             : FD_POD_IMPL( ushort, USHORT )
     133             : FD_POD_IMPL( uint,   UINT   )
     134             : FD_POD_IMPL( ulong,  ULONG  )
     135             : FD_POD_IMPL( short,  SHORT )
     136             : FD_POD_IMPL( int,    INT   )
     137             : FD_POD_IMPL( long,   LONG  )
     138             : FD_POD_IMPL( char,   CHAR   )
     139             : FD_POD_IMPL( schar,  SCHAR  )
     140             : FD_POD_IMPL( uchar,  UCHAR  )
     141             : FD_POD_IMPL( float,  FLOAT  )
     142             : #if FD_HAS_DOUBLE
     143             : FD_POD_IMPL( double, DOUBLE )
     144             : #endif
     145             : 
     146             : #undef FD_POD_IMPL
     147             : 
     148             : __attribute__ ((format (printf, 3, 4)))
     149             : static inline char const *
     150             : fd_pod_queryf_cstr( uchar const * FD_RESTRICT pod,
     151             :                     char const  * FD_RESTRICT def,
     152           0 :                     char const  * FD_RESTRICT fmt, ... ) {
     153           0 :   va_list ap;
     154           0 :   va_start( ap, fmt );
     155           0 :   char buf[ 128UL ];
     156           0 :   int   ret = vsnprintf( buf, 128UL, fmt, ap );
     157           0 :   ulong len = fd_ulong_if( ret<0, 0UL, fd_ulong_min( (ulong)ret, 128UL-1UL ) );
     158           0 :   buf[ len ] = '\0';
     159           0 :   va_end( ap );
     160           0 :   if( FD_UNLIKELY( ret<0 || (ulong)ret>=128UL ) ) return 0UL;
     161           0 :   return fd_pod_query_cstr( pod, buf, def );
     162           0 : }
     163             : 
     164             : #endif /* HEADER_fd_src_disco_topo_fd_pod_format_h */

Generated by: LCOV version 1.14