From e84f7290001cedb44e0a3a3d7536f4de3bf505cd Mon Sep 17 00:00:00 2001 From: Stefan Csomor Date: Sat, 8 Mar 2008 15:46:39 +0000 Subject: [PATCH] cleaning up common OSX code git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@52385 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- src/common/encconv.cpp | 31 ++++++++++++------------------- 1 file changed, 12 insertions(+), 19 deletions(-) diff --git a/src/common/encconv.cpp b/src/common/encconv.cpp index 15509c9cbc..da88c09d52 100644 --- a/src/common/encconv.cpp +++ b/src/common/encconv.cpp @@ -32,15 +32,8 @@ #endif #ifdef __WXMAC__ -#ifdef __DARWIN__ -#include -#else -#include -#include -#include -#endif - #include "wx/fontutil.h" - #include "wx/mac/private.h" // includes mac headers + #include "wx/mac/corefoundation/cfstring.h" + #include wxUint16 gMacEncodings[wxFONTENCODING_MACMAX-wxFONTENCODING_MACMIN+1][128] ; bool gMacEncodingsInited[wxFONTENCODING_MACMAX-wxFONTENCODING_MACMIN+1] ; @@ -58,20 +51,20 @@ static const wxUint16* GetEncTable(wxFontEncoding enc) int i = enc-wxFONTENCODING_MACMIN ; if ( gMacEncodingsInited[i] == false ) { - TECObjectRef converter ; - TextEncodingBase code = wxMacGetSystemEncFromFontEnc( enc ) ; - TextEncodingBase unicode = CreateTextEncoding(kTextEncodingUnicodeDefault,0,kUnicode16BitFormat) ; - OSStatus status = TECCreateConverter(&converter,code,unicode); - char s[2] ; - s[1] = 0 ; - ByteCount byteInLen, byteOutLen ; + // create + CFStringEncoding cfencoding = wxMacGetSystemEncFromFontEnc( enc ) ; + if( !CFStringIsEncodingAvailable( cfencoding ) ) + return NULL; + + memset( gMacEncodings[i] , 0 , 128 * 2 ); + char s[2] = { 0 , 0 }; + CFRange firstchar = CFRangeMake( 0, 1 ); for( unsigned char c = 255 ; c >= 128 ; --c ) { s[0] = c ; - status = TECConvertText(converter, (ConstTextPtr) &s , 1, &byteInLen, - (TextPtr) &gMacEncodings[i][c-128] , 2, &byteOutLen); + wxCFStringRef cfref( CFStringCreateWithCStringNoCopy( NULL, s, cfencoding , kCFAllocatorNull ) ); + CFStringGetCharacters( cfref, firstchar, (UniChar*) &gMacEncodings[i][c-128] ); } - status = TECDisposeConverter(converter); gMacEncodingsInited[i]=true; } return gMacEncodings[i] ; -- 2.47.2