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 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
/*
* 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 <functional>
#include <memory>
#include <string>
class CFileItem;
namespace XFILE
{
/*!
\ingroup filesystem
\brief Wrappers for \e IDirectory
*/
class CDirectory
{
public:
CDirectory(void);
virtual ~CDirectory(void);
class CHints
{
public:
std::string mask;
int flags = DIR_FLAG_DEFAULTS;
};
static bool GetDirectory(const CURL& url
, CFileItemList &items
, const std::string &strMask
, int flags);
static bool GetDirectory(const CURL& url,
const std::shared_ptr<IDirectory>& pDirectory,
CFileItemList& items,
const CHints& hints);
static bool GetDirectory(const CURL& url
, CFileItemList &items
, const CHints &hints);
static bool Create(const CURL& url);
static bool Exists(const CURL& url, bool bUseCache = true);
static bool Remove(const CURL& url);
static bool RemoveRecursive(const CURL& url);
static bool GetDirectory(const std::string& strPath
, CFileItemList &items
, const std::string &strMask
, int flags);
static bool GetDirectory(const std::string& strPath,
const std::shared_ptr<IDirectory>& pDirectory,
CFileItemList& items,
const std::string& strMask,
int flags);
static bool GetDirectory(const std::string& strPath
, CFileItemList &items
, const CHints &hints);
using DirectoryEnumerationCallback = std::function<void(const std::shared_ptr<CFileItem>& item)>;
using DirectoryFilter = std::function<bool(const std::shared_ptr<CFileItem>& folder)>;
/*!
* \brief Enumerates files and folders in and below a directory. Every applicable gets passed to the callback.
*
* \param path Directory to enumerate
* \param callback Files and folders matching the criteria are passed to this function
* \param filter Only folders are passed to this function. If it return false the folder and everything below it will skipped from the enumeration
* \param fileOnly If true only files are passed to \p callback. Doesn't affect \p filter
* \param mask Only files matching this mask are passed to \p callback
* \param flags See \ref DIR_FLAG enum
*/
static bool EnumerateDirectory(
const std::string& path,
const DirectoryEnumerationCallback& callback,
const DirectoryFilter& filter = [](const std::shared_ptr<CFileItem>&) { return true; },
bool fileOnly = false,
const std::string& mask = "",
int flags = DIR_FLAG_DEFAULTS);
static bool Create(const std::string& strPath);
static bool Exists(const std::string& strPath, bool bUseCache = true);
static bool Remove(const std::string& strPath);
static bool RemoveRecursive(const std::string& strPath);
/*! \brief Filter files that act like directories from the list, replacing them with their directory counterparts
\param items The item list to filter
\param mask The mask to apply when filtering files
\param expandImages True to include disc images in file directory expansion
*/
static void FilterFileDirectories(CFileItemList &items, const std::string &mask,
bool expandImages=false);
};
}
|