[videodb] remove unused seasons table from episode_view
[xbmc.git] / xbmc / addons / Service.cpp
blobe9b6b402ed25ed778f303c143bc86d36113cb479
1 /*
2 * Copyright (C) 2005-2018 Team Kodi
3 * This file is part of Kodi - https://kodi.tv
5 * SPDX-License-Identifier: GPL-2.0-or-later
6 * See LICENSES/README.md for more information.
7 */
8 #include "Service.h"
10 #include "addons/AddonManager.h"
11 #include "addons/addoninfo/AddonType.h"
12 #include "interfaces/generic/ScriptInvocationManager.h"
13 #include "utils/StringUtils.h"
14 #include "utils/log.h"
16 #include <mutex>
19 namespace ADDON
22 CService::CService(const AddonInfoPtr& addonInfo) : CAddon(addonInfo, AddonType::SERVICE)
26 CServiceAddonManager::CServiceAddonManager(CAddonMgr& addonMgr) :
27 m_addonMgr(addonMgr)
31 CServiceAddonManager::~CServiceAddonManager()
33 m_addonMgr.Events().Unsubscribe(this);
34 m_addonMgr.UnloadEvents().Unsubscribe(this);
37 void CServiceAddonManager::OnEvent(const ADDON::AddonEvent& event)
39 if (typeid(event) == typeid(ADDON::AddonEvents::Enabled))
41 Start(event.addonId);
43 else if (typeid(event) == typeid(ADDON::AddonEvents::ReInstalled))
45 Stop(event.addonId);
46 Start(event.addonId);
48 else if (typeid(event) == typeid(ADDON::AddonEvents::Disabled) ||
49 typeid(event) == typeid(ADDON::AddonEvents::Unload))
51 Stop(event.addonId);
55 void CServiceAddonManager::Start()
57 m_addonMgr.Events().Subscribe(this, &CServiceAddonManager::OnEvent);
58 m_addonMgr.UnloadEvents().Subscribe(this, &CServiceAddonManager::OnEvent);
59 VECADDONS addons;
60 if (m_addonMgr.GetAddons(addons, AddonType::SERVICE))
62 for (const auto& addon : addons)
64 Start(addon);
69 void CServiceAddonManager::Start(const std::string& addonId)
71 AddonPtr addon;
72 if (m_addonMgr.GetAddon(addonId, addon, AddonType::SERVICE, OnlyEnabled::CHOICE_YES))
74 Start(addon);
78 void CServiceAddonManager::Start(const AddonPtr& addon)
80 std::unique_lock<CCriticalSection> lock(m_criticalSection);
81 if (m_services.find(addon->ID()) != m_services.end())
83 CLog::Log(LOGDEBUG, "CServiceAddonManager: {} already started.", addon->ID());
84 return;
87 if (StringUtils::EndsWith(addon->LibPath(), ".py"))
89 CLog::Log(LOGDEBUG, "CServiceAddonManager: starting {}", addon->ID());
90 auto handle = CScriptInvocationManager::GetInstance().ExecuteAsync(addon->LibPath(), addon);
91 if (handle == -1)
93 CLog::Log(LOGERROR, "CServiceAddonManager: {} failed to start", addon->ID());
94 return;
96 m_services[addon->ID()] = handle;
100 void CServiceAddonManager::Stop()
102 m_addonMgr.Events().Unsubscribe(this);
103 m_addonMgr.UnloadEvents().Unsubscribe(this);
104 std::unique_lock<CCriticalSection> lock(m_criticalSection);
105 for (const auto& service : m_services)
107 Stop(service);
109 m_services.clear();
112 void CServiceAddonManager::Stop(const std::string& addonId)
114 std::unique_lock<CCriticalSection> lock(m_criticalSection);
115 auto it = m_services.find(addonId);
116 if (it != m_services.end())
118 Stop(*it);
119 m_services.erase(it);
123 void CServiceAddonManager::Stop(const std::map<std::string, int>::value_type& service)
125 CLog::Log(LOGDEBUG, "CServiceAddonManager: stopping {}.", service.first);
126 if (!CScriptInvocationManager::GetInstance().Stop(service.second))
128 CLog::Log(LOGINFO, "CServiceAddonManager: failed to stop {} (may have ended)", service.first);