]> git.saurik.com Git - wxWidgets.git/blobdiff - src/mac/corefoundation/strconv_cf.cpp
see http://thread.gmane.org/gmane.comp.lib.wxwidgets.devel/97537
[wxWidgets.git] / src / mac / corefoundation / strconv_cf.cpp
index 94cb8f34af291e67f1f80d5b2b5c0190b52d52ca..e68d8e4ef6af34cc614ea77ffed0fd2427dc4c74 100644 (file)
 // CoreFoundation conversion classes
 // ============================================================================
 
 // CoreFoundation conversion classes
 // ============================================================================
 
+/* Provide factory functions for unit tests.  Not in any header.  Do not
+ * assume ABI compatibility even within a given wxWidgets release.
+ */
+
+WXDLLIMPEXP_BASE wxMBConv* new_wxMBConv_cf( const char* name)
+{
+    wxMBConv_cf *result = new wxMBConv_cf(name);
+    if(!result->IsOk())
+    {
+        delete result;
+        return NULL;
+    }
+    else
+        return result;
+}
+
+WXDLLIMPEXP_BASE wxMBConv* new_wxMBConv_cf(wxFontEncoding encoding)
+{
+    wxMBConv_cf *result = new wxMBConv_cf(encoding);
+    if(!result->IsOk())
+    {
+        delete result;
+        return NULL;
+    }
+    else
+        return result;
+}
 
 
-#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4
 // Provide a constant for the wchat_t encoding used by the host platform.
 #ifdef WORDS_BIGENDIAN
     static const CFStringEncoding wxCFStringEncodingWcharT = kCFStringEncodingUTF32BE;
 // Provide a constant for the wchat_t encoding used by the host platform.
 #ifdef WORDS_BIGENDIAN
     static const CFStringEncoding wxCFStringEncodingWcharT = kCFStringEncodingUTF32BE;
@@ -38,8 +64,6 @@
     static const CFStringEncoding wxCFStringEncodingWcharT = kCFStringEncodingUTF32LE;
 #endif
 
     static const CFStringEncoding wxCFStringEncodingWcharT = kCFStringEncodingUTF32LE;
 #endif
 
-#endif /* MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4 */
-
     size_t wxMBConv_cf::ToWChar(wchar_t * dst, size_t dstSize, const char * src, size_t srcSize) const
     {
         wxCHECK(src, wxCONV_FAILED);
     size_t wxMBConv_cf::ToWChar(wchar_t * dst, size_t dstSize, const char * src, size_t srcSize) const
     {
         wxCHECK(src, wxCONV_FAILED);
@@ -74,7 +98,6 @@
  * to UTF32.  If we are then run against a pre-Tiger system, the encoding
  * won't be available so we'll defer to the string->UTF-16->UTF-32 conversion.
  */
  * to UTF32.  If we are then run against a pre-Tiger system, the encoding
  * won't be available so we'll defer to the string->UTF-16->UTF-32 conversion.
  */
-#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4
         if(CFStringIsEncodingAvailable(wxCFStringEncodingWcharT))
         {
             CFRange fullStringRange = CFRangeMake(0, CFStringGetLength(theString));
         if(CFStringIsEncodingAvailable(wxCFStringEncodingWcharT))
         {
             CFRange fullStringRange = CFRangeMake(0, CFStringGetLength(theString));
             return usedBufLen / sizeof(wchar_t);
         }
         else
             return usedBufLen / sizeof(wchar_t);
         }
         else
-#endif /* MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4 */
         {
             // NOTE: Includes NULL iff source did
             /* NOTE: This is an approximation.  The eventual UTF-32 will    
         {
             // NOTE: Includes NULL iff source did
             /* NOTE: This is an approximation.  The eventual UTF-32 will    
  * from UTF32.  If we are then run against a pre-Tiger system, the encoding
  * won't be available so we'll defer to the UTF-32->UTF-16->string conversion.
  */
  * from UTF32.  If we are then run against a pre-Tiger system, the encoding
  * won't be available so we'll defer to the UTF-32->UTF-16->string conversion.
  */
-#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4
         if(CFStringIsEncodingAvailable(wxCFStringEncodingWcharT))
         {
             theString = wxCFRef<CFStringRef>(CFStringCreateWithBytes(
         if(CFStringIsEncodingAvailable(wxCFStringEncodingWcharT))
         {
             theString = wxCFRef<CFStringRef>(CFStringCreateWithBytes(
                     false));
         }
         else
                     false));
         }
         else
-#endif /* MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4 */
         {
             wxMBConvUTF16 converter;
             size_t cbUniBuffer = converter.FromWChar( NULL, 0, src, srcSize );
         {
             wxMBConvUTF16 converter;
             size_t cbUniBuffer = converter.FromWChar( NULL, 0, src, srcSize );