xchange v1.0
Structured data exchange for C/C++
Loading...
Searching...
No Matches
xchange.c File Reference

A collection of commonly used functions for standard data exchange for scalars and arrays, and ASCII representations. More...

Macros

#define __XCHANGE_INTERNAL_API__
 Use internal definitions.
 
#define EIXPLICIT_PARSE_SPECIAL_DOUBLES   TRUE
 

Functions

int x_error (int ret, int en, const char *from, const char *desc,...)
 
int x_trace (const char *loc, const char *op, int n)
 
void * x_trace_null (const char *loc, const char *op)
 
int x_warn (const char *from, const char *desc,...)
 
void * xAlloc (XType type, int count)
 
int xElementSizeOf (XType type)
 
int xError (const char *fn, int code)
 
const char * xErrorDescription (int code)
 
int xGetElementCount (int ndim, const int *sizes)
 
boolean xIsCharSequence (XType type)
 
boolean xIsDecimal (XType type)
 
boolean xIsInteger (XType type)
 
boolean xIsNumeric (XType type)
 
boolean xIsVerbose ()
 
boolean xParseBoolean (char *str, char **end)
 
int xParseDims (const char *src, int *sizes)
 
double xParseDouble (const char *str, char **tail)
 
int xPrintDims (char *dst, int ndim, const int *sizes)
 
int xPrintDouble (char *str, double value)
 
int xPrintFloat (char *str, float value)
 
void xSetDebug (boolean value)
 
void xSetVerbose (boolean value)
 
char * xStringCopyOf (const char *str)
 
int xStringElementSizeOf (XType type)
 
char xTypeChar (XType type)
 
void xZero (void *buf, XType type, int count)
 

Variables

boolean xDebug = FALSE
 Switch to enable debugging (very verbose) output for XChange operations.
 
boolean xVerbose
 Switch to enable verbose console output for XChange operations.
 

Detailed Description

A collection of commonly used functions for standard data exchange for scalars and arrays, and ASCII representations.

Date
Nov 25, 2020
Author
Attila Kovacs

Macro Definition Documentation

◆ EIXPLICIT_PARSE_SPECIAL_DOUBLES

#define EIXPLICIT_PARSE_SPECIAL_DOUBLES   TRUE

Check if we need to parse special floating point values, such as 'nan', 'infinity' or 'inf'... These were added in the C99 standard, at the same time as the constant INFINITY was added.

Function Documentation

◆ x_error()

int x_error ( int  ret,
int  en,
const char *  from,
const char *  desc,
  ... 
)

(for internal use) Sets errno and reports errors to the standard error, depending on the current debug mode, before returning the supplied return code.

Parameters
retreturn value
enUNIX error code (see errno.h)
fromfunction (:location) where error originated
descdescription of error, with information to convey to user.
See also
x_set_errno()
x_trace()

References xDebug.

◆ x_trace()

int x_trace ( const char *  loc,
const char *  op,
int  n 
)

(for internal use) Propagates an error (if any). If the error is non-zero, it returns with the offset error value. Otherwise it keeps going as if it weren't even there...

Parameters
locFunction [:location] where error was produced.
op(optional) further info or NULL.
nerror code that was received.
Returns
n

References xDebug.

◆ x_trace_null()

void * x_trace_null ( const char *  loc,
const char *  op 
)

(for internal use) Traces an error before returning NULL.

Parameters
locFunction [:location] where error was produced.
op(optional) further info or NULL.
Returns
NULL

References xDebug.

◆ x_warn()

int x_warn ( const char *  from,
const char *  desc,
  ... 
)

(for internal use) Prints a warning message.

Parameters
fromfunction (:location) where error originated
descdescription of error, with information to convey to user.
See also
x_set_errno()
x_trace()

References xDebug.

◆ xAlloc()

void * xAlloc ( XType  type,
int  count 
)

Allocates a buffer for a given SMA-X type and element count. The buffer is initialized with zeroes.

Parameters
typeSMA-X type
countnumber of elements.
Returns
Pointer to the initialized buffer or NULL if there was an error (errno will be set accordingly).

References x_error(), x_trace_null(), and xElementSizeOf().

◆ xElementSizeOf()

int xElementSizeOf ( XType  type)

Returns the storage byte size of a single element of a given type.

Parameters
typeThe data type, as defined in 'xchange.h'
Returns
[bytes] the native storage size of a single element of that type. E.g. for X_CHAR(20) it will return 20. X_DOUBLE will return 8, etc. Unrecognised types will return 0.

