summaryrefslogtreecommitdiffstats
path: root/src/core/hle/service/bcat/news/service_creator.cpp
diff options
context:
space:
mode:
authorNarr the Reg <juangerman-13@hotmail.com>2024-02-09 17:31:35 +0100
committerNarr the Reg <juangerman-13@hotmail.com>2024-02-10 07:23:23 +0100
commit816d03f7d96278c5b3d2604f94901270b10d4167 (patch)
tree3ef3a65b365de1217d60b9aad6a6d063e800e07b /src/core/hle/service/bcat/news/service_creator.cpp
parentservice: bcat: Implement news interfaces (diff)
downloadyuzu-816d03f7d96278c5b3d2604f94901270b10d4167.tar
yuzu-816d03f7d96278c5b3d2604f94901270b10d4167.tar.gz
yuzu-816d03f7d96278c5b3d2604f94901270b10d4167.tar.bz2
yuzu-816d03f7d96278c5b3d2604f94901270b10d4167.tar.lz
yuzu-816d03f7d96278c5b3d2604f94901270b10d4167.tar.xz
yuzu-816d03f7d96278c5b3d2604f94901270b10d4167.tar.zst
yuzu-816d03f7d96278c5b3d2604f94901270b10d4167.zip
Diffstat (limited to 'src/core/hle/service/bcat/news/service_creator.cpp')
-rw-r--r--src/core/hle/service/bcat/news/service_creator.cpp64
1 files changed, 64 insertions, 0 deletions
diff --git a/src/core/hle/service/bcat/news/service_creator.cpp b/src/core/hle/service/bcat/news/service_creator.cpp
new file mode 100644
index 000000000..d5ba5dff7
--- /dev/null
+++ b/src/core/hle/service/bcat/news/service_creator.cpp
@@ -0,0 +1,64 @@
+// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
+// SPDX-License-Identifier: GPL-3.0-or-later
+
+#include "core/hle/service/bcat/news/newly_arrived_event_holder.h"
+#include "core/hle/service/bcat/news/news_data_service.h"
+#include "core/hle/service/bcat/news/news_database_service.h"
+#include "core/hle/service/bcat/news/news_service.h"
+#include "core/hle/service/bcat/news/overwrite_event_holder.h"
+#include "core/hle/service/bcat/news/service_creator.h"
+#include "core/hle/service/cmif_serialization.h"
+
+namespace Service::News {
+
+IServiceCreator::IServiceCreator(Core::System& system_, u32 permissions_, const char* name_)
+ : ServiceFramework{system_, name_}, permissions{permissions_} {
+ // clang-format off
+ static const FunctionInfo functions[] = {
+ {0, C<&IServiceCreator::CreateNewsService>, "CreateNewsService"},
+ {1, C<&IServiceCreator::CreateNewlyArrivedEventHolder>, "CreateNewlyArrivedEventHolder"},
+ {2, C<&IServiceCreator::CreateNewsDataService>, "CreateNewsDataService"},
+ {3, C<&IServiceCreator::CreateNewsDatabaseService>, "CreateNewsDatabaseService"},
+ {4, C<&IServiceCreator::CreateOverwriteEventHolder>, "CreateOverwriteEventHolder"},
+ };
+ // clang-format on
+
+ RegisterHandlers(functions);
+}
+
+IServiceCreator::~IServiceCreator() = default;
+
+Result IServiceCreator::CreateNewsService(OutInterface<INewsService> out_interface) {
+ LOG_INFO(Service_BCAT, "called");
+ *out_interface = std::make_shared<INewsService>(system);
+ R_SUCCEED();
+}
+
+Result IServiceCreator::CreateNewlyArrivedEventHolder(
+ OutInterface<INewlyArrivedEventHolder> out_interface) {
+ LOG_INFO(Service_BCAT, "called");
+ *out_interface = std::make_shared<INewlyArrivedEventHolder>(system);
+ R_SUCCEED();
+}
+
+Result IServiceCreator::CreateNewsDataService(OutInterface<INewsDataService> out_interface) {
+ LOG_INFO(Service_BCAT, "called");
+ *out_interface = std::make_shared<INewsDataService>(system);
+ R_SUCCEED();
+}
+
+Result IServiceCreator::CreateNewsDatabaseService(
+ OutInterface<INewsDatabaseService> out_interface) {
+ LOG_INFO(Service_BCAT, "called");
+ *out_interface = std::make_shared<INewsDatabaseService>(system);
+ R_SUCCEED();
+}
+
+Result IServiceCreator::CreateOverwriteEventHolder(
+ OutInterface<IOverwriteEventHolder> out_interface) {
+ LOG_INFO(Service_BCAT, "called");
+ *out_interface = std::make_shared<IOverwriteEventHolder>(system);
+ R_SUCCEED();
+}
+
+} // namespace Service::News