From 0c431303cc7f0e91c70e06126353072e9a9bdb05 Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Wed, 11 Jan 2017 11:03:24 +0100 Subject: Add rtems_assoc_32_to_string() --- cpukit/libcsupport/Makefile.am | 1 + cpukit/libcsupport/include/rtems/assoc.h | 33 ++++++++++++++++- cpukit/libcsupport/src/assoc32tostring.c | 61 ++++++++++++++++++++++++++++++++ 3 files changed, 94 insertions(+), 1 deletion(-) create mode 100644 cpukit/libcsupport/src/assoc32tostring.c (limited to 'cpukit') diff --git a/cpukit/libcsupport/Makefile.am b/cpukit/libcsupport/Makefile.am index 559ad81446..ec5dd02832 100644 --- a/cpukit/libcsupport/Makefile.am +++ b/cpukit/libcsupport/Makefile.am @@ -38,6 +38,7 @@ ASSOCIATION_C_FILES = src/assoclocalbyname.c \ src/assocnamebyremote.c src/assocptrbylocal.c src/assocptrbyname.c \ src/assocptrbyremote.c src/assocremotebylocalbitfield.c \ src/assocremotebylocal.c src/assocremotebyname.c +ASSOCIATION_C_FILES += src/assoc32tostring.c BASE_FS_C_FILES = src/base_fs.c src/mount.c src/unmount.c src/libio.c \ src/mount-mgr.c src/mount-mktgt.c src/libio_init.c \ diff --git a/cpukit/libcsupport/include/rtems/assoc.h b/cpukit/libcsupport/include/rtems/assoc.h index c4933159e0..9f65ba60a4 100644 --- a/cpukit/libcsupport/include/rtems/assoc.h +++ b/cpukit/libcsupport/include/rtems/assoc.h @@ -16,7 +16,8 @@ */ /**@{*/ -#include /* uint32_t */ +#include +#include #ifdef __cplusplus extern "C" { @@ -150,6 +151,36 @@ const char *rtems_assoc_name_bad( ); #endif +typedef struct { + uint32_t bits; + const char *name; +} rtems_assoc_32_pair; + +/** + * @brief Converts the specified value into a text representation. + * + * @param[in] value The value to convert. + * @param[in] buffer The buffer for the text representation. + * @param[in] buffer_size The buffer size in characters. + * @param[in] pairs Names for particular bits. + * @param[in] pair_count Count of pairs. + * @param[in] separator Separator between individual names. + * @param[in] fallback Fallback value in case no bits contained in the pairs + * are set in the value. + * + * @retval The length of the text representation. May be greater than the + * buffer size if truncation occurred. + */ +size_t rtems_assoc_32_to_string( + uint32_t value, + char *buffer, + size_t buffer_size, + const rtems_assoc_32_pair *pairs, + size_t pair_count, + const char *separator, + const char *fallback +); + #ifdef __cplusplus } #endif diff --git a/cpukit/libcsupport/src/assoc32tostring.c b/cpukit/libcsupport/src/assoc32tostring.c new file mode 100644 index 0000000000..31b08857d3 --- /dev/null +++ b/cpukit/libcsupport/src/assoc32tostring.c @@ -0,0 +1,61 @@ +/* + * Copyright (c) 2016 embedded brains GmbH. + * + * The license and distribution terms for this file may be + * found in the file LICENSE in this distribution or at + * http://www.rtems.org/license/LICENSE. + */ + +#if HAVE_CONFIG_H +#include "config.h" +#endif + +#include + +#include +#include + +static size_t space( size_t buffer_size, size_t len ) +{ + if ( len < buffer_size ) { + return buffer_size - len; + } else { + return 0; + } +} + +size_t rtems_assoc_32_to_string( + uint32_t value, + char *buffer, + size_t buffer_size, + const rtems_assoc_32_pair *pairs, + size_t pair_count, + const char *separator, + const char *fallback +) +{ + size_t len; + size_t i; + + len = 0; + + for ( i = 0; i < pair_count ; ++i ) { + const rtems_assoc_32_pair *p; + + p = &pairs[ i ]; + + if ( ( value & p->bits ) != 0 ) { + if ( len > 0 ) { + len += strlcpy( &buffer[ len ], separator, space( buffer_size, len ) ); + } + + len += strlcpy( &buffer[ len ], p->name, space( buffer_size, len ) ); + } + } + + if ( len == 0 ) { + len += strlcpy( buffer, fallback, buffer_size ); + } + + return len; +} -- cgit v1.2.3