/* ******************************************************************************* * * Copyright (C) 1998-1999, International Business Machines * Corporation and others. All Rights Reserved. * ******************************************************************************* * * File uprintf.h * * Modification History: * * Date Name Description * 11/19/98 stephen Creation. * 03/12/99 stephen Modified for new C API. ******************************************************************************* */ #ifndef UPRINTF_H #define UPRINTF_H #include "unicode/utypes.h" #include "unicode/ustdio.h" #include "ufmt_cmn.h" /** * Struct encapsulating a single uprintf format specification. */ struct u_printf_spec_info { UChar fSpec; /* Conversion specification */ int32_t fPrecision; /* Precision */ int32_t fWidth; /* Width */ UChar fPadChar; /* Padding character */ bool_t fAlt; /* # flag */ bool_t fSpace; /* Space flag */ bool_t fLeft; /* - flag */ bool_t fShowSign; /* + flag */ bool_t fZero; /* 0 flag */ bool_t fIsLongDouble; /* L flag */ bool_t fIsShort; /* h flag */ bool_t fIsLong; /* l flag */ bool_t fIsLongLong; /* ll flag */ }; typedef struct u_printf_spec_info u_printf_spec_info; /** * A u_printf info function. * A u_printf info is reponsible for reporting to u_printf how many * arguments are required for the u_printf_spec_info info, * and what their types are. * @param info A pointer to a u_print_info struct containing * information on the format specification. * @param argtypes The array to receive the types of arguments specified * by info. * @param n The number of available slots in the array argtypes * @return The number of arguments required by info. */ typedef int32_t (*u_printf_info) (const u_printf_spec_info *info, int32_t *argtypes, int32_t n); /** * A u_printf handler function. * A u_printf handler is responsible for handling a single u_printf * format specification, for example 'd' or 's'. * @param stream The UFILE to which to write output. * @param info A pointer to a u_printf_spec_info struct containing * information on the format specification. * @param args A pointer to the argument data * @return The number of Unicode characters written to stream. */ typedef int32_t (*u_printf_handler) (UFILE *stream, const u_printf_spec_info *info, const ufmt_args *args); /** * Register a uprintf handler function with uprintf. * @param spec The format specififier handled by the handler func. * @param info A pointer to the uprintf_info function used * to determine how many arguments are required for spec, and * what their types are. * @param handler A pointer to the uprintf_handler function. * @return 0 if successful */ int32_t u_printf_register_handler(UChar spec, u_printf_info info, u_printf_handler handler); #endif