You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
124 lines
3.4 KiB
124 lines
3.4 KiB
/* This file is part of the KDE libraries
|
|
Copyright (C) 2002 Carsten Pfeiffer <pfeiffer@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 version 2, as published by the Free Software Foundation.
|
|
|
|
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 KCLIPBOARD_H
|
|
#define KCLIPBOARD_H
|
|
|
|
#include <tqclipboard.h>
|
|
#include <tqmime.h>
|
|
#include <tqobject.h>
|
|
#include <tqstrlist.h>
|
|
#include "tdelibs_export.h"
|
|
|
|
/**
|
|
* This class is only for internal use.
|
|
*
|
|
* @short Allowing to automatically synchronize the X11 Clipboard and Selection buffers.
|
|
* @author Carsten Pfeiffer <pfeiffer@kde.org>
|
|
* @since 3.1
|
|
* @internal
|
|
*/
|
|
class TDECORE_EXPORT KClipboardSynchronizer : public TQObject
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/** Systray widget for manipulating the clipboard. */
|
|
friend class KlipperWidget;
|
|
friend class KApplication;
|
|
|
|
/**
|
|
* Returns the KClipboardSynchronizer singleton object.
|
|
* @return the KClipboardSynchronizer singleton object.
|
|
*/
|
|
static KClipboardSynchronizer *self();
|
|
|
|
/**
|
|
* Configures KClipboardSynchronizer to synchronize the Selection to Clipboard whenever
|
|
* it changes.
|
|
*
|
|
* Default is false.
|
|
* @see isSynchronizing
|
|
*/
|
|
static void setSynchronizing( bool sync );
|
|
|
|
/**
|
|
* Checks whether Clipboard and Selection will be synchronized upon changes.
|
|
* @returns whether Clipboard and Selection will be synchronized upon
|
|
* changes.
|
|
* @see setSynchronizing
|
|
*/
|
|
static bool isSynchronizing()
|
|
{
|
|
return s_sync;
|
|
}
|
|
|
|
/**
|
|
* Configures KClipboardSynchronizer to copy the Clipboard buffer to the Selection
|
|
* buffer whenever the Clipboard changes.
|
|
*
|
|
*
|
|
* @param enable true to enable implicit selection, false otherwise.
|
|
* Default is true.
|
|
* @see selectionSetting
|
|
*/
|
|
static void setReverseSynchronizing( bool enable );
|
|
|
|
/**
|
|
* Checks whether the Clipboard buffer will be copied to the Selection
|
|
* buffer upon changes.
|
|
* @returns whether the Clipboard buffer will be copied to the Selection
|
|
* buffer upon changes.
|
|
* @see setSelectionSetting
|
|
*/
|
|
static bool isReverseSynchronizing()
|
|
{
|
|
return s_reverse_sync;
|
|
}
|
|
|
|
|
|
protected:
|
|
~KClipboardSynchronizer();
|
|
|
|
private slots:
|
|
void slotSelectionChanged();
|
|
void slotClipboardChanged();
|
|
|
|
private:
|
|
KClipboardSynchronizer( TQObject *parent = 0, const char *name = 0L );
|
|
void setupSignals();
|
|
|
|
static void setClipboard( TQMimeSource* data, TQClipboard::Mode mode );
|
|
|
|
static KClipboardSynchronizer *s_self;
|
|
static bool s_sync;
|
|
static bool s_reverse_sync;
|
|
static bool s_blocked;
|
|
|
|
class MimeSource;
|
|
|
|
private:
|
|
// needed by klipper
|
|
enum Configuration { Synchronize = 1 };
|
|
// called by KApplication upon kipc message, invoked by klipper
|
|
static void newConfiguration( int config );
|
|
|
|
};
|
|
|
|
#endif // KCLIPBOARD_H
|