/* ****************************************************************************** * * Copyright (C) 2000-2001, International Business Machines * Corporation and others. All Rights Reserved. * ****************************************************************************** * * File sprintf.h * * Modification History: * * Date Name Description * 02/08/00 george Creation. Copied from uprintf.h ****************************************************************************** */ #ifndef USPRINTF_H #define USPRINTF_H #include "unicode/utypes.h" #include "unicode/ustdio.h" #include "ufmt_cmn.h" #include "locbund.h" /** * Struct encapsulating a single uprintf format specification. */ struct u_sprintf_spec_info { UChar fSpec; /* Conversion specification */ int32_t fPrecision; /* Precision */ int32_t fWidth; /* Width */ UChar fPadChar; /* Padding character */ UBool fAlt; /* # flag */ UBool fSpace; /* Space flag */ UBool fLeft; /* - flag */ UBool fShowSign; /* + flag */ UBool fZero; /* 0 flag */ UBool fIsLongDouble; /* L flag */ UBool fIsShort; /* h flag */ UBool fIsLong; /* l flag */ UBool fIsLongLong; /* ll flag */ }; typedef struct u_sprintf_spec_info u_sprintf_spec_info; struct u_localized_string { UChar *str; /* Place to write the string */ int32_t available;/* Number of codeunits available to write to */ int32_t len; /* Maximum number of code units that can be written to output */ ULocaleBundle *fBundle; /* formatters */ UBool fOwnBundle; /* TRUE if fBundle should be deleted */ }; typedef struct u_localized_string u_localized_string; /** * 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 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_sprintf_handler) (u_localized_string *output, const u_sprintf_spec_info *info, const ufmt_args *args); #endif