225 lines
5.2 KiB
C++
225 lines
5.2 KiB
C++
// © 2016 and later: Unicode, Inc. and others.
|
|
// License & terms of use: http://www.unicode.org/copyright.html
|
|
/********************************************************************
|
|
* COPYRIGHT:
|
|
* Copyright (c) 2002-2006, International Business Machines Corporation and
|
|
* others. All Rights Reserved.
|
|
********************************************************************/
|
|
|
|
/* Created by weiv 05/09/2002 */
|
|
|
|
#include "unicode/datamap.h"
|
|
#include "unicode/resbund.h"
|
|
#include "unicode/unistr.h"
|
|
#include "hash.h"
|
|
#include <stdlib.h>
|
|
|
|
DataMap::~DataMap() {}
|
|
DataMap::DataMap() {}
|
|
|
|
int32_t
|
|
DataMap::utoi(const UnicodeString &s) const
|
|
{
|
|
char ch[256];
|
|
const UChar *u = toUCharPtr(s.getBuffer());
|
|
int32_t len = s.length();
|
|
u_UCharsToChars(u, ch, len);
|
|
ch[len] = 0; /* include terminating \0 */
|
|
return atoi(ch);
|
|
}
|
|
|
|
U_CDECL_BEGIN
|
|
void U_CALLCONV
|
|
deleteResBund(void *obj) {
|
|
delete (ResourceBundle *)obj;
|
|
}
|
|
U_CDECL_END
|
|
|
|
|
|
RBDataMap::~RBDataMap()
|
|
{
|
|
delete fData;
|
|
}
|
|
|
|
RBDataMap::RBDataMap()
|
|
{
|
|
UErrorCode status = U_ZERO_ERROR;
|
|
fData = new Hashtable(TRUE, status);
|
|
fData->setValueDeleter(deleteResBund);
|
|
}
|
|
|
|
// init from table resource
|
|
// will put stuff in hashtable according to
|
|
// keys.
|
|
RBDataMap::RBDataMap(UResourceBundle *data, UErrorCode &status)
|
|
{
|
|
fData = new Hashtable(TRUE, status);
|
|
fData->setValueDeleter(deleteResBund);
|
|
init(data, status);
|
|
}
|
|
|
|
// init from headers and resource
|
|
// with checking the whether the size of resource matches
|
|
// header size
|
|
RBDataMap::RBDataMap(UResourceBundle *headers, UResourceBundle *data, UErrorCode &status)
|
|
{
|
|
fData = new Hashtable(TRUE, status);
|
|
fData->setValueDeleter(deleteResBund);
|
|
init(headers, data, status);
|
|
}
|
|
|
|
|
|
void RBDataMap::init(UResourceBundle *data, UErrorCode &status) {
|
|
int32_t i = 0;
|
|
fData->removeAll();
|
|
UResourceBundle *t = NULL;
|
|
for(i = 0; i < ures_getSize(data); i++) {
|
|
t = ures_getByIndex(data, i, t, &status);
|
|
fData->put(UnicodeString(ures_getKey(t), -1, US_INV), new ResourceBundle(t, status), status);
|
|
}
|
|
ures_close(t);
|
|
}
|
|
|
|
void RBDataMap::init(UResourceBundle *headers, UResourceBundle *data, UErrorCode &status)
|
|
{
|
|
int32_t i = 0;
|
|
fData->removeAll();
|
|
UResourceBundle *t = NULL;
|
|
const UChar *key = NULL;
|
|
int32_t keyLen = 0;
|
|
if(ures_getSize(headers) == ures_getSize(data)) {
|
|
for(i = 0; i < ures_getSize(data); i++) {
|
|
t = ures_getByIndex(data, i, t, &status);
|
|
key = ures_getStringByIndex(headers, i, &keyLen, &status);
|
|
fData->put(UnicodeString(key, keyLen), new ResourceBundle(t, status), status);
|
|
}
|
|
} else {
|
|
// error
|
|
status = U_INVALID_FORMAT_ERROR;
|
|
}
|
|
ures_close(t);
|
|
}
|
|
|
|
const ResourceBundle *RBDataMap::getItem(const char* key, UErrorCode &status) const
|
|
{
|
|
if(U_FAILURE(status)) {
|
|
return NULL;
|
|
}
|
|
|
|
UnicodeString hashKey(key, -1, US_INV);
|
|
const ResourceBundle *r = (ResourceBundle *)fData->get(hashKey);
|
|
if(r != NULL) {
|
|
return r;
|
|
} else {
|
|
status = U_MISSING_RESOURCE_ERROR;
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
const UnicodeString RBDataMap::getString(const char* key, UErrorCode &status) const
|
|
{
|
|
const ResourceBundle *r = getItem(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
return r->getString(status);
|
|
} else {
|
|
return UnicodeString();
|
|
}
|
|
}
|
|
|
|
int32_t
|
|
RBDataMap::getInt28(const char* key, UErrorCode &status) const
|
|
{
|
|
const ResourceBundle *r = getItem(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
return r->getInt(status);
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
uint32_t
|
|
RBDataMap::getUInt28(const char* key, UErrorCode &status) const
|
|
{
|
|
const ResourceBundle *r = getItem(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
return r->getUInt(status);
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
const int32_t *
|
|
RBDataMap::getIntVector(int32_t &length, const char *key, UErrorCode &status) const {
|
|
const ResourceBundle *r = getItem(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
return r->getIntVector(length, status);
|
|
} else {
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
const uint8_t *
|
|
RBDataMap::getBinary(int32_t &length, const char *key, UErrorCode &status) const {
|
|
const ResourceBundle *r = getItem(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
return r->getBinary(length, status);
|
|
} else {
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
int32_t RBDataMap::getInt(const char* key, UErrorCode &status) const
|
|
{
|
|
UnicodeString r = this->getString(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
return utoi(r);
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
const UnicodeString* RBDataMap::getStringArray(int32_t& count, const char* key, UErrorCode &status) const
|
|
{
|
|
const ResourceBundle *r = getItem(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
int32_t i = 0;
|
|
|
|
count = r->getSize();
|
|
if(count <= 0) {
|
|
return NULL;
|
|
}
|
|
|
|
UnicodeString *result = new UnicodeString[count];
|
|
for(i = 0; i<count; i++) {
|
|
result[i] = r->getStringEx(i, status);
|
|
}
|
|
return result;
|
|
} else {
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
const int32_t* RBDataMap::getIntArray(int32_t& count, const char* key, UErrorCode &status) const
|
|
{
|
|
const ResourceBundle *r = getItem(key, status);
|
|
if(U_SUCCESS(status)) {
|
|
int32_t i = 0;
|
|
|
|
count = r->getSize();
|
|
if(count <= 0) {
|
|
return NULL;
|
|
}
|
|
|
|
int32_t *result = new int32_t[count];
|
|
UnicodeString stringRes;
|
|
for(i = 0; i<count; i++) {
|
|
stringRes = r->getStringEx(i, status);
|
|
result[i] = utoi(stringRes);
|
|
}
|
|
return result;
|
|
} else {
|
|
return NULL;
|
|
}
|
|
}
|
|
|