mirror of
https://github.com/xiaoyifang/goldendict-ng.git
synced 2024-11-23 20:14:05 +00:00
Compare commits
14 commits
1bd4bf58e3
...
8b3e94757c
Author | SHA1 | Date | |
---|---|---|---|
8b3e94757c | |||
bd13598cc2 | |||
c7d0feb2e8 | |||
3c5233f2a1 | |||
c5ca1b7d63 | |||
5092ebe2ee | |||
5bef4cef22 | |||
59d01868da | |||
10b0496cce | |||
1cf495e7dd | |||
c2fc90801b | |||
2de2141758 | |||
db4c352d6c | |||
7c32cad65a |
2
.github/workflows/PR-check-cmake.yml
vendored
2
.github/workflows/PR-check-cmake.yml
vendored
|
@ -67,7 +67,7 @@ jobs:
|
|||
libzim \
|
||||
qt
|
||||
|
||||
wget ftp://ftp.sra.co.jp/pub/misc/eb/eb-4.4.3.tar.bz2
|
||||
wget https://github.com/mistydemeo/eb/releases/download/v4.4.3/eb-4.4.3.tar.bz2
|
||||
tar xvjf eb-4.4.3.tar.bz2
|
||||
cd eb-4.4.3 && ./configure && make -j 8 && sudo make install && cd ..
|
||||
|
||||
|
|
|
@ -3,11 +3,6 @@
|
|||
if (APPLE)
|
||||
# old & new homebrew's include paths
|
||||
target_include_directories(${GOLDENDICT} PRIVATE /usr/local/include /opt/homebrew/include)
|
||||
|
||||
# libzim depends on ICU, but the ICU from homebrew is "key-only", we need to manually prioritize it
|
||||
# See `brew info icu4c` if this no longer works
|
||||
# Note: Remove icu4c@75 if it fails again
|
||||
set(ENV{PKG_CONFIG_PATH} "$ENV{PKG_CONFIG_PATH}:/usr/local/opt/icu4c@75/lib/pkgconfig:/opt/homebrew/opt/icu4c@75/lib/pkgconfig:/usr/local/opt/icu4c/lib/pkgconfig:/opt/homebrew/opt/icu4c/lib/pkgconfig")
|
||||
endif ()
|
||||
|
||||
target_include_directories(${GOLDENDICT} PRIVATE
|
||||
|
@ -82,13 +77,31 @@ if (WITH_EPWING_SUPPORT)
|
|||
endif ()
|
||||
|
||||
if (WITH_ZIM)
|
||||
if (APPLE)
|
||||
# ICU from homebrew is "key-only", we need to manually prioritize it -> see `brew info icu4c`
|
||||
set(ENV{PKG_CONFIG_PATH} "$ENV{PKG_CONFIG_PATH}:/usr/local/opt/icu4c@76/lib/pkgconfig:/opt/homebrew/opt/icu4c@76/lib/pkgconfig:/usr/local/opt/icu4c/lib/pkgconfig:/opt/homebrew/opt/icu4c/lib/pkgconfig")
|
||||
endif ()
|
||||
|
||||
pkg_check_modules(ZIM REQUIRED IMPORTED_TARGET libzim)
|
||||
target_link_libraries(${GOLDENDICT} PRIVATE PkgConfig::ZIM)
|
||||
|
||||
if (APPLE)
|
||||
# For some reason, icu4c as transitive dependency of libzim may not be copied into app bundle,
|
||||
# so we directly depends on it to help macdeployqt or whatever
|
||||
pkg_check_modules(BREW_ICU_FOR_LIBZIM_FORCE_LINK REQUIRED IMPORTED_TARGET icu-i18n icu-uc)
|
||||
target_link_libraries(${GOLDENDICT} PUBLIC PkgConfig::BREW_ICU_FOR_LIBZIM_FORCE_LINK)
|
||||
# icu4c as transitive dependency of libzim may not be copied into app bundle, so we directly depends on it to assist macdeployqt
|
||||
# Why such complexities: 1) System or XCode SDKS's icu exists 2) icu itself is depended by various stuffs and homebrew may need multiple versions of it
|
||||
pkg_check_modules(BREW_ICU REQUIRED IMPORTED_TARGET icu-i18n icu-uc)
|
||||
target_link_libraries(${GOLDENDICT} PUBLIC PkgConfig::BREW_ICU)
|
||||
|
||||
# Verify icu <-> zim matches
|
||||
message("Zim include dirs -> ${ZIM_INCLUDE_DIRS}")
|
||||
message("Homebrew icu include dirs-> ${BREW_ICU_INCLUDE_DIRS}")
|
||||
|
||||
list(GET BREW_ICU_INCLUDE_DIRS 0 ONE_OF_BREW_ICU_INCLUDE_DIR)
|
||||
if (ONE_OF_BREW_ICU_INCLUDE_DIR IN_LIST ZIM_INCLUDE_DIRS)
|
||||
message("ZIM OK!")
|
||||
else ()
|
||||
message(FATAL_ERROR "!!!! ZIM <-> icu error -> check `brew info libzim` and `brew list libzim`")
|
||||
endif ()
|
||||
# TODO: get rid of these 💩, how?
|
||||
endif ()
|
||||
endif ()
|
||||
|
||||
|
|
|
@ -3,34 +3,39 @@
|
|||
|
||||
#include <QScopedPointer>
|
||||
#include <QObject>
|
||||
#include <utility>
|
||||
#include "audioplayerfactory.hh"
|
||||
#include "ffmpegaudioplayer.hh"
|
||||
#include "multimediaaudioplayer.hh"
|
||||
#include "externalaudioplayer.hh"
|
||||
#include "gddebug.hh"
|
||||
|
||||
AudioPlayerFactory::AudioPlayerFactory( Config::Preferences const & p ):
|
||||
useInternalPlayer( p.useInternalPlayer ),
|
||||
internalPlayerBackend( p.internalPlayerBackend ),
|
||||
audioPlaybackProgram( p.audioPlaybackProgram )
|
||||
AudioPlayerFactory::AudioPlayerFactory( bool useInternalPlayer,
|
||||
InternalPlayerBackend internalPlayerBackend,
|
||||
QString audioPlaybackProgram ):
|
||||
useInternalPlayer( useInternalPlayer ),
|
||||
internalPlayerBackend( std::move( internalPlayerBackend ) ),
|
||||
audioPlaybackProgram( std::move( audioPlaybackProgram ) )
|
||||
{
|
||||
reset();
|
||||
}
|
||||
|
||||
void AudioPlayerFactory::setPreferences( Config::Preferences const & p )
|
||||
void AudioPlayerFactory::setPreferences( bool new_useInternalPlayer,
|
||||
const InternalPlayerBackend & new_internalPlayerBackend,
|
||||
const QString & new_audioPlaybackProgram )
|
||||
{
|
||||
if ( p.useInternalPlayer != useInternalPlayer ) {
|
||||
useInternalPlayer = p.useInternalPlayer;
|
||||
internalPlayerBackend = p.internalPlayerBackend;
|
||||
audioPlaybackProgram = p.audioPlaybackProgram;
|
||||
if ( useInternalPlayer != new_useInternalPlayer ) {
|
||||
useInternalPlayer = new_useInternalPlayer;
|
||||
internalPlayerBackend = new_internalPlayerBackend;
|
||||
audioPlaybackProgram = new_audioPlaybackProgram;
|
||||
reset();
|
||||
}
|
||||
else if ( useInternalPlayer && p.internalPlayerBackend != internalPlayerBackend ) {
|
||||
internalPlayerBackend = p.internalPlayerBackend;
|
||||
else if ( useInternalPlayer && internalPlayerBackend != new_internalPlayerBackend ) {
|
||||
internalPlayerBackend = new_internalPlayerBackend;
|
||||
reset();
|
||||
}
|
||||
else if ( !useInternalPlayer && p.audioPlaybackProgram != audioPlaybackProgram ) {
|
||||
audioPlaybackProgram = p.audioPlaybackProgram;
|
||||
else if ( !useInternalPlayer && new_audioPlaybackProgram != audioPlaybackProgram ) {
|
||||
audioPlaybackProgram = new_audioPlaybackProgram;
|
||||
ExternalAudioPlayer * const externalPlayer = qobject_cast< ExternalAudioPlayer * >( playerPtr.data() );
|
||||
if ( externalPlayer ) {
|
||||
setAudioPlaybackProgram( *externalPlayer );
|
||||
|
@ -50,7 +55,7 @@ void AudioPlayerFactory::reset()
|
|||
// another object of the same type.
|
||||
|
||||
#ifdef MAKE_FFMPEG_PLAYER
|
||||
Q_ASSERT( Config::InternalPlayerBackend::defaultBackend().isFfmpeg()
|
||||
Q_ASSERT( InternalPlayerBackend::defaultBackend().isFfmpeg()
|
||||
&& "Adjust the code below after changing the default backend." );
|
||||
|
||||
if ( !internalPlayerBackend.isQtmultimedia() ) {
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
#pragma once
|
||||
|
||||
#include "audioplayerinterface.hh"
|
||||
#include "config.hh"
|
||||
#include "internalplayerbackend.hh"
|
||||
|
||||
class ExternalAudioPlayer;
|
||||
|
||||
|
@ -13,8 +13,12 @@ class AudioPlayerFactory
|
|||
Q_DISABLE_COPY( AudioPlayerFactory )
|
||||
|
||||
public:
|
||||
explicit AudioPlayerFactory( Config::Preferences const & );
|
||||
void setPreferences( Config::Preferences const & );
|
||||
explicit AudioPlayerFactory( bool useInternalPlayer,
|
||||
InternalPlayerBackend internalPlayerBackend,
|
||||
QString audioPlaybackProgram );
|
||||
void setPreferences( bool new_useInternalPlayer,
|
||||
const InternalPlayerBackend & new_internalPlayerBackend,
|
||||
const QString & new_audioPlaybackProgram );
|
||||
/// The returned reference to a smart pointer is valid as long as this object
|
||||
/// exists. The pointer to the owned AudioPlayerInterface may change after the
|
||||
/// call to setPreferences(), but it is guaranteed to never be null.
|
||||
|
@ -28,7 +32,7 @@ private:
|
|||
void setAudioPlaybackProgram( ExternalAudioPlayer & externalPlayer );
|
||||
|
||||
bool useInternalPlayer;
|
||||
Config::InternalPlayerBackend internalPlayerBackend;
|
||||
InternalPlayerBackend internalPlayerBackend;
|
||||
QString audioPlaybackProgram;
|
||||
AudioPlayerPtr playerPtr;
|
||||
};
|
||||
|
|
51
src/audio/internalplayerbackend.cc
Normal file
51
src/audio/internalplayerbackend.cc
Normal file
|
@ -0,0 +1,51 @@
|
|||
#include "internalplayerbackend.hh"
|
||||
|
||||
bool InternalPlayerBackend::anyAvailable()
|
||||
{
|
||||
#if defined( MAKE_FFMPEG_PLAYER ) || defined( MAKE_QTMULTIMEDIA_PLAYER )
|
||||
return true;
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
InternalPlayerBackend InternalPlayerBackend::defaultBackend()
|
||||
{
|
||||
#if defined( MAKE_FFMPEG_PLAYER )
|
||||
return ffmpeg();
|
||||
#elif defined( MAKE_QTMULTIMEDIA_PLAYER )
|
||||
return qtmultimedia();
|
||||
#else
|
||||
return InternalPlayerBackend( QString() );
|
||||
#endif
|
||||
}
|
||||
|
||||
QStringList InternalPlayerBackend::nameList()
|
||||
{
|
||||
QStringList result;
|
||||
#ifdef MAKE_FFMPEG_PLAYER
|
||||
result.push_back( ffmpeg().uiName() );
|
||||
#endif
|
||||
#ifdef MAKE_QTMULTIMEDIA_PLAYER
|
||||
result.push_back( qtmultimedia().uiName() );
|
||||
#endif
|
||||
return result;
|
||||
}
|
||||
|
||||
bool InternalPlayerBackend::isFfmpeg() const
|
||||
{
|
||||
#ifdef MAKE_FFMPEG_PLAYER
|
||||
return *this == ffmpeg();
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
bool InternalPlayerBackend::isQtmultimedia() const
|
||||
{
|
||||
#ifdef MAKE_QTMULTIMEDIA_PLAYER
|
||||
return *this == qtmultimedia();
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
61
src/audio/internalplayerbackend.hh
Normal file
61
src/audio/internalplayerbackend.hh
Normal file
|
@ -0,0 +1,61 @@
|
|||
#pragma once
|
||||
#include <QStringList>
|
||||
|
||||
/// Overly engineered dummy/helper/wrapper "backend", which is not, to manage backends.
|
||||
class InternalPlayerBackend
|
||||
{
|
||||
public:
|
||||
/// Returns true if at least one backend is available.
|
||||
static bool anyAvailable();
|
||||
/// Returns the default backend or null backend if none is available.
|
||||
static InternalPlayerBackend defaultBackend();
|
||||
/// Returns the name list of supported backends.
|
||||
static QStringList nameList();
|
||||
|
||||
/// Returns true if built with FFmpeg player support and the name matches.
|
||||
bool isFfmpeg() const;
|
||||
/// Returns true if built with Qt Multimedia player support and the name matches.
|
||||
bool isQtmultimedia() const;
|
||||
|
||||
QString const & uiName() const
|
||||
{
|
||||
return name;
|
||||
}
|
||||
|
||||
void setUiName( QString const & name_ )
|
||||
{
|
||||
name = name_;
|
||||
}
|
||||
|
||||
bool operator==( InternalPlayerBackend const & other ) const
|
||||
{
|
||||
return name == other.name;
|
||||
}
|
||||
|
||||
bool operator!=( InternalPlayerBackend const & other ) const
|
||||
{
|
||||
return !operator==( other );
|
||||
}
|
||||
|
||||
private:
|
||||
#ifdef MAKE_FFMPEG_PLAYER
|
||||
static InternalPlayerBackend ffmpeg()
|
||||
{
|
||||
return InternalPlayerBackend( "FFmpeg" );
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MAKE_QTMULTIMEDIA_PLAYER
|
||||
static InternalPlayerBackend qtmultimedia()
|
||||
{
|
||||
return InternalPlayerBackend( "Qt Multimedia" );
|
||||
}
|
||||
#endif
|
||||
|
||||
explicit InternalPlayerBackend( QString const & name_ ):
|
||||
name( name_ )
|
||||
{
|
||||
}
|
||||
|
||||
QString name;
|
||||
};
|
|
@ -119,57 +119,6 @@ QKeySequence HotKey::toKeySequence() const
|
|||
;
|
||||
}
|
||||
|
||||
|
||||
bool InternalPlayerBackend::anyAvailable()
|
||||
{
|
||||
#if defined( MAKE_FFMPEG_PLAYER ) || defined( MAKE_QTMULTIMEDIA_PLAYER )
|
||||
return true;
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
InternalPlayerBackend InternalPlayerBackend::defaultBackend()
|
||||
{
|
||||
#if defined( MAKE_FFMPEG_PLAYER )
|
||||
return ffmpeg();
|
||||
#elif defined( MAKE_QTMULTIMEDIA_PLAYER )
|
||||
return qtmultimedia();
|
||||
#else
|
||||
return InternalPlayerBackend( QString() );
|
||||
#endif
|
||||
}
|
||||
|
||||
QStringList InternalPlayerBackend::nameList()
|
||||
{
|
||||
QStringList result;
|
||||
#ifdef MAKE_FFMPEG_PLAYER
|
||||
result.push_back( ffmpeg().uiName() );
|
||||
#endif
|
||||
#ifdef MAKE_QTMULTIMEDIA_PLAYER
|
||||
result.push_back( qtmultimedia().uiName() );
|
||||
#endif
|
||||
return result;
|
||||
}
|
||||
|
||||
bool InternalPlayerBackend::isFfmpeg() const
|
||||
{
|
||||
#ifdef MAKE_FFMPEG_PLAYER
|
||||
return *this == ffmpeg();
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
bool InternalPlayerBackend::isQtmultimedia() const
|
||||
{
|
||||
#ifdef MAKE_QTMULTIMEDIA_PLAYER
|
||||
return *this == qtmultimedia();
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
QString Preferences::sanitizeInputPhrase( QString const & inputWord ) const
|
||||
{
|
||||
QString result = inputWord;
|
||||
|
|
|
@ -3,19 +3,20 @@
|
|||
|
||||
#pragma once
|
||||
|
||||
#include <QObject>
|
||||
#include <QList>
|
||||
#include <QString>
|
||||
#include <QSize>
|
||||
#include <QDateTime>
|
||||
#include <QKeySequence>
|
||||
#include <QSet>
|
||||
#include <QMetaType>
|
||||
#include "audio/internalplayerbackend.hh"
|
||||
#include "ex.hh"
|
||||
#include <QDateTime>
|
||||
#include <QDomDocument>
|
||||
#include <QKeySequence>
|
||||
#include <QList>
|
||||
#include <QLocale>
|
||||
#include <optional>
|
||||
#include <QMetaType>
|
||||
#include <QObject>
|
||||
#include <QSet>
|
||||
#include <QSize>
|
||||
#include <QString>
|
||||
#include <QThread>
|
||||
#include <optional>
|
||||
|
||||
/// Special group IDs
|
||||
enum GroupId : unsigned {
|
||||
|
@ -269,66 +270,6 @@ struct CustomFonts
|
|||
}
|
||||
};
|
||||
|
||||
/// This class encapsulates supported backend preprocessor logic,
|
||||
/// discourages duplicating backend names in code, which is error-prone.
|
||||
class InternalPlayerBackend
|
||||
{
|
||||
public:
|
||||
/// Returns true if at least one backend is available.
|
||||
static bool anyAvailable();
|
||||
/// Returns the default backend or null backend if none is available.
|
||||
static InternalPlayerBackend defaultBackend();
|
||||
/// Returns the name list of supported backends.
|
||||
static QStringList nameList();
|
||||
|
||||
/// Returns true if built with FFmpeg player support and the name matches.
|
||||
bool isFfmpeg() const;
|
||||
/// Returns true if built with Qt Multimedia player support and the name matches.
|
||||
bool isQtmultimedia() const;
|
||||
|
||||
QString const & uiName() const
|
||||
{
|
||||
return name;
|
||||
}
|
||||
|
||||
void setUiName( QString const & name_ )
|
||||
{
|
||||
name = name_;
|
||||
}
|
||||
|
||||
bool operator==( InternalPlayerBackend const & other ) const
|
||||
{
|
||||
return name == other.name;
|
||||
}
|
||||
|
||||
bool operator!=( InternalPlayerBackend const & other ) const
|
||||
{
|
||||
return !operator==( other );
|
||||
}
|
||||
|
||||
private:
|
||||
#ifdef MAKE_FFMPEG_PLAYER
|
||||
static InternalPlayerBackend ffmpeg()
|
||||
{
|
||||
return InternalPlayerBackend( "FFmpeg" );
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MAKE_QTMULTIMEDIA_PLAYER
|
||||
static InternalPlayerBackend qtmultimedia()
|
||||
{
|
||||
return InternalPlayerBackend( "Qt Multimedia" );
|
||||
}
|
||||
#endif
|
||||
|
||||
explicit InternalPlayerBackend( QString const & name_ ):
|
||||
name( name_ )
|
||||
{
|
||||
}
|
||||
|
||||
QString name;
|
||||
};
|
||||
|
||||
/// Various user preferences
|
||||
struct Preferences
|
||||
{
|
||||
|
|
|
@ -224,7 +224,7 @@ void loadDictionaries( QWidget * parent,
|
|||
|
||||
loadDicts.wait();
|
||||
|
||||
if ( loadDicts.getExceptionText().size() ) {
|
||||
if ( !loadDicts.getExceptionText().empty() ) {
|
||||
QMessageBox::critical( parent,
|
||||
QCoreApplication::translate( "LoadDictionaries", "Error loading dictionaries" ),
|
||||
QString::fromUtf8( loadDicts.getExceptionText().c_str() ) );
|
||||
|
|
|
@ -204,26 +204,11 @@ void EditDictionaries::acceptChangedSources( bool rebuildGroups )
|
|||
// Those hold pointers to dictionaries, we need to free them.
|
||||
groupInstances.clear();
|
||||
|
||||
groups.clear();
|
||||
orderAndProps.clear();
|
||||
|
||||
loadDictionaries( this, cfg, dictionaries, dictNetMgr );
|
||||
|
||||
Instances::updateNames( savedGroups, dictionaries );
|
||||
Instances::updateNames( savedOrder, dictionaries );
|
||||
Instances::updateNames( savedInactive, dictionaries );
|
||||
|
||||
if ( rebuildGroups ) {
|
||||
ui.tabs->removeTab( 1 );
|
||||
ui.tabs->removeTab( 1 );
|
||||
|
||||
orderAndProps = new OrderAndProps( this, savedOrder, savedInactive, dictionaries );
|
||||
groups = new Groups( this, dictionaries, savedGroups, orderAndProps->getCurrentDictionaryOrder() );
|
||||
|
||||
ui.tabs->insertTab( 1, orderAndProps, QIcon( ":/icons/book.svg" ), tr( "&Dictionaries" ) );
|
||||
ui.tabs->insertTab( 2, groups, QIcon( ":/icons/bookcase.svg" ), tr( "&Groups" ) );
|
||||
connect( groups, &Groups::showDictionaryInfo, this, &EditDictionaries::showDictionaryInfo );
|
||||
connect( orderAndProps, &OrderAndProps::showDictionaryHeadwords, this, &EditDictionaries::showDictionaryHeadwords );
|
||||
orderAndProps->rebuild( savedOrder, savedInactive, dictionaries );
|
||||
groups->rebuild( dictionaries, savedGroups, orderAndProps->getCurrentDictionaryOrder() );
|
||||
}
|
||||
setUpdatesEnabled( true );
|
||||
}
|
||||
|
|
|
@ -64,6 +64,24 @@ Groups::Groups( QWidget * parent,
|
|||
countChanged();
|
||||
}
|
||||
|
||||
void Groups::rebuild( vector< sptr< Dictionary::Class > > const & dicts_,
|
||||
Config::Groups const & groups_,
|
||||
Config::Group const & order )
|
||||
{
|
||||
this->setUpdatesEnabled( false );
|
||||
dicts = dicts_;
|
||||
groups = groups_;
|
||||
|
||||
ui.dictionaries->setAsSource();
|
||||
ui.dictionaries->populate( Instances::Group( order, dicts, Config::Group() ).dictionaries, dicts );
|
||||
|
||||
// Populate groups' widget
|
||||
ui.groups->populate( groups, dicts, ui.dictionaries->getCurrentDictionaries() );
|
||||
|
||||
countChanged();
|
||||
this->setUpdatesEnabled( true );
|
||||
}
|
||||
|
||||
void Groups::editGroup( unsigned id )
|
||||
{
|
||||
for ( int x = 0; x < groups.size(); ++x ) {
|
||||
|
|
|
@ -18,7 +18,9 @@ public:
|
|||
std::vector< sptr< Dictionary::Class > > const &,
|
||||
Config::Groups const &,
|
||||
Config::Group const & order );
|
||||
|
||||
void rebuild( std::vector< sptr< Dictionary::Class > > const & dicts_,
|
||||
Config::Groups const & groups_,
|
||||
Config::Group const & order );
|
||||
/// Instructs the dialog to position itself on editing the given group.
|
||||
void editGroup( unsigned id );
|
||||
|
||||
|
@ -31,7 +33,7 @@ public:
|
|||
|
||||
private:
|
||||
Ui::Groups ui;
|
||||
std::vector< sptr< Dictionary::Class > > const & dicts;
|
||||
std::vector< sptr< Dictionary::Class > > dicts;
|
||||
Config::Groups groups;
|
||||
|
||||
QToolButton * groupsListButton;
|
||||
|
|
|
@ -167,7 +167,8 @@ MainWindow::MainWindow( Config::Class & cfg_ ):
|
|||
cfg.preferences.disallowContentFromOtherSites,
|
||||
cfg.preferences.hideGoldenDictHeader ),
|
||||
dictNetMgr( this ),
|
||||
audioPlayerFactory( cfg.preferences ),
|
||||
audioPlayerFactory(
|
||||
cfg.preferences.useInternalPlayer, cfg.preferences.internalPlayerBackend, cfg.preferences.audioPlaybackProgram ),
|
||||
wordFinder( this ),
|
||||
wordListSelChanged( false ),
|
||||
wasMaximized( false ),
|
||||
|
@ -2356,7 +2357,9 @@ void MainWindow::editPreferences()
|
|||
#endif
|
||||
}
|
||||
|
||||
audioPlayerFactory.setPreferences( cfg.preferences );
|
||||
audioPlayerFactory.setPreferences( cfg.preferences.useInternalPlayer,
|
||||
cfg.preferences.internalPlayerBackend,
|
||||
cfg.preferences.audioPlaybackProgram );
|
||||
|
||||
trayIconUpdateOrInit();
|
||||
applyProxySettings();
|
||||
|
|
|
@ -133,6 +133,25 @@ OrderAndProps::OrderAndProps( QWidget * parent,
|
|||
showDictNumbers();
|
||||
}
|
||||
|
||||
void OrderAndProps::rebuild( Config::Group const & dictionaryOrder,
|
||||
Config::Group const & inactiveDictionaries,
|
||||
std::vector< sptr< Dictionary::Class > > const & allDictionaries )
|
||||
{
|
||||
Instances::Group order( dictionaryOrder, allDictionaries, Config::Group() );
|
||||
Instances::Group inactive( inactiveDictionaries, allDictionaries, Config::Group() );
|
||||
|
||||
Instances::complementDictionaryOrder( order, inactive, allDictionaries );
|
||||
|
||||
setUpdatesEnabled( false );
|
||||
ui.dictionaryOrder->populate( order.dictionaries, allDictionaries );
|
||||
ui.inactiveDictionaries->populate( inactive.dictionaries, allDictionaries );
|
||||
|
||||
disableDictionaryDescription();
|
||||
|
||||
showDictNumbers();
|
||||
setUpdatesEnabled( true );
|
||||
}
|
||||
|
||||
Config::Group OrderAndProps::getCurrentDictionaryOrder() const
|
||||
{
|
||||
Instances::Group g;
|
||||
|
|
|
@ -17,7 +17,9 @@ public:
|
|||
Config::Group const & dictionaryOrder,
|
||||
Config::Group const & inactiveDictionaries,
|
||||
std::vector< sptr< Dictionary::Class > > const & allDictionaries );
|
||||
|
||||
void rebuild( Config::Group const & dictionaryOrder,
|
||||
Config::Group const & inactiveDictionaries,
|
||||
std::vector< sptr< Dictionary::Class > > const & allDictionaries );
|
||||
Config::Group getCurrentDictionaryOrder() const;
|
||||
Config::Group getCurrentInactiveDictionaries() const;
|
||||
|
||||
|
|
|
@ -294,7 +294,7 @@ Preferences::Preferences( QWidget * parent, Config::Class & cfg_ ):
|
|||
ui.pronounceOnLoadMain->setChecked( p.pronounceOnLoadMain );
|
||||
ui.pronounceOnLoadPopup->setChecked( p.pronounceOnLoadPopup );
|
||||
|
||||
ui.internalPlayerBackend->addItems( Config::InternalPlayerBackend::nameList() );
|
||||
ui.internalPlayerBackend->addItems( InternalPlayerBackend::nameList() );
|
||||
|
||||
// Make sure that exactly one radio button in the group is checked and that
|
||||
// on_useExternalPlayer_toggled() is called.
|
||||
|
@ -306,7 +306,7 @@ Preferences::Preferences( QWidget * parent, Config::Class & cfg_ ):
|
|||
|
||||
int index = ui.internalPlayerBackend->findText( p.internalPlayerBackend.uiName() );
|
||||
if ( index < 0 ) { // The specified backend is unavailable.
|
||||
index = ui.internalPlayerBackend->findText( Config::InternalPlayerBackend::defaultBackend().uiName() );
|
||||
index = ui.internalPlayerBackend->findText( InternalPlayerBackend::defaultBackend().uiName() );
|
||||
}
|
||||
Q_ASSERT( index >= 0 && "Logic error: the default backend must be present in the backend name list." );
|
||||
ui.internalPlayerBackend->setCurrentIndex( index );
|
||||
|
|
Loading…
Reference in a new issue