Gettext support on Android (#11435)
Co-authored-by: sfan5 <sfan5@live.de> Co-authored-by: =?UTF-8?q?Olivier=20Samyn=20=F0=9F=8E=BB?= <code@oleastre.be>
This commit is contained in:
parent
4a3728d828
commit
c6eddb0bae
.github/workflows
android
src
2
.github/workflows/android.yml
vendored
2
.github/workflows/android.yml
vendored
@ -28,6 +28,8 @@ jobs:
|
|||||||
uses: actions/setup-java@v1
|
uses: actions/setup-java@v1
|
||||||
with:
|
with:
|
||||||
java-version: 1.8
|
java-version: 1.8
|
||||||
|
- name: Install deps
|
||||||
|
run: sudo apt-get update; sudo apt-get install -y --no-install-recommends gettext
|
||||||
- name: Build with Gradle
|
- name: Build with Gradle
|
||||||
run: cd android; ./gradlew assemblerelease
|
run: cd android; ./gradlew assemblerelease
|
||||||
- name: Save armeabi artifact
|
- name: Save armeabi artifact
|
||||||
|
@ -76,10 +76,13 @@ task prepareAssets() {
|
|||||||
copy {
|
copy {
|
||||||
from "${projRoot}/games/${gameToCopy}" into "${assetsFolder}/games/${gameToCopy}"
|
from "${projRoot}/games/${gameToCopy}" into "${assetsFolder}/games/${gameToCopy}"
|
||||||
}
|
}
|
||||||
/*copy {
|
fileTree("${projRoot}/po").include("**/*.po").forEach { poFile ->
|
||||||
// ToDo: fix broken locales
|
def moPath = "${assetsFolder}/locale/${poFile.parentFile.name}/LC_MESSAGES/"
|
||||||
from "${projRoot}/po" into "${assetsFolder}/po"
|
file(moPath).mkdirs()
|
||||||
}*/
|
exec {
|
||||||
|
commandLine 'msgfmt', '-o', "${moPath}/minetest.mo", poFile
|
||||||
|
}
|
||||||
|
}
|
||||||
copy {
|
copy {
|
||||||
from "${projRoot}/textures" into "${assetsFolder}/textures"
|
from "${projRoot}/textures" into "${assetsFolder}/textures"
|
||||||
}
|
}
|
||||||
|
@ -47,6 +47,11 @@ LOCAL_MODULE := OpenAL
|
|||||||
LOCAL_SRC_FILES := deps/Android/OpenAL-Soft/${NDK_TOOLCHAIN_VERSION}/$(APP_ABI)/libopenal.a
|
LOCAL_SRC_FILES := deps/Android/OpenAL-Soft/${NDK_TOOLCHAIN_VERSION}/$(APP_ABI)/libopenal.a
|
||||||
include $(PREBUILT_STATIC_LIBRARY)
|
include $(PREBUILT_STATIC_LIBRARY)
|
||||||
|
|
||||||
|
include $(CLEAR_VARS)
|
||||||
|
LOCAL_MODULE := GetText
|
||||||
|
LOCAL_SRC_FILES := deps/Android/GetText/${NDK_TOOLCHAIN_VERSION}/$(APP_ABI)/libintl.a
|
||||||
|
include $(PREBUILT_STATIC_LIBRARY)
|
||||||
|
|
||||||
include $(CLEAR_VARS)
|
include $(CLEAR_VARS)
|
||||||
LOCAL_MODULE := Vorbis
|
LOCAL_MODULE := Vorbis
|
||||||
LOCAL_SRC_FILES := deps/Android/Vorbis/${NDK_TOOLCHAIN_VERSION}/$(APP_ABI)/libvorbis.a
|
LOCAL_SRC_FILES := deps/Android/Vorbis/${NDK_TOOLCHAIN_VERSION}/$(APP_ABI)/libvorbis.a
|
||||||
@ -64,6 +69,7 @@ LOCAL_CFLAGS += \
|
|||||||
-DUSE_FREETYPE=1 \
|
-DUSE_FREETYPE=1 \
|
||||||
-DUSE_LEVELDB=0 \
|
-DUSE_LEVELDB=0 \
|
||||||
-DUSE_LUAJIT=1 \
|
-DUSE_LUAJIT=1 \
|
||||||
|
-DUSE_GETTEXT=1 \
|
||||||
-DVERSION_MAJOR=${versionMajor} \
|
-DVERSION_MAJOR=${versionMajor} \
|
||||||
-DVERSION_MINOR=${versionMinor} \
|
-DVERSION_MINOR=${versionMinor} \
|
||||||
-DVERSION_PATCH=${versionPatch} \
|
-DVERSION_PATCH=${versionPatch} \
|
||||||
@ -89,6 +95,7 @@ LOCAL_C_INCLUDES := \
|
|||||||
deps/Android/Freetype/include \
|
deps/Android/Freetype/include \
|
||||||
deps/Android/Irrlicht/include \
|
deps/Android/Irrlicht/include \
|
||||||
deps/Android/LevelDB/include \
|
deps/Android/LevelDB/include \
|
||||||
|
deps/Android/GetText/include \
|
||||||
deps/Android/libiconv/include \
|
deps/Android/libiconv/include \
|
||||||
deps/Android/libiconv/libcharset/include \
|
deps/Android/libiconv/libcharset/include \
|
||||||
deps/Android/LuaJIT/src \
|
deps/Android/LuaJIT/src \
|
||||||
@ -194,7 +201,7 @@ LOCAL_SRC_FILES += \
|
|||||||
# SQLite3
|
# SQLite3
|
||||||
LOCAL_SRC_FILES += deps/Android/sqlite/sqlite3.c
|
LOCAL_SRC_FILES += deps/Android/sqlite/sqlite3.c
|
||||||
|
|
||||||
LOCAL_STATIC_LIBRARIES += Curl Freetype Irrlicht OpenAL mbedTLS mbedx509 mbedcrypto Vorbis LuaJIT android_native_app_glue $(PROFILER_LIBS) #LevelDB
|
LOCAL_STATIC_LIBRARIES += Curl Freetype Irrlicht OpenAL mbedTLS mbedx509 mbedcrypto Vorbis LuaJIT GetText android_native_app_glue $(PROFILER_LIBS) #LevelDB
|
||||||
|
|
||||||
LOCAL_LDLIBS := -lEGL -lGLESv1_CM -lGLESv2 -landroid -lOpenSLES
|
LOCAL_LDLIBS := -lEGL -lGLESv1_CM -lGLESv2 -landroid -lOpenSLES
|
||||||
|
|
||||||
|
@ -127,6 +127,10 @@ void init_gettext(const char *path, const std::string &configured_language,
|
|||||||
// Add user specified locale to environment
|
// Add user specified locale to environment
|
||||||
setenv("LANGUAGE", configured_language.c_str(), 1);
|
setenv("LANGUAGE", configured_language.c_str(), 1);
|
||||||
|
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
setenv("LANG", configured_language.c_str(), 1);
|
||||||
|
#endif
|
||||||
|
|
||||||
// Reload locale with changed environment
|
// Reload locale with changed environment
|
||||||
setlocale(LC_ALL, "");
|
setlocale(LC_ALL, "");
|
||||||
#elif defined(_MSC_VER)
|
#elif defined(_MSC_VER)
|
||||||
|
@ -268,7 +268,7 @@ bool GUIModalMenu::preprocessEvent(const SEvent &event)
|
|||||||
std::string label = wide_to_utf8(getLabelByID(hovered->getID()));
|
std::string label = wide_to_utf8(getLabelByID(hovered->getID()));
|
||||||
if (label.empty())
|
if (label.empty())
|
||||||
label = "text";
|
label = "text";
|
||||||
message += gettext(label) + ":";
|
message += strgettext(label) + ":";
|
||||||
|
|
||||||
// single line text input
|
// single line text input
|
||||||
int type = 2;
|
int type = 2;
|
||||||
|
@ -190,6 +190,7 @@ void initializePathsAndroid()
|
|||||||
|
|
||||||
path_user = path_storage + DIR_DELIM + PROJECT_NAME_C;
|
path_user = path_storage + DIR_DELIM + PROJECT_NAME_C;
|
||||||
path_share = path_storage + DIR_DELIM + PROJECT_NAME_C;
|
path_share = path_storage + DIR_DELIM + PROJECT_NAME_C;
|
||||||
|
path_locale = path_share + DIR_DELIM + "locale";
|
||||||
path_cache = getAndroidPath(nativeActivity,
|
path_cache = getAndroidPath(nativeActivity,
|
||||||
app_global->activity->clazz, mt_getAbsPath, "getCacheDir");
|
app_global->activity->clazz, mt_getAbsPath, "getCacheDir");
|
||||||
migrateCachePath();
|
migrateCachePath();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user