/usr/include/KF5/KWayland/Server/resource.h is in libkf5wayland-dev 4:5.44.0-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 | /********************************************************************
Copyright 2014 Martin Gräßlin <mgraesslin@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) version 3, or any
later version accepted by the membership of KDE e.V. (or its
successor approved by the membership of KDE e.V.), which shall
act as a proxy defined in Section 6 of version 3 of the license.
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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library. If not, see <http://www.gnu.org/licenses/>.
*********************************************************************/
#ifndef WAYLAND_SERVER_RESOURCE_H
#define WAYLAND_SERVER_RESOURCE_H
#include <QObject>
#include <KWayland/Server/kwaylandserver_export.h>
struct wl_client;
struct wl_resource;
namespace KWayland
{
namespace Server
{
class ClientConnection;
class Global;
/**
* @brief Represents a bound Resource.
*
* A Resource normally gets created by a @link Global @endlink.
*
* The Resource is a base class for all specific resources and provides
* access to various common aspects.
**/
class KWAYLANDSERVER_EXPORT Resource : public QObject
{
Q_OBJECT
public:
virtual ~Resource();
void create(ClientConnection *client, quint32 version, quint32 id);
/**
* @returns the native wl_resource this Resource was created for.
**/
wl_resource *resource();
/**
* @returns The ClientConnection for which the Resource was created.
**/
ClientConnection *client();
/**
* @returns The Global which created the Resource.
**/
Global *global();
/**
* @returns the native parent wl_resource, e.g. the wl_resource bound on the Global
**/
wl_resource *parentResource() const;
/**
* @returns The id of this Resource if it is created, otherwise @c 0.
*
* This is a convenient wrapper for wl_resource_get_id.
* @since 5.3
**/
quint32 id() const;
Q_SIGNALS:
/**
* This signal is emitted when the client unbound this Resource.
* The Resource will be deleted in the next event cycle after this event.
* @since 5.24
**/
void unbound();
/**
* This signal is emitted when the client is in the process of unbinding the Resource.
* In opposite to @link{unbound} the @link{resource} is still valid and allows to perform
* cleanup tasks. Example: send a keyboard leave for the Surface which is in the process of
* getting destroyed.
*
* @see unbound
* @since 5.37
**/
void aboutToBeUnbound();
protected:
class Private;
explicit Resource(Private *d, QObject *parent = nullptr);
QScopedPointer<Private> d;
};
}
}
#endif
|