mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-07 11:56:51 +00:00
824 lines
22 KiB
C++
824 lines
22 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
*
|
|
* The contents of this file are subject to the Netscape Public License
|
|
* Version 1.0 (the "License"); you may not use this file except in
|
|
* compliance with the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/NPL/
|
|
*
|
|
* Software distributed under the License is distributed on an "AS IS"
|
|
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
|
|
* the License for the specific language governing rights and limitations
|
|
* under the License.
|
|
*
|
|
* The Original Code is Mozilla Communicator client code.
|
|
*
|
|
* The Initial Developer of the Original Code is Netscape Communications
|
|
* Corporation. Portions created by Netscape are Copyright (C) 1998
|
|
* Netscape Communications Corporation. All Rights Reserved.
|
|
*/
|
|
|
|
#define NS_IMPL_IDS
|
|
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include "nsIServiceManager.h"
|
|
#include "nsISupports.h"
|
|
#include "nsICharsetConverterManager.h"
|
|
|
|
// include the CIDs
|
|
#include "nsUCvLatinCID.h"
|
|
#include "nsUCVJACID.h"
|
|
#include "nsUCVJA2CID.h"
|
|
|
|
#ifdef XP_UNIX
|
|
#define UCONV_DLL "libuconv.so"
|
|
#define UCVLATIN_DLL "libucvlatin.so"
|
|
#define UCVJA_DLL "libucvja.so"
|
|
#define UCVJA2_DLL "libucvja2.so"
|
|
#else /* XP_UNIX */
|
|
#ifdef XP_MAC
|
|
#define UCONV_DLL "UCONV_DLL"
|
|
#define UCVLATIN_DLL "UCVLATIN_DLL"
|
|
#define UCVJA_DLL "UCVJA_DLL"
|
|
#define UCVJA2_DLL "UCVJA2_DLL"
|
|
#else /* XP_MAC */
|
|
#define UCONV_DLL "uconv.dll"
|
|
#define UCVLATIN_DLL "ucvlatin.dll"
|
|
#define UCVJA_DLL "ucvja.dll"
|
|
#define UCVJA2_DLL "ucvja2.dll"
|
|
#endif
|
|
#endif
|
|
|
|
/**
|
|
* Test program for the Unicode Converters.
|
|
*
|
|
* Error messages format inside of a test.
|
|
*
|
|
* - silent while all is OK.
|
|
*
|
|
* - "ERROR at T001.easyConversion.Convert() code=0xfffd.\n"
|
|
* - "ERROR at T001.easyConversion.ConvResLen expected=0x02 result=0x04.\n"
|
|
*
|
|
* - "Test Passed.\n" for a successful end.
|
|
*
|
|
* @created 01/Dec/1998
|
|
* @author Catalin Rotaru [CATA]
|
|
*/
|
|
|
|
//----------------------------------------------------------------------
|
|
// Global variables and macros
|
|
|
|
#define GENERAL_BUFFER 20000 // general purpose buffer; for Unicode divide by 2
|
|
|
|
nsICharsetConverterManager * ccMan = NULL;
|
|
|
|
//----------------------------------------------------------------------
|
|
// Registry setup function(s)
|
|
|
|
nsresult setupRegistry()
|
|
{
|
|
nsresult res;
|
|
|
|
res = nsRepository::RegisterFactory(kCharsetConverterManagerCID, UCONV_DLL, PR_FALSE, PR_FALSE);
|
|
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
|
|
|
|
res = nsRepository::RegisterFactory(kLatin1ToUnicodeCID, UCVLATIN_DLL, PR_FALSE, PR_FALSE);
|
|
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
|
|
|
|
res = nsRepository::RegisterFactory(kCP1253ToUnicodeCID, UCVLATIN_DLL, PR_FALSE, PR_FALSE);
|
|
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
|
|
|
|
res = nsRepository::RegisterFactory(kISO88597ToUnicodeCID, UCVLATIN_DLL, PR_FALSE, PR_FALSE);
|
|
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
|
|
|
|
res = nsRepository::RegisterFactory(kSJIS2UnicodeCID, UCVJA_DLL, PR_FALSE, PR_FALSE);
|
|
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
|
|
|
|
res = nsRepository::RegisterFactory(kISO2022JPToUnicodeCID, UCVJA2_DLL, PR_FALSE, PR_FALSE);
|
|
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// Converter Manager test code
|
|
|
|
nsresult testCharsetConverterManager()
|
|
{
|
|
printf("\n[T001] CharsetConverterManager\n");
|
|
|
|
nsresult res = nsServiceManager::GetService(kCharsetConverterManagerCID,
|
|
kICharsetConverterManagerIID, (nsISupports **)&ccMan);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at GetService() code=0x%x.\n",res);
|
|
return res;
|
|
}
|
|
|
|
nsString ** cs;
|
|
PRInt32 ct;
|
|
|
|
res = ccMan->GetDecodableCharsets(&cs, &ct);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at GetDecodableCharsets() code=0x%x.\n", res);
|
|
} else {
|
|
printf("UDecoders (%d): ", ct);
|
|
for (int i=0;i<ct;i++) {
|
|
char * cstr = cs[i]->ToNewCString();
|
|
printf("%s ",cstr);
|
|
delete [] cstr;
|
|
}
|
|
printf("\n");
|
|
}
|
|
delete [] cs;
|
|
|
|
res = ccMan->GetEncodableCharsets(&cs, &ct);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at GetEncodableCharsets() code=0x%x.\n", res);
|
|
} else {
|
|
printf("UEncoders (%d): ", ct);
|
|
for (int i=0;i<ct;i++) {
|
|
char * cstr = cs[i]->ToNewCString();
|
|
printf("%s ",cstr);
|
|
delete [] cstr;
|
|
}
|
|
printf("\n");
|
|
}
|
|
delete [] cs;
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// Old SHIT !!! Don't copy this crap, go to the new stuff down in the file.
|
|
// XXX move it to the new & improved framework
|
|
|
|
#define TABLE_SIZE1 5
|
|
|
|
#define ISO88597TABLE_SIZE 16
|
|
nsresult testISO88597Decoder()
|
|
{
|
|
printf("\n[T3] ISO-8859-7 To Unicode\n");
|
|
|
|
// create converter
|
|
nsIUnicodeDecoder * dec;
|
|
nsAutoString str("iso-8859-7");
|
|
nsresult res = ccMan->GetUnicodeDecoder(&str,&dec);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR 0x%x: Cannot instantiate.\n",res);
|
|
return res;
|
|
} else {
|
|
printf("Instantiated.\n");
|
|
}
|
|
|
|
//test converter
|
|
|
|
PRInt32 srcL = ISO88597TABLE_SIZE;
|
|
PRInt32 destL = ISO88597TABLE_SIZE;
|
|
// some randon C0, ASCII, C1 and ISO-8859-7 code
|
|
static char src [ISO88597TABLE_SIZE + 1] =
|
|
{
|
|
"\x09\x0d\x20\x40"
|
|
"\x80\x98\xa3\xaf"
|
|
"\xa7\xb1\xb3\xc9"
|
|
"\xd9\xe3\xf4\xff"
|
|
};
|
|
static PRUnichar expect [ISO88597TABLE_SIZE] =
|
|
{
|
|
0x0009, 0x000d, 0x0020, 0x0040,
|
|
0xfffd, 0xfffd, 0x00a3, 0x2015,
|
|
0x00a7, 0x00b1, 0x00b3, 0x0399,
|
|
0x03a9, 0x03b3, 0x03c4, 0xfffd
|
|
|
|
};
|
|
PRUnichar dest [ISO88597TABLE_SIZE];
|
|
|
|
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR 0x%x: Convert().\n",res);
|
|
} else {
|
|
printf("Read %d, write %d.\n",srcL,destL);
|
|
printf("Converted:");
|
|
|
|
PRBool failed = PR_FALSE;
|
|
for (int i=0;i<ISO88597TABLE_SIZE;i++) {
|
|
printf("%x convert to %x. expect value is %x\n" , src[i], dest[i], expect[i]);
|
|
if (dest[i] != expect[i]) failed = PR_TRUE;
|
|
}
|
|
printf("\n");
|
|
|
|
if (failed) {
|
|
printf("Test FAILED!!!\n");
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
}
|
|
}
|
|
|
|
NS_RELEASE(dec);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
|
|
#define SJIS_TEST_SRC_SIZE 40
|
|
#define SJIS_TEST_DEST_SIZE 24
|
|
nsresult testSJISDecoder()
|
|
{
|
|
/*
|
|
[Shift_JIS=4a][Shift_JIS=61][Shift_JIS=70][Shift_JIS=61][Shift_JIS=6e][Shift_JIS=65][Shift_JIS=73][Shift_JIS=65]
|
|
[Shift_JIS=8abf][Shift_JIS=8e9a]
|
|
[Shift_JIS=834a][Shift_JIS=835e][Shift_JIS=834a][Shift_JIS=8369]
|
|
[Shift_JIS=82d0][Shift_JIS=82e7][Shift_JIS=82aa][Shift_JIS=82c8]
|
|
[Shift_JIS=8250][Shift_JIS=8251][Shift_JIS=8252][Shift_JIS=8260][Shift_JIS=8261][Shift_JIS=8262]
|
|
U+004A U+0061 U+0070 U+0061 U+006E U+0065 U+0073 U+0065
|
|
U+6F22 U+5B57
|
|
U+30AB U+30BF U+30AB U+30CA
|
|
U+3072 U+3089 U+304C U+306A
|
|
U+FF11 U+FF12 U+FF13 U+FF21 U+FF22 U+FF23
|
|
*/
|
|
static const char src[SJIS_TEST_SRC_SIZE + 1] = {
|
|
"Japanese" /* English */
|
|
"\x8a\xbf\x8e\x9a" /* Kanji */
|
|
"\x83\x4a\x83\x5e\x83\x4a\x83\x69" /* Kantakana */
|
|
"\x82\xd0\x82\xe7\x82\xaa\x82\xc8" /* Hiragana */
|
|
"\x82\x50\x82\x51\x82\x52\x82\x60\x82\x61\x82\x62" /* full width 123ABC */
|
|
};
|
|
static const PRUnichar expect[SJIS_TEST_DEST_SIZE] = {
|
|
0x004A, 0x0061, 0x0070, 0x0061, 0x006E, 0x0065, 0x0073, 0x0065,
|
|
0x6f22, 0x5b57,
|
|
0x30ab, 0x30bf, 0x30ab, 0x30ca,
|
|
0x3072, 0x3089, 0x304c, 0x306a,
|
|
0xff11, 0xff12, 0xff13, 0xff21, 0xff22, 0xff23
|
|
};
|
|
PRUnichar dest[SJIS_TEST_DEST_SIZE + 44];
|
|
printf("\n[T3] SJIS2Unicode\n");
|
|
|
|
// create converter
|
|
nsIUnicodeDecoder * dec;
|
|
nsAutoString str("Shift_JIS");
|
|
nsresult res = ccMan->GetUnicodeDecoder(&str,&dec);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR 0x%x: Cannot instantiate.\n",res);
|
|
return res;
|
|
} else {
|
|
printf("Instantiated.\n");
|
|
}
|
|
|
|
//test converter
|
|
|
|
PRInt32 srcL = SJIS_TEST_SRC_SIZE;
|
|
PRInt32 destL = SJIS_TEST_DEST_SIZE+ 44;
|
|
PRBool failed = PR_FALSE;
|
|
printf("Test Normal Case\n");
|
|
|
|
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR 0x%x: Convert().\n",res);
|
|
failed = PR_TRUE;
|
|
} else {
|
|
printf("Read %d, write %d.\n",srcL,destL);
|
|
printf("Converted:");
|
|
|
|
|
|
if(destL != SJIS_TEST_DEST_SIZE)
|
|
{
|
|
printf("Dest Size bad. Should be %d but got %d!!\n",
|
|
SJIS_TEST_DEST_SIZE, destL);
|
|
failed = PR_TRUE;
|
|
}
|
|
for (int i=0;i< destL ;i++) {
|
|
if (dest[i] != expect[i] ) failed = PR_TRUE;
|
|
}
|
|
printf("\n");
|
|
if (failed) {
|
|
printf("Test FAILED!!!\n");
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
}
|
|
failed = PR_FALSE;
|
|
|
|
// Test NS_PARTIAL_MORE_INPUT case
|
|
printf("Test NS_PARTIAL_MORE_INPUT Case\n");
|
|
srcL= SJIS_TEST_SRC_SIZE - 1;
|
|
destL = SJIS_TEST_DEST_SIZE+ 44;
|
|
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
|
|
|
|
if (NS_PARTIAL_MORE_INPUT != res) {
|
|
printf("ERROR 0x%x: Convert().\n",res);
|
|
failed = PR_TRUE;
|
|
|
|
} else {
|
|
if((SJIS_TEST_SRC_SIZE -2 ) != srcL )
|
|
{
|
|
printf("Src Size bad. Should be %d but got %d!!\n",
|
|
SJIS_TEST_SRC_SIZE-2, srcL);
|
|
failed = PR_TRUE;
|
|
}
|
|
|
|
if(destL != (SJIS_TEST_DEST_SIZE-1))
|
|
{
|
|
printf("Dest Size bad. Should be %d but got %d!!\n",
|
|
SJIS_TEST_DEST_SIZE-1, destL);
|
|
failed = PR_TRUE;
|
|
}
|
|
for (int i=0;i< destL ;i++) {
|
|
if (dest[i] != expect[i] ) failed = PR_TRUE;
|
|
}
|
|
}
|
|
if (failed) {
|
|
printf("Test FAILED!!!\n");
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
}
|
|
failed = PR_FALSE;
|
|
|
|
// Test NS_PARTIAL_MORE_OUTPUT case
|
|
printf("Test NS_PARTIAL_MORE_OUTNPUT Case\n");
|
|
|
|
srcL= SJIS_TEST_SRC_SIZE;
|
|
destL = SJIS_TEST_DEST_SIZE-1;
|
|
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
|
|
|
|
if (NS_PARTIAL_MORE_OUTPUT != res) {
|
|
printf("ERROR 0x%x: Convert().\n",res);
|
|
failed = PR_TRUE;
|
|
|
|
} else {
|
|
if((SJIS_TEST_SRC_SIZE -2 ) != srcL )
|
|
{
|
|
printf("Src Size bad. Should be %d but got %d!!\n",
|
|
SJIS_TEST_SRC_SIZE-2, srcL);
|
|
failed = PR_TRUE;
|
|
}
|
|
|
|
if(destL != (SJIS_TEST_DEST_SIZE-1))
|
|
{
|
|
printf("Dest Size bad. Should be %d but got %d!!\n",
|
|
SJIS_TEST_DEST_SIZE-1, destL);
|
|
failed = PR_TRUE;
|
|
}
|
|
for (int i=0;i< destL ;i++) {
|
|
if (dest[i] != expect[i] ) failed = PR_TRUE;
|
|
}
|
|
}
|
|
|
|
// Test NS_ERROR_ILLEGAL_INPUT case
|
|
//printf("Test NS_ERROR_ILLEGAL_INPUT Case\n");
|
|
// To Be Implement
|
|
|
|
if (failed) {
|
|
printf("Test FAILED!!!\n");
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
}
|
|
}
|
|
|
|
NS_RELEASE(dec);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// Helper functions and macros for testing decoders and encoders
|
|
|
|
#define CREATE_DECODER(_charset) \
|
|
nsIUnicodeDecoder * dec; \
|
|
nsAutoString str(_charset); \
|
|
nsresult res = ccMan->GetUnicodeDecoder(&str,&dec); \
|
|
if (NS_FAILED(res)) { \
|
|
printf("ERROR at GetUnicodeDecoder() code=0x%x.\n",res); \
|
|
return res; \
|
|
}
|
|
|
|
#define CREATE_ENCODER(_charset) \
|
|
nsIUnicodeEncoder * enc; \
|
|
nsAutoString str(_charset); \
|
|
nsresult res = ccMan->GetUnicodeEncoder(&str,&enc); \
|
|
if (NS_FAILED(res)) { \
|
|
printf("ERROR at GetUnicodeEncoder() code=0x%x.\n",res); \
|
|
return res; \
|
|
}
|
|
|
|
#define ARRAY_SIZE(_array) \
|
|
(sizeof(_array) / sizeof(_array[0]))
|
|
|
|
/**
|
|
* Decoder test.
|
|
*
|
|
* This method will test the conversion only.
|
|
*/
|
|
nsresult testDecoder(nsIUnicodeDecoder * aDec,
|
|
const char * aSrc, PRInt32 aSrcLength,
|
|
const PRUnichar * aRes, PRInt32 aResLength,
|
|
const char * aTestName)
|
|
{
|
|
nsresult res;
|
|
|
|
// prepare for conversion
|
|
PRInt32 srcLen = aSrcLength;
|
|
PRUnichar dest[GENERAL_BUFFER/2];
|
|
PRInt32 destLen = GENERAL_BUFFER/2;
|
|
|
|
// conversion
|
|
res = aDec->Convert(dest, 0, &destLen, aSrc, 0, &srcLen);
|
|
// we want a perfect result here - the test data should be complete!
|
|
if (res != NS_OK) {
|
|
printf("ERROR at %s.easy.Convert() code=0x%x.\n",aTestName,res);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
// compare results
|
|
if (aResLength != destLen) {
|
|
printf("ERROR at %s.easy.ConvResLen expected=0x%x result=0x%x.\n",
|
|
aTestName, aResLength, destLen);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
for (PRInt32 i=0; i<aResLength; i++) if (aRes[i] != dest[i]) {
|
|
printf("ERROR at %s.easy.ConvResChar[%d] expected=0x%x result=0x%x.\n",
|
|
aTestName, i, aRes[i], dest[i]);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
/**
|
|
* Decoder test.
|
|
*
|
|
* This method will test a given converter under a given set of data and some
|
|
* very stressful conditions.
|
|
*/
|
|
nsresult testStressDecoder(nsIUnicodeDecoder * aDec,
|
|
const char * aSrc, PRInt32 aSrcLength,
|
|
const PRUnichar * aRes, PRInt32 aResLength,
|
|
const char * aTestName)
|
|
{
|
|
nsresult res;
|
|
|
|
// get estimated length
|
|
PRInt32 estimatedLength;
|
|
res = aDec->Length(aSrc, 0, aSrcLength, &estimatedLength);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at %s.stress.Length() code=0x%x.\n",aTestName,res);
|
|
return res;
|
|
}
|
|
PRBool exactLength = (res == NS_EXACT_LENGTH);
|
|
|
|
// prepare for conversion
|
|
PRInt32 srcLen = 0;
|
|
PRInt32 srcOff = 0;
|
|
PRUnichar dest[1024];
|
|
PRInt32 destLen = 0;
|
|
PRInt32 destOff = 0;
|
|
|
|
// controlled conversion
|
|
for (;srcOff < aSrcLength;) {
|
|
res = aDec->Convert(dest, destOff, &destLen, aSrc, srcOff, &srcLen);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at %s.stress.Convert() code=0x%x.\n",aTestName,res);
|
|
return res;
|
|
}
|
|
|
|
srcOff+=srcLen;
|
|
destOff+=destLen;
|
|
|
|
// give a little input each time; it'll be consumed if enough output space
|
|
srcLen = 1;
|
|
// give output space only when requested: sadic!
|
|
if (res == NS_PARTIAL_MORE_OUTPUT) {
|
|
destLen = 1;
|
|
} else {
|
|
destLen = 0;
|
|
}
|
|
}
|
|
|
|
// we want perfect result here - the test data should be complete!
|
|
if (res != NS_OK) {
|
|
printf("ERROR at %s.stress.postConvert() code=0x%x.\n",aTestName,res);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
// compare lengths
|
|
if (exactLength) {
|
|
if (destOff != estimatedLength) {
|
|
printf("ERROR at %s.stress.EstimatedLen expected=0x%x result=0x%x.\n",
|
|
aTestName, estimatedLength, destOff);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
} else {
|
|
if (destOff > estimatedLength) {
|
|
printf("ERROR at %s.stress.EstimatedLen expected<=0x%x result=0x%x.\n",
|
|
aTestName, estimatedLength, destOff);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
}
|
|
|
|
// compare results
|
|
if (aResLength != destOff) {
|
|
printf("ERROR at %s.stress.ConvResLen expected=0x%x result=0x%x.\n",
|
|
aTestName, aResLength, destOff);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
for (PRInt32 i=0; i<aResLength; i++) if (aRes[i] != dest[i]) {
|
|
printf("ERROR at %s.stress.ConvResChar[%d] expected=0x%x result=0x%x.\n",
|
|
aTestName, i, aRes[i], dest[i]);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
/**
|
|
* Reset decoder.
|
|
*/
|
|
nsresult resetDecoder(nsIUnicodeDecoder * aDec, const char * aTestName)
|
|
{
|
|
nsresult res = aDec->Reset();
|
|
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at %s.reset.Reset() code=0x%x.\n",aTestName,res);
|
|
return res;
|
|
}
|
|
|
|
return res;
|
|
}
|
|
|
|
nsresult loadBinaryFile(char * aFile, char * aBuff, PRInt32 * aBuffLen)
|
|
{
|
|
FILE * f = fopen(aFile, "rb");
|
|
if (f == NULL) {
|
|
printf("ERROR at opening file: \"%s\".\n", aFile);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
PRInt32 n = fread(aBuff, 1, *aBuffLen, f);
|
|
if (n >= *aBuffLen) {
|
|
printf("ERROR at reading from file \"%s\": too much input data.\n", aFile);
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
*aBuffLen = n;
|
|
fclose(f);
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult loadUnicodeFile(char * aFile, PRUnichar * aBuff, PRInt32 * aBuffLen)
|
|
{
|
|
PRInt32 buffLen = 2*(*aBuffLen);
|
|
|
|
nsresult res = loadBinaryFile(aFile, (char *)aBuff, &buffLen);
|
|
if (NS_FAILED(res)) return res;
|
|
|
|
*aBuffLen = buffLen/2;
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult testDecoderFromFiles(char * aCharset, char * aSrcFile, char * aResultFile)
|
|
{
|
|
// create converter
|
|
CREATE_DECODER(aCharset);
|
|
|
|
PRInt32 srcLen = GENERAL_BUFFER;
|
|
char src[GENERAL_BUFFER];
|
|
PRInt32 expLen = GENERAL_BUFFER/2;
|
|
PRUnichar exp[GENERAL_BUFFER/2];
|
|
|
|
res = loadBinaryFile(aSrcFile, src, &srcLen);
|
|
if (NS_FAILED(res)) return res;
|
|
|
|
res = loadUnicodeFile(aResultFile, exp, &expLen);
|
|
if (NS_FAILED(res)) return res;
|
|
|
|
// test converter - easy test
|
|
res = testDecoder(dec, src, srcLen, exp, expLen, "dec");
|
|
|
|
// release converter
|
|
NS_RELEASE(dec);
|
|
|
|
if (NS_FAILED(res)) {
|
|
return res;
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
return NS_OK;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult testEncoderFromFiles(char * aCharset, char * aSrcFile, char * aResultFile)
|
|
{
|
|
// XXX write me
|
|
return NS_OK;
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// Decoders testing functions
|
|
|
|
/**
|
|
* Test the Latin1 decoder.
|
|
*/
|
|
nsresult testLatin1Decoder()
|
|
{
|
|
char * testName = "T101";
|
|
printf("\n[%s] Latin1ToUnicode\n", testName);
|
|
|
|
// create converter
|
|
CREATE_DECODER("iso-8859-1");
|
|
|
|
// test data
|
|
char src[] = {"\x00\x0d\x7f\x80\xff"};
|
|
PRUnichar exp[] = {0x0000,0x000d,0x007F,0x0080,0x00FF};
|
|
|
|
// test converter - easy test
|
|
res = testDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
|
|
|
|
// reset converter
|
|
if (NS_SUCCEEDED(res)) res = resetDecoder(dec, testName);
|
|
|
|
// test converter - stress test
|
|
if (NS_SUCCEEDED(res))
|
|
res = testStressDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
|
|
|
|
// release converter
|
|
NS_RELEASE(dec);
|
|
|
|
if (NS_FAILED(res)) {
|
|
return res;
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
return NS_OK;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Test the ISO2022JP decoder.
|
|
*/
|
|
nsresult testISO2022JPDecoder()
|
|
{
|
|
char * testName = "T102";
|
|
printf("\n[%s] ISO2022JPToUnicode\n", testName);
|
|
|
|
// create converter
|
|
CREATE_DECODER("iso-2022-jp");
|
|
|
|
// test data
|
|
char src[] = {"\x0d\x7f\xdd" "\x1b(J\xaa\xdc\x41" "\x1b$B\x21\x21" "\x1b$@\x32\x37" "\x1b(J\x1b(B\xcc"};
|
|
PRUnichar exp[] = {0x000d,0x007f,0xfffd, 0xff6a,0xFF9C,0x0041, 0x3000, 0x5378, 0xfffd};
|
|
|
|
// test converter - normal operation
|
|
res = testDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
|
|
|
|
// reset converter
|
|
if (NS_SUCCEEDED(res)) res = resetDecoder(dec, testName);
|
|
|
|
// test converter - stress test
|
|
if (NS_SUCCEEDED(res))
|
|
res = testStressDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
|
|
|
|
// release converter
|
|
NS_RELEASE(dec);
|
|
|
|
if (NS_FAILED(res)) {
|
|
return res;
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
return NS_OK;
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// Encoders testing functions
|
|
|
|
/**
|
|
* Test the Latin1 encoder.
|
|
*/
|
|
nsresult testLatin1Encoder()
|
|
{
|
|
char * testName = "T201";
|
|
printf("\n[%s] UnicodeToLatin1\n", testName);
|
|
|
|
// create converter
|
|
CREATE_ENCODER("iso-8859-1");
|
|
|
|
// XXX finish me
|
|
|
|
/*
|
|
// test data
|
|
char src[] = {"\x00\x0d\x7f\x80\xff"};
|
|
PRUnichar exp[] = {0x0000,0x000d,0x007F,0x0080,0x00FF};
|
|
|
|
// test converter - easy test
|
|
res = testDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
|
|
|
|
// reset converter
|
|
if (NS_SUCCEEDED(res)) res = resetDecoder(dec, testName);
|
|
|
|
// test converter - stress test
|
|
if (NS_SUCCEEDED(res))
|
|
res = testStressDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
|
|
*/
|
|
|
|
// release converter
|
|
NS_RELEASE(enc);
|
|
|
|
if (NS_FAILED(res)) {
|
|
return res;
|
|
} else {
|
|
printf("Test Passed.\n");
|
|
return NS_OK;
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// Testing functions
|
|
|
|
nsresult testAll()
|
|
{
|
|
nsresult res;
|
|
|
|
// test the manager(s)
|
|
res = testCharsetConverterManager();
|
|
if (NS_FAILED(res)) return res;
|
|
|
|
// test decoders
|
|
testLatin1Decoder();
|
|
testISO2022JPDecoder();
|
|
|
|
// test encoders
|
|
testLatin1Encoder();
|
|
|
|
// older tests - XXX to be rewritten in new style
|
|
testSJISDecoder();
|
|
testISO88597Decoder();
|
|
|
|
// return
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult testFromArgs(int argc, char **argv)
|
|
{
|
|
nsresult res = nsServiceManager::GetService(kCharsetConverterManagerCID,
|
|
kICharsetConverterManagerIID, (nsISupports **)&ccMan);
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at GetService() code=0x%x.\n",res);
|
|
return res;
|
|
}
|
|
|
|
if ((argc == 5) && (!strcmp(argv[1], "-tdec"))) {
|
|
res = testDecoderFromFiles(argv[2], argv[3], argv[4]);
|
|
} else if ((argc == 5) && (!strcmp(argv[1], "-tenc"))) {
|
|
res = testEncoderFromFiles(argv[2], argv[3], argv[4]);
|
|
} else {
|
|
printf("Usage:\n");
|
|
printf(" TestUConv.exe\n");
|
|
printf(" TestUConv.exe -tdec encoding inputEncodedFile expectedResultUnicodeFile\n");
|
|
printf(" TestUConv.exe -tenc encoding inputUnicodeFile expectedResultEncodedFile\n");
|
|
}
|
|
|
|
return res;
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// Main program functions
|
|
|
|
nsresult init()
|
|
{
|
|
nsresult res;
|
|
|
|
res = setupRegistry();
|
|
if (NS_FAILED(res)) {
|
|
printf("ERROR at setupRegistry() code=0x%x.\n", res);
|
|
return res;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult done()
|
|
{
|
|
if (ccMan != NULL) nsServiceManager::
|
|
ReleaseService(kCharsetConverterManagerCID, ccMan);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
nsresult res;
|
|
|
|
res = init();
|
|
if (NS_FAILED(res)) return -1;
|
|
|
|
if (argc <= 1) {
|
|
printf("*** Unicode Converters Test ***\n");
|
|
res = testAll();
|
|
printf("\n***--------- Done --------***\n");
|
|
} else {
|
|
res = testFromArgs(argc, argv);
|
|
}
|
|
|
|
done();
|
|
|
|
if (NS_FAILED(res)) return -1;
|
|
else return 0;
|
|
}
|