References X_BOOLEAN, X_BYTE, X_DOUBLE, X_FIELD, X_FLOAT, X_INT, X_LONG, X_RAW, X_SHORT, X_STRING, and X_STRUCT.

◆ xError()

int xError ( const char *  fn,
int  code 
)

Prints a descriptive error message to stderr, and returns the error code.

Parameters
fnString that describes the function or location where the error occurred.
codeThe xchange error code that describes the failure (see xchange.h).
Returns
Same error code as specified on input.

References X_ALREADY_OPEN, x_error(), X_FAILURE, X_GROUP_INVALID, X_INCOMPLETE, X_INTERRUPTED, X_NAME_INVALID, X_NO_BLOCKED_READ, X_NO_INIT, X_NO_PIPELINE, X_NO_SERVICE, X_NOT_ENOUGH_TOKENS, X_NULL, X_PARSE_ERROR, X_SIZE_INVALID, X_SUCCESS, X_TIMEDOUT, and X_TYPE_INVALID.

◆ xErrorDescription()

const char * xErrorDescription ( int  code)

Returns a string description for one of the standard X-change error codes, and sets errno as appropriate also. (The mapping to error codes is not one-to-one. The same errno may be used to describe different X-change errors. Nevertheless, it is a guide that can be used when the X-change error is not directtly available, e.g. because it is not returned by a given function.)

Parameters
codeOne of the error codes defined in 'xchange.h'
Returns
A constant string with the error description.

References X_ALREADY_OPEN, X_FAILURE, X_GROUP_INVALID, X_INCOMPLETE, X_INTERRUPTED, X_NAME_INVALID, X_NO_BLOCKED_READ, X_NO_INIT, X_NO_PIPELINE, X_NO_SERVICE, X_NOT_ENOUGH_TOKENS, X_NULL, X_PARSE_ERROR, X_SIZE_INVALID, X_SUCCESS, X_TIMEDOUT, and X_TYPE_INVALID.

◆ xGetElementCount()

int xGetElementCount ( int  ndim,
const int *  sizes 
)

Returns the total element count specified by along a number of dimensions. It ignores dimensions that have size components <= 0;

Parameters
ndimNumber of dimensions
sizesSizes along each dimension.
Returns
Total element count specified by the dimensions. Defaults to 1.

References x_error(), and X_MAX_DIMS.

◆ xIsCharSequence()

boolean xIsCharSequence ( XType  type)

Checks if the type represents a fixed-size character / binary sequence.

Parameters
typexchange type to check.
Returns
TRUE (1) if it is a type for a (fixed size) character array, otherwise FALSE (0).

◆ xIsDecimal()

boolean xIsDecimal ( XType  type)

Checks if the type represents a floating-point value of any width.

Parameters
typexchange type to check.
Returns
TRUE (1) if the type is for a floating-point value, or else FALSE (0)
See also
xIsInteger()
xIsNumeric()
xGetAsDouble()

References X_DOUBLE, and X_FLOAT.

◆ xIsInteger()

boolean xIsInteger ( XType  type)

Checks if the type represents a signed integer value of any width.

Parameters
typexchange type to check.
Returns
TRUE (1) if the type is for an integer value, or else FALSE (0)
See also
xIsDecimal()
xIsNumeric()
xGetAsLong()

References FALSE, TRUE, X_BOOLEAN, X_BYTE, X_INT, X_LONG, and X_SHORT.

◆ xIsNumeric()

boolean xIsNumeric ( XType  type)

Checks if the type represents a numerical value.

Parameters
typexchange type to check.
Returns
TRUE (1) if the type is for a number value, or else FALSE (0)
See also
xIsInteger()
xIsDecimal()

References xIsDecimal(), and xIsInteger().

◆ xIsVerbose()

boolean xIsVerbose ( )

Checks if verbosity is enabled for the xchange library.

Returns
TRUE (1) if verbosity is enabled, or else FALSE (0).
See also
xSetVerbose()
xSetDebug()

References xVerbose.

◆ xParseBoolean()

boolean xParseBoolean ( char *  str,
char **  end 
)

Parses a boolean value, either as a zero/non-zero number or as a case-insensitive match to the next token to one of the recognized boolean terms, such as "true"/"false", "on"/"off", "yes"/"no", "t"/"f", "y"/"n", "enabled"/"disabled" or "active"/"inactive". If a boolean value cannot be matched, FALSE is returned, and errno is set to ERANGE.

