aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/icu/i18n/ufieldpositer.cpp
diff options
context:
space:
mode:
authormonster <monster@ydb.tech>2022-07-07 14:41:37 +0300
committermonster <monster@ydb.tech>2022-07-07 14:41:37 +0300
commit06e5c21a835c0e923506c4ff27929f34e00761c2 (patch)
tree75efcbc6854ef9bd476eb8bf00cc5c900da436a2 /contrib/libs/icu/i18n/ufieldpositer.cpp
parent03f024c4412e3aa613bb543cf1660176320ba8f4 (diff)
downloadydb-06e5c21a835c0e923506c4ff27929f34e00761c2.tar.gz
fix ya.make
Diffstat (limited to 'contrib/libs/icu/i18n/ufieldpositer.cpp')
-rw-r--r--contrib/libs/icu/i18n/ufieldpositer.cpp61
1 files changed, 61 insertions, 0 deletions
diff --git a/contrib/libs/icu/i18n/ufieldpositer.cpp b/contrib/libs/icu/i18n/ufieldpositer.cpp
new file mode 100644
index 0000000000..64de856c30
--- /dev/null
+++ b/contrib/libs/icu/i18n/ufieldpositer.cpp
@@ -0,0 +1,61 @@
+// © 2016 and later: Unicode, Inc. and others.
+// License & terms of use: http://www.unicode.org/copyright.html
+/*
+*****************************************************************************************
+* Copyright (C) 2015, International Business Machines
+* Corporation and others. All Rights Reserved.
+*****************************************************************************************
+*/
+
+#include "unicode/utypes.h"
+
+#if !UCONFIG_NO_FORMATTING
+
+#include "unicode/ufieldpositer.h"
+#include "unicode/fpositer.h"
+#include "unicode/localpointer.h"
+
+U_NAMESPACE_USE
+
+
+U_CAPI UFieldPositionIterator* U_EXPORT2
+ufieldpositer_open(UErrorCode* status)
+{
+ if (U_FAILURE(*status)) {
+ return NULL;
+ }
+ FieldPositionIterator* fpositer = new FieldPositionIterator();
+ if (fpositer == NULL) {
+ *status = U_MEMORY_ALLOCATION_ERROR;
+ }
+ return (UFieldPositionIterator*)fpositer;
+}
+
+
+U_CAPI void U_EXPORT2
+ufieldpositer_close(UFieldPositionIterator *fpositer)
+{
+ delete (FieldPositionIterator*)fpositer;
+}
+
+
+U_CAPI int32_t U_EXPORT2
+ufieldpositer_next(UFieldPositionIterator *fpositer,
+ int32_t *beginIndex, int32_t *endIndex)
+{
+ FieldPosition fp;
+ int32_t field = -1;
+ if (((FieldPositionIterator*)fpositer)->next(fp)) {
+ field = fp.getField();
+ if (beginIndex) {
+ *beginIndex = fp.getBeginIndex();
+ }
+ if (endIndex) {
+ *endIndex = fp.getEndIndex();
+ }
+ }
+ return field;
+}
+
+
+#endif /* #if !UCONFIG_NO_FORMATTING */