diff --git a/Source/Core/DolphinQt/Settings/GeneralPane.cpp b/Source/Core/DolphinQt/Settings/GeneralPane.cpp
index 508a5bdbbf..93e3d0d9c8 100644
--- a/Source/Core/DolphinQt/Settings/GeneralPane.cpp
+++ b/Source/Core/DolphinQt/Settings/GeneralPane.cpp
@@ -95,6 +95,8 @@ void GeneralPane::OnEmulationStateChanged(Core::State state)
m_checkbox_discord_presence->setEnabled(!running);
#endif
m_combobox_fallback_region->setEnabled(!running);
+
+ UpdateDescriptionsUsingHardcoreStatus();
}
void GeneralPane::ConnectLayout()
@@ -397,12 +399,6 @@ void GeneralPane::AddDescriptions()
"
This setting cannot be changed while emulation is active."
"
If unsure, leave this checked.");
#endif
- static constexpr char TR_SPEEDLIMIT_DESCRIPTION[] =
- QT_TR_NOOP("Controls how fast emulation runs relative to the original hardware."
- "
Values higher than 100% will emulate faster than the original hardware "
- "can run, if your hardware is able to keep up. Values lower than 100% will slow "
- "emulation instead. Unlimited will emulate as fast as your hardware is able to."
- "
If unsure, select 100%.");
static constexpr char TR_UPDATE_TRACK_DESCRIPTION[] = QT_TR_NOOP(
"Selects which update track Dolphin uses when checking for updates at startup. If a new "
"update is available, Dolphin will show a list of changes made since your current version "
@@ -450,7 +446,6 @@ void GeneralPane::AddDescriptions()
#endif
m_combobox_speedlimit->SetTitle(tr("Speed Limit"));
- m_combobox_speedlimit->SetDescription(tr(TR_SPEEDLIMIT_DESCRIPTION));
if (AutoUpdateChecker::SystemSupportsAutoUpdates())
{
@@ -468,3 +463,30 @@ void GeneralPane::AddDescriptions()
m_button_generate_new_identity->SetDescription(tr(TR_GENERATE_NEW_IDENTITY_DESCRIPTION));
#endif
}
+
+void GeneralPane::UpdateDescriptionsUsingHardcoreStatus()
+{
+ const bool hardcore_enabled = AchievementManager::GetInstance().IsHardcoreModeActive();
+
+ static constexpr char TR_SPEEDLIMIT_DESCRIPTION[] =
+ QT_TR_NOOP("Controls how fast emulation runs relative to the original hardware."
+ "
Values higher than 100% will emulate faster than the original hardware "
+ "can run, if your hardware is able to keep up. Values lower than 100% will slow "
+ "emulation instead. Unlimited will emulate as fast as your hardware is able to."
+ "
If unsure, select 100%.");
+ static constexpr char TR_SPEEDLIMIT_RESTRICTION_IN_HARDCORE_DESCRIPTION[] =
+ QT_TR_NOOP("When Hardcore Mode is enabled, Speed Limit values less than "
+ "100% will be treated as 100%.");
+
+ if (hardcore_enabled)
+ {
+ m_combobox_speedlimit->SetDescription(
+ tr("%1
%2")
+ .arg(tr(TR_SPEEDLIMIT_DESCRIPTION))
+ .arg(tr(TR_SPEEDLIMIT_RESTRICTION_IN_HARDCORE_DESCRIPTION)));
+ }
+ else
+ {
+ m_combobox_speedlimit->SetDescription(tr(TR_SPEEDLIMIT_DESCRIPTION));
+ }
+}
diff --git a/Source/Core/DolphinQt/Settings/GeneralPane.h b/Source/Core/DolphinQt/Settings/GeneralPane.h
index ffe850491b..17d80f7c38 100644
--- a/Source/Core/DolphinQt/Settings/GeneralPane.h
+++ b/Source/Core/DolphinQt/Settings/GeneralPane.h
@@ -39,6 +39,7 @@ private:
void LoadConfig();
void OnSaveConfig();
void OnEmulationStateChanged(Core::State state);
+ void UpdateDescriptionsUsingHardcoreStatus();
// Widgets
QVBoxLayout* m_main_layout;