/usr/include/KF5/KContacts/kcontacts/secrecy.h is in libkf5contacts-dev 4:17.12.3-0ubuntu1.
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  | /*
    This file is part of the KContacts framework.
    Copyright (c) 2002 Tobias Koenig <tokoe@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) 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 KCONTACTS_SECRECY_H
#define KCONTACTS_SECRECY_H
#include "kcontacts_export.h"
#include <QVector>
#include <QSharedDataPointer>
namespace KContacts
{
class KCONTACTS_EXPORT Secrecy
{
    friend KCONTACTS_EXPORT QDataStream &operator<<(QDataStream &, const Secrecy &);
    friend KCONTACTS_EXPORT QDataStream &operator>>(QDataStream &, Secrecy &);
public:
    /**
     * Secrecy types
     *
     * @li Public       - for public access
     * @li Private      - only private access
     * @li Confidential - access for confidential persons
     */
    enum Type {
        Public,
        Private,
        Confidential,
        Invalid
    };
    /**
     * List of secrecy types.
     */
    typedef QVector<Type> TypeList;
    /**
     * Creates a new secrecy of the given type.
     *
     * @param type  The secrecy type. @see Type
     */
    Secrecy(Type type = Invalid);
    /**
     * Copy constructor.
     */
    Secrecy(const Secrecy &other);
    /**
     * Destroys the secrecy.
     */
    ~Secrecy();
    Secrecy &operator=(const Secrecy &other);
    bool operator==(const Secrecy &other) const;
    bool operator!=(const Secrecy &other) const;
    /**
     * Returns if the Secrecy object has a valid value.
     */
    bool isValid() const;
    /**
     * Sets the @p type.
     *
     * @param type The #Type of secrecy
     */
    void setType(Type type);
    /**
     * Returns the type.
     */
    Type type() const;
    /**
     * Returns a list of all available secrecy types.
     */
    static TypeList typeList();
    /**
     * Returns a translated label for a given secrecy @p type.
     */
    static QString typeLabel(Type type);
    /**
     * Returns a string representation of the secrecy.
     */
    QString toString() const;
private:
    class PrivateData;
    QSharedDataPointer<PrivateData> d;
};
/**
 * Serializes the @p secrecy object into the @p stream.
 */
KCONTACTS_EXPORT QDataStream &operator<<(QDataStream &stream, const Secrecy &secrecy);
/**
 * Initializes the @p secrecy object from the @p stream.
 */
KCONTACTS_EXPORT QDataStream &operator>>(QDataStream &stream, Secrecy &secrecy);
}
Q_DECLARE_TYPEINFO(KContacts::Secrecy, Q_MOVABLE_TYPE);
#endif
 |