blob: 0ff0c112e61a30a9a5fe7a0f55ca730b6f488fd0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
/*
* Copyright (C) 2005-2018 Team Kodi
* This file is part of Kodi - https://kodi.tv
*
* SPDX-License-Identifier: GPL-2.0-or-later
* See LICENSES/README.md for more information.
*/
#pragma once
#include "IDirectory.h"
#include <memory>
#include <vector>
class CFileItem;
class CFileItemList;
class CURL;
typedef std::shared_ptr<CFileItem> CFileItemPtr;
namespace ADDON
{
class IAddon;
using VECADDONS = std::vector<std::shared_ptr<IAddon>>;
} // namespace ADDON
namespace XFILE
{
/*!
\ingroup windows
\brief Get access to shares and it's directories.
*/
class CAddonsDirectory : public IDirectory
{
public:
CAddonsDirectory(void);
~CAddonsDirectory(void) override;
bool GetDirectory(const CURL& url, CFileItemList &items) override;
bool Create(const CURL& url) override { return true; }
bool Exists(const CURL& url) override { return true; }
bool AllowAll() const override { return true; }
/*! \brief Fetch script and plugin addons of a given content type
\param content the content type to fetch
\param addons the list of addons to fill with scripts and plugin content
\return true if content is valid, false if it's invalid.
*/
static bool GetScriptsAndPlugins(const std::string &content, ADDON::VECADDONS &addons);
/*! \brief Fetch scripts and plugins of a given content type
\param content the content type to fetch
\param items the list to fill with scripts and content
\return true if more than one item is found, false otherwise.
*/
static bool GetScriptsAndPlugins(const std::string &content, CFileItemList &items);
static void GenerateAddonListing(const CURL& path,
const ADDON::VECADDONS& addons,
CFileItemList& items,
const std::string& label);
static CFileItemPtr FileItemFromAddon(const std::shared_ptr<ADDON::IAddon>& addon,
const std::string& path,
bool folder = false);
/*! \brief Returns true if `path` is a path or subpath of the repository directory, otherwise false */
static bool IsRepoDirectory(const CURL& path);
private:
bool GetSearchResults(const CURL& path, CFileItemList &items);
};
}
|