2 * SPDX-FileCopyrightText: 2011 Janardhan Reddy <annapareddyjanardhanreddy@gmail.com>
4 * SPDX-License-Identifier: GPL-2.0-or-later
7 #ifndef KFILEITEMMODELFILTER_H
8 #define KFILEITEMMODELFILTER_H
10 #include "dolphin_export.h"
12 #include <QStringList>
15 class QRegularExpression
;
18 * @brief Allows to check whether an item of the KFileItemModel
19 * matches with a set filter-string.
21 * Currently the filter is only checked for the KFileItem::text()
22 * property of the KFileItem, but this might get extended in
25 class DOLPHIN_EXPORT KFileItemModelFilter
28 KFileItemModelFilter();
29 virtual ~KFileItemModelFilter();
32 * Sets the pattern that is used for a comparison with the item
33 * in KFileItemModelFilter::matches(). Per default the pattern
34 * defines a sub-string. As soon as the pattern contains at least
35 * a '*', '?' or '[' the pattern represents a regular expression.
37 void setPattern(const QString
&pattern
);
38 QString
pattern() const;
41 * Set the list of mimetypes that are used for comparison with the
42 * item in KFileItemModelFilter::matchesMimeType.
44 void setMimeTypes(const QStringList
&types
);
45 QStringList
mimeTypes() const;
48 * Set the list of mimetypes that are used for comparison and excluded with the
49 * item in KFileItemModelFilter::matchesMimeType.
51 void setExcludeMimeTypes(const QStringList
&types
);
52 QStringList
excludeMimeTypes() const;
55 * @return True if either the pattern or mimetype filters has been set.
57 bool hasSetFilters() const;
60 * @return True if the item matches with the pattern defined by
61 * @ref setPattern() or @ref setMimeTypes
63 bool matches(const KFileItem
&item
) const;
67 * @return True if item matches pattern set by @ref setPattern.
69 bool matchesPattern(const KFileItem
&item
) const;
72 * @return True if item matches mimetypes set by @ref setMimeTypes.
74 bool matchesType(const KFileItem
&item
) const;
76 bool m_useRegExp
; // If true, m_regExp is used for filtering,
77 // otherwise m_lowerCaseFilter is used.
78 QRegularExpression
*m_regExp
;
79 QString m_lowerCasePattern
; // Lowercase version of m_filter for
80 // faster comparison in matches().
81 QString m_pattern
; // Property set by setPattern().
82 QStringList m_mimeTypes
; // Property set by setMimeTypes()
83 QStringList m_excludeMimeTypes
; // Property set by setExcludeMimeTypes()