1999-08-16 21:50:52 +00:00
|
|
|
/*
|
2001-03-21 22:07:51 +00:00
|
|
|
******************************************************************************
|
2000-01-13 23:54:23 +00:00
|
|
|
*
|
2001-03-21 22:07:51 +00:00
|
|
|
* Copyright (C) 1998-2001, International Business Machines
|
2000-01-13 23:54:23 +00:00
|
|
|
* Corporation and others. All Rights Reserved.
|
|
|
|
*
|
2001-03-21 22:07:51 +00:00
|
|
|
******************************************************************************
|
1999-08-16 21:50:52 +00:00
|
|
|
*
|
|
|
|
* File uscanf.h
|
|
|
|
*
|
|
|
|
* Modification History:
|
|
|
|
*
|
|
|
|
* Date Name Description
|
|
|
|
* 12/02/98 stephen Creation.
|
|
|
|
* 03/13/99 stephen Modified for new C API.
|
2001-03-21 22:07:51 +00:00
|
|
|
******************************************************************************
|
1999-08-16 21:50:52 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef USCANF_H
|
|
|
|
#define USCANF_H
|
|
|
|
|
2002-10-01 01:26:49 +00:00
|
|
|
#include "unicode/utypes.h"
|
|
|
|
|
|
|
|
#if !UCONFIG_NO_FORMATTING
|
|
|
|
|
2000-01-05 19:40:01 +00:00
|
|
|
#include "unicode/ustdio.h"
|
1999-08-16 21:50:52 +00:00
|
|
|
#include "ufmt_cmn.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Struct encapsulating a single uscanf format specification.
|
|
|
|
*/
|
|
|
|
struct u_scanf_spec_info {
|
2003-10-02 17:05:26 +00:00
|
|
|
int32_t fWidth; /* Width */
|
1999-08-16 21:50:52 +00:00
|
|
|
|
2003-10-02 17:05:26 +00:00
|
|
|
UChar fSpec; /* Format specification */
|
1999-08-16 21:50:52 +00:00
|
|
|
|
2003-10-02 17:05:26 +00:00
|
|
|
UChar fPadChar; /* Padding character */
|
1999-08-16 21:50:52 +00:00
|
|
|
|
2003-10-02 17:05:26 +00:00
|
|
|
UBool fIsLongDouble; /* L flag */
|
|
|
|
UBool fIsShort; /* h flag */
|
2000-05-18 22:08:39 +00:00
|
|
|
UBool fIsLong; /* l flag */
|
2003-10-02 17:05:26 +00:00
|
|
|
UBool fIsLongLong; /* ll flag */
|
1999-08-16 21:50:52 +00:00
|
|
|
};
|
|
|
|
typedef struct u_scanf_spec_info u_scanf_spec_info;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A u_scanf handler function.
|
|
|
|
* A u_scanf handler is responsible for handling a single u_scanf
|
|
|
|
* format specification, for example 'd' or 's'.
|
|
|
|
* @param stream The UFILE to which to write output.
|
|
|
|
* @param info A pointer to a <TT>u_scanf_spec_info</TT> struct containing
|
|
|
|
* information on the format specification.
|
|
|
|
* @param args A pointer to the argument data
|
|
|
|
* @param fmt A pointer to the first character in the format string
|
|
|
|
* following the spec.
|
|
|
|
* @param consumed On output, set to the number of characters consumed
|
|
|
|
* in <TT>fmt</TT>.
|
|
|
|
* @return The number of arguments converted and assigned, or -1 if an
|
|
|
|
* error occurred.
|
|
|
|
*/
|
|
|
|
typedef int32_t (*u_scanf_handler) (UFILE *stream,
|
|
|
|
const u_scanf_spec_info *info,
|
|
|
|
ufmt_args *args,
|
|
|
|
const UChar *fmt,
|
|
|
|
int32_t *consumed);
|
|
|
|
|
2002-10-01 01:26:49 +00:00
|
|
|
#endif /* #if !UCONFIG_NO_FORMATTING */
|
1999-08-16 21:50:52 +00:00
|
|
|
|
2003-10-02 17:05:26 +00:00
|
|
|
#endif
|