2017-01-20 00:20:31 +00:00
|
|
|
// © 2016 and later: Unicode, Inc. and others.
|
2016-06-15 18:58:17 +00:00
|
|
|
// License & terms of use: http://www.unicode.org/copyright.html
|
2001-03-21 20:09:56 +00:00
|
|
|
/********************************************************************
|
|
|
|
* COPYRIGHT:
|
2016-05-31 21:45:07 +00:00
|
|
|
* Copyright (c) 1997-2003, International Business Machines Corporation and
|
|
|
|
* others. All Rights Reserved.
|
2001-03-21 20:09:56 +00:00
|
|
|
********************************************************************/
|
|
|
|
/* file name: sfwdchit.cpp
|
2017-02-03 18:57:23 +00:00
|
|
|
* encoding: UTF-8
|
2001-03-21 20:09:56 +00:00
|
|
|
* tab size: 8 (not used)
|
|
|
|
* indentation:4
|
|
|
|
*/
|
|
|
|
|
2000-12-12 19:40:58 +00:00
|
|
|
#include "sfwdchit.h"
|
|
|
|
#include "unicode/ustring.h"
|
|
|
|
#include "unicode/unistr.h"
|
|
|
|
#include "uhash.h"
|
|
|
|
#include "cmemory.h"
|
|
|
|
|
|
|
|
// A hash code of kInvalidHashCode indicates that the has code needs
|
|
|
|
// to be computed. A hash code of kEmptyHashCode is used for empty keys
|
|
|
|
// and for any key whose computed hash code is kInvalidHashCode.
|
|
|
|
const int32_t SimpleFwdCharIterator::kInvalidHashCode = 0;
|
|
|
|
const int32_t SimpleFwdCharIterator::kEmptyHashCode = 1;
|
|
|
|
|
2003-12-16 22:28:42 +00:00
|
|
|
#if 0 // not used
|
2000-12-12 19:40:58 +00:00
|
|
|
SimpleFwdCharIterator::SimpleFwdCharIterator(const UnicodeString& s) {
|
|
|
|
|
|
|
|
fHashCode = kInvalidHashCode;
|
|
|
|
fLen = s.length();
|
|
|
|
fStart = new UChar[fLen];
|
|
|
|
if(fStart == NULL) {
|
|
|
|
fBogus = TRUE;
|
|
|
|
} else {
|
|
|
|
fEnd = fStart+fLen;
|
|
|
|
fCurrent = fStart;
|
|
|
|
fBogus = FALSE;
|
|
|
|
s.extract(0, fLen, fStart);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2003-12-16 22:28:42 +00:00
|
|
|
#endif
|
2000-12-12 19:40:58 +00:00
|
|
|
|
|
|
|
SimpleFwdCharIterator::SimpleFwdCharIterator(UChar *s, int32_t len, UBool adopt) {
|
|
|
|
|
|
|
|
fHashCode = kInvalidHashCode;
|
|
|
|
|
|
|
|
fLen = len==-1 ? u_strlen(s) : len;
|
|
|
|
|
|
|
|
if(adopt == FALSE) {
|
|
|
|
fStart = new UChar[fLen];
|
|
|
|
if(fStart == NULL) {
|
|
|
|
fBogus = TRUE;
|
|
|
|
} else {
|
|
|
|
uprv_memcpy(fStart, s, fLen);
|
|
|
|
fEnd = fStart+fLen;
|
|
|
|
fCurrent = fStart;
|
|
|
|
fBogus = FALSE;
|
|
|
|
}
|
|
|
|
} else { // adopt = TRUE
|
|
|
|
fCurrent = fStart = s;
|
|
|
|
fEnd = fStart + fLen;
|
|
|
|
fBogus = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
SimpleFwdCharIterator::~SimpleFwdCharIterator() {
|
|
|
|
delete[] fStart;
|
|
|
|
}
|
|
|
|
|
2003-12-16 22:28:42 +00:00
|
|
|
#if 0 // not used
|
2000-12-12 19:40:58 +00:00
|
|
|
UBool SimpleFwdCharIterator::operator==(const ForwardCharacterIterator& that) const {
|
|
|
|
if(this == &that) {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
if(that->fHashCode != kInvalidHashCode && this->fHashCode = that->fHashCode) {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(this->fStart == that->fStart) {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(this->fLen == that->fLen && uprv_memcmp(this->fStart, that->fStart, this->fLen) {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
return FALSE;
|
|
|
|
}
|
2003-12-16 22:28:42 +00:00
|
|
|
#endif
|
|
|
|
|
2000-12-12 19:40:58 +00:00
|
|
|
int32_t SimpleFwdCharIterator::hashCode(void) const {
|
|
|
|
if (fHashCode == kInvalidHashCode)
|
|
|
|
{
|
2001-10-16 18:31:13 +00:00
|
|
|
UHashTok key;
|
2001-07-06 19:53:12 +00:00
|
|
|
key.pointer = fStart;
|
|
|
|
((SimpleFwdCharIterator *)this)->fHashCode = uhash_hashUChars(key);
|
2000-12-12 19:40:58 +00:00
|
|
|
}
|
|
|
|
return fHashCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
UClassID SimpleFwdCharIterator::getDynamicClassID(void) const {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
UChar SimpleFwdCharIterator::nextPostInc(void) {
|
|
|
|
if(fCurrent == fEnd) {
|
|
|
|
return ForwardCharacterIterator::DONE;
|
|
|
|
} else {
|
|
|
|
return *(fCurrent)++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
UChar32 SimpleFwdCharIterator::next32PostInc(void) {
|
|
|
|
return ForwardCharacterIterator::DONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
UBool SimpleFwdCharIterator::hasNext() {
|
|
|
|
return fCurrent < fEnd;
|
|
|
|
}
|