1998-03-28 02:44:41 +00:00
|
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
|
*
|
|
|
|
|
* The contents of this file are subject to the Netscape Public License
|
|
|
|
|
* Version 1.0 (the "NPL"); you may not use this file except in
|
|
|
|
|
* compliance with the NPL. You may obtain a copy of the NPL at
|
|
|
|
|
* http://www.mozilla.org/NPL/
|
|
|
|
|
*
|
|
|
|
|
* Software distributed under the NPL is distributed on an "AS IS" basis,
|
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
|
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
|
* NPL.
|
|
|
|
|
*
|
|
|
|
|
* The Initial Developer of this code under the NPL is Netscape
|
|
|
|
|
* Communications Corporation. Portions created by Netscape are
|
|
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
|
|
|
|
|
* Reserved.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "stdafx.h"
|
|
|
|
|
#include "mainfrm.h"
|
|
|
|
|
#include "libi18n.h"
|
|
|
|
|
#include "xplocale.h"
|
|
|
|
|
#include "cxprint.h"
|
|
|
|
|
#include "cxsave.h"
|
|
|
|
|
|
|
|
|
|
#include "np.h"
|
|
|
|
|
#include "prlog.h"
|
|
|
|
|
#include "prlink.h"
|
|
|
|
|
#include "xpstrsw.h"
|
|
|
|
|
|
1998-06-03 06:19:45 +00:00
|
|
|
|
#if defined(OJI)
|
|
|
|
|
#include "jvmmgr.h"
|
|
|
|
|
#elif defined(JAVA)
|
|
|
|
|
#include "java.h"
|
|
|
|
|
#endif
|
|
|
|
|
|
1998-03-28 02:44:41 +00:00
|
|
|
|
#include "intl_csi.h"
|
|
|
|
|
#include "edt.h"
|
|
|
|
|
|
|
|
|
|
#include "prefapi.h"
|
|
|
|
|
#include "edt.h"
|
|
|
|
|
|
1998-09-19 00:27:03 +00:00
|
|
|
|
#define SIMULATE_WIN95_ON_NT true
|
|
|
|
|
#ifdef SIMULATE_WIN95_ON_NT
|
1998-10-12 12:01:51 +00:00
|
|
|
|
static XP_Bool useSystemW = FALSE;
|
|
|
|
|
#define IsRunningOnNT useSystemW
|
1998-09-19 00:27:03 +00:00
|
|
|
|
#else
|
|
|
|
|
#define IsRunningOnNT sysInfo.m_bWinNT
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
1998-03-28 02:44:41 +00:00
|
|
|
|
#ifdef XP_WIN32
|
|
|
|
|
static BOOL intlUnicodeFlag(int16 wincsid);
|
|
|
|
|
#define INIT_FLAG_FOR_CSID(c) { CIntlWin::flagTable[(c) & MASK_FLAG_TABLE] = intlUnicodeFlag(c);}
|
|
|
|
|
BOOL CIntlWin::flagTable[MAX_FLAG_TABLE_NUM];
|
|
|
|
|
#endif // XP_WIN32
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
extern int INTL_DocCharSetID(MWContext *context);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Data type use for Unicode table loader
|
|
|
|
|
//
|
|
|
|
|
#define MAXUTABLENAME 16
|
|
|
|
|
typedef struct tblrsrcinfo {
|
|
|
|
|
char name[MAXUTABLENAME];
|
|
|
|
|
uint16 refcount;
|
|
|
|
|
HGLOBAL hTbl;
|
|
|
|
|
} tblrsrcinfo;
|
|
|
|
|
|
|
|
|
|
typedef struct utablename {
|
|
|
|
|
uint16 csid;
|
|
|
|
|
tblrsrcinfo frominfo;
|
|
|
|
|
tblrsrcinfo toinfo;
|
|
|
|
|
|
|
|
|
|
} utablename;
|
|
|
|
|
//
|
|
|
|
|
// The following are private
|
|
|
|
|
//
|
|
|
|
|
static void intl_WriteUnicodeConvList(int num_of_csid, int16* csidlist);
|
|
|
|
|
static void intl_ReadUnicodeConvList();
|
|
|
|
|
static void intl_UnloadUCS2Table(uint16 csid, void *utblPtr, int from);
|
|
|
|
|
static tblrsrcinfo* intl_FindUTableName(uint16 csid, int from);
|
|
|
|
|
static void *intl_LoadUCS2Table(uint16 csid, int from);
|
|
|
|
|
static void intl_UnloadUCS2Table(uint16 csid, void *utblPtr, int from);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// This structure is used for following table for default font value,
|
|
|
|
|
// It'll be removed after default value goes to resource file.
|
|
|
|
|
struct FontCharTable
|
|
|
|
|
{
|
|
|
|
|
int16 csid;
|
|
|
|
|
char szPropFont[LF_FACESIZE] ;
|
|
|
|
|
int iPropSize ;
|
|
|
|
|
char szFixFont[LF_FACESIZE] ;
|
|
|
|
|
int iFixSize ;
|
|
|
|
|
int iPropCharset;
|
|
|
|
|
int iFixCharset;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Note: always add new comer to last line.
|
|
|
|
|
struct FontCharTable fontchar_tbl[] =
|
|
|
|
|
{
|
|
|
|
|
CS_LATIN1, DEF_PROPORTIONAL_FONT, 12, DEF_FIXED_FONT, 10, ANSI_CHARSET, ANSI_CHARSET,
|
|
|
|
|
CS_SJIS, "<EFBFBD>l<EFBFBD>r <20><><EFBFBD><EFBFBD>", 10, "<EFBFBD>l<EFBFBD>r <20><><EFBFBD><EFBFBD>", 10, SHIFTJIS_CHARSET, SHIFTJIS_CHARSET,
|
|
|
|
|
CS_BIG5, "Times New Roman", 12, "Courier New", 10, CHINESEBIG5_CHARSET, CHINESEBIG5_CHARSET,
|
|
|
|
|
CS_KSC_8BIT,"Times New Roman", 12, "Courier New", 10, HANGEUL_CHARSET, HANGEUL_CHARSET,
|
|
|
|
|
CS_GB_8BIT, "Times New Roman", 12, "Courier New", 10, 134, 134,
|
|
|
|
|
CS_CP_1250, "Times New Roman", 12, "Courier New", 10, 238,238,
|
|
|
|
|
CS_CP_1251, "Times New Roman", 12, "Courier New", 10, 204,204,
|
1998-05-08 19:23:48 +00:00
|
|
|
|
CS_ARMSCII8, "ArmNet Helvetica", 12, "ArmNet Courier", 10, 160, 160,
|
1998-03-28 02:44:41 +00:00
|
|
|
|
CS_CP_1253, "Times New Roman", 12, "Courier New", 10, 161,161,
|
|
|
|
|
CS_8859_9, "Times New Roman", 12, "Courier New", 10, 162,162,
|
1998-08-13 22:25:08 +00:00
|
|
|
|
CS_VIET_VIQR, "Times New Roman", 12, "Courier New", 10, 163,163,
|
|
|
|
|
CS_VIET_VISCII, "<EFBFBD>nhMinh 1.1", 12, "MinhQu<EFBFBD>n 1.1", 10, 163,163,
|
|
|
|
|
CS_VIET_VPS, "VPS Times", 12, "VPS Courier", 10, 163,163,
|
1998-09-30 10:48:13 +00:00
|
|
|
|
CS_VIET_TCVN, ".VNTime", 12, ".VNCourier New", 10, 163,163,
|
|
|
|
|
CS_VIET_VNI, "VNI-Times", 12, "VNI-Internet Mail",10, 163,163,
|
|
|
|
|
CS_CP_1258, "Times New Roman", 12, "Courier New", 10, 163,163,
|
1998-08-01 07:49:21 +00:00
|
|
|
|
CS_TIS620, "AngsanaUPC", 16, "CordiaUPC", 14, THAI_CHARSET, THAI_CHARSET,
|
1998-03-28 02:44:41 +00:00
|
|
|
|
CS_UTF8, DEF_PROPORTIONAL_FONT, 12, DEF_FIXED_FONT, 10, DEFAULT_CHARSET, DEFAULT_CHARSET,
|
|
|
|
|
CS_USER_DEFINED_ENCODING, DEF_PROPORTIONAL_FONT, 12, DEF_FIXED_FONT, 10, ANSI_CHARSET, ANSI_CHARSET,
|
|
|
|
|
0, "", 0, "", 0, 0, 0
|
|
|
|
|
} ;
|
|
|
|
|
|
|
|
|
|
// This table defined how many encoding we supports in our Navigator and
|
|
|
|
|
// what kind of conversion we support for each encoding.
|
|
|
|
|
// Note: always add new comer to last line.
|
|
|
|
|
// Encoding, Encoding used for Display, supported CSID list, 0
|
|
|
|
|
|
|
|
|
|
unsigned int lang_table[] =
|
|
|
|
|
{
|
|
|
|
|
IDS_LANGUAGE_LATIN1, CS_LATIN1, CS_LATIN1, 0,
|
|
|
|
|
IDS_LANGUAGE_LATIN2, CS_CP_1250, CS_CP_1250, CS_LATIN2, 0,
|
|
|
|
|
IDS_LANGUAGE_JAPANESE, CS_SJIS, CS_AUTO | CS_SJIS, CS_SJIS, CS_JIS, CS_EUCJP, 0,
|
1998-04-14 20:49:47 +00:00
|
|
|
|
IDS_LANGUAGE_TAIWANESE, CS_BIG5, CS_BIG5, CS_CNS_8BIT,
|
1998-08-01 07:49:21 +00:00
|
|
|
|
CS_X_BIG5, 0,
|
1998-04-14 20:49:47 +00:00
|
|
|
|
IDS_LANGUAGE_CHINESE, CS_GB_8BIT, CS_GB_8BIT,
|
1998-07-13 16:38:30 +00:00
|
|
|
|
CS_GB2312, CS_GB2312_11, CS_HZ, 0,
|
1998-04-14 20:49:47 +00:00
|
|
|
|
IDS_LANGUAGE_KOREAN, CS_KSC_8BIT, CS_KSC_8BIT | CS_AUTO, CS_KSC_8BIT, CS_2022_KR,
|
1998-08-01 07:49:21 +00:00
|
|
|
|
CS_KSC5601, 0,
|
1998-03-28 02:44:41 +00:00
|
|
|
|
IDS_LANGUAGE_WIN1251, CS_CP_1251, CS_CP_1251, CS_8859_5, CS_KOI8_R, 0,
|
1998-05-08 19:23:48 +00:00
|
|
|
|
IDS_LANGUAGE_ARMENIAN, CS_ARMSCII8, CS_ARMSCII8, 0,
|
1998-03-28 02:44:41 +00:00
|
|
|
|
IDS_LANGUAGE_GREEK, CS_CP_1253, CS_CP_1253, CS_8859_7, 0,
|
|
|
|
|
IDS_LANGUAGE_TURKISH, CS_8859_9, CS_8859_9, 0,
|
1998-09-30 10:48:13 +00:00
|
|
|
|
IDS_LANGUAGE_VIETNAMESE_VIQR, CS_VIET_VIQR, CS_VIET_VIQR, CS_VIET_VISCII, CS_VIET_VPS, CS_VIET_TCVN, CS_VIET_VNI, CS_CP_1258, 0,
|
|
|
|
|
IDS_LANGUAGE_VIETNAMESE_VISCII, CS_VIET_VISCII, CS_VIET_VISCII, CS_VIET_VPS, CS_VIET_TCVN, CS_VIET_VIQR, CS_VIET_VNI, CS_CP_1258, 0,
|
|
|
|
|
IDS_LANGUAGE_VIETNAMESE_VPS, CS_VIET_VPS, CS_VIET_VPS, CS_VIET_VISCII, CS_VIET_TCVN, CS_VIET_VIQR, CS_VIET_VNI, CS_CP_1258, 0,
|
|
|
|
|
IDS_LANGUAGE_VIETNAMESE_TCVN, CS_VIET_TCVN, CS_VIET_TCVN, CS_VIET_VISCII, CS_VIET_VPS, CS_VIET_VIQR, CS_VIET_VNI, CS_CP_1258, 0,
|
|
|
|
|
IDS_LANGUAGE_VIETNAMESE_VNI, CS_VIET_VNI, CS_VIET_TCVN, CS_VIET_VISCII, CS_VIET_VPS, CS_VIET_VIQR, CS_VIET_VNI, CS_CP_1258, 0,
|
|
|
|
|
IDS_LANGUAGE_VIETNAMESE_CP1258, CS_CP_1258, CS_CP_1258, CS_VIET_VISCII, CS_VIET_VPS, CS_VIET_VIQR, CS_VIET_VNI, CS_VIET_TCVN, 0,
|
1998-08-01 07:49:21 +00:00
|
|
|
|
IDS_LANGUAGE_THAI, CS_TIS620, CS_TIS620, 0,
|
1998-09-19 00:27:03 +00:00
|
|
|
|
IDS_LANGUAGE_UTF8, CS_UTF8, CS_UTF8, CS_UTF7, CS_UCS2, CS_UCS2_SWAP, CS_T61, 0,
|
1998-03-28 02:44:41 +00:00
|
|
|
|
IDS_LANGUAGE_USERDEFINED, CS_USER_DEFINED_ENCODING, CS_USER_DEFINED_ENCODING, 0,
|
|
|
|
|
UINT_MAX
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
CIntlFont::CIntlFont()
|
|
|
|
|
{
|
|
|
|
|
CString fontList;
|
|
|
|
|
LPSTR lpszPropName = NULL;
|
|
|
|
|
LPSTR lpszFixName = NULL;
|
|
|
|
|
int32 iPropSize, iFixSize ;
|
|
|
|
|
int iPropCharset, iFixCharset;
|
|
|
|
|
BOOL ret = FALSE;
|
|
|
|
|
int i ;
|
|
|
|
|
int nLang ;
|
|
|
|
|
EncodingInfo *pEncoding;
|
|
|
|
|
|
|
|
|
|
iPropCharset = iFixCharset = 0;
|
|
|
|
|
|
|
|
|
|
#ifdef XP_WIN32
|
|
|
|
|
for(int j = 0; j < MAX_FLAG_TABLE_NUM; j++)
|
|
|
|
|
INIT_FLAG_FOR_CSID(j);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
pEncodingInfoTbl = (struct EncodingInfo *) malloc( (MAXLANGNUM + 1) * sizeof (struct EncodingInfo) ) ;
|
|
|
|
|
|
|
|
|
|
if (pEncodingInfoTbl == NULL)
|
|
|
|
|
{
|
|
|
|
|
TRACE("No memory for MultiLingual support.\n");
|
|
|
|
|
return ;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
memset(pEncodingInfoTbl, 0, (MAXLANGNUM + 1) * sizeof(struct EncodingInfo));
|
|
|
|
|
|
|
|
|
|
nLang = 0;
|
|
|
|
|
pEncoding = pEncodingInfoTbl;
|
|
|
|
|
for (i = 0; (lang_table[i] != UINT_MAX) && (nLang < MAXLANGNUM); i++)
|
|
|
|
|
{
|
|
|
|
|
pEncoding->iLangResId = lang_table[i++];
|
|
|
|
|
pEncoding->iCSID = lang_table[i++];
|
|
|
|
|
|
|
|
|
|
// Setup default font information.
|
|
|
|
|
for (int j = 0; j < MAXLANGNUM; j++)
|
|
|
|
|
{
|
|
|
|
|
if (fontchar_tbl[j].csid == pEncoding->iCSID)
|
|
|
|
|
{
|
|
|
|
|
// First, lets try to copy from the hard coded table
|
|
|
|
|
strcpy(pEncoding->szPropName, fontchar_tbl[j].szPropFont);
|
|
|
|
|
pEncoding->iPropSize = fontchar_tbl[j].iPropSize;
|
|
|
|
|
strcpy(pEncoding->szFixName, fontchar_tbl[j].szFixFont);
|
|
|
|
|
pEncoding->iFixSize = fontchar_tbl[j].iFixSize;
|
|
|
|
|
pEncoding->iPropCharset = fontchar_tbl[j].iPropCharset;
|
|
|
|
|
pEncoding->iFixCharset = fontchar_tbl[j].iFixCharset;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
char key[80];
|
|
|
|
|
// Now, let's try to get it from the PREF
|
|
|
|
|
sprintf(key, "intl.font%d.win.prop_font", pEncoding->iCSID);
|
|
|
|
|
lpszPropName = NULL;
|
|
|
|
|
if( PREF_NOERROR == PREF_CopyCharPref(key, &lpszPropName))
|
|
|
|
|
{
|
|
|
|
|
strcpy(pEncoding->szPropName, lpszPropName);
|
|
|
|
|
XP_FREE(lpszPropName);
|
|
|
|
|
}
|
|
|
|
|
sprintf(key, "intl.font%d.win.fixed_font", pEncoding->iCSID);
|
|
|
|
|
lpszFixName = NULL;
|
|
|
|
|
if( PREF_NOERROR == PREF_CopyCharPref(key, &lpszFixName))
|
|
|
|
|
{
|
|
|
|
|
strcpy(pEncoding->szFixName, lpszFixName);
|
|
|
|
|
XP_FREE(lpszFixName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sprintf(key, "intl.font%d.win.prop_size", pEncoding->iCSID);
|
|
|
|
|
if( PREF_NOERROR == PREF_GetIntPref(key, &iPropSize))
|
|
|
|
|
pEncoding->iPropSize = (int)iPropSize;
|
|
|
|
|
|
|
|
|
|
sprintf(key, "intl.font%d.win.fixed_size", pEncoding->iCSID);
|
|
|
|
|
if( PREF_NOERROR == PREF_GetIntPref(key, &iFixSize))
|
|
|
|
|
pEncoding->iFixSize = (int)iFixSize;
|
|
|
|
|
|
|
|
|
|
// Setup supported CSID list
|
|
|
|
|
for (j =0; lang_table[i]; j++)
|
|
|
|
|
{
|
|
|
|
|
pEncoding->csid[j] = lang_table[i++] ;
|
|
|
|
|
#ifdef XP_WIN32
|
|
|
|
|
INIT_FLAG_FOR_CSID(pEncoding->csid[j]);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pEncoding->nCodeset = j;
|
|
|
|
|
|
|
|
|
|
nLang ++ ;
|
|
|
|
|
pEncoding ++ ;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
nEncoding = MAXLANGNUM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
EncodingInfo * CIntlFont::GetEncodingInfo(int id)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if (id < nEncoding)
|
|
|
|
|
return &pEncodingInfoTbl[id];
|
|
|
|
|
else
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
EncodingInfo * CIntlFont::GetEncodingInfo(MWContext *pContext)
|
|
|
|
|
{
|
|
|
|
|
int doc_csid, id;
|
|
|
|
|
doc_csid = INTL_DocCharSetID(pContext) & ~CS_AUTO ;
|
|
|
|
|
id = DocCSIDtoID(doc_csid);
|
|
|
|
|
|
|
|
|
|
return GetEncodingInfo(id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int16 IntlCharsetToCsid(BYTE charset)
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < MAXLANGNUM; i++)
|
|
|
|
|
{
|
|
|
|
|
EncodingInfo *pEncoding = theApp.m_pIntlFont->GetEncodingInfo(i);
|
|
|
|
|
if (charset == pEncoding->iPropCharset)
|
|
|
|
|
return (pEncoding->iCSID & ~CS_AUTO);
|
|
|
|
|
}
|
|
|
|
|
return CS_LATIN1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int CIntlFont::DocCSIDtoID(int doc_csid)
|
|
|
|
|
{
|
|
|
|
|
int i, j;
|
|
|
|
|
EncodingInfo *pEncoding ;
|
|
|
|
|
|
1998-08-13 22:25:08 +00:00
|
|
|
|
/**************************************************************/
|
|
|
|
|
/*** This section should work for everybody, but for now we ***/
|
|
|
|
|
/*** make it work for vietnamese only (our area). Basically ***/
|
|
|
|
|
/*** instead of returning the first csid found in doc_csid, ***/
|
|
|
|
|
/*** we check the default view encoding first, and return ***/
|
|
|
|
|
/*** that default view csid if found, otherwise it will ***/
|
|
|
|
|
/*** return the value as the usual way ***/
|
|
|
|
|
int k;
|
|
|
|
|
int16 def_doccsid;
|
|
|
|
|
def_doccsid = INTL_DefaultDocCharSetID(0);
|
|
|
|
|
if (! ((def_doccsid == CS_VIET_VISCII) ||
|
|
|
|
|
(def_doccsid == CS_VIET_VPS) ||
|
|
|
|
|
(def_doccsid == CS_VIET_TCVN) ||
|
1998-08-18 19:03:36 +00:00
|
|
|
|
(def_doccsid == CS_VIET_VNI) ||
|
1998-09-30 10:48:13 +00:00
|
|
|
|
(def_doccsid == CS_CP_1258) ||
|
1998-08-13 22:25:08 +00:00
|
|
|
|
(def_doccsid == CS_VIET_VIQR)
|
|
|
|
|
)) {
|
|
|
|
|
def_doccsid = 0;
|
|
|
|
|
}
|
|
|
|
|
k = 0;
|
|
|
|
|
pEncoding = &pEncodingInfoTbl[0];
|
|
|
|
|
for (i = 0; i < nEncoding; i++)
|
|
|
|
|
{
|
|
|
|
|
for (j = 0; j < pEncoding->nCodeset; j++)
|
|
|
|
|
{
|
|
|
|
|
if (doc_csid == pEncoding->csid[j])
|
|
|
|
|
{
|
|
|
|
|
if ((def_doccsid == 0) ||
|
|
|
|
|
(def_doccsid == pEncoding->iCSID))
|
|
|
|
|
return i ;
|
|
|
|
|
if (k == 0) k = i;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
pEncoding ++ ;
|
|
|
|
|
}
|
|
|
|
|
// Note!!!: return 0 here is not good idea, but it can avoid crash.
|
|
|
|
|
// need to revisit this code later.
|
|
|
|
|
return k;
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
char * CIntlFont::GetEncodingName(int id)
|
|
|
|
|
{
|
|
|
|
|
if (id < nEncoding)
|
|
|
|
|
return szLoadString(pEncodingInfoTbl[id].iLangResId);
|
|
|
|
|
else // Never should come here
|
|
|
|
|
return "Unknown";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void CIntlFont::WriteToIniFile()
|
|
|
|
|
{
|
|
|
|
|
EncodingInfo *pEncoding;
|
|
|
|
|
pEncoding = &pEncodingInfoTbl[0];
|
|
|
|
|
for (int i = 0; i < MAXLANGNUM; i++)
|
|
|
|
|
{
|
|
|
|
|
char key[80];
|
|
|
|
|
|
|
|
|
|
sprintf(key, "intl.font%d.win.prop_font", pEncoding->iCSID);
|
|
|
|
|
PREF_SetCharPref(key, pEncoding->szPropName);
|
|
|
|
|
|
|
|
|
|
sprintf(key, "intl.font%d.win.fixed_font", pEncoding->iCSID);
|
|
|
|
|
PREF_SetCharPref(key, pEncoding->szFixName);
|
|
|
|
|
|
|
|
|
|
sprintf(key, "intl.font%d.win.prop_size", pEncoding->iCSID);
|
|
|
|
|
PREF_SetIntPref(key, (int32)pEncoding->iPropSize);
|
|
|
|
|
|
|
|
|
|
sprintf(key, "intl.font%d.win.fixed_size", pEncoding->iCSID);
|
|
|
|
|
PREF_SetIntPref(key, (int32)pEncoding->iFixSize);
|
|
|
|
|
|
|
|
|
|
pEncoding ++ ;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BYTE IntlGetLfCharset(int csid)
|
|
|
|
|
{
|
|
|
|
|
int id;
|
|
|
|
|
if (csid == 0)
|
|
|
|
|
csid = INTL_DefaultWinCharSetID(0);
|
|
|
|
|
csid = csid & ~CS_AUTO; // mask off AUTO bit
|
|
|
|
|
|
|
|
|
|
if (csid == 0 || csid == CS_LATIN1 || csid == CS_UNKNOWN)
|
|
|
|
|
return ANSI_CHARSET;
|
|
|
|
|
|
|
|
|
|
id = theApp.m_pIntlFont->DocCSIDtoID(csid);
|
|
|
|
|
EncodingInfo *pEncoding = theApp.m_pIntlFont->GetEncodingInfo(id);
|
|
|
|
|
return pEncoding->iPropCharset;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const char *IntlGetUIFixFaceName(int csid)
|
|
|
|
|
{
|
|
|
|
|
int id ;
|
|
|
|
|
if (csid == 0)
|
|
|
|
|
csid = INTL_DefaultWinCharSetID(0);
|
|
|
|
|
csid = csid & ~CS_AUTO; // mask off AUTO bit
|
|
|
|
|
|
|
|
|
|
id = theApp.m_pIntlFont->DocCSIDtoID(csid);
|
|
|
|
|
EncodingInfo *pEncoding = theApp.m_pIntlFont->GetEncodingInfo(id);
|
|
|
|
|
return pEncoding->szFixName;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const char *IntlGetUIPropFaceName(int csid)
|
|
|
|
|
{
|
|
|
|
|
int id ;
|
|
|
|
|
if (csid == 0)
|
|
|
|
|
csid = INTL_DefaultWinCharSetID(0);
|
|
|
|
|
csid = csid & ~CS_AUTO; // mask off AUTO bit
|
|
|
|
|
|
|
|
|
|
id = theApp.m_pIntlFont->DocCSIDtoID(csid);
|
|
|
|
|
EncodingInfo *pEncoding = theApp.m_pIntlFont->GetEncodingInfo(id);
|
|
|
|
|
return pEncoding->szPropName;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//------------------------------------------------------------
|
|
|
|
|
// Function called from cross-platform code
|
|
|
|
|
//------------------------------------------------------------
|
|
|
|
|
extern "C" int FE_StrColl(const char* s1, const char* s2)
|
|
|
|
|
{
|
|
|
|
|
return lstrcmp(s1, s2);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
extern "C" size_t FE_StrfTime(MWContext *context, char *result, size_t maxsize, int format,
|
|
|
|
|
const struct tm *timeptr)
|
|
|
|
|
{
|
|
|
|
|
#ifdef XP_WIN16
|
|
|
|
|
switch(format)
|
|
|
|
|
{
|
|
|
|
|
case XP_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%H:%M", timeptr);
|
|
|
|
|
case XP_WEEKDAY_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%a %H:%M", timeptr);
|
|
|
|
|
case XP_DATE_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%x %H:%M", timeptr);
|
|
|
|
|
case XP_LONG_DATE_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%c", timeptr);
|
|
|
|
|
default:
|
|
|
|
|
result[0] = '\0';
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
int wincsid = INTL_DefaultWinCharSetID(context);
|
|
|
|
|
LANGID langid;
|
|
|
|
|
langid = GetSystemDefaultLangID();
|
|
|
|
|
|
|
|
|
|
if ((wincsid & MULTIBYTE) &&
|
|
|
|
|
sysInfo.m_bDBCS &&
|
|
|
|
|
!((GetSystemDefaultLangID() == 0x0411 && wincsid == CS_SJIS) ||
|
|
|
|
|
(GetSystemDefaultLangID() == 0x0412 && wincsid == CS_KSC_8BIT) ||
|
|
|
|
|
(GetSystemDefaultLangID() == 0x0812 && wincsid == CS_KSC_8BIT) ||
|
|
|
|
|
(GetSystemDefaultLangID() == 0x0804 && wincsid == CS_GB_8BIT) ||
|
|
|
|
|
(GetSystemDefaultLangID() == 0x1004 && wincsid == CS_GB_8BIT) ||
|
|
|
|
|
(GetSystemDefaultLangID() == 0x0C04 && wincsid == CS_BIG5) ||
|
|
|
|
|
(GetSystemDefaultLangID() == 0x0404 && wincsid == CS_BIG5)))
|
|
|
|
|
{ // In multibyte, if system doesn't match with current win_csid
|
|
|
|
|
switch(format)
|
|
|
|
|
{
|
|
|
|
|
case XP_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%H:%M", timeptr);
|
|
|
|
|
case XP_WEEKDAY_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%a %H:%M", timeptr);
|
|
|
|
|
case XP_DATE_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%x %H:%M", timeptr);
|
|
|
|
|
case XP_LONG_DATE_TIME_FORMAT:
|
|
|
|
|
return strftime (result, maxsize, "%c", timeptr);
|
|
|
|
|
default:
|
|
|
|
|
result[0] = '\0';
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
SYSTEMTIME daytime;
|
|
|
|
|
int n, m;
|
|
|
|
|
daytime.wYear = 1900 + timeptr->tm_year;
|
|
|
|
|
daytime.wMonth = timeptr->tm_mon + 1;
|
|
|
|
|
daytime.wDayOfWeek = timeptr->tm_wday;
|
|
|
|
|
daytime.wDay = timeptr->tm_mday;
|
|
|
|
|
daytime.wHour = timeptr->tm_hour;
|
|
|
|
|
daytime.wMinute = timeptr->tm_min;
|
|
|
|
|
daytime.wSecond = timeptr->tm_sec;
|
|
|
|
|
daytime.wMilliseconds = 0;
|
|
|
|
|
|
|
|
|
|
*result = '\0';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
switch(format)
|
|
|
|
|
{
|
|
|
|
|
case XP_TIME_FORMAT:
|
|
|
|
|
// return strftime (result, maxsize, "%X", timeptr);
|
1998-06-22 21:19:46 +00:00
|
|
|
|
if (n = GetTimeFormat(LOCALE_USER_DEFAULT, TIME_NOSECONDS, &daytime, NULL, result, maxsize))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
return n;
|
|
|
|
|
else
|
|
|
|
|
return strftime (result, maxsize, "%H:%M", timeptr);
|
|
|
|
|
case XP_WEEKDAY_TIME_FORMAT:
|
|
|
|
|
// return strftime (result, maxsize, "%a %X", timeptr);
|
1998-06-22 21:19:46 +00:00
|
|
|
|
if (GetDateFormat(LOCALE_USER_DEFAULT,0,&daytime,"ddd ", result, maxsize))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
{
|
|
|
|
|
n = strlen(result);
|
1998-06-22 21:19:46 +00:00
|
|
|
|
if (m = GetTimeFormat(LOCALE_USER_DEFAULT, TIME_NOSECONDS, &daytime, NULL, result+n, maxsize-n))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
return n + m;
|
|
|
|
|
else
|
|
|
|
|
return strftime (result, maxsize, "%a %H:%M", timeptr);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
return strftime (result, maxsize, "%a %H:%M", timeptr);
|
|
|
|
|
case XP_DATE_TIME_FORMAT:
|
|
|
|
|
// return strftime (result, maxsize, "%x %X", timeptr);
|
1998-06-22 21:19:46 +00:00
|
|
|
|
if (GetDateFormat(LOCALE_USER_DEFAULT,DATE_SHORTDATE, &daytime,NULL, result, maxsize))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
{
|
|
|
|
|
n = strlen(result);
|
|
|
|
|
result[n++] = ' ';
|
1998-06-22 21:19:46 +00:00
|
|
|
|
if (m = GetTimeFormat(LOCALE_USER_DEFAULT, TIME_NOSECONDS, &daytime, NULL, result+n, maxsize-n))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
return m + n;
|
|
|
|
|
else
|
|
|
|
|
return strftime (result, maxsize, "%x %H:%M", timeptr);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
return strftime (result, maxsize, "%x %H:%M", timeptr);
|
|
|
|
|
case XP_LONG_DATE_TIME_FORMAT:
|
|
|
|
|
// return strftime (result, maxsize, "%x %X", timeptr);
|
1998-06-22 21:19:46 +00:00
|
|
|
|
if (GetDateFormat(LOCALE_USER_DEFAULT,DATE_LONGDATE, &daytime,NULL, result, maxsize))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
{
|
|
|
|
|
n = strlen(result);
|
|
|
|
|
result[n++] = ' ';
|
1998-06-22 21:19:46 +00:00
|
|
|
|
if (m = GetTimeFormat(LOCALE_USER_DEFAULT, 0, &daytime, NULL, result+n, maxsize-n))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
return m + n;
|
|
|
|
|
else
|
|
|
|
|
return strftime (result, maxsize, "%x %H:%M", timeptr);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
return strftime (result, maxsize, "%x %H:%M", timeptr);
|
|
|
|
|
default:
|
|
|
|
|
result[0] = '\0';
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CXPResSwitcher g_xpResSwitcher;
|
|
|
|
|
|
|
|
|
|
/* XP_GetString
|
|
|
|
|
*
|
|
|
|
|
* This one takes XP string ID (which is used mainly by libnet, libsec)
|
|
|
|
|
* and loads String from resource file (netscape.rc3).
|
|
|
|
|
*/
|
|
|
|
|
extern "C" char *XP_GetString(int id)
|
|
|
|
|
{
|
|
|
|
|
int16 resid;
|
|
|
|
|
resid = id + 7000;
|
|
|
|
|
|
|
|
|
|
char *buf = szLoadString(resid, &g_xpResSwitcher);
|
|
|
|
|
return buf;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
INTL_DocCharSetID and INTL_DefaultDocCharSetID getting closer and closer
|
|
|
|
|
For 2.1, we need to remove one of them.
|
|
|
|
|
*/
|
|
|
|
|
int INTL_DocCharSetID(MWContext *context)
|
|
|
|
|
{
|
|
|
|
|
int doccsid;
|
|
|
|
|
if (context == NULL)
|
|
|
|
|
return theApp.m_iCSID;
|
|
|
|
|
else if (doccsid = INTL_GetCSIDocCSID(LO_GetDocumentCharacterSetInfo(context)))
|
|
|
|
|
return doccsid;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifndef MOZ_NGLAYOUT
|
1998-03-28 02:44:41 +00:00
|
|
|
|
else if (context->type == MWContextPrint && ((CPrintCX *)((context)->fe.cx))->m_iCSID)
|
|
|
|
|
return ((CPrintCX *)((context)->fe.cx))->m_iCSID;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif
|
1998-03-28 02:44:41 +00:00
|
|
|
|
else if (GetFrame(context) && GetFrame(context)->m_iCSID)
|
|
|
|
|
return GetFrame(context)->m_iCSID;
|
|
|
|
|
else
|
|
|
|
|
return theApp.m_iCSID;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
This routine will retrieve default URL charset Id
|
|
|
|
|
from conversion engine.
|
|
|
|
|
*/
|
|
|
|
|
extern int16 INTL_DefaultDocCharSetID(MWContext * context)
|
|
|
|
|
{
|
|
|
|
|
int doccsid;
|
|
|
|
|
if (context == NULL)
|
|
|
|
|
return theApp.m_iCSID;
|
|
|
|
|
else if (doccsid = INTL_GetCSIDocCSID(LO_GetDocumentCharacterSetInfo(context)))
|
|
|
|
|
return doccsid;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifndef MOZ_NGLAYOUT
|
1998-03-28 02:44:41 +00:00
|
|
|
|
else if (context->type == MWContextPrint && ((CPrintCX *)((context)->fe.cx))->m_iCSID)
|
|
|
|
|
return ((CPrintCX *)((context)->fe.cx))->m_iCSID;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif
|
1998-03-28 02:44:41 +00:00
|
|
|
|
else if (context->type == MWContextSaveToDisk && ((CSaveCX*)((context)->fe.cx))->m_iCSID)
|
|
|
|
|
return ((CSaveCX *)((context)->fe.cx))->m_iCSID;
|
|
|
|
|
else if (GetFrame(context) && ((CMainFrame *)GetFrame(context))->m_iCSID)
|
|
|
|
|
return ((CMainFrame *)GetFrame(context))->m_iCSID;
|
|
|
|
|
else
|
|
|
|
|
return theApp.m_iCSID;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
extern "C" uint16 FE_DefaultDocCharSetID(MWContext * context)
|
|
|
|
|
{
|
|
|
|
|
if (context == NULL)
|
|
|
|
|
return theApp.m_iCSID;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifndef MOZ_NGLAYOUT
|
1998-03-28 02:44:41 +00:00
|
|
|
|
else if (context->type == MWContextPrint && ((CPrintCX *)((context)->fe.cx))->m_iCSID)
|
|
|
|
|
return ((CPrintCX *)((context)->fe.cx))->m_iCSID;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif
|
1998-03-28 02:44:41 +00:00
|
|
|
|
else if (context->type == MWContextSaveToDisk && ((CSaveCX*)((context)->fe.cx))->m_iCSID)
|
|
|
|
|
return ((CSaveCX *)((context)->fe.cx))->m_iCSID;
|
|
|
|
|
else if (GetFrame(context) && ((CMainFrame *)GetFrame(context))->m_iCSID)
|
|
|
|
|
return ((CMainFrame *)GetFrame(context))->m_iCSID;
|
|
|
|
|
else
|
|
|
|
|
return theApp.m_iCSID;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
This routine will relayout current document.
|
|
|
|
|
It's called from xp rountine to do CharSet conversion
|
|
|
|
|
based on new doc_csid found from <Meta ...>
|
|
|
|
|
*/
|
|
|
|
|
extern void INTL_Relayout(MWContext * pContext)
|
|
|
|
|
{
|
|
|
|
|
if(pContext == NULL || ABSTRACTCX(pContext) == NULL || ABSTRACTCX(pContext)->IsDestroyed()) {
|
|
|
|
|
// Don't allow this to happen if the context has been destroyed...
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Let the page load, so that it is in the cache (bug fix 51701)
|
|
|
|
|
// or will get a page that is partially "transfer interrupted"
|
|
|
|
|
// if just doing a Reload() as that part of the page is
|
|
|
|
|
// possibly already cached before the entire page is downloaded
|
|
|
|
|
// leading to lossy display.
|
|
|
|
|
// Another way to do this is to ignore the cache altogether for a
|
|
|
|
|
// more immediate effect: Reload(NET_SUPER_RELOAD)
|
|
|
|
|
// but that is not nice to the cache, or the user if working
|
|
|
|
|
// offline, etc.
|
1998-08-13 23:14:59 +00:00
|
|
|
|
#if 0 //#ifdef EDITOR
|
1998-03-28 02:44:41 +00:00
|
|
|
|
if(EDT_IS_EDITOR(pContext)){
|
|
|
|
|
EDT_RefreshLayout(pContext);
|
|
|
|
|
} else
|
|
|
|
|
#endif
|
|
|
|
|
ABSTRACTCX(pContext)->NiceReload();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
See information in
|
|
|
|
|
Unicode Functions Supported by Windows 95
|
|
|
|
|
PSS ID Number: Q125671
|
|
|
|
|
*/
|
|
|
|
|
int CIntlWin::m_iConvBufSize = 0;
|
|
|
|
|
#ifdef XP_WIN32
|
|
|
|
|
LPWSTR CIntlWin::m_wConvBuf = NULL;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
BOOL CIntlWin::FontSelectIgnorePitch(int16 wincsid)
|
|
|
|
|
{
|
1998-08-01 07:49:21 +00:00
|
|
|
|
return ( (wincsid & MULTIBYTE) ||
|
|
|
|
|
(CS_TIS620 == wincsid ) ||
|
|
|
|
|
(CS_ARMSCII8 == wincsid )
|
1998-03-28 02:44:41 +00:00
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
BOOL CIntlWin::FontSelectIgnoreCharset(int16 wincsid)
|
|
|
|
|
{
|
|
|
|
|
return ( UseUnicodeFontAPI(wincsid) ||
|
|
|
|
|
( CS_USER_DEFINED_ENCODING == wincsid)
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
BOOL CIntlWin::AllocConvBuffer(int iLength)
|
|
|
|
|
{
|
|
|
|
|
#ifdef WIN32
|
|
|
|
|
if (m_iConvBufSize == 0)
|
|
|
|
|
{
|
|
|
|
|
if (iLength < 1024)
|
|
|
|
|
iLength = 1024;
|
|
|
|
|
m_wConvBuf = (WCHAR *)malloc(iLength);
|
|
|
|
|
m_iConvBufSize = iLength;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
m_wConvBuf = (WCHAR *) realloc(m_wConvBuf, iLength);
|
|
|
|
|
m_iConvBufSize = iLength;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int16 CIntlWin::m_system_locale_csid = 0;
|
|
|
|
|
|
|
|
|
|
int16 CIntlWin::GetSystemLocaleCsid()
|
|
|
|
|
{
|
|
|
|
|
if( 0 == m_system_locale_csid )
|
|
|
|
|
{
|
|
|
|
|
#ifdef XP_WIN32
|
|
|
|
|
m_system_locale_csid = CodePageToCsid(GetACP());
|
|
|
|
|
#else
|
|
|
|
|
m_system_locale_csid = CodePageToCsid(GetKBCodePage()); // In Win3.1 We cannot call GetACP(), we can just call GetKBCodePage()
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
if( 0 == m_system_locale_csid ) // if still cannot find the csid, Fall back to Latin 1
|
|
|
|
|
{
|
|
|
|
|
m_system_locale_csid = CS_LATIN1;
|
|
|
|
|
}
|
|
|
|
|
return m_system_locale_csid;
|
|
|
|
|
}
|
|
|
|
|
int16 CIntlWin::CodePageToCsid(UINT cp)
|
|
|
|
|
{
|
|
|
|
|
switch(cp)
|
|
|
|
|
{
|
|
|
|
|
case 1250:
|
|
|
|
|
case 852: // MS-DOS Slavic OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
return CS_CP_1250;
|
|
|
|
|
|
|
|
|
|
case 1251:
|
|
|
|
|
case 855: // IBM Cyrillic OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 866: // MS-DOS Russian OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
return CS_CP_1251;
|
|
|
|
|
|
|
|
|
|
case 1252:
|
|
|
|
|
case 437: // US OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 850: // MS-DOS Multilingual OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 860: // MS-DOS Portutuese OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 861: // MS-DOS Icelandic OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 863: // MS-DOS Canadian-French OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 865: // MS-DOS Nordic OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
return CS_LATIN1;
|
|
|
|
|
|
|
|
|
|
case 1253:
|
|
|
|
|
case 737: // Greek OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 869: // IBM Modern Greek OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
return CS_CP_1253;
|
|
|
|
|
|
|
|
|
|
case 1254:
|
|
|
|
|
case 857: // IBM Turkish OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
return CS_CP_1254; // CS_CP_1254;
|
|
|
|
|
|
|
|
|
|
case 1255:
|
|
|
|
|
return CS_UNKNOWN; // CS_CP_1255;
|
|
|
|
|
|
|
|
|
|
case 1256:
|
|
|
|
|
return CS_UNKNOWN; // CS_CP_1256;
|
|
|
|
|
|
|
|
|
|
case 775: // Baltic OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
case 1257:
|
|
|
|
|
return CS_UNKNOWN; // CS_CP_1257;
|
|
|
|
|
|
|
|
|
|
case 932:
|
|
|
|
|
return CS_SJIS;
|
|
|
|
|
|
|
|
|
|
case 936:
|
|
|
|
|
return CS_GB_8BIT;
|
|
|
|
|
|
|
|
|
|
case 949:
|
|
|
|
|
case 1361: // Korean (Johab) OEM in the case of Win16 GetKBCodePage
|
|
|
|
|
return CS_KSC_8BIT;
|
|
|
|
|
|
|
|
|
|
case 950:
|
|
|
|
|
return CS_BIG5;
|
|
|
|
|
|
1998-08-01 07:49:21 +00:00
|
|
|
|
case 874:
|
|
|
|
|
return CS_TIS620;
|
|
|
|
|
|
1998-09-30 10:48:13 +00:00
|
|
|
|
case 1258:
|
|
|
|
|
return CS_CP_1258;
|
|
|
|
|
|
1998-03-28 02:44:41 +00:00
|
|
|
|
default:
|
|
|
|
|
return CS_UNKNOWN;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
int CIntlWin::MultiByteToWideChar(int16 wincsid, LPCSTR lpMultiByte, int iLength)
|
|
|
|
|
{
|
|
|
|
|
if((lpMultiByte == NULL) || (lpMultiByte[0] == '\0') || (iLength == 0))
|
|
|
|
|
return 0;
|
|
|
|
|
#ifdef WIN32
|
|
|
|
|
if (iLength == -1)
|
|
|
|
|
iLength = strlen(lpMultiByte);
|
|
|
|
|
if (((iLength+1) * 2) > m_iConvBufSize)
|
|
|
|
|
AllocConvBuffer((iLength+1) * 2);
|
|
|
|
|
|
|
|
|
|
iLength = INTL_TextToUnicode(wincsid, (unsigned char*)lpMultiByte, iLength, m_wConvBuf, m_iConvBufSize) ;
|
|
|
|
|
#endif
|
|
|
|
|
return iLength;
|
|
|
|
|
}
|
|
|
|
|
//
|
|
|
|
|
// UseUnicodeFontAPI return
|
|
|
|
|
//
|
|
|
|
|
// csid Latin1/Symbol/ UTF8 MultiByte Other Single Byte
|
|
|
|
|
// UserDefined/Digbats J/K/SC/TC CE/Greek/Cyr/Turk
|
|
|
|
|
// Platform
|
|
|
|
|
// Win 95 NonDB FALSE TRUE TRUE FALSE (Need test)
|
|
|
|
|
// Win NT NonDB FALSE TRUE TRUE TRUE (Need test)
|
|
|
|
|
// Win 95 DB FALSE TRUE (1) FALSE
|
|
|
|
|
// Win NT DB FALSE TRUE (1) TRUE(2)
|
|
|
|
|
//
|
|
|
|
|
// (1) FALSE if it is equal to the system locale's csid.
|
|
|
|
|
// (2) Could be true or false. But need more work for Edit control if use TRUE
|
|
|
|
|
//
|
|
|
|
|
#ifdef XP_WIN32
|
|
|
|
|
static BOOL intlUnicodeFlag(int16 wincsid)
|
|
|
|
|
{
|
|
|
|
|
if(! theApp.m_bUseUnicodeFont)
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
if(0 == wincsid) // Unknown csid
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
if(CS_UTF8 == wincsid)
|
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
|
|
if( (CS_LATIN1 == wincsid) || (CS_SYMBOL == wincsid) ||
|
|
|
|
|
(CS_DINGBATS == wincsid) || (CS_USER_DEFINED_ENCODING == wincsid))
|
|
|
|
|
{
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
if( wincsid & MULTIBYTE)
|
|
|
|
|
{
|
|
|
|
|
if(CIntlWin::GetSystemLocaleCsid() == wincsid)
|
|
|
|
|
return FALSE;
|
|
|
|
|
else
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
else // Other SingleByte csid
|
|
|
|
|
{
|
1998-08-25 20:05:52 +00:00
|
|
|
|
if((CS_VIET_VISCII == wincsid) ||
|
|
|
|
|
(CS_VIET_VPS == wincsid) ||
|
|
|
|
|
(CS_VIET_TCVN == wincsid) ||
|
1998-09-30 10:48:13 +00:00
|
|
|
|
(CS_VIET_VNI == wincsid) ||
|
|
|
|
|
(CS_CP_1258 == wincsid) ||
|
1998-08-25 20:05:52 +00:00
|
|
|
|
(CS_VIET_VIQR == wincsid) ||
|
|
|
|
|
(CS_TIS620 == wincsid)
|
|
|
|
|
)
|
1998-08-01 07:49:21 +00:00
|
|
|
|
return FALSE;
|
|
|
|
|
|
1998-09-19 00:27:03 +00:00
|
|
|
|
if(IsRunningOnNT)
|
1998-03-28 02:44:41 +00:00
|
|
|
|
return TRUE;
|
|
|
|
|
else
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOL CIntlWin::GetTextExtentPoint(int wincsid, HDC hDC, LPCSTR pString, int iLength, LPSIZE lpSize)
|
|
|
|
|
{
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifdef MOZ_NGLAYOUT
|
|
|
|
|
XP_ASSERT(0);
|
|
|
|
|
return FALSE;
|
|
|
|
|
#else
|
1998-03-28 02:44:41 +00:00
|
|
|
|
if(0 == iLength)
|
|
|
|
|
{
|
|
|
|
|
lpSize->cx = 0;
|
|
|
|
|
lpSize->cy = 0;
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
wincsid = INTL_DocToWinCharSetID(wincsid) & ~ CS_AUTO;
|
|
|
|
|
int wlen;
|
|
|
|
|
|
|
|
|
|
if ( CIntlWin::UseUnicodeFontAPI(wincsid))
|
|
|
|
|
{
|
|
|
|
|
if(wlen = MultiByteToWideChar(wincsid, pString, iLength))
|
|
|
|
|
{
|
|
|
|
|
return ::GetTextExtentPoint32W(hDC, m_wConvBuf, wlen, lpSize);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return::GetTextExtentPoint32(hDC, pString, iLength, lpSize);
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif /* MOZ_NGLAYOUT */
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL CIntlWin::GetTextExtentPointWithCyaFont(CyaFont *theNSFont,int wincsid, HDC hDC, LPCSTR pString, int iLength, LPSIZE lpSize)
|
|
|
|
|
{
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifdef MOZ_NGLAYOUT
|
|
|
|
|
XP_ASSERT(0);
|
|
|
|
|
return FALSE;
|
|
|
|
|
#else
|
1998-03-28 02:44:41 +00:00
|
|
|
|
if(0 == iLength)
|
|
|
|
|
{
|
|
|
|
|
lpSize->cx = 0;
|
|
|
|
|
lpSize->cy = 0;
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
// wincsid = INTL_DocToWinCharSetID(wincsid) & ~ CS_AUTO;
|
|
|
|
|
XP_ASSERT(((wincsid & CS_AUTO) == 0) && (wincsid != CS_JIS) && (wincsid!=CS_EUCJP));
|
|
|
|
|
int wlen;
|
|
|
|
|
|
|
|
|
|
if ( CIntlWin::UseUnicodeFontAPI(wincsid))
|
|
|
|
|
{
|
|
|
|
|
if(wlen = MultiByteToWideChar(wincsid, pString, iLength))
|
|
|
|
|
{
|
|
|
|
|
return theNSFont->MeasureTextSize(hDC, (char *)m_wConvBuf, wlen*sizeof(*m_wConvBuf), NULL, 0, lpSize);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return( theNSFont->MeasureTextSize( hDC, (char *)pString, iLength, NULL, 0, lpSize) );
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif /* MOZ_NGLAYOUT */
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
CSize CIntlWin::GetTextExtent(int16 wincsid, HDC pDC, LPCTSTR pString, int iLength)
|
|
|
|
|
{
|
|
|
|
|
CSize csSize;
|
|
|
|
|
BOOL bRetval;
|
|
|
|
|
bRetval = CIntlWin::GetTextExtentPoint(wincsid, pDC, pString, iLength, &csSize);
|
|
|
|
|
return(csSize);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL CIntlWin::TextOut(int16 wincsid, HDC hDC, int nXStart, int nYStart, LPCSTR lpString,int iLength)
|
|
|
|
|
{
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifdef MOZ_NGLAYOUT
|
|
|
|
|
XP_ASSERT(0);
|
|
|
|
|
return FALSE;
|
|
|
|
|
#else
|
1998-03-28 02:44:41 +00:00
|
|
|
|
if(0 == iLength)
|
|
|
|
|
return TRUE;
|
|
|
|
|
wincsid = INTL_DocToWinCharSetID(wincsid) & ~ CS_AUTO;
|
|
|
|
|
int wlen;
|
|
|
|
|
if ( CIntlWin::UseUnicodeFontAPI(wincsid))
|
|
|
|
|
{
|
|
|
|
|
if(wlen = MultiByteToWideChar(wincsid, lpString, iLength))
|
|
|
|
|
{
|
|
|
|
|
return ::TextOutW(hDC, nXStart, nYStart, m_wConvBuf, wlen);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return ::TextOut(hDC, nXStart, nYStart, lpString, iLength); // The final fallback
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif /* MOZ_NGLAYOUT */
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//based on BOOL CIntlWin::TextOut(int16 wincsid, HDC hDC, int nXStart, int nYStart, LPCSTR lpString,int iLength)
|
|
|
|
|
BOOL CIntlWin::TextOutWithCyaFont(CyaFont *theNSFont, int16 wincsid, HDC hDC,
|
|
|
|
|
int nXStart, int nYStart, LPCSTR lpString,int iLength)
|
|
|
|
|
{
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifdef MOZ_NGLAYOUT
|
|
|
|
|
XP_ASSERT(0);
|
|
|
|
|
return FALSE;
|
|
|
|
|
#else
|
1998-03-28 02:44:41 +00:00
|
|
|
|
if(0 == iLength)
|
|
|
|
|
return TRUE;
|
|
|
|
|
int wlen;
|
|
|
|
|
if ( CIntlWin::UseUnicodeFontAPI(wincsid))
|
|
|
|
|
{
|
|
|
|
|
if(wlen = MultiByteToWideChar(wincsid, lpString, iLength))
|
|
|
|
|
{
|
|
|
|
|
// the encording flag in theNSFont makes it call ::TextOutW()
|
1998-08-25 20:05:52 +00:00
|
|
|
|
return ( theNSFont->drawText(hDC, nXStart, nYStart, (char *)m_wConvBuf, wlen * 2) == FONTERR_OK);
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
1998-08-25 20:05:52 +00:00
|
|
|
|
return( theNSFont->drawText(hDC, nXStart, nYStart, (char *)lpString, iLength) == FONTERR_OK ) ;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif /* MOZ_NGLAYOUT */
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL CIntlWin::ExtTextOut(int16 wincsid, HDC pDC, int x, int y, UINT nOptions, LPCRECT lpRect, LPCSTR lpszString, UINT nCount, LPINT lpDxWidths)
|
|
|
|
|
{
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifdef MOZ_NGLAYOUT
|
|
|
|
|
XP_ASSERT(0);
|
|
|
|
|
return FALSE;
|
|
|
|
|
#else
|
1998-03-28 02:44:41 +00:00
|
|
|
|
if(0 == nCount)
|
|
|
|
|
return TRUE;
|
|
|
|
|
wincsid = INTL_DocToWinCharSetID(wincsid) & ~ CS_AUTO;
|
|
|
|
|
int wlen;
|
|
|
|
|
if ( CIntlWin::UseUnicodeFontAPI(wincsid))
|
|
|
|
|
{
|
|
|
|
|
if(wlen = MultiByteToWideChar(wincsid, lpszString, nCount))
|
|
|
|
|
{
|
|
|
|
|
return ::ExtTextOutW(pDC, x, y, nOptions, lpRect, m_wConvBuf, wlen, lpDxWidths);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return ::ExtTextOut(pDC, x, y, nOptions, lpRect, lpszString, nCount, lpDxWidths);
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif /* MOZ_NGLAYOUT */
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
1998-10-12 12:01:51 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static int intlwin_SLDrawTextExW(
|
|
|
|
|
HDC hdc, LPWSTR text, int len,LPRECT lprc,UINT flag,LPDRAWTEXTPARAMS lpparam)
|
|
|
|
|
{
|
|
|
|
|
// XP_ASSERT(DT_SINGLELINE & flag);
|
|
|
|
|
int ext = 0;
|
|
|
|
|
SIZE sz;
|
|
|
|
|
int x,y;
|
|
|
|
|
::GetTextExtentPoint32W(hdc, text, len, &sz);
|
|
|
|
|
if(flag & DT_CALCRECT)
|
|
|
|
|
{
|
|
|
|
|
lprc->top = 0;
|
|
|
|
|
lprc->left = 0;
|
|
|
|
|
lprc->right = sz.cx;
|
|
|
|
|
lprc->bottom = sz.cy;
|
|
|
|
|
return sz.cy;
|
|
|
|
|
}
|
|
|
|
|
if(flag & DT_EXTERNALLEADING)
|
|
|
|
|
{
|
|
|
|
|
TEXTMETRIC tm;
|
|
|
|
|
GetTextMetrics( hdc, &tm);
|
|
|
|
|
ext = tm.tmExternalLeading;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Caculate X
|
|
|
|
|
x = lprc->left;
|
|
|
|
|
if(flag & DT_CENTER)
|
|
|
|
|
x = (lprc->left + lprc->right - sz.cx) / 2;
|
|
|
|
|
else if(flag & DT_RIGHT)
|
|
|
|
|
x = lprc->right - sz.cx;
|
|
|
|
|
|
|
|
|
|
// Caculate Y
|
|
|
|
|
y = lprc->top ;
|
|
|
|
|
if(flag & DT_VCENTER)
|
|
|
|
|
y = ( lprc->top + lprc->bottom - sz.cy ) / 2;
|
|
|
|
|
else if(flag & DT_BOTTOM)
|
|
|
|
|
y = lprc->bottom - sz.cy;
|
|
|
|
|
|
|
|
|
|
return ext + ::TextOutW(hdc, x, y, text, len);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
static int intlwin_MLDrawTextExW(
|
|
|
|
|
HDC hdc, LPWSTR text, int len,LPRECT lprc,UINT flag,LPDRAWTEXTPARAMS lpparam)
|
|
|
|
|
{
|
|
|
|
|
// Not implement yet. Call the intlwin_SLDrawTextExW for now.
|
|
|
|
|
return intlwin_SLDrawTextExW(hdc,text,len, lprc, flag, lpparam);
|
|
|
|
|
}
|
|
|
|
|
static LPWSTR intlwin_ExpandTabsAndCollapAmps(
|
|
|
|
|
LPWSTR text, int len, int* outLen,
|
|
|
|
|
XP_Bool expandTab, XP_Bool havePrefix, int tabstop )
|
|
|
|
|
{
|
|
|
|
|
int tabs=0;
|
|
|
|
|
int i;
|
|
|
|
|
LPWSTR outText=NULL;
|
|
|
|
|
if(expandTab)
|
|
|
|
|
{
|
|
|
|
|
for(i = 0; i < len; i++)
|
|
|
|
|
{
|
|
|
|
|
if(0x0009 == text[i])
|
|
|
|
|
tabs++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
int alloclen = len + tabs * tabstop;
|
|
|
|
|
outText = (WCHAR*) XP_ALLOC(alloclen * sizeof(WCHAR));
|
|
|
|
|
|
|
|
|
|
XP_ASSERT(outText != NULL);
|
|
|
|
|
if(NULL != outText)
|
|
|
|
|
{
|
|
|
|
|
int j=0;
|
|
|
|
|
for(i = 0; i < len; i++)
|
|
|
|
|
{
|
|
|
|
|
if(expandTab && ( 0x0009 == text[i] ))
|
|
|
|
|
{
|
|
|
|
|
for(int k = 0; k < tabstop; k++)
|
|
|
|
|
outText[j++] = 0x0020;
|
|
|
|
|
} else if(havePrefix &&
|
|
|
|
|
( i < (len-1)) &&
|
|
|
|
|
(0x0026 == text[i]) &&
|
|
|
|
|
(0x0026 == text[i+1])
|
|
|
|
|
)
|
|
|
|
|
{
|
|
|
|
|
outText[j++] = text[i];
|
|
|
|
|
i++;
|
|
|
|
|
} else {
|
|
|
|
|
outText[j++] = text[i];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
*outLen = j;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
*outLen = 0;
|
|
|
|
|
}
|
|
|
|
|
return outText;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int intlwin_DrawTextExW(
|
|
|
|
|
HDC hdc, LPWSTR text, int len,LPRECT lprc,UINT flag,LPDRAWTEXTPARAMS lpparam)
|
|
|
|
|
{
|
|
|
|
|
int h;
|
|
|
|
|
// Expand Tab and eat PREFIX here
|
|
|
|
|
LPWSTR exp = NULL;
|
|
|
|
|
|
|
|
|
|
if((flag & DT_EXPANDTABS) || (DT_NOPREFIX != (flag & DT_NOPREFIX)))
|
|
|
|
|
{
|
|
|
|
|
int explen;
|
|
|
|
|
int ts = 8;
|
|
|
|
|
if(flag & DT_TABSTOP)
|
|
|
|
|
{
|
|
|
|
|
ts = (flag >> 8) & 0x00FF;
|
|
|
|
|
flag &= 0x00FF;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exp = intlwin_ExpandTabsAndCollapAmps(text, len, &explen,
|
|
|
|
|
((flag & DT_EXPANDTABS)? TRUE : FALSE),
|
|
|
|
|
((flag & DT_NOPREFIX)? FALSE : TRUE),
|
|
|
|
|
ts);
|
|
|
|
|
text = exp;
|
|
|
|
|
len = explen;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(DT_SINGLELINE & flag)
|
|
|
|
|
h = intlwin_SLDrawTextExW(hdc, text, len, lprc, flag, lpparam);
|
|
|
|
|
else
|
|
|
|
|
h = intlwin_MLDrawTextExW(hdc, text, len, lprc, flag, lpparam);
|
|
|
|
|
XP_FREEIF(exp);
|
|
|
|
|
return h;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
1998-03-28 02:44:41 +00:00
|
|
|
|
#ifdef XP_WIN32
|
1998-10-12 12:01:51 +00:00
|
|
|
|
int CIntlWin::DrawTextEx(int16 wincsid, HDC hdc,
|
|
|
|
|
LPSTR lpchText, int cchText,
|
|
|
|
|
LPRECT lprc,UINT flag,LPDRAWTEXTPARAMS lpParams)
|
1998-03-28 02:44:41 +00:00
|
|
|
|
{
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifdef MOZ_NGLAYOUT
|
|
|
|
|
XP_ASSERT(0);
|
|
|
|
|
return 0;
|
|
|
|
|
#else
|
1998-10-05 14:56:00 +00:00
|
|
|
|
|
1998-03-28 02:44:41 +00:00
|
|
|
|
wincsid = INTL_DocToWinCharSetID(wincsid) & ~ CS_AUTO;
|
|
|
|
|
|
|
|
|
|
int iRetval;
|
|
|
|
|
int wlen;
|
|
|
|
|
if (cchText == -1)
|
|
|
|
|
cchText = strlen(lpchText);
|
|
|
|
|
|
1998-10-12 12:01:51 +00:00
|
|
|
|
if ( CIntlWin::UseUnicodeFontAPI(wincsid))
|
1998-03-28 02:44:41 +00:00
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
// DrawTextExW and DrawTextW is not working on Win95 right now. See Note above
|
1998-10-12 12:01:51 +00:00
|
|
|
|
wlen = MultiByteToWideChar(wincsid, lpchText, cchText);
|
|
|
|
|
|
|
|
|
|
if( IsRunningOnNT)
|
|
|
|
|
return ::DrawTextW(hdc, m_wConvBuf, wlen, lprc, flag);
|
|
|
|
|
else
|
|
|
|
|
return intlwin_DrawTextExW(hdc, m_wConvBuf, wlen, lprc, flag,lpParams);
|
1998-03-28 02:44:41 +00:00
|
|
|
|
|
|
|
|
|
}
|
1998-10-12 12:01:51 +00:00
|
|
|
|
else
|
1998-03-28 02:44:41 +00:00
|
|
|
|
{
|
1998-09-19 00:27:03 +00:00
|
|
|
|
if (IsRunningOnNT)
|
1998-10-12 12:01:51 +00:00
|
|
|
|
iRetval = ::DrawText(hdc, lpchText, cchText, lprc, flag);
|
1998-03-28 02:44:41 +00:00
|
|
|
|
else
|
1998-10-12 12:01:51 +00:00
|
|
|
|
iRetval = ::DrawTextEx(hdc, lpchText, cchText, lprc, flag, lpParams);
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
return iRetval;
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif /* MOZ_NGLAYOUT */
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
int CIntlWin::DrawText(int16 wincsid, HDC hdc, LPSTR lpchText, int cchText,LPRECT lprc,UINT dwDTFormat)
|
|
|
|
|
{
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#ifdef MOZ_NGLAYOUT
|
|
|
|
|
XP_ASSERT(0);
|
|
|
|
|
return 0;
|
|
|
|
|
#else
|
1998-03-28 02:44:41 +00:00
|
|
|
|
return CIntlWin::DrawTextEx( wincsid, hdc, lpchText, cchText, lprc, dwDTFormat, NULL);
|
1998-06-05 01:03:18 +00:00
|
|
|
|
#endif /* MOZ_NGLAYOUT */
|
1998-03-28 02:44:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
extern "C" void *FE_GetSingleByteTable(int16 from_csid, int16 to_csid, int resourceid)
|
|
|
|
|
{
|
|
|
|
|
HRSRC hrsrc;
|
|
|
|
|
HGLOBAL hRes;
|
|
|
|
|
char szName[256];
|
|
|
|
|
|
|
|
|
|
strcpy(szName, (const char *)INTL_CsidToCharsetNamePt(from_csid));
|
|
|
|
|
strcpy(szName + strlen(szName), "_TO_");
|
|
|
|
|
strcpy(szName + strlen(szName), (const char *)INTL_CsidToCharsetNamePt(to_csid));
|
|
|
|
|
for (char *p = szName; *p; p++)
|
|
|
|
|
{
|
|
|
|
|
if (*p == '-') *p = '_';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
hrsrc = ::FindResource(AfxGetResourceHandle(), szName, RT_RCDATA);
|
|
|
|
|
|
|
|
|
|
XP_ASSERT(hrsrc);
|
|
|
|
|
|
|
|
|
|
if (!hrsrc) {
|
|
|
|
|
TRACE1("FE_GetSingleByteTable cannot find resource: %s\n", szName);
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
hRes = ::LoadResource(AfxGetResourceHandle(), hrsrc);
|
|
|
|
|
|
|
|
|
|
XP_ASSERT(hRes);
|
|
|
|
|
|
|
|
|
|
if (!hRes) {
|
|
|
|
|
TRACE1("FE_GetSingleByteTable cannot load resource: %s\n", szName);
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return (void *) hRes;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
extern "C" char *FE_LockTable(void **hres)
|
|
|
|
|
{
|
|
|
|
|
return (LPSTR)::LockResource((HGLOBAL) hres);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
extern "C" void FE_FreeSingleByteTable(void **hres)
|
|
|
|
|
{
|
|
|
|
|
#ifndef XP_WIN32
|
|
|
|
|
::UnlockResource((HGLOBAL) hres);
|
|
|
|
|
#endif
|
|
|
|
|
::FreeResource((HGLOBAL) hres);
|
|
|
|
|
}
|
|
|
|
|
|
1998-09-04 03:45:51 +00:00
|
|
|
|
|
|
|
|
|
extern "C" INTLCharSetID FE_GetCharSetID(INTL_CharSetID_Selector selector)
|
|
|
|
|
{
|
|
|
|
|
INTLCharSetID charsetID = CS_DEFAULT;
|
|
|
|
|
|
|
|
|
|
switch (selector)
|
|
|
|
|
{
|
|
|
|
|
case INTL_FileNameCsidSel:
|
|
|
|
|
case INTL_DefaultTextWidgetCsidSel:
|
1998-09-04 23:12:45 +00:00
|
|
|
|
case INTL_OldBookmarkCsidSel:
|
1998-10-05 14:56:00 +00:00
|
|
|
|
case INTL_MenuCsidSel:
|
1998-09-04 03:45:51 +00:00
|
|
|
|
charsetID = (INTLCharSetID) CIntlWin::GetSystemLocaleCsid();
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
#ifdef DEBUG_ricardob
|
|
|
|
|
XP_ASSERT(CS_DEFAULT != charsetID);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
return charsetID;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|