/* * The contents of this file are subject to the Mozilla Public * License Version 1.1 (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/MPL/ * * 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 the Netscape security libraries. * * The Initial Developer of the Original Code is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 1994-2000 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): * * Alternatively, the contents of this file may be used under the * terms of the GNU General Public License Version 2 or later (the * "GPL"), in which case the provisions of the GPL are applicable * instead of those above. If you wish to allow use of your * version of this file only under the terms of the GPL and not to * allow others to use your version of this file under the MPL, * indicate your decision by deleting the provisions above and * replace them with the notice and other provisions required by * the GPL. If you do not delete the provisions above, a recipient * may use your version of this file under either the MPL or the * GPL. */ #include "nspr.h" #include "nscore.h" #include "nsString.h" #include "nsIServiceManager.h" #include "nsIStringBundle.h" #include "nsIDateTimeFormat.h" #include "nsDateTimeFormatCID.h" #include "nsICharsetConverterManager.h" extern "C" { #include "nlslayer.h" } static NS_DEFINE_IID(kStringBundleServiceCID, NS_STRINGBUNDLESERVICE_CID); static NS_DEFINE_IID(kIStringBundleServiceIID, NS_ISTRINGBUNDLESERVICE_IID); static NS_DEFINE_CID(kDateTimeCID, NS_DATETIMEFORMAT_CID); static NS_DEFINE_CID(kCharsetConverterManagerCID, NS_ICHARSETCONVERTERMANAGER_CID); static nsIUnicodeEncoder *encoderUTF8 = nsnull; static nsIUnicodeDecoder *decoderUTF8 = nsnull; static nsIUnicodeEncoder *encoderASCII = nsnull; static nsIUnicodeDecoder *decoderASCII = nsnull; #define TEXT_BUNDLE "resource:/ui/psm_text.properties" #define UI_BUNDLE "resource:/ui/psm_ui.properties" #define BIN_BUNDLE "resource:/ui/psm_bin.properties" #define DOC_BUNDLE "resource:/ui/psm_doc.properties" extern "C" { static nsIStringBundle* nlsCreateBundle(char* bundleURL); static char* nlsGetUTF8StringFromBundle(nsIStringBundle *bundle, const char *name); static nsIStringBundle * bundles[4] = {NULL, NULL, NULL, NULL}; } extern "C" PRBool nlsInit() { nsICharsetConverterManager *ccm = nsnull; nsAutoString charsetUTF8("UTF-8"); nsAutoString charsetASCII("ISO-8859-1"); PRBool ret = PR_FALSE; nsresult res; res = NS_InitXPCOM(NULL, NULL); NS_ASSERTION( NS_SUCCEEDED(res), "NS_InitXPCOM failed" ); // Register components res = nsComponentManager::AutoRegister(nsIComponentManager::NS_Startup, NULL /* default */); if(NS_FAILED(res)) { goto loser; } // Create the bundles bundles[0] = nlsCreateBundle(TEXT_BUNDLE); bundles[1] = nlsCreateBundle(UI_BUNDLE); bundles[2] = nlsCreateBundle(BIN_BUNDLE); bundles[3] = nlsCreateBundle(DOC_BUNDLE); // Create a unicode encoder and decoder res = nsServiceManager::GetService(kCharsetConverterManagerCID, NS_GET_IID(nsICharsetConverterManager), (nsISupports**)&ccm); if (NS_FAILED(res) || (nsnull == ccm)) { goto loser; } res = ccm->GetUnicodeEncoder(&charsetUTF8, &encoderUTF8); if (NS_FAILED(res) || (nsnull == encoderUTF8)) { goto loser; } res = ccm->GetUnicodeDecoder(&charsetUTF8, &decoderUTF8); if (NS_FAILED(res) || (nsnull == decoderUTF8)) { goto loser; } res = ccm->GetUnicodeEncoder(&charsetASCII, &encoderASCII); if (NS_FAILED(res) || (nsnull == encoderASCII)) { goto loser; } res = ccm->GetUnicodeDecoder(&charsetASCII, &decoderASCII); if (NS_FAILED(res) || (nsnull == decoderASCII)) { goto loser; } ret = PR_TRUE; goto done; loser: NS_IF_RELEASE(bundles[0]); NS_IF_RELEASE(bundles[1]); NS_IF_RELEASE(bundles[2]); NS_IF_RELEASE(bundles[3]); NS_IF_RELEASE(encoderUTF8); NS_IF_RELEASE(decoderUTF8); NS_IF_RELEASE(encoderASCII); NS_IF_RELEASE(decoderASCII); done: return ret; } extern "C" nsIStringBundle* nlsCreateBundle(char* bundleURL) { nsresult ret; nsIStringBundleService *service = nsnull; nsIStringBundle* bundle = nsnull; nsILocale *locale = nsnull; // Get the string bundle service ret = nsServiceManager::GetService(kStringBundleServiceCID, kIStringBundleServiceIID, (nsISupports**)&service); if (NS_FAILED(ret)) { return NULL; } // Create the bundle ret = service->CreateBundle(bundleURL, locale, &bundle); if (NS_FAILED(ret)) { return NULL; } NS_IF_RELEASE(service); return bundle; } extern "C" char* nlsGetUTF8StringFromBundle(nsIStringBundle *bundle, const char *name) { nsresult ret; nsString key(name); nsString value; PRUnichar * p = NULL; ret = bundle->GetStringFromName(key.GetUnicode(), &p); if (NS_FAILED(ret)) { return NULL; } value = p; // XXX This is a hack to get cr and lf chars in string. // See bug# 21418 value.ReplaceSubstring("", "\r"); value.ReplaceSubstring("", "\n"); return value.ToNewUTF8String(); } extern "C" char* nlsGetUTF8String(const char *name) { int i; char *value = NULL; for (i=0;i<4;i++) { value = nlsGetUTF8StringFromBundle(bundles[i], name); if (value) { break; } } return value; } extern "C" void * nlsNewDateFormat() { nsIComponentManager *comMgr; nsIDateTimeFormat *dateTimeFormat = nsnull; nsresult rv; rv = NS_GetGlobalComponentManager(&comMgr); if (NS_FAILED(rv)) { return NULL; } rv = comMgr->CreateInstance(kDateTimeCID, nsnull, NS_GET_IID(nsIDateTimeFormat), (void**)&dateTimeFormat); if (NS_FAILED(rv)) { return NULL; } return dateTimeFormat; } extern "C" void nlsFreeDateFormat(void * p) { nsIDateTimeFormat *dateTimeFormat = (nsIDateTimeFormat*)p; NS_IF_RELEASE(dateTimeFormat); } extern "C" char * nslPRTimeToUTF8String(void* p, PRInt64 t) { nsIDateTimeFormat *dateTimeFormat = (nsIDateTimeFormat*)p; nsString dateTime; nsresult rv; rv = dateTimeFormat->FormatPRTime(nsnull, kDateFormatShort, kTimeFormatNoSeconds, PRTime(t), dateTime); if (NS_FAILED(rv)) { return nsnull; } return dateTime.ToNewUTF8String(); } extern "C" PRBool nlsUnicodeToUTF8(unsigned char * inBuf, unsigned int inBufBytes, unsigned char * outBuf, unsigned int maxOutBufLen, unsigned int * outBufLen) { PRBool ret = PR_FALSE; nsIUnicodeEncoder *enc = encoderUTF8; PRInt32 dstLength; nsresult res; res = enc->GetMaxLength((const PRUnichar *)inBuf, inBufBytes, &dstLength); if (NS_FAILED(res) || (dstLength > maxOutBufLen)) { goto loser; } res = enc->Convert((const PRUnichar *)inBuf, (PRInt32*)&inBufBytes, (char*)outBuf, &dstLength); if (NS_FAILED(res)) { goto loser; } /* outBuf[dstLength] = '\0';*/ *outBufLen = dstLength; ret = PR_TRUE; loser: return ret; } extern "C" PRBool nlsUTF8ToUnicode(unsigned char * inBuf, unsigned int inBufBytes, unsigned char * outBuf, unsigned int maxOutBufLen, unsigned int * outBufLen) { PRBool ret = PR_FALSE; PRInt32 dstLength; nsIUnicodeDecoder *dec = decoderUTF8; nsresult res; res = dec->GetMaxLength((const char*)inBuf, inBufBytes, &dstLength); if (NS_FAILED(res) || (dstLength > maxOutBufLen)) { goto loser; } res = dec->Convert((const char *)inBuf, (PRInt32*)&inBufBytes, (PRUnichar*)outBuf, &dstLength); if (NS_FAILED(res)) { goto loser; } ret = PR_TRUE; loser: return ret; } extern "C" PRBool nlsUnicodeToASCII(unsigned char * inBuf, unsigned int inBufBytes, unsigned char * outBuf, unsigned int maxOutBufLen, unsigned int * outBufLen) { PRBool ret = PR_FALSE; nsIUnicodeEncoder *enc = encoderASCII; PRInt32 dstLength; nsresult res; res = enc->GetMaxLength((const PRUnichar *)inBuf, inBufBytes, &dstLength); if (NS_FAILED(res) || (dstLength > maxOutBufLen)) { goto loser; } res = enc->Convert((const PRUnichar *)inBuf, (PRInt32*)&inBufBytes, (char*)outBuf, &dstLength); if (NS_FAILED(res)) { goto loser; } /* outBuf[dstLength] = '\0';*/ *outBufLen = dstLength; ret = PR_TRUE; loser: return ret; } extern "C" PRBool nlsASCIIToUnicode(unsigned char * inBuf, unsigned int inBufBytes, unsigned char * outBuf, unsigned int maxOutBufLen, unsigned int * outBufLen) { PRBool ret = PR_FALSE; PRInt32 dstLength; nsIUnicodeDecoder *dec = decoderASCII; nsresult res; res = dec->GetMaxLength((const char*)inBuf, inBufBytes, &dstLength); if (NS_FAILED(res) || (dstLength > maxOutBufLen)) { goto loser; } res = dec->Convert((const char *)inBuf, (PRInt32*)&inBufBytes, (PRUnichar*)outBuf, &dstLength); if (NS_FAILED(res)) { goto loser; } *outBufLen = (unsigned int)dstLength*2; ret = PR_TRUE; loser: return ret; }