• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2 ********************************************************************************
3 *   Copyright (C) 2010, International Business Machines
4 *   Corporation and others.  All Rights Reserved.
5 ********************************************************************************
6 *
7 * File attiter.h
8 *
9 * Modification History:
10 *
11 *   Date        Name        Description
12 *   12/15/2009  dougfelt    Created
13 ********************************************************************************
14 */
15 
16 #ifndef FPOSITER_H
17 #define FPOSITER_H
18 
19 #include "unicode/utypes.h"
20 #include "unicode/uobject.h"
21 
22 /**
23  * \file
24  * \brief C++ API: FieldPosition Iterator.
25  */
26 
27 #if UCONFIG_NO_FORMATTING
28 
29 U_NAMESPACE_BEGIN
30 
31 /*
32  * Allow the declaration of APIs with pointers to FieldPositionIterator
33  * even when formatting is removed from the build.
34  */
35 class FieldPositionIterator;
36 
37 U_NAMESPACE_END
38 
39 #else
40 
41 #include "unicode/fieldpos.h"
42 #include "unicode/umisc.h"
43 
44 U_NAMESPACE_BEGIN
45 
46 class UVector32;
47 
48 /**
49  * FieldPositionIterator returns the field ids and their start/limit positions generated
50  * by a call to Format::format.  See Format, NumberFormat, DecimalFormat.
51  * @stable ICU 4.4
52  */
53 class U_I18N_API FieldPositionIterator : public UObject {
54 public:
55     /**
56      * Destructor.
57      * @stable ICU 4.4
58      */
59     ~FieldPositionIterator();
60 
61     /**
62      * Constructs a new, empty iterator.
63      * @stable ICU 4.4
64      */
65     FieldPositionIterator(void);
66 
67     /**
68      * Copy constructor.  If the copy failed for some reason, the new iterator will
69      * be empty.
70      * @stable ICU 4.4
71      */
72     FieldPositionIterator(const FieldPositionIterator&);
73 
74     /**
75      * Return true if another object is semantically equal to this
76      * one.
77      * <p>
78      * Return true if this FieldPositionIterator is at the same position in an
79      * equal array of run values.
80      * @stable ICU 4.4
81      */
82     UBool operator==(const FieldPositionIterator&) const;
83 
84     /**
85      * Returns the complement of the result of operator==
86      * @param rhs The FieldPositionIterator to be compared for inequality
87      * @return the complement of the result of operator==
88      * @stable ICU 4.4
89      */
90     UBool operator!=(const FieldPositionIterator& rhs) const { return !operator==(rhs); }
91 
92     /**
93      * If the current position is valid, updates the FieldPosition values, advances the iterator,
94      * and returns TRUE, otherwise returns FALSE.
95      * @stable ICU 4.4
96      */
97     UBool next(FieldPosition& fp);
98 
99     // BEGIN android-added
100     /**
101      * Returns the data.  If dest is null, returns the length of the data.
102      * Otherwise, if capacity is insufficient, returns the negative of the
103      * length of the data.  Otherwise, copies data into dest and returns
104      * the length of the data.
105      * @internal
106      */
107     int32_t getData(int32_t *dest, int32_t capacity) const;
108    // END android-added
109 
110 private:
111     friend class FieldPositionIteratorHandler;
112 
113     /**
114      * Sets the data used by the iterator, and resets the position.
115      * Returns U_ILLEGAL_ARGUMENT_ERROR in status if the data is not valid
116      * (length is not a multiple of 3, or start >= limit for any run).
117      */
118     void setData(UVector32 *adopt, UErrorCode& status);
119 
120     UVector32 *data;
121     int32_t pos;
122 
123     // No ICU "poor man's RTTI" for this class nor its subclasses.
124     virtual UClassID getDynamicClassID() const;
125 };
126 
127 U_NAMESPACE_END
128 
129 #endif /* #if !UCONFIG_NO_FORMATTING */
130 
131 #endif // FPOSITER_H
132