X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/954e8c47906c12edaaf6e6aebdd41516eceb0d44..e1b325a867ede95c5815ca11998017c67fc78ea9:/src/settings/viewmodes/viewmodesettings.cpp diff --git a/src/settings/viewmodes/viewmodesettings.cpp b/src/settings/viewmodes/viewmodesettings.cpp index 2ea843f3b..1644cc074 100644 --- a/src/settings/viewmodes/viewmodesettings.cpp +++ b/src/settings/viewmodes/viewmodesettings.cpp @@ -1,5 +1,6 @@ /* * SPDX-FileCopyrightText: 2011 Peter Penz + * SPDX-FileCopyrightText: 2021 Felix Ernst * * SPDX-License-Identifier: GPL-2.0-or-later */ @@ -10,121 +11,191 @@ #include "dolphin_detailsmodesettings.h" #include "dolphin_iconsmodesettings.h" -#define VIEWMODESETTINGS_SET_VALUE(mode, setValue, value) \ - switch (mode) { \ - case ViewModeSettings::IconsMode: IconsModeSettings::setValue(value); break; \ - case ViewModeSettings::CompactMode: CompactModeSettings::setValue(value); break; \ - case ViewModeSettings::DetailsMode: DetailsModeSettings::setValue(value); break; \ - default: Q_ASSERT(false); break; \ +#include "dolphin_generalsettings.h" + +ViewModeSettings::ViewModeSettings() +{ + auto removeEntries = [](KConfigGroup &group) { + group.deleteEntry("FontFamily"); + group.deleteEntry("FontWeight"); + group.deleteEntry("ItalicFont"); + }; + + KSharedConfig::Ptr config = KSharedConfig::openConfig(); + // Migrate old config entries + if (GeneralSettings::version() < 202) { + for (const QString &groupName : {QStringLiteral("CompactMode"), QStringLiteral("DetailsMode"), QStringLiteral("IconsMode")}) { + KConfigGroup group = config->group(groupName); + const QString family = group.readEntry("FontFamily", QString{}); + if (family.isEmpty()) { + removeEntries(group); + continue; + } + + QFont font; + font.setFamily(family); + const int weight = group.readEntry("FontWeight", QFont::Normal); + font.setWeight(static_cast(weight)); + font.setItalic(group.readEntry("ItalicFont", false)); + removeEntries(group); + + // Write the new config entry + group.writeEntry("ViewFont", font); + } + + config->sync(); } - -#define VIEWMODESETTINGS_RETURN_VALUE(mode, getValue, type) \ - type value; \ - switch (m_mode) { \ - case IconsMode: value = IconsModeSettings::getValue(); break; \ - case CompactMode: value = CompactModeSettings::getValue(); break; \ - case DetailsMode: value = DetailsModeSettings::getValue(); break; \ - default: value = IconsModeSettings::getValue(); \ - Q_ASSERT(false); \ - break; \ - } \ - return value - -ViewModeSettings::ViewModeSettings(ViewMode mode) : - m_mode(mode) -{ } -ViewModeSettings::~ViewModeSettings() -{ -} - -void ViewModeSettings::setIconSize(int size) const -{ - VIEWMODESETTINGS_SET_VALUE(m_mode, setIconSize, size); -} - -int ViewModeSettings::iconSize() const -{ - VIEWMODESETTINGS_RETURN_VALUE(m_mode, iconSize, int); -} - -void ViewModeSettings::setPreviewSize(int size) const -{ - VIEWMODESETTINGS_SET_VALUE(m_mode, setPreviewSize, size); +ViewModeSettings::ViewModeSettings(DolphinView::Mode mode) + : ViewModeSettings() +{ + switch (mode) { + case DolphinView::IconsView: + m_viewModeSettingsVariant = IconsModeSettings::self(); + return; + case DolphinView::CompactView: + m_viewModeSettingsVariant = CompactModeSettings::self(); + return; + case DolphinView::DetailsView: + m_viewModeSettingsVariant = DetailsModeSettings::self(); + return; + default: + Q_UNREACHABLE(); + } } -int ViewModeSettings::previewSize() const -{ - VIEWMODESETTINGS_RETURN_VALUE(m_mode, previewSize, int); +ViewModeSettings::ViewModeSettings(ViewSettingsTab::Mode mode) + : ViewModeSettings() +{ + switch (mode) { + case ViewSettingsTab::IconsMode: + m_viewModeSettingsVariant = IconsModeSettings::self(); + return; + case ViewSettingsTab::CompactMode: + m_viewModeSettingsVariant = CompactModeSettings::self(); + return; + case ViewSettingsTab::DetailsMode: + m_viewModeSettingsVariant = DetailsModeSettings::self(); + return; + default: + Q_UNREACHABLE(); + } } -void ViewModeSettings::setUseSystemFont(bool flag) -{ - VIEWMODESETTINGS_SET_VALUE(m_mode, setUseSystemFont, flag); +ViewModeSettings::ViewModeSettings(KStandardItemListView::ItemLayout itemLayout) + : ViewModeSettings() +{ + switch (itemLayout) { + case KStandardItemListView::IconsLayout: + m_viewModeSettingsVariant = IconsModeSettings::self(); + return; + case KStandardItemListView::CompactLayout: + m_viewModeSettingsVariant = CompactModeSettings::self(); + return; + case KStandardItemListView::DetailsLayout: + m_viewModeSettingsVariant = DetailsModeSettings::self(); + return; + default: + Q_UNREACHABLE(); + } } -bool ViewModeSettings::useSystemFont() const +void ViewModeSettings::setIconSize(int iconSize) { - VIEWMODESETTINGS_RETURN_VALUE(m_mode, useSystemFont, bool); + std::visit( + [iconSize](auto &&v) { + v->setIconSize(iconSize); + }, + m_viewModeSettingsVariant); } -void ViewModeSettings::setFontFamily(const QString& fontFamily) +int ViewModeSettings::iconSize() const { - VIEWMODESETTINGS_SET_VALUE(m_mode, setFontFamily, fontFamily); + return std::visit( + [](auto &&v) { + return v->iconSize(); + }, + m_viewModeSettingsVariant); } -QString ViewModeSettings::fontFamily() const +void ViewModeSettings::setPreviewSize(int previewSize) { - VIEWMODESETTINGS_RETURN_VALUE(m_mode, fontFamily, QString); + std::visit( + [previewSize](auto &&v) { + v->setPreviewSize(previewSize); + }, + m_viewModeSettingsVariant); } -void ViewModeSettings::setFontSize(qreal fontSize) +int ViewModeSettings::previewSize() const { - VIEWMODESETTINGS_SET_VALUE(m_mode, setFontSize, fontSize); + return std::visit( + [](auto &&v) { + return v->previewSize(); + }, + m_viewModeSettingsVariant); } -qreal ViewModeSettings::fontSize() const +void ViewModeSettings::setUseSystemFont(bool useSystemFont) { - VIEWMODESETTINGS_RETURN_VALUE(m_mode, fontSize, qreal); + std::visit( + [useSystemFont](auto &&v) { + v->setUseSystemFont(useSystemFont); + }, + m_viewModeSettingsVariant); } -void ViewModeSettings::setItalicFont(bool italic) +bool ViewModeSettings::useSystemFont() const { - VIEWMODESETTINGS_SET_VALUE(m_mode, setItalicFont, italic); + return std::visit( + [](auto &&v) { + return v->useSystemFont(); + }, + m_viewModeSettingsVariant); } -bool ViewModeSettings::italicFont() const +void ViewModeSettings::setViewFont(const QFont &font) { - VIEWMODESETTINGS_RETURN_VALUE(m_mode, italicFont, bool); + std::visit( + [&font](auto &&v) { + v->setViewFont(font); + }, + m_viewModeSettingsVariant); } -void ViewModeSettings::setFontWeight(int fontWeight) +QFont ViewModeSettings::viewFont() const { - VIEWMODESETTINGS_SET_VALUE(m_mode, setFontWeight, fontWeight); + return std::visit( + [](auto &&v) { + return v->viewFont(); + }, + m_viewModeSettingsVariant); } -int ViewModeSettings::fontWeight() const +void ViewModeSettings::useDefaults(bool useDefaults) { - VIEWMODESETTINGS_RETURN_VALUE(m_mode, fontWeight, int); + std::visit( + [useDefaults](auto &&v) { + v->useDefaults(useDefaults); + }, + m_viewModeSettingsVariant); } void ViewModeSettings::readConfig() { - switch (m_mode) { - case ViewModeSettings::IconsMode: IconsModeSettings::self()->load(); break; - case ViewModeSettings::CompactMode: CompactModeSettings::self()->load(); break; - case ViewModeSettings::DetailsMode: DetailsModeSettings::self()->load(); break; - default: Q_ASSERT(false); break; - } + std::visit( + [](auto &&v) { + v->load(); + }, + m_viewModeSettingsVariant); } void ViewModeSettings::save() { - switch (m_mode) { - case ViewModeSettings::IconsMode: IconsModeSettings::self()->save(); break; - case ViewModeSettings::CompactMode: CompactModeSettings::self()->save(); break; - case ViewModeSettings::DetailsMode: DetailsModeSettings::self()->save(); break; - default: Q_ASSERT(false); break; - } + std::visit( + [](auto &&v) { + return v->save(); + }, + m_viewModeSettingsVariant); }