Changeset - r23075:bed1a8fa17ea
[Not reviewed]
master
0 3 2
Michael Lutz - 6 years ago 2018-09-23 17:26:09
michi@icosahedron.de
Add: [OSX] Native natural sort implementation.
5 files changed with 101 insertions and 0 deletions:
0 comments (0 inline, 0 general)
source.list
Show inline comments
 
@@ -413,6 +413,7 @@ music/qtmidi.h
 
os/macosx/macos.h
 
os/macosx/osx_stdafx.h
 
os/macosx/splash.h
 
os/macosx/string_osx.h
 
sound/cocoa_s.h
 
video/cocoa/cocoa_keys.h
 
video/cocoa/cocoa_v.h
 
@@ -1167,6 +1168,7 @@ sound/null_s.cpp
 
		music/cocoa_m.cpp
 
		sound/cocoa_s.cpp
 
		os/macosx/splash.cpp
 
		os/macosx/string_osx.cpp
 
	#end
 
#end
 

	
src/os/macosx/string_osx.cpp
Show inline comments
 
new file 100644
 
/* $Id$ */
 

	
 
/*
 
 * This file is part of OpenTTD.
 
 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
 
 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 
 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
 
 */
 

	
 
/** @file string_osx.cpp Functions related to localized text support on OSX. */
 

	
 
#include "../../stdafx.h"
 
#include "string_osx.h"
 
#include "macos.h"
 

	
 
#include <CoreFoundation/CoreFoundation.h>
 

	
 

	
 
#if (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_5)
 
static CFLocaleRef _osx_locale = NULL;
 

	
 
/** Store current language locale as a CoreFounation locale. */
 
void MacOSSetCurrentLocaleName(const char *iso_code)
 
{
 
	if (!MacOSVersionIsAtLeast(10, 5, 0)) return;
 

	
 
	if (_osx_locale != NULL) CFRelease(_osx_locale);
 

	
 
	CFStringRef iso = CFStringCreateWithCString(kCFAllocatorNull, iso_code, kCFStringEncodingUTF8);
 
	_osx_locale = CFLocaleCreate(kCFAllocatorDefault, iso);
 
	CFRelease(iso);
 
}
 

	
 
/**
 
 * Compares two strings using case insensitive natural sort.
 
 *
 
 * @param s1 First string to compare.
 
 * @param s2 Second string to compare.
 
 * @return 1 if s1 < s2, 2 if s1 == s2, 3 if s1 > s2, or 0 if not supported by the OS.
 
 */
 
int MacOSStringCompare(const char *s1, const char *s2)
 
{
 
	static bool supported = MacOSVersionIsAtLeast(10, 5, 0);
 
	if (!supported) return 0;
 

	
 
	CFStringCompareFlags flags = kCFCompareCaseInsensitive | kCFCompareNumerically | kCFCompareLocalized | kCFCompareWidthInsensitive | kCFCompareForcedOrdering;
 

	
 
	CFStringRef cf1 = CFStringCreateWithCString(kCFAllocatorDefault, s1, kCFStringEncodingUTF8);
 
	CFStringRef cf2 = CFStringCreateWithCString(kCFAllocatorDefault, s2, kCFStringEncodingUTF8);
 

	
 
	CFComparisonResult res = CFStringCompareWithOptionsAndLocale(cf1, cf2, CFRangeMake(0, CFStringGetLength(cf1)), flags, _osx_locale);
 

	
 
	CFRelease(cf1);
 
	CFRelease(cf2);
 

	
 
	return (int)res + 2;
 
}
 

	
 
#else
 
void MacOSSetCurrentLocaleName(const char *iso_code) {}
 

	
 
int MacOSStringCompare(const char *s1, const char *s2)
 
{
 
	return 0;
 
}
 
#endif /* (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_5) */
src/os/macosx/string_osx.h
Show inline comments
 
new file 100644
 
/* $Id$ */
 

	
 
/*
 
 * This file is part of OpenTTD.
 
 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
 
 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 
 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
 
 */
 

	
 
/** @file string_osx.h Functions related to localized text support on OSX. */
 

	
 
#ifndef STRING_OSX_H
 
#define STRING_OSX_H
 

	
 

	
 
void MacOSSetCurrentLocaleName(const char *iso_code);
 
int MacOSStringCompare(const char *s1, const char *s2);
 

	
 
#endif /* STRING_OSX_H */
src/string.cpp
Show inline comments
 
@@ -33,6 +33,10 @@
 
#include "os/windows/string_uniscribe.h"
 
#endif
 

	
 
#if defined(WITH_COCOA)
 
#include "os/macosx/string_osx.h"
 
#endif
 

	
 
#ifdef WITH_ICU_SORT
 
/* Required by strnatcmp. */
 
#include <unicode/ustring.h>
 
@@ -593,6 +597,11 @@ int strnatcmp(const char *s1, const char
 
	if (res != 0) return res - 2; // Convert to normal C return values.
 
#endif
 

	
 
#if defined(WITH_COCOA) && !defined(STRGEN) && !defined(SETTINGSGEN)
 
	int res = MacOSStringCompare(s1, s2);
 
	if (res != 0) return res - 2; // Convert to normal C return values.
 
#endif
 

	
 
	/* Do a normal comparison if ICU is missing or if we cannot create a collator. */
 
	return strcasecmp(s1, s2);
 
}
src/strings.cpp
Show inline comments
 
@@ -1791,6 +1791,11 @@ bool ReadLanguagePack(const LanguageMeta
 
	Win32SetCurrentLocaleName(_current_language->isocode);
 
#endif
 

	
 
#ifdef WITH_COCOA
 
	extern void MacOSSetCurrentLocaleName(const char *iso_code);
 
	MacOSSetCurrentLocaleName(_current_language->isocode);
 
#endif
 

	
 
#ifdef WITH_ICU_SORT
 
	/* Delete previous collator. */
 
	if (_current_collator != NULL) {
0 comments (0 inline, 0 general)