scuffed-code/icu4c/source/common/uchriter.cpp

358 lines
7.4 KiB
C++
Raw Normal View History

1999-08-16 21:50:52 +00:00
/*
*******************************************************************************
* Copyright (C) 1998-1999, International Business Machines Corporation and *
* others. All Rights Reserved. *
1999-08-16 21:50:52 +00:00
*******************************************************************************
*/
#include "unicode/uchriter.h"
#include "uhash.h"
UCharCharacterIterator::UCharCharacterIterator()
: CharacterIterator(),
text(0)
{
// never default construct!
}
1999-08-16 21:50:52 +00:00
UCharCharacterIterator::UCharCharacterIterator(const UChar* text,
int32_t textLength)
: CharacterIterator(text != 0 ? textLength : 0),
text(text)
1999-08-16 21:50:52 +00:00
{
}
UCharCharacterIterator::UCharCharacterIterator(const UChar* text,
int32_t textLength,
UTextOffset pos)
: CharacterIterator(text != 0 ? textLength : 0, pos),
text(text)
{
}
UCharCharacterIterator::UCharCharacterIterator(const UChar* text,
int32_t textLength,
UTextOffset begin,
UTextOffset end,
UTextOffset pos)
: CharacterIterator(text != 0 ? textLength : 0, begin, end, pos),
text(text)
{
1999-08-16 21:50:52 +00:00
}
UCharCharacterIterator::UCharCharacterIterator(const UCharCharacterIterator& that)
: CharacterIterator(that),
text(that.text)
1999-08-16 21:50:52 +00:00
{
}
UCharCharacterIterator&
UCharCharacterIterator::operator=(const UCharCharacterIterator& that) {
CharacterIterator::operator=(that);
1999-08-16 21:50:52 +00:00
text = that.text;
return *this;
}
UCharCharacterIterator::~UCharCharacterIterator() {
}
1999-08-16 21:50:52 +00:00
UBool
UCharCharacterIterator::operator==(const ForwardCharacterIterator& that) const {
if (this == &that) {
1999-08-16 21:50:52 +00:00
return TRUE;
}
1999-08-16 21:50:52 +00:00
if (getDynamicClassID() != that.getDynamicClassID()) {
1999-08-16 21:50:52 +00:00
return FALSE;
}
1999-08-16 21:50:52 +00:00
UCharCharacterIterator& realThat = (UCharCharacterIterator&)that;
return text == realThat.text
&& textLength == realThat.textLength
1999-08-16 21:50:52 +00:00
&& pos == realThat.pos
&& begin == realThat.begin
&& end == realThat.end;
}
int32_t
UCharCharacterIterator::hashCode() const {
return uhash_hashUCharsN(text, textLength) ^ pos ^ begin ^ end;
1999-08-16 21:50:52 +00:00
}
CharacterIterator*
UCharCharacterIterator::clone() const {
1999-08-16 21:50:52 +00:00
return new UCharCharacterIterator(*this);
}
UChar
UCharCharacterIterator::first() {
1999-08-16 21:50:52 +00:00
pos = begin;
if(pos < end) {
return text[pos];
} else {
return DONE;
}
1999-08-16 21:50:52 +00:00
}
UChar
UCharCharacterIterator::firstPostInc() {
pos = begin;
if(pos < end) {
return text[pos++];
} else {
return DONE;
}
1999-08-16 21:50:52 +00:00
}
UChar
UCharCharacterIterator::last() {
pos = end;
if(pos > begin) {
return text[--pos];
} else {
return DONE;
}
}
1999-08-16 21:50:52 +00:00
UChar
UCharCharacterIterator::setIndex(UTextOffset pos) {
if(pos < begin) {
pos = begin;
} else if(pos > end) {
pos = end;
}
this->pos = pos;
if(pos < end) {
1999-08-16 21:50:52 +00:00
return text[pos];
} else {
return DONE;
}
1999-08-16 21:50:52 +00:00
}
UChar
UCharCharacterIterator::current() const {
if (pos >= begin && pos < end) {
1999-08-16 21:50:52 +00:00
return text[pos];
} else {
return DONE;
1999-08-16 21:50:52 +00:00
}
}
UChar
UCharCharacterIterator::next() {
if (pos + 1 < end) {
return text[++pos];
} else {
/* make current() return DONE */
1999-08-16 21:50:52 +00:00
pos = end;
return DONE;
1999-08-16 21:50:52 +00:00
}
}
UChar
UCharCharacterIterator::nextPostInc() {
if (pos < end) {
return text[pos++];
} else {
return DONE;
}
}
UBool
UCharCharacterIterator::hasNext() {
return pos < end ? TRUE : FALSE;
}
UChar
UCharCharacterIterator::previous() {
if (pos > begin) {
1999-08-16 21:50:52 +00:00
return text[--pos];
} else {
return DONE;
}
}
UBool
UCharCharacterIterator::hasPrevious() {
return pos > begin ? TRUE : FALSE;
}
UChar32
UCharCharacterIterator::first32() {
pos = begin;
if(pos < end) {
UTextOffset i = pos;
UChar32 c;
UTF_NEXT_CHAR(text, i, end, c);
return c;
} else {
return DONE;
}
}
UChar32
UCharCharacterIterator::first32PostInc() {
pos = begin;
if(pos < end) {
UChar32 c;
UTF_NEXT_CHAR(text, pos, end, c);
return c;
} else {
return DONE;
}
}
UChar32
UCharCharacterIterator::last32() {
pos = end;
if(pos > begin) {
UChar32 c;
UTF_PREV_CHAR(text, begin, pos, c);
return c;
} else {
return DONE;
}
}
UChar32
UCharCharacterIterator::setIndex32(UTextOffset pos) {
if(pos < begin) {
pos = begin;
} else if(pos > end) {
pos = end;
}
if(pos < end) {
UTF_SET_CHAR_START(text, begin, pos);
UTextOffset i = this->pos = pos;
UChar32 c;
UTF_NEXT_CHAR(text, i, end, c);
return c;
} else {
this->pos = pos;
return DONE;
}
}
UChar32
UCharCharacterIterator::current32() const {
if (pos >= begin && pos < end) {
UChar32 c;
UTF_GET_CHAR(text, begin, pos, end, c);
return c;
} else {
return DONE;
}
}
UChar32
UCharCharacterIterator::next32() {
if (pos < end) {
UTF_FWD_1(text, pos, end);
if(pos < end) {
UTextOffset i = pos;
UChar32 c;
UTF_NEXT_CHAR(text, i, end, c);
return c;
}
}
/* make current() return DONE */
pos = end;
return DONE;
}
UChar32
UCharCharacterIterator::next32PostInc() {
if (pos < end) {
UChar32 c;
UTF_NEXT_CHAR(text, pos, end, c);
return c;
} else {
1999-08-16 21:50:52 +00:00
return DONE;
}
}
UChar32
UCharCharacterIterator::previous32() {
if (pos > begin) {
UChar32 c;
UTF_PREV_CHAR(text, begin, pos, c);
return c;
} else {
return DONE;
}
1999-08-16 21:50:52 +00:00
}
UTextOffset
UCharCharacterIterator::move(int32_t delta, CharacterIterator::EOrigin origin) {
switch(origin) {
case kStart:
pos = begin + delta;
break;
case kCurrent:
pos += delta;
break;
case kEnd:
pos = end + delta;
break;
default:
break;
}
1999-08-16 21:50:52 +00:00
if(pos < begin) {
pos = begin;
} else if(pos > end) {
pos = end;
}
return pos;
1999-08-16 21:50:52 +00:00
}
UTextOffset
UCharCharacterIterator::move32(int32_t delta, CharacterIterator::EOrigin origin) {
// this implementation relies on the "safe" version of the UTF macros
// (or the trustworthiness of the caller)
switch(origin) {
case kStart:
pos = begin;
if(delta > 0) {
UTF_FWD_N(text, pos, end, delta);
}
break;
case kCurrent:
if(delta > 0) {
UTF_FWD_N(text, pos, end, delta);
} else {
UTF_BACK_N(text, pos, end, -delta);
}
break;
case kEnd:
pos = end;
if(delta < 0) {
UTF_BACK_N(text, pos, end, -delta);
}
break;
default:
break;
}
1999-08-16 21:50:52 +00:00
return pos;
}
void UCharCharacterIterator::setText(const UChar* newText,
int32_t newTextLength) {
text = newText;
if(newText == 0 || newTextLength < 0) {
newTextLength = 0;
}
end = textLength = newTextLength;
pos = begin = 0;
}
1999-08-16 21:50:52 +00:00
void
UCharCharacterIterator::getText(UnicodeString& result) {
result = UnicodeString(text, textLength);
1999-08-16 21:50:52 +00:00
}
char UCharCharacterIterator::fgClassID = 0;