/usr/include/KF5/messageviewer/editorwatcher.h is in libkf5messageviewer-dev 4:16.04.3-3~deb9u1.
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 | /*
Copyright (c) 2007 Volker Krause <vkrause@kde.org>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifndef MESSAGEVIEWER_EDITORWATCHER_H
#define MESSAGEVIEWER_EDITORWATCHER_H
#include "messageviewer_export.h"
#include <qurl.h>
#include <qobject.h>
#include <qtimer.h>
#include <QTime>
class KProcess;
namespace MessageViewer
{
/**
Starts an editor for the given URL and emits an signal when
editing has been finished. Both, the editor process as well
as the edited file are watched to work with as many as possible
editors.
*/
class MESSAGEVIEWER_EXPORT EditorWatcher : public QObject
{
Q_OBJECT
public:
enum OpenWithOption {
OpenWithDialog,
NoOpenWithDialog
};
enum ErrorEditorWatcher {
Unknown = 0,
Canceled,
NoServiceFound,
CannotStart,
NoError
};
/**
* Constructs an EditorWatcher.
* @param parent the parent object of this EditorWatcher, which will take care of deleting
* this EditorWatcher if the parent is deleted.
* @param parentWidget the parent widget of this EditorWatcher, which will be used as the parent
* widget for message dialogs.
*/
EditorWatcher(const QUrl &url, const QString &mimeType, OpenWithOption option,
QObject *parent, QWidget *parentWidget);
~EditorWatcher();
ErrorEditorWatcher start();
bool fileChanged() const;
QUrl url() const;
Q_SIGNALS:
void editDone(MessageViewer::EditorWatcher *watcher);
private Q_SLOTS:
void editorExited();
void inotifyEvent();
void checkEditDone();
private:
QUrl mUrl;
QString mMimeType;
QTimer mTimer;
QTime mEditTime;
KProcess *mEditor;
QWidget *mParentWidget;
int mInotifyFd;
int mInotifyWatch;
OpenWithOption mOpenWithOption;
bool mHaveInotify;
bool mFileOpen;
bool mEditorRunning;
bool mFileModified;
bool mDone;
};
}
#endif
|