123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- // © 2016 and later: Unicode, Inc. and others.
- // License & terms of use: http://www.unicode.org/copyright.html
- /*
- ******************************************************************************
- * Copyright (C) 1997-2012, International Business Machines
- * Corporation and others. All Rights Reserved.
- ******************************************************************************
- * file name: nfrlist.h
- * encoding: UTF-8
- * tab size: 8 (not used)
- * indentation:4
- *
- * Modification history
- * Date Name Comments
- * 10/11/2001 Doug Ported from ICU4J
- */
- #ifndef NFRLIST_H
- #define NFRLIST_H
- #include "unicode/rbnf.h"
- #if U_HAVE_RBNF
- #include "unicode/uobject.h"
- #include "nfrule.h"
- #include "cmemory.h"
- U_NAMESPACE_BEGIN
- // unsafe class for internal use only. assume memory allocations succeed, indexes are valid.
- // should be a template, but we can't use them
- class NFRuleList : public UMemory {
- protected:
- NFRule** fStuff;
- uint32_t fCount;
- uint32_t fCapacity;
- public:
- NFRuleList(uint32_t capacity = 10)
- : fStuff(capacity ? (NFRule**)uprv_malloc(capacity * sizeof(NFRule*)) : nullptr)
- , fCount(0)
- , fCapacity(capacity) {}
- ~NFRuleList() {
- if (fStuff) {
- for(uint32_t i = 0; i < fCount; ++i) {
- delete fStuff[i];
- }
- uprv_free(fStuff);
- }
- }
- NFRule* operator[](uint32_t index) const { return fStuff != nullptr ? fStuff[index] : nullptr; }
- NFRule* remove(uint32_t index) {
- if (fStuff == nullptr) {
- return nullptr;
- }
- NFRule* result = fStuff[index];
- fCount -= 1;
- for (uint32_t i = index; i < fCount; ++i) { // assumes small arrays
- fStuff[i] = fStuff[i+1];
- }
- return result;
- }
- void add(NFRule* thing) {
- if (fCount == fCapacity) {
- fCapacity += 10;
- fStuff = (NFRule**)uprv_realloc(fStuff, fCapacity * sizeof(NFRule*)); // assume success
- }
- if (fStuff != nullptr) {
- fStuff[fCount++] = thing;
- } else {
- fCapacity = 0;
- fCount = 0;
- }
- }
- uint32_t size() const { return fCount; }
- NFRule* last() const { return (fCount > 0 && fStuff != nullptr) ? fStuff[fCount-1] : nullptr; }
- NFRule** release() {
- add(nullptr); // ensure null termination
- NFRule** result = fStuff;
- fStuff = nullptr;
- fCount = 0;
- fCapacity = 0;
- return result;
- }
- void deleteAll() {
- NFRule** tmp = nullptr;
- int32_t size = fCount;
- if (size > 0) {
- tmp = release();
- for (int32_t i = 0; i < size; i++) {
- delete tmp[i];
- }
- if (tmp) {
- uprv_free(tmp);
- }
- }
- }
- private:
- NFRuleList(const NFRuleList &other); // forbid copying of this class
- NFRuleList &operator=(const NFRuleList &other); // forbid copying of this class
- };
- U_NAMESPACE_END
- /* U_HAVE_RBNF */
- #endif
- // NFRLIST_H
- #endif
|