/usr/include/kfileitemlistproperties.h is in kdelibs5-dev 4:4.8.5-0ubuntu0.6.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 | /* This file is part of the KDE project
Copyright (C) 2008 by Peter Penz <peter.penz@gmx.at>
Copyright (C) 2008 by George Goldberg <grundleborg@googlemail.com>
Copyright 2009 David Faure <faure@kde.org>
This library is free software; you can redistribute it and/or modify
it under the terms of the GNU Library General Public License as published
by the Free Software Foundation; either version 2 of the License or
( at your option ) version 3 or, at the discretion of KDE e.V.
( which shall act as a proxy as in section 14 of the GPLv3 ), any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#ifndef KFILEITEMLISTPROPERTIES_H
#define KFILEITEMLISTPROPERTIES_H
#include <kio/kio_export.h>
#include <kurl.h>
#include <QtCore/QSharedDataPointer>
class KFileItemListPropertiesPrivate;
class KFileItemList;
/**
* @brief Provides information about the common properties of a group of
* KFileItem objects.
*
* Given a list of KFileItems, this class can determine (and cache) the common
* mimetype for all items, whether all items are directories, whether all items
* are readable, writable, etc.
* As soon as one file item does not support a specific capability (read, write etc.),
* it is marked as unsupported for all items.
*
* This class is implicitly shared, which means it can be used as a value and
* copied around at almost no cost.
*
* @since 4.3
*/
class KIO_EXPORT KFileItemListProperties
{
public:
/**
* @brief Default constructor. Use setItems to specify the items.
*/
KFileItemListProperties();
/**
* @brief Constructor that takes a KFileItemList and sets the capabilities
* supported by all the FileItems as true.
* @param items The list of items that are to have their supported
* capabilities checked.
*/
KFileItemListProperties(const KFileItemList& items);
/**
* @brief Copy constructor
*/
KFileItemListProperties(const KFileItemListProperties&);
/**
* @brief Destructor
*/
virtual ~KFileItemListProperties();
/**
* @brief Assignment operator
*/
KFileItemListProperties& operator=(const KFileItemListProperties& other);
/**
* Sets the items that are to have their supported capabilities checked.
*/
void setItems(const KFileItemList& items);
/**
* @brief Check if reading capability is supported
* @return true if all the FileItems can be read, otherwise false.
*/
bool supportsReading() const;
/**
* @brief Check if deleting capability is supported
* @return true if all the FileItems can be deleted, otherwise false.
*/
bool supportsDeleting() const;
/**
* @brief Check if writing capability is supported
* (file managers use this mostly for directories)
* @return true if all the FileItems can be written to, otherwise false.
*/
bool supportsWriting() const;
/**
* @brief Check if moving capability is supported
* @return true if all the FileItems can be moved, otherwise false.
*/
bool supportsMoving() const;
/**
* @brief Check if files are local
* @return true if all the FileItems are local, otherwise there is one or more
* remote file, so false.
*/
bool isLocal() const;
/**
* List of fileitems passed to the constructor or to setItems().
*/
KFileItemList items() const;
/**
* List of urls, gathered from the fileitems
*/
KUrl::List urlList() const;
/**
* @return true if all items are directories
*/
bool isDirectory() const;
/**
* @return the mimetype of all items, if they all have the same, otherwise empty
*/
QString mimeType() const;
/**
* @return the mimetype group (e.g. "text") of all items, if they all have the same, otherwise empty
*/
QString mimeGroup() const;
private:
/** @brief d-pointer */
QSharedDataPointer<KFileItemListPropertiesPrivate> d;
};
#endif /* KFILEITEMLISTPROPERTIES_H */
|