mirror of
				https://github.com/yuzu-emu/yuzu-android
				synced 2025-10-25 03:32:27 -07:00 
			
		
		
		
	am: rewrite IApplicationCreator
This commit is contained in:
		| @@ -1,8 +1,12 @@ | ||||
| // SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
 | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later
 | ||||
| 
 | ||||
| #include "core/hle/service/am/application_creator.h" | ||||
| #include "core/hle/service/ipc_helpers.h" | ||||
| #include "core/hle/service/am/am_types.h" | ||||
| #include "core/hle/service/am/applet.h" | ||||
| #include "core/hle/service/am/applet_manager.h" | ||||
| #include "core/hle/service/am/service/application_accessor.h" | ||||
| #include "core/hle/service/am/service/application_creator.h" | ||||
| #include "core/hle/service/cmif_serialization.h" | ||||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| @@ -10,7 +14,7 @@ IApplicationCreator::IApplicationCreator(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IApplicationCreator"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "CreateApplication"}, | ||||
|         {0, D<&IApplicationCreator::CreateApplication>, "CreateApplication"}, | ||||
|         {1, nullptr, "PopLaunchRequestedApplication"}, | ||||
|         {10, nullptr, "CreateSystemApplication"}, | ||||
|         {100, nullptr, "PopFloatingApplicationForDevelopment"}, | ||||
| @@ -22,4 +26,10 @@ IApplicationCreator::IApplicationCreator(Core::System& system_) | ||||
| 
 | ||||
| IApplicationCreator::~IApplicationCreator() = default; | ||||
| 
 | ||||
| Result IApplicationCreator::CreateApplication( | ||||
|     Out<SharedPointer<IApplicationAccessor>> out_application_accessor, u64 application_id) { | ||||
|     LOG_ERROR(Service_NS, "called, application_id={:x}", application_id); | ||||
|     R_THROW(ResultUnknown); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::AM
 | ||||
| @@ -3,14 +3,21 @@ | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include "core/hle/service/cmif_types.h" | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| class IApplicationAccessor; | ||||
| struct Applet; | ||||
| 
 | ||||
| class IApplicationCreator final : public ServiceFramework<IApplicationCreator> { | ||||
| public: | ||||
|     explicit IApplicationCreator(Core::System& system_); | ||||
|     ~IApplicationCreator() override; | ||||
| 
 | ||||
| private: | ||||
|     Result CreateApplication(Out<SharedPointer<IApplicationAccessor>>, u64 application_id); | ||||
| }; | ||||
| 
 | ||||
| } // namespace Service::AM
 | ||||
| @@ -1,8 +1,8 @@ | ||||
| // SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later | ||||
|  | ||||
| #include "core/hle/service/am/application_creator.h" | ||||
| #include "core/hle/service/am/service/applet_common_functions.h" | ||||
| #include "core/hle/service/am/service/application_creator.h" | ||||
| #include "core/hle/service/am/service/audio_controller.h" | ||||
| #include "core/hle/service/am/service/common_state_getter.h" | ||||
| #include "core/hle/service/am/service/debug_functions.h" | ||||
| @@ -104,8 +104,9 @@ Result ISystemAppletProxy::GetLibraryAppletCreator( | ||||
|  | ||||
| Result ISystemAppletProxy::GetApplicationCreator( | ||||
|     Out<SharedPointer<IApplicationCreator>> out_application_creator) { | ||||
|     LOG_ERROR(Service_AM, "called"); | ||||
|     R_THROW(ResultUnknown); | ||||
|     LOG_DEBUG(Service_AM, "called"); | ||||
|     *out_application_creator = std::make_shared<IApplicationCreator>(system); | ||||
|     R_SUCCEED(); | ||||
| } | ||||
|  | ||||
| Result ISystemAppletProxy::GetAppletCommonFunctions( | ||||
|   | ||||
		Reference in New Issue
	
	Block a user