1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * @file FileFilterMgr.h
5 * @brief Declaration file for FileFilterMgr
10 #include "UnicodeString.h"
11 #include "FileFilter.h"
14 * @brief Return values for many filter functions.
18 FILTER_OK = 0, /**< Success */
19 FILTER_ERROR_FILEACCESS, /**< File could not be opened etc. */
20 FILTER_NOTFOUND, /**< Filter not found */
24 * @brief File filter manager for handling filefilters.
26 * The FileFilterMgr loads a collection of named file filters from disk,
27 * and provides lookup access by name, or array access by index, to these
28 * named filters. It also provides test functions for actually using the
31 * We are using PCRE for regular expressions. Nice thing in PCRE is it supports
32 * UTF-8 unicode, unlike many other libs. For ANSI builds we use just ansi
33 * strings, and for unicode we must first convert strings to UTF-8.
41 // Reload filter array from specified directory (passed to CFileFind)
42 void LoadFromDirectory(const String& dir, const String& szPattern, const String& szExt);
43 // Reload an edited filter
44 int ReloadFilterFromDisk(FileFilter * pfilter);
45 int ReloadFilterFromDisk(const String& szFullPath);
46 // Load a filter from a string
47 void LoadFilterString(const String& szFilterString);
48 int AddFilter(const String& szFilterFile);
49 void RemoveFilter(const String& szFilterFile);
51 // access to array of filters
52 int GetFilterCount() const { return (int) m_filters.size(); }
53 String GetFilterName(int i) const;
54 String GetFilterName(const FileFilter *pFilter) const;
55 String GetFilterPath(int i) const;
56 String GetFilterDesc(int i) const;
57 String GetFilterDesc(const FileFilter *pFilter) const;
58 FileFilter * GetFilterByPath(const String& szFilterName);
59 String GetFullpath(FileFilter * pfilter) const;
61 // methods to actually use filter
62 bool TestFileNameAgainstFilter(const FileFilter * pFilter, const String& szFileName) const;
63 bool TestDirNameAgainstFilter(const FileFilter * pFilter, const String& szDirName) const;
65 void DeleteAllFilters();
67 // Implementation methods
69 // Clear the list of known filters
70 // Load a filter from a file (if syntax is valid)
71 FileFilter * LoadFilterFile(const String& szFilepath, int & errorcode);
73 // Implementation data
75 std::vector<FileFilterPtr> m_filters; /*< List of filters loaded */
79 bool TestAgainstRegList(const std::vector<FileFilterElementPtr> *filterList, const String& szTest);
80 void EmptyFilterList(std::vector<FileFilterElementPtr> *filterList);
83 * @brief Return name of filter.
85 * @param [in] i Index of filter.
86 * @return Name of filter in given index.
88 inline String FileFilterMgr::GetFilterName(int i) const
90 return m_filters[i]->name;
94 * @brief Return name of filter.
95 * @param [in] pFilter Filter to get name for.
96 * @return Given filter's name.
98 inline String FileFilterMgr::GetFilterName(const FileFilter *pFilter) const
100 return pFilter->name;
104 * @brief Return description of filter.
106 * @param [in] i Index of filter.
107 * @return Description of filter in given index.
109 inline String FileFilterMgr::GetFilterDesc(int i) const
111 return m_filters[i]->description;
115 * @brief Return description of filter.
116 * @param [in] pFilter Filter to get description for.
117 * @return Given filter's description.
119 inline String FileFilterMgr::GetFilterDesc(const FileFilter *pFilter) const
121 return pFilter->description;
125 * @brief Return full path to filter.
127 * @param [in] i Index of filter.
128 * @return Full path of filter in given index.
130 inline String FileFilterMgr::GetFilterPath(int i) const
132 return m_filters[i]->fullpath;
136 * @brief Return full path to filter.
138 * @param [in] pFilter Pointer to filter.
139 * @return Full path of filter.
141 inline String FileFilterMgr::GetFullpath(FileFilter * pfilter) const
143 return pfilter->fullpath;