1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4 * Copyright (C) 1997-2005, International Business Machines Corporation and others. All Rights Reserved.
5 *******************************************************************************
6 *
7 * File PARSEPOS.H
8 *
9 * Modification History:
10 *
11 *   Date        Name        Description
12 *   07/09/97    helena      Converted from java.
13 *   07/17/98    stephen     Added errorIndex support.
14 *   05/11/99    stephen     Cleaned up.
15 *******************************************************************************
16 */
17 
18 #ifndef PARSEPOS_H
19 #define PARSEPOS_H
20 
21 #include "unicode/utypes.h"
22 
23 #if U_SHOW_CPLUSPLUS_API
24 
25 #include "unicode/uobject.h"
26 
27 
28 U_NAMESPACE_BEGIN
29 
30 /**
31  * \file
32  * \brief C++ API: Canonical Iterator
33  */
34 /**
35  * <code>ParsePosition</code> is a simple class used by <code>Format</code>
36  * and its subclasses to keep track of the current position during parsing.
37  * The <code>parseObject</code> method in the various <code>Format</code>
38  * classes requires a <code>ParsePosition</code> object as an argument.
39  *
40  * <p>
41  * By design, as you parse through a string with different formats,
42  * you can use the same <code>ParsePosition</code>, since the index parameter
43  * records the current position.
44  *
45  * The ParsePosition class is not suitable for subclassing.
46  *
47  * @version     1.3 10/30/97
48  * @author      Mark Davis, Helena Shih
49  * @see         java.text.Format
50  */
51 
52 class U_COMMON_API ParsePosition : public UObject {
53 public:
54     /**
55      * Default constructor, the index starts with 0 as default.
56      * @stable ICU 2.0
57      */
ParsePosition()58     ParsePosition()
59         : UObject(),
60         index(0),
61         errorIndex(-1)
62       {}
63 
64     /**
65      * Create a new ParsePosition with the given initial index.
66      * @param newIndex the new text offset.
67      * @stable ICU 2.0
68      */
ParsePosition(int32_t newIndex)69     ParsePosition(int32_t newIndex)
70         : UObject(),
71         index(newIndex),
72         errorIndex(-1)
73       {}
74 
75     /**
76      * Copy constructor
77      * @param copy the object to be copied from.
78      * @stable ICU 2.0
79      */
ParsePosition(const ParsePosition & copy)80     ParsePosition(const ParsePosition& copy)
81         : UObject(copy),
82         index(copy.index),
83         errorIndex(copy.errorIndex)
84       {}
85 
86     /**
87      * Destructor
88      * @stable ICU 2.0
89      */
90     virtual ~ParsePosition();
91 
92     /**
93      * Assignment operator
94      * @stable ICU 2.0
95      */
96     inline ParsePosition&      operator=(const ParsePosition& copy);
97 
98     /**
99      * Equality operator.
100      * @return true if the two parse positions are equal, false otherwise.
101      * @stable ICU 2.0
102      */
103     inline bool               operator==(const ParsePosition& that) const;
104 
105     /**
106      * Equality operator.
107      * @return true if the two parse positions are not equal, false otherwise.
108      * @stable ICU 2.0
109      */
110     inline bool               operator!=(const ParsePosition& that) const;
111 
112     /**
113      * Clone this object.
114      * Clones can be used concurrently in multiple threads.
115      * If an error occurs, then NULL is returned.
116      * The caller must delete the clone.
117      *
118      * @return a clone of this object
119      *
120      * @see getDynamicClassID
121      * @stable ICU 2.8
122      */
123     ParsePosition *clone() const;
124 
125     /**
126      * Retrieve the current parse position.  On input to a parse method, this
127      * is the index of the character at which parsing will begin; on output, it
128      * is the index of the character following the last character parsed.
129      * @return the current index.
130      * @stable ICU 2.0
131      */
132     inline int32_t getIndex(void) const;
133 
134     /**
135      * Set the current parse position.
136      * @param index the new index.
137      * @stable ICU 2.0
138      */
139     inline void setIndex(int32_t index);
140 
141     /**
142      * Set the index at which a parse error occurred.  Formatters
143      * should set this before returning an error code from their
144      * parseObject method.  The default value is -1 if this is not
145      * set.
146      * @stable ICU 2.0
147      */
148     inline void setErrorIndex(int32_t ei);
149 
150     /**
151      * Retrieve the index at which an error occurred, or -1 if the
152      * error index has not been set.
153      * @stable ICU 2.0
154      */
155     inline int32_t getErrorIndex(void) const;
156 
157     /**
158      * ICU "poor man's RTTI", returns a UClassID for this class.
159      *
160      * @stable ICU 2.2
161      */
162     static UClassID U_EXPORT2 getStaticClassID();
163 
164     /**
165      * ICU "poor man's RTTI", returns a UClassID for the actual class.
166      *
167      * @stable ICU 2.2
168      */
169     virtual UClassID getDynamicClassID() const override;
170 
171 private:
172     /**
173      * Input: the place you start parsing.
174      * <br>Output: position where the parse stopped.
175      * This is designed to be used serially,
176      * with each call setting index up for the next one.
177      */
178     int32_t index;
179 
180     /**
181      * The index at which a parse error occurred.
182      */
183     int32_t errorIndex;
184 
185 };
186 
187 inline ParsePosition&
188 ParsePosition::operator=(const ParsePosition& copy)
189 {
190   index = copy.index;
191   errorIndex = copy.errorIndex;
192   return *this;
193 }
194 
195 inline bool
196 ParsePosition::operator==(const ParsePosition& copy) const
197 {
198   if(index != copy.index || errorIndex != copy.errorIndex)
199   return false;
200   else
201   return true;
202 }
203 
204 inline bool
205 ParsePosition::operator!=(const ParsePosition& copy) const
206 {
207   return !operator==(copy);
208 }
209 
210 inline int32_t
getIndex()211 ParsePosition::getIndex() const
212 {
213   return index;
214 }
215 
216 inline void
setIndex(int32_t offset)217 ParsePosition::setIndex(int32_t offset)
218 {
219   this->index = offset;
220 }
221 
222 inline int32_t
getErrorIndex()223 ParsePosition::getErrorIndex() const
224 {
225   return errorIndex;
226 }
227 
228 inline void
setErrorIndex(int32_t ei)229 ParsePosition::setErrorIndex(int32_t ei)
230 {
231   this->errorIndex = ei;
232 }
233 U_NAMESPACE_END
234 
235 #endif /* U_SHOW_CPLUSPLUS_API */
236 
237 #endif
238