forked from eden-emu/eden
		
	general: Make most settings a BasicSetting
Creates a new BasicSettings class in common/settings, and forces setting a default and label for each setting that uses it in common/settings. Moves defaults and labels from both frontends into common settings. Creates a helper function in each frontend to facillitate reading the settings now with the new default and label properties. Settings::Setting is also now a subclass of Settings::BasicSetting. Also adds documentation for both Setting and BasicSetting.
This commit is contained in:
		
							parent
							
								
									2a3db91559
								
							
						
					
					
						commit
						794c444285
					
				
					 32 changed files with 813 additions and 666 deletions
				
			
		|  | @ -263,9 +263,9 @@ struct System::Impl { | |||
|         if (Settings::values.gamecard_inserted) { | ||||
|             if (Settings::values.gamecard_current_game) { | ||||
|                 fs_controller.SetGameCard(GetGameFileFromPath(virtual_filesystem, filepath)); | ||||
|             } else if (!Settings::values.gamecard_path.empty()) { | ||||
|                 fs_controller.SetGameCard( | ||||
|                     GetGameFileFromPath(virtual_filesystem, Settings::values.gamecard_path)); | ||||
|             } else if (!Settings::values.gamecard_path.GetValue().empty()) { | ||||
|                 fs_controller.SetGameCard(GetGameFileFromPath( | ||||
|                     virtual_filesystem, static_cast<std::string>(Settings::values.gamecard_path))); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,7 +13,7 @@ ProfileSelectApplet::~ProfileSelectApplet() = default; | |||
| void DefaultProfileSelectApplet::SelectProfile( | ||||
|     std::function<void(std::optional<Common::UUID>)> callback) const { | ||||
|     Service::Account::ProfileManager manager; | ||||
|     callback(manager.GetUser(Settings::values.current_user).value_or(Common::UUID{})); | ||||
|     callback(manager.GetUser(Settings::values.current_user.GetValue()).value_or(Common::UUID{})); | ||||
|     LOG_INFO(Service_ACC, "called, selecting current user instead of prompting..."); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -48,7 +48,8 @@ ProfileManager::ProfileManager() { | |||
|         CreateNewUser(UUID::Generate(), "yuzu"); | ||||
|     } | ||||
| 
 | ||||
|     auto current = std::clamp<int>(Settings::values.current_user, 0, MAX_USERS - 1); | ||||
|     auto current = | ||||
|         std::clamp<int>(static_cast<s32>(Settings::values.current_user), 0, MAX_USERS - 1); | ||||
| 
 | ||||
|     // If user index don't exist. Load the first user and change the active user
 | ||||
|     if (!UserExistsIndex(current)) { | ||||
|  |  | |||
|  | @ -1443,7 +1443,7 @@ void IApplicationFunctions::PopLaunchParameter(Kernel::HLERequestContext& ctx) { | |||
|         params.is_account_selected = 1; | ||||
| 
 | ||||
|         Account::ProfileManager profile_manager{}; | ||||
|         const auto uuid = profile_manager.GetUser(Settings::values.current_user); | ||||
|         const auto uuid = profile_manager.GetUser(static_cast<s32>(Settings::values.current_user)); | ||||
|         ASSERT(uuid); | ||||
|         params.current_user = uuid->uuid; | ||||
| 
 | ||||
|  |  | |||
|  | @ -179,7 +179,7 @@ private: | |||
|         IPC::ResponseBuilder rb{ctx, 3}; | ||||
|         rb.Push(ResultSuccess); | ||||
| 
 | ||||
|         if (Settings::values.bcat_backend == "none") { | ||||
|         if (Settings::values.bcat_backend.GetValue() == "none") { | ||||
|             rb.PushEnum(RequestState::NotSubmitted); | ||||
|         } else { | ||||
|             rb.PushEnum(RequestState::Connected); | ||||
|  | @ -384,7 +384,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 3}; | ||||
|         rb.Push(ResultSuccess); | ||||
|         if (Settings::values.bcat_backend == "none") { | ||||
|         if (Settings::values.bcat_backend.GetValue() == "none") { | ||||
|             rb.Push<u8>(0); | ||||
|         } else { | ||||
|             rb.Push<u8>(1); | ||||
|  | @ -395,7 +395,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 3}; | ||||
|         rb.Push(ResultSuccess); | ||||
|         if (Settings::values.bcat_backend == "none") { | ||||
|         if (Settings::values.bcat_backend.GetValue() == "none") { | ||||
|             rb.Push<u8>(0); | ||||
|         } else { | ||||
|             rb.Push<u8>(1); | ||||
|  |  | |||
|  | @ -160,7 +160,7 @@ void SET::GetQuestFlag(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 3}; | ||||
|     rb.Push(ResultSuccess); | ||||
|     rb.Push(static_cast<u32>(Settings::values.quest_flag)); | ||||
|     rb.Push(static_cast<u32>(Settings::values.quest_flag.GetValue())); | ||||
| } | ||||
| 
 | ||||
| void SET::GetLanguageCode(Kernel::HLERequestContext& ctx) { | ||||
|  |  | |||
|  | @ -155,8 +155,8 @@ static bool LoadNroImpl(Kernel::KProcess& process, const std::vector<u8>& data) | |||
|         codeset.segments[i].size = PageAlignSize(nro_header.segments[i].size); | ||||
|     } | ||||
| 
 | ||||
|     if (!Settings::values.program_args.empty()) { | ||||
|         const auto arg_data = Settings::values.program_args; | ||||
|     if (!Settings::values.program_args.GetValue().empty()) { | ||||
|         const auto arg_data = Settings::values.program_args.GetValue(); | ||||
|         codeset.DataSegment().size += NSO_ARGUMENT_DATA_ALLOCATION_SIZE; | ||||
|         NSOArgumentHeader args_header{ | ||||
|             NSO_ARGUMENT_DATA_ALLOCATION_SIZE, static_cast<u32_le>(arg_data.size()), {}}; | ||||
|  |  | |||
|  | @ -104,8 +104,8 @@ std::optional<VAddr> AppLoader_NSO::LoadModule(Kernel::KProcess& process, Core:: | |||
|         codeset.segments[i].size = nso_header.segments[i].size; | ||||
|     } | ||||
| 
 | ||||
|     if (should_pass_arguments && !Settings::values.program_args.empty()) { | ||||
|         const auto arg_data{Settings::values.program_args}; | ||||
|     if (should_pass_arguments && !Settings::values.program_args.GetValue().empty()) { | ||||
|         const auto arg_data{Settings::values.program_args.GetValue()}; | ||||
| 
 | ||||
|         codeset.DataSegment().size += NSO_ARGUMENT_DATA_ALLOCATION_SIZE; | ||||
|         NSOArgumentHeader args_header{ | ||||
|  |  | |||
|  | @ -397,7 +397,7 @@ void Reporter::ClearFSAccessLog() const { | |||
| } | ||||
| 
 | ||||
| bool Reporter::IsReportingEnabled() const { | ||||
|     return Settings::values.reporting_services; | ||||
|     return Settings::values.reporting_services.GetValue(); | ||||
| } | ||||
| 
 | ||||
| } // namespace Core
 | ||||
|  |  | |||
|  | @ -212,7 +212,7 @@ void TelemetrySession::AddInitialInfo(Loader::AppLoader& app_loader, | |||
| 
 | ||||
|     // Log user configuration information
 | ||||
|     constexpr auto field_type = Telemetry::FieldType::UserConfig; | ||||
|     AddField(field_type, "Audio_SinkId", Settings::values.sink_id); | ||||
|     AddField(field_type, "Audio_SinkId", Settings::values.sink_id.GetValue()); | ||||
|     AddField(field_type, "Audio_EnableAudioStretching", | ||||
|              Settings::values.enable_audio_stretching.GetValue()); | ||||
|     AddField(field_type, "Core_UseMultiCore", Settings::values.use_multi_core.GetValue()); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 lat9nq
						lat9nq