/* * Copyright (c) 2019 Adubbz * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "../lr_contentlocationresolver.hpp" #include "../lr_redirectonlylocationresolver.hpp" #include "lr_manager.hpp" namespace sts::lr::impl { namespace { BoundedMap, 5> g_location_resolvers; std::shared_ptr g_registered_location_resolver = nullptr; std::shared_ptr g_add_on_content_location_resolver = nullptr; HosMutex g_mutex; } Result OpenLocationResolver(Out> out, ncm::StorageId storage_id) { std::scoped_lock lk(g_mutex); auto resolver = g_location_resolvers.Find(storage_id); if (!resolver) { if (storage_id == ncm::StorageId::Host) { g_location_resolvers[storage_id] = std::make_shared(); } else { auto content_resolver = std::make_shared(storage_id); R_TRY(content_resolver->Refresh()); g_location_resolvers[storage_id] = std::move(content_resolver); } } /* Make a copy of the resolver for output. */ auto tmp_resolver = g_location_resolvers[storage_id]; out.SetValue(std::move(tmp_resolver)); return ResultSuccess; } Result OpenRegisteredLocationResolver(Out> out) { std::scoped_lock lk(g_mutex); if (!g_registered_location_resolver) { g_registered_location_resolver = std::make_shared(); } /* Make a copy of the resolver for output. */ auto tmp_resolver = g_registered_location_resolver; out.SetValue(std::move(tmp_resolver)); return ResultSuccess; } Result RefreshLocationResolver(ncm::StorageId storage_id) { std::scoped_lock lk(g_mutex); auto resolver = g_location_resolvers.Find(storage_id); if (!resolver) { return ResultLrUnknownStorageId; } (*resolver)->Refresh(); return ResultSuccess; } Result OpenAddOnContentLocationResolver(Out> out) { std::scoped_lock lk(g_mutex); if (!g_add_on_content_location_resolver) { g_add_on_content_location_resolver = std::make_shared(); } /* Make a copy of the resolver for output. */ auto tmp_resolver = g_add_on_content_location_resolver; out.SetValue(std::move(tmp_resolver)); return ResultSuccess; } }