2017-01-20 00:20:31 +00:00
|
|
|
// © 2016 and later: Unicode, Inc. and others.
|
2016-06-15 18:58:17 +00:00
|
|
|
// License & terms of use: http://www.unicode.org/copyright.html
|
2002-07-09 06:15:34 +00:00
|
|
|
/*
|
|
|
|
*******************************************************************************
|
|
|
|
*
|
2016-05-31 21:45:07 +00:00
|
|
|
* Copyright (C) 2002-2006, International Business Machines
|
|
|
|
* Corporation and others. All Rights Reserved.
|
2002-07-09 06:15:34 +00:00
|
|
|
*
|
|
|
|
*******************************************************************************
|
|
|
|
* file name: uenumimp.h
|
2017-02-03 18:57:23 +00:00
|
|
|
* encoding: UTF-8
|
2002-07-09 06:15:34 +00:00
|
|
|
* tab size: 8 (not used)
|
|
|
|
* indentation:2
|
|
|
|
*
|
|
|
|
* created on: 2002jul08
|
|
|
|
* created by: Vladimir Weinstein
|
|
|
|
*/
|
|
|
|
|
2002-07-08 23:04:59 +00:00
|
|
|
#ifndef __UENUMIMP_H
|
|
|
|
#define __UENUMIMP_H
|
|
|
|
|
|
|
|
#include "unicode/uenum.h"
|
|
|
|
|
2002-07-13 16:31:03 +00:00
|
|
|
U_CDECL_BEGIN
|
|
|
|
|
2002-07-09 18:19:16 +00:00
|
|
|
/**
|
|
|
|
* following are the type declarations for
|
|
|
|
* implementations of APIs. If any of these
|
|
|
|
* functions are NULL, U_UNSUPPORTED_ERROR
|
|
|
|
* is returned. If close is NULL, the enumeration
|
|
|
|
* object is going to be released.
|
|
|
|
* Initial error checking is done in the body
|
|
|
|
* of API function, so the implementations
|
|
|
|
* need not to check the initial error condition.
|
|
|
|
*/
|
|
|
|
|
2002-07-09 06:15:34 +00:00
|
|
|
/**
|
|
|
|
* Function type declaration for uenum_close().
|
|
|
|
*
|
|
|
|
* This function should cleanup the enumerator object
|
|
|
|
*
|
|
|
|
* @param en enumeration to be closed
|
|
|
|
*/
|
|
|
|
typedef void U_CALLCONV
|
|
|
|
UEnumClose(UEnumeration *en);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function type declaration for uenum_count().
|
|
|
|
*
|
|
|
|
* This function should count the number of elements
|
|
|
|
* in this enumeration
|
|
|
|
*
|
|
|
|
* @param en enumeration to be counted
|
|
|
|
* @param status pointer to UErrorCode variable
|
|
|
|
* @return number of elements in enumeration
|
|
|
|
*/
|
|
|
|
typedef int32_t U_CALLCONV
|
|
|
|
UEnumCount(UEnumeration *en, UErrorCode *status);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function type declaration for uenum_unext().
|
|
|
|
*
|
2006-08-06 22:38:31 +00:00
|
|
|
* This function returns the next element as a UChar *,
|
|
|
|
* or NULL after all elements haven been enumerated.
|
2002-07-09 06:15:34 +00:00
|
|
|
*
|
|
|
|
* @param en enumeration
|
|
|
|
* @param resultLength pointer to result length
|
|
|
|
* @param status pointer to UErrorCode variable
|
2006-08-06 22:38:31 +00:00
|
|
|
* @return next element as UChar *,
|
|
|
|
* or NULL after all elements haven been enumerated
|
2002-07-09 06:15:34 +00:00
|
|
|
*/
|
|
|
|
typedef const UChar* U_CALLCONV
|
|
|
|
UEnumUNext(UEnumeration* en,
|
|
|
|
int32_t* resultLength,
|
|
|
|
UErrorCode* status);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function type declaration for uenum_next().
|
|
|
|
*
|
2006-08-06 22:38:31 +00:00
|
|
|
* This function returns the next element as a char *,
|
|
|
|
* or NULL after all elements haven been enumerated.
|
2002-07-09 06:15:34 +00:00
|
|
|
*
|
|
|
|
* @param en enumeration
|
|
|
|
* @param resultLength pointer to result length
|
|
|
|
* @param status pointer to UErrorCode variable
|
2006-08-06 22:38:31 +00:00
|
|
|
* @return next element as char *,
|
|
|
|
* or NULL after all elements haven been enumerated
|
2002-07-09 06:15:34 +00:00
|
|
|
*/
|
|
|
|
typedef const char* U_CALLCONV
|
|
|
|
UEnumNext(UEnumeration* en,
|
|
|
|
int32_t* resultLength,
|
|
|
|
UErrorCode* status);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function type declaration for uenum_reset().
|
|
|
|
*
|
|
|
|
* This function should reset the enumeration
|
|
|
|
* object
|
|
|
|
*
|
|
|
|
* @param en enumeration
|
|
|
|
* @param status pointer to UErrorCode variable
|
|
|
|
*/
|
|
|
|
typedef void U_CALLCONV
|
|
|
|
UEnumReset(UEnumeration* en,
|
|
|
|
UErrorCode* status);
|
|
|
|
|
|
|
|
|
2002-07-08 23:04:59 +00:00
|
|
|
struct UEnumeration {
|
2002-08-02 23:01:10 +00:00
|
|
|
/* baseContext. For the base class only. Don't touch! */
|
|
|
|
void *baseContext;
|
|
|
|
|
|
|
|
/* context. Use it for what you need */
|
|
|
|
void *context;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* these are functions that will
|
|
|
|
* be used for APIs
|
|
|
|
*/
|
|
|
|
/* called from uenum_close */
|
|
|
|
UEnumClose *close;
|
|
|
|
/* called from uenum_count */
|
|
|
|
UEnumCount *count;
|
|
|
|
/* called from uenum_unext */
|
|
|
|
UEnumUNext *uNext;
|
|
|
|
/* called from uenum_next */
|
|
|
|
UEnumNext *next;
|
|
|
|
/* called from uenum_reset */
|
|
|
|
UEnumReset *reset;
|
2002-07-08 23:04:59 +00:00
|
|
|
};
|
|
|
|
|
2002-07-13 16:31:03 +00:00
|
|
|
U_CDECL_END
|
|
|
|
|
2002-08-02 23:01:10 +00:00
|
|
|
/* This is the default implementation for uenum_unext().
|
|
|
|
* It automatically converts the char * string to UChar *.
|
2002-10-11 20:20:46 +00:00
|
|
|
* Don't call this directly. This is called internally by uenum_unext
|
|
|
|
* when a UEnumeration is defined with 'uNext' pointing to this
|
|
|
|
* function.
|
2002-08-02 23:01:10 +00:00
|
|
|
*/
|
|
|
|
U_CAPI const UChar* U_EXPORT2
|
|
|
|
uenum_unextDefault(UEnumeration* en,
|
|
|
|
int32_t* resultLength,
|
|
|
|
UErrorCode* status);
|
|
|
|
|
2002-10-11 20:20:46 +00:00
|
|
|
/* This is the default implementation for uenum_next().
|
|
|
|
* It automatically converts the UChar * string to char *.
|
|
|
|
* Don't call this directly. This is called internally by uenum_next
|
|
|
|
* when a UEnumeration is defined with 'next' pointing to this
|
|
|
|
* function.
|
|
|
|
*/
|
|
|
|
U_CAPI const char* U_EXPORT2
|
|
|
|
uenum_nextDefault(UEnumeration* en,
|
|
|
|
int32_t* resultLength,
|
|
|
|
UErrorCode* status);
|
2002-07-09 18:19:16 +00:00
|
|
|
|
2002-07-08 23:04:59 +00:00
|
|
|
#endif
|