diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 8c596a827..c7811122c 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -11,7 +11,7 @@ jobs: - run: sudo apt-get update - run: sudo apt-get remove libunwind-14-dev - run: sudo apt-get install -y build-essential gettext cmake valac libgee-0.8-dev libsqlite3-dev libgtk-4-dev libnotify-dev libgpgme-dev libsoup2.4-dev libgcrypt20-dev libqrencode-dev libnice-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev libsrtp2-dev libadwaita-1-dev libsignal-protocol-c-dev libcanberra-dev - - run: ./configure --release --no-debug --with-tests --enable-plugin=notification-sound --prefix=/usr --without-webrtc + - run: ./configure --release --no-debug --with-tests --enable-plugin=notification-sound --prefix=/usr --without-webrtc --enable-select-lang - run: cmake --build build - run: cmake --build build --target=test - name: Build DEB-package @@ -41,7 +41,7 @@ jobs: - run: sudo apt-get update - run: sudo apt-get remove libunwind-14-dev - run: sudo apt-get install -y build-essential gettext libadwaita-1-dev libcanberra-dev libgcrypt20-dev libgee-0.8-dev libgpgme-dev libgstreamer-plugins-base1.0-dev libgstreamer1.0-dev libgtk-4-dev libnice-dev libnotify-dev libqrencode-dev libsignal-protocol-c-dev libsoup2.4-dev libsqlite3-dev libsrtp2-dev meson valac - - run: meson setup build -Duse-soup2=true -Dplugin-rtp-webrtc-audio-processing=disabled + - run: meson setup build -Duse-soup2=true -Dplugin-rtp-webrtc-audio-processing=disabled -Dselect-lang=enabled - run: meson compile -C build - run: meson test -C build build-flatpak: diff --git a/CMakeLists.txt b/CMakeLists.txt index 99d81319c..d212b13bd 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -14,6 +14,7 @@ include(CTest) option(PLUGIN_RTP_WEBRTC_AUDIO_PROCESSING "Use WebRTC audio processing" ON) option(WITH_WASAPI "Use wasapi instead of directsound on windows" ON) +option(ENABLE_SELECT_LANG "Add language change to settings" OFF) # https://gitlab.kitware.com/cmake/cmake/-/issues/19804 if (WIN32) @@ -195,7 +196,11 @@ endif (NOT NO_DEBUG) if (WIN32) set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D_POSIX_C_SOURCE=1") set(CMAKE_VALA_FLAGS "${CMAKE_VALA_FLAGS} --define=_WIN32") -endif(WIN32) +endif (WIN32) + +if (ENABLE_SELECT_LANG) + set(CMAKE_VALA_FLAGS "${CMAKE_VALA_FLAGS} --define=ENABLE_SELECT_LANG") +endif (ENABLE_SELECT_LANG) set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}) set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}) diff --git a/build-win64.sh b/build-win64.sh index f0c689afc..b9e7f7b1c 100644 --- a/build-win64.sh +++ b/build-win64.sh @@ -94,7 +94,7 @@ prepare() configure_cmake() { msg "Running configuration for Windows" - ./configure --program-prefix="$DIST_DIR" --no-debug --release --disable-fast-vapi --with-libsoup3 --with-tests + ./configure --program-prefix="$DIST_DIR" --no-debug --release --disable-fast-vapi --with-libsoup3 --with-tests --enable-select-lang msg "Configured!" } @@ -125,6 +125,7 @@ configure_meson() meson setup ${cmd} --prefix "$DIST_DIR" \ -D crypto-backend=${encr} \ -D plugin-ice=enabled \ + -D select-lang=enabled \ $PROJ_DIR $BUILD_DIR } diff --git a/configure b/configure index 24a13bc3f..3289e53af 100755 --- a/configure +++ b/configure @@ -2,6 +2,7 @@ OPTS=`getopt -o "h" --long \ help,fetch-only,no-debug,disable-fast-vapi,with-tests,release,with-libsoup3,without-webrtcdsp,\ +enable-select-lang,\ enable-plugin:,disable-plugin:,\ prefix:,program-prefix:,exec-prefix:,lib-suffix:,\ bindir:,libdir:,includedir:,datadir:,\ @@ -18,6 +19,7 @@ DISABLED_PLUGINS= BUILD_TESTS=no BUILD_TYPE=Debug DISABLE_FAST_VAPI= +ENABLE_SELECT_LANG=no LIB_SUFFIX= NO_DEBUG= USE_SOUP3= @@ -52,6 +54,7 @@ Configuration: builds (during development). --fetch-only Only fetch the files required to run ./configure without network access later and exit. + --enable-select-lang enable language switching for the settings menu --no-debug Build without debug symbols --release Configure to build an optimized release version --with-libsoup3 Build with libsoup-3.0 @@ -113,6 +116,7 @@ while true; do --with-libsoup3 ) USE_SOUP3=yes; shift ;; --without-webrtcdsp ) PLUGIN_RTP_WEBRTC_AUDIO_PROCESSING=no; shift ;; --disable-fast-vapi ) DISABLE_FAST_VAPI=yes; shift ;; + --enable-select-lang) ENABLE_SELECT_LANG=yes; shift ;; --no-debug ) NO_DEBUG=yes; shift ;; --release ) BUILD_TYPE=RelWithDebInfo; shift ;; --with-tests ) BUILD_TESTS=yes; shift ;; @@ -223,6 +227,7 @@ cmake -G "$cmake_type" \ -DINCLUDE_INSTALL_DIR="$INCLUDEDIR" \ -DLIB_INSTALL_DIR="$LIBDIR" \ -DPLUGIN_RTP_WEBRTC_AUDIO_PROCESSING="$PLUGIN_RTP_WEBRTC_AUDIO_PROCESSING" \ + -DENABLE_SELECT_LANG="$ENABLE_SELECT_LANG" \ -Wno-dev \ .. || exit 9 diff --git a/libdino/src/application.vala b/libdino/src/application.vala index 0fcee7310..b66d928b0 100644 --- a/libdino/src/application.vala +++ b/libdino/src/application.vala @@ -34,6 +34,10 @@ public interface Application : GLib.Application { this.settings = new Dino.Entities.Settings.from_db(db); this.stream_interactor = new StreamInteractor(db); +#if ENABLE_SELECT_LANG + Environment.set_variable("LANGUAGE", settings.ui_language, true); +#endif + MessageProcessor.start(stream_interactor, db); MessageStorage.start(stream_interactor, db); PresenceManager.start(stream_interactor); diff --git a/libdino/src/entity/settings.vala b/libdino/src/entity/settings.vala index 8f39713f2..07b983255 100644 --- a/libdino/src/entity/settings.vala +++ b/libdino/src/entity/settings.vala @@ -15,6 +15,7 @@ public class Settings : Object { default_encryption = col_to_encryption_or_default("default_encryption", Encryption.UNKNOWN); send_button = col_to_bool_or_default("send_button", false); enter_newline = col_to_bool_or_default("enter_newline", false); + ui_language_ = col_to_string_or_default("ui_language", "en"); } private bool col_to_bool_or_default(string key, bool def) { @@ -28,6 +29,12 @@ public class Settings : Object { return val != null ? Encryption.parse(val) : def; } + private string col_to_string_or_default(string key, string def) { + var sval = db.settings.value; + string? val = db.settings.select({sval}).with(db.settings.key, "=", key)[sval]; + return val != null ? val : def; + } + private bool send_typing_; public bool send_typing { get { return send_typing_; } @@ -128,6 +135,19 @@ public class Settings : Object { enter_newline_ = value; } } + + private string ui_language_; + public string ui_language { + get { return ui_language_; } + set { + string valstr = value.to_string(); + db.settings.upsert() + .value(db.settings.key, "ui_language", true) + .value(db.settings.value, valstr) + .perform(); + ui_language_ = value; + } + } } } diff --git a/main/data/settings_dialog.ui b/main/data/settings_dialog.ui index 04bd548bf..b9208abf2 100644 --- a/main/data/settings_dialog.ui +++ b/main/data/settings_dialog.ui @@ -140,6 +140,25 @@ + + + False + + + Select language + Application restart required + + + + English + Русский + + + + + + + diff --git a/main/po/en.po b/main/po/en.po index 7fb7fc6f0..5ae2bf666 100644 --- a/main/po/en.po +++ b/main/po/en.po @@ -1024,6 +1024,14 @@ msgstr "" msgid "Check spelling" msgstr "" +#: main/data/settings_dialog.ui:148 +msgid "Select language" +msgstr "" + +#: main/data/settings_dialog.ui:149 +msgid "Application restart required" +msgstr "" + #: main/data/im.dino.Dino.appdata.xml.in:7 msgid "Modern XMPP Chat Client" msgstr "" diff --git a/main/po/ru.po b/main/po/ru.po index 2b3af4d18..07a59327e 100644 --- a/main/po/ru.po +++ b/main/po/ru.po @@ -1040,6 +1040,14 @@ msgstr "Превращать смайлы в эмодзи" msgid "Check spelling" msgstr "Проверка орфографии" +#: main/data/settings_dialog.ui:148 +msgid "Select language" +msgstr "Выбор языка" + +#: main/data/settings_dialog.ui:149 +msgid "Application restart required" +msgstr "Требуется перезапуск приложения" + #: main/data/im.dino.Dino.appdata.xml.in:7 msgid "Modern XMPP Chat Client" msgstr "Современный XMPP клиент" diff --git a/main/src/ui/settings_dialog.vala b/main/src/ui/settings_dialog.vala index 5bdcee992..646e51499 100644 --- a/main/src/ui/settings_dialog.vala +++ b/main/src/ui/settings_dialog.vala @@ -15,6 +15,10 @@ class SettingsDialog : Adw.PreferencesWindow { [GtkChild] private unowned CheckButton encryption_radio_openpgp; [GtkChild] private unowned Switch send_button_switch; [GtkChild] private unowned Switch enter_newline_switch; +#if ENABLE_SELECT_LANG + [GtkChild] private unowned Adw.ComboRow select_lang_comborow; + [GtkChild] private unowned Adw.PreferencesGroup select_lang_group; +#endif Dino.Entities.Settings settings = Dino.Application.get_default().settings; @@ -65,6 +69,21 @@ class SettingsDialog : Adw.PreferencesWindow { enter_newline_switch.active = visible; } }); + +#if ENABLE_SELECT_LANG + var lang_short_list = new Gee.ArrayList(); + lang_short_list.add("en"); + lang_short_list.add("ru"); + + select_lang_comborow.set_selected(lang_short_list.index_of(settings.ui_language)); + + select_lang_comborow.notify["selected-item"].connect(() => { + settings.ui_language = lang_short_list.get((int)select_lang_comborow.get_selected()); + }); + + select_lang_group.visible = true; +#endif + } } diff --git a/meson.build b/meson.build index 6c7643e72..e25e53769 100644 --- a/meson.build +++ b/meson.build @@ -24,6 +24,10 @@ else endforeach endif +if get_option('select-lang').allowed() + add_project_arguments('-D', 'ENABLE_SELECT_LANG', language: 'vala') +endif + if get_option('crypto-backend') == 'auto' # Prefer libgcrypt/gnutls over openssl because glib-networking is usually # built with gnutls anyway. diff --git a/meson_options.txt b/meson_options.txt index b384cb41c..22dc6070a 100644 --- a/meson_options.txt +++ b/meson_options.txt @@ -17,3 +17,5 @@ option('plugin-rtp-webrtc-audio-processing', type: 'feature', description: 'Voic option('use-soup2', type: 'boolean', value: false, description: 'Use libsoup version 2 instead of 3') option('with-wasapi', type: 'boolean', value: true, description: 'Use wasapi insted of directsound on windows') + +option('select-lang', type: 'feature', value: 'disabled', description: 'Enable language change in settings')