ICU-2235 .res 1.1 adds indexes[] for friendly reading and swapping

X-SVN-Rev: 13181
This commit is contained in:
Markus Scherer 2003-09-24 00:26:23 +00:00
parent ac34860b7c
commit 5ed52c5047
2 changed files with 69 additions and 21 deletions

View File

@ -16,6 +16,7 @@
*/ */
#include <assert.h> #include <assert.h>
#include <stdio.h>
#include "reslist.h" #include "reslist.h"
#include "unewdata.h" #include "unewdata.h"
#include "unicode/ures.h" #include "unicode/ures.h"
@ -38,7 +39,7 @@ static const UDataInfo dataInfo= {
0, 0,
{0x52, 0x65, 0x73, 0x42}, /* dataFormat="resb" */ {0x52, 0x65, 0x73, 0x42}, /* dataFormat="resb" */
{1, 0, 0, 0}, /* formatVersion */ {1, 1, 0, 0}, /* formatVersion */
{1, 4, 0, 0} /* dataVersion take a look at version inside parsed resb*/ {1, 4, 0, 0} /* dataVersion take a look at version inside parsed resb*/
}; };
@ -205,7 +206,7 @@ static uint32_t table_write(UNewDataMemory *mem, struct SResource *res,
assert(i < res->u.fTable.fCount); assert(i < res->u.fTable.fCount);
/* where the key is plus root pointer */ /* where the key is plus root pointer */
keys[i] = (uint16_t) (current->fKey + sizeof(uint32_t)); keys[i] = (uint16_t) current->fKey;
if (current->fType == URES_INT) { if (current->fType == URES_INT) {
resources[i] = (current->fType << 28) | (current->u.fIntValue.fValue & 0xFFFFFFF); resources[i] = (current->fType << 28) | (current->u.fIntValue.fValue & 0xFFFFFFF);
@ -279,7 +280,9 @@ void bundle_write(struct SRBRoot *bundle, const char *outputDir, const char *out
uint8_t pad = 0; uint8_t pad = 0;
uint32_t root = 0; uint32_t root = 0;
uint32_t usedOffset = 0; uint32_t usedOffset = 0;
uint32_t top, size;
char dataName[1024]; char dataName[1024];
int32_t indexes[URES_INDEX_TOP];
if (writtenFilename && writtenFilenameLen) { if (writtenFilename && writtenFilenameLen) {
*writtenFilename = 0; *writtenFilename = 0;
@ -345,19 +348,49 @@ void bundle_write(struct SRBRoot *bundle, const char *outputDir, const char *out
} }
pad = calcPadding(bundle->fKeyPoint); pad = calcPadding(bundle->fKeyPoint);
usedOffset = sizeof(uint32_t) + bundle->fKeyPoint + pad ; /*this is how much root and keys are taking up*/ usedOffset = bundle->fKeyPoint + pad ; /* top of the strings */
root = ((usedOffset + bundle->fRoot->u.fTable.fChildrenSize) >> 2) | (URES_TABLE << 28); /* we're gonna put the main table at the end */ /* we're gonna put the main table at the end */
top = usedOffset + bundle->fRoot->u.fTable.fChildrenSize;
root = (top) >> 2 | (bundle->fRoot->fType << 28);
/* write the root item */
udata_write32(mem, root); udata_write32(mem, root);
udata_writeBlock(mem, bundle->fKeys, bundle->fKeyPoint); /* add to top the size of the root item */
top += bundle->fRoot->fSize;
top += calcPadding(top);
/*
* formatVersion 1.1 (ICU 2.8):
* write int32_t indexes[] after root and before the strings
* to make it easier to parse resource bundles in icuswap or from Java etc.
*/
indexes[URES_INDEX_LENGTH]= URES_INDEX_TOP;
indexes[URES_INDEX_STRINGS_TOP]= (int32_t)(usedOffset>>2);
indexes[URES_INDEX_RESOURCES_TOP]= (int32_t)(top>>2);
indexes[URES_INDEX_BUNDLE_TOP]= indexes[URES_INDEX_RESOURCES_TOP];
indexes[URES_INDEX_MAX_TABLE_LENGTH]= bundle->fMaxTableLength;
/* write the indexes[] */
udata_writeBlock(mem, indexes, sizeof(indexes));
/* write the table key strings */
udata_writeBlock(mem, bundle->fKeys+URES_STRINGS_BOTTOM,
bundle->fKeyPoint-URES_STRINGS_BOTTOM);
/* write the padding bytes after the table key strings */
udata_writePadding(mem, pad); udata_writePadding(mem, pad);
/* write all of the bundle contents: the root item and its children */
usedOffset = res_write(mem, bundle->fRoot, usedOffset, status); usedOffset = res_write(mem, bundle->fRoot, usedOffset, status);
udata_finish(mem, status); size = udata_finish(mem, status);
if(top != size) {
fprintf(stderr, "genrb error: wrote %u bytes but counted %u\n",
size, top);
*status = U_INTERNAL_PROGRAM_ERROR;
}
} }
/* Opening Functions */ /* Opening Functions */
@ -619,8 +652,10 @@ struct SRBRoot *bundle_open(const struct UString* comment, UErrorCode *status) {
*status = U_MEMORY_ALLOCATION_ERROR; *status = U_MEMORY_ALLOCATION_ERROR;
return 0; return 0;
} }
uprv_memset(bundle, 0, sizeof(struct SRBRoot));
bundle->fLocale = NULL; bundle->fLocale = NULL;
bundle->fKeyPoint = 0;
bundle->fKeys = (char *) uprv_malloc(sizeof(char) * KEY_SPACE_SIZE); bundle->fKeys = (char *) uprv_malloc(sizeof(char) * KEY_SPACE_SIZE);
if(comment != NULL){ if(comment != NULL){
@ -633,11 +668,17 @@ struct SRBRoot *bundle_open(const struct UString* comment, UErrorCode *status) {
return NULL; return NULL;
} }
/* formatVersion 1.1: start fKeyPoint after the root item and indexes[] */
bundle->fKeyPoint = URES_STRINGS_BOTTOM;
uprv_memset(bundle->fKeys, 0, URES_STRINGS_BOTTOM);
bundle->fCount = 0; bundle->fCount = 0;
bundle->fRoot = table_open(bundle, NULL, comment, status); bundle->fRoot = table_open(bundle, NULL, comment, status);
if (bundle->fRoot == NULL || U_FAILURE(*status)) { if (bundle->fRoot == NULL || U_FAILURE(*status)) {
*status = U_MEMORY_ALLOCATION_ERROR; if (U_SUCCESS(*status)) {
*status = U_MEMORY_ALLOCATION_ERROR;
}
uprv_free(bundle->fKeys); uprv_free(bundle->fKeys);
uprv_free(bundle); uprv_free(bundle);
@ -790,6 +831,10 @@ void table_add(struct SResource *table, struct SResource *res, int linenumber, U
list = &(table->u.fTable); list = &(table->u.fTable);
++(list->fCount); ++(list->fCount);
if(list->fCount > list->fRoot->fMaxTableLength) {
list->fRoot->fMaxTableLength = list->fCount;
}
table->fSize += sizeof(uint32_t) + sizeof(uint16_t); table->fSize += sizeof(uint32_t) + sizeof(uint16_t);
table->u.fTable.fChildrenSize += res->fSize + calcPadding(res->fSize); table->u.fTable.fChildrenSize += res->fSize + calcPadding(res->fSize);
@ -899,27 +944,29 @@ void bundle_setlocale(struct SRBRoot *bundle, UChar *locale, UErrorCode *status)
} }
uint16_t bundle_addtag(struct SRBRoot *bundle, const char *tag, UErrorCode *status) { int32_t
uint16_t keypos; bundle_addtag(struct SRBRoot *bundle, const char *tag, UErrorCode *status) {
int32_t keypos, length;
if (U_FAILURE(*status)) { if (U_FAILURE(*status)) {
return (uint16_t) - 1; return -1;
} }
if (tag == NULL) { if (tag == NULL) {
return (uint16_t) - 1; /* do not set an error: the root table has a NULL tag */
return -1;
} }
keypos = (uint16_t)bundle->fKeyPoint; keypos = bundle->fKeyPoint;
bundle->fKeyPoint += (uint16_t) (uprv_strlen(tag) + 1); bundle->fKeyPoint += length = (int32_t) (uprv_strlen(tag) + 1);
if (bundle->fKeyPoint > KEY_SPACE_SIZE) { if (bundle->fKeyPoint > KEY_SPACE_SIZE) {
*status = U_MEMORY_ALLOCATION_ERROR; *status = U_MEMORY_ALLOCATION_ERROR;
return (uint16_t) - 1; return -1;
} }
uprv_strcpy(bundle->fKeys + keypos, tag); uprv_memcpy(bundle->fKeys + keypos, tag, length);
return keypos; return keypos;
} }

View File

@ -18,7 +18,7 @@
#ifndef RESLIST_H #ifndef RESLIST_H
#define RESLIST_H #define RESLIST_H
#define KEY_SPACE_SIZE 65532 #define KEY_SPACE_SIZE 65536
#define RESLIST_MAX_INT_VECTOR 2048 #define RESLIST_MAX_INT_VECTOR 2048
#include "unicode/utypes.h" #include "unicode/utypes.h"
@ -35,10 +35,11 @@ U_CDECL_BEGIN
/* Resource bundle root table */ /* Resource bundle root table */
struct SRBRoot { struct SRBRoot {
char *fLocale; char *fLocale;
uint32_t fKeyPoint; int32_t fKeyPoint;
char *fKeys; char *fKeys;
int32_t fCount; int32_t fCount;
struct SResource *fRoot; struct SResource *fRoot;
int32_t fMaxTableLength;
}; };
struct SRBRoot *bundle_open(const struct UString* comment, UErrorCode *status); struct SRBRoot *bundle_open(const struct UString* comment, UErrorCode *status);
@ -59,7 +60,7 @@ void bundle_write_xml(struct SRBRoot *bundle, const char *outputDir,const char*
void bundle_close(struct SRBRoot *bundle, UErrorCode *status); void bundle_close(struct SRBRoot *bundle, UErrorCode *status);
void bundle_setlocale(struct SRBRoot *bundle, UChar *locale, UErrorCode *status); void bundle_setlocale(struct SRBRoot *bundle, UChar *locale, UErrorCode *status);
uint16_t bundle_addtag(struct SRBRoot *bundle, const char *tag, UErrorCode *status); int32_t bundle_addtag(struct SRBRoot *bundle, const char *tag, UErrorCode *status);
/* Various resource types */ /* Various resource types */
@ -125,7 +126,7 @@ void bin_close(struct SResource *binres, UErrorCode *status);
struct SResource { struct SResource {
UResType fType; UResType fType;
uint16_t fKey; int32_t fKey;
uint32_t fSize; /* Size in bytes outside the header part */ uint32_t fSize; /* Size in bytes outside the header part */
int line; /* used internally to report duplicate keys in tables */ int line; /* used internally to report duplicate keys in tables */
struct SResource *fNext; /*This is for internal chaining while building*/ struct SResource *fNext; /*This is for internal chaining while building*/