From 52b80d231cb3e1b234f1fcfe00cc1577d42cb966 Mon Sep 17 00:00:00 2001 From: Zach Hilman Date: Sun, 26 May 2019 20:36:54 -0400 Subject: ncm: Implement LR OpenAddOnContentLocationResolver (2) Returns an object of type IAddOnContentLocationResolver for the provided StorageId. --- src/core/hle/service/ncm/ncm.cpp | 45 +++++++++++++++++++--------------------- 1 file changed, 21 insertions(+), 24 deletions(-) (limited to 'src/core/hle/service/ncm') diff --git a/src/core/hle/service/ncm/ncm.cpp b/src/core/hle/service/ncm/ncm.cpp index c59bcc2a7..b405a4b66 100644 --- a/src/core/hle/service/ncm/ncm.cpp +++ b/src/core/hle/service/ncm/ncm.cpp @@ -4,17 +4,19 @@ #include +#include "core/file_sys/romfs_factory.h" +#include "core/hle/ipc_helpers.h" #include "core/hle/service/ncm/ncm.h" #include "core/hle/service/service.h" #include "core/hle/service/sm/sm.h" namespace Service::NCM { -class LocationResolver final : public ServiceFramework { class ILocationResolver final : public ServiceFramework { public: explicit ILocationResolver(FileSys::StorageId id) : ServiceFramework{"ILocationResolver"}, storage(id) { + // clang-format off static const FunctionInfo functions[] = { {0, nullptr, "ResolveProgramPath"}, {1, nullptr, "RedirectProgramPath"}, @@ -37,6 +39,7 @@ public: {18, nullptr, ""}, {19, nullptr, ""}, }; + // clang-format on RegisterHandlers(functions); } @@ -48,6 +51,7 @@ private: class IRegisteredLocationResolver final : public ServiceFramework { public: explicit IRegisteredLocationResolver() : ServiceFramework{"IRegisteredLocationResolver"} { + // clang-format off static const FunctionInfo functions[] = { {0, nullptr, "ResolveProgramPath"}, {1, nullptr, "RegisterProgramPath"}, @@ -59,13 +63,27 @@ public: {7, nullptr, "RedirectHtmlDocumentPath"}, {8, nullptr, ""}, }; + // clang-format on RegisterHandlers(functions); } }; +class IAddOnContentLocationResolver final : public ServiceFramework { public: - explicit LocationResolver() : ServiceFramework{"lr"} { + explicit IAddOnContentLocationResolver() : ServiceFramework{"IAddOnContentLocationResolver"} { + // clang-format off + static const FunctionInfo functions[] = { + {0, nullptr, "ResolveAddOnContentPath"}, + {1, nullptr, "RegisterAddOnContentStorage"}, + {2, nullptr, "UnregisterAllAddOnContentPath"}, + }; + // clang-format on + + RegisterHandlers(functions); + } +}; + class LR final : public ServiceFramework { public: explicit LR() : ServiceFramework{"lr"} { @@ -80,27 +98,6 @@ public: RegisterHandlers(functions); } - -private: - void OpenLocationResolver(Kernel::HLERequestContext& ctx) { - IPC::RequestParser rp{ctx}; - const auto id = rp.PopRaw(); - - LOG_DEBUG(Service_NCM, "called, id={:02X}", static_cast(id)); - - IPC::ResponseBuilder rb{ctx, 2, 0, 1}; - rb.Push(RESULT_SUCCESS); - rb.PushIpcInterface(std::make_shared(id)); - } - - void OpenRegisteredLocationResolver(Kernel::HLERequestContext& ctx) { - LOG_DEBUG(Service_NCM, "called"); - - IPC::ResponseBuilder rb{ctx, 2, 0, 1}; - rb.Push(RESULT_SUCCESS); - rb.PushIpcInterface(std::make_shared()); - } - }; class NCM final : public ServiceFramework { @@ -129,7 +126,7 @@ public: }; void InstallInterfaces(SM::ServiceManager& sm) { - std::make_shared()->InstallAsService(sm); + std::make_shared()->InstallAsService(sm); std::make_shared()->InstallAsService(sm); } -- cgit v1.2.3