diff options
author | vvvv <vvvv@yandex-team.ru> | 2022-03-03 23:09:11 +0300 |
---|---|---|
committer | vvvv <vvvv@yandex-team.ru> | 2022-03-03 23:09:11 +0300 |
commit | 8dbdbab054b6eb352cfffdad09991052008062fc (patch) | |
tree | 71befed92d327f2cc409bff4986ec510d0530d92 /contrib/libs/icu/i18n/ufieldpositer.cpp | |
parent | ed3f4e21f3a3837059607ec2606e1dc910269ac0 (diff) | |
download | ydb-8dbdbab054b6eb352cfffdad09991052008062fc.tar.gz |
YQL-13710 try to switch to new shiny PG
ref:2bed0445c8e8bd6c575883632adf19445f0a72a7
Diffstat (limited to 'contrib/libs/icu/i18n/ufieldpositer.cpp')
-rw-r--r-- | contrib/libs/icu/i18n/ufieldpositer.cpp | 61 |
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 */ |