Parameters
strPointer to the string token.
endWhere the pointer to after the successfully parsed token is returned, on NULL.
Returns
TRUE (1) or FALSE (0).

References FALSE, TRUE, and x_error().

◆ xParseDims()

int xParseDims ( const char *  src,
int *  sizes 
)

Deserializes the sizes from a space-separated list of dimensions. The parsing will terminate at the first non integer value or the end of string, whichever comes first. Integer values <= 0 are ignored.

Parameters
srcPointer to a string buffer that contains the serialized dimensions, as a list of space separated integers.
sizesPointer to an array of ints (usually of X_MAX_DIMS size) to which the valid dimensions are deserialized.
Returns
Number of valid (i.e. positive) dimensions parsed.

References x_error(), and X_MAX_DIMS.

◆ xParseDouble()

double xParseDouble ( const char *  str,
char **  tail 
)

Same as strtod() on C99, but with explicit parsing of NaN and Infinity values on older platforms also.

Parameters
strString to parse floating-point value from
tail(optional) reference to pointed in which to return the parse position after successfully parsing a floating-point value.
Returns
the floating-point value at the head of the string, or NAN if the input string is NULL.

References INFINITY, NAN, and x_error().

◆ xPrintDims()

int xPrintDims ( char *  dst,
int  ndim,
const int *  sizes 
)

Serializes the dimensions to a string as a space-separated list of integers.

Parameters
[out]dstPointer to a string buffer with at least X_MAX_STRING_DIMS bytes size.
[in]ndimNumber of dimensions
[in]sizesSizes along each dimension.
Returns
Number of characters written into the destination buffer, not counting the string termination, or -1 if an the essential pointer arguments is NULL.

References x_error(), and X_MAX_DIMS.

◆ xPrintDouble()

int xPrintDouble ( char *  str,
double  value 
)

Prints a double precision number, restricted to IEEE double-precision range. If the native value has abolute value smaller than the smallest non-zero value, then 0 will printed instead. For values that exceed the IEEE double precision range, "nan" will be printed.

Parameters
strPointer to buffer for printed value.
valueValue to print.
Returns
Number of characters printed into the buffer, or -1 if there was an error.

References x_error().

◆ xPrintFloat()

int xPrintFloat ( char *  str,
float  value 
)

Prints a single-precision number, restricted to IEEE single-precision range. If the native value has abolute value smaller than the smallest non-zero value, then 0 will printed instead. For values that exceed the IEEE double precision range, "nan" will be printed.

Parameters
strPointer to buffer for printed value.
valueValue to print.
Returns
Number of characters printed into the buffer.

References x_error().

◆ xSetDebug()

void xSetDebug ( boolean  value)

Enables or disables debugging output.

Parameters
valueTRUE (non-zero) to enable verbose output, or else FALSE (0).
See also
xSetVerbose()

References FALSE, TRUE, and xDebug.

◆ xSetVerbose()

void xSetVerbose ( boolean  value)

Sets verbose output for the xchange library.

Parameters
valueTRUE (non-zero) to enable verbose output, or else FALSE (0).
See also
xIsVerbose()

References FALSE, TRUE, and xVerbose.

◆ xStringCopyOf()

char * xStringCopyOf ( const char *  str)

Returns a freshly allocated string with the same content as the argument.

Parameters
strPointer to string we want to copy.
Returns
A copy of the supplied string, or NULL if the argument itself was NULL.

◆ xStringElementSizeOf()

int xStringElementSizeOf ( XType  type)

Returns the number of characters, including a '\0' termination that a single element of the might be expected to fill.

Parameters
typeX-Change type to check.
Returns
Number of characters (including termination) required for the string representation of an element of the given variable, or 0 if the variable is of unknown type.

References X_BOOLEAN, X_BYTE, X_DOUBLE, x_error(), X_FLOAT, X_INT, X_LONG, and X_SHORT.

◆ xTypeChar()

char xTypeChar ( XType  type)

Returns the character of the field type. For X_CHAR types it returns 'C' (without the length specification), and for all other types it returns the constant XType value itself.

Parameters
typeThe single-character IF of the field type.
Returns
A character that represented the type.

References x_error().

◆ xZero()

void xZero ( void *  buf,
XType  type,
int  count 
)

Zeroes out the contents of an SMA-X buffer.

Parameters
bufPointer to the buffer to fill with zeroes.
typeSMA-X type
countnumber of elements.

References xElementSizeOf().