2002-08-02 23:57:46 +04:00
|
|
|
/*
|
|
|
|
* synergy -- mouse and keyboard sharing utility
|
|
|
|
* Copyright (C) 2002 Chris Schoeneman
|
|
|
|
*
|
|
|
|
* This package is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* found in the file COPYING that should have accompanied this file.
|
|
|
|
*
|
|
|
|
* This package 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.
|
|
|
|
*/
|
|
|
|
|
2002-07-10 01:22:31 +04:00
|
|
|
#ifndef ICLIENT_H
|
|
|
|
#define ICLIENT_H
|
|
|
|
|
2004-02-14 17:04:36 +03:00
|
|
|
#include "IScreen.h"
|
2002-07-10 01:22:31 +04:00
|
|
|
#include "ClipboardTypes.h"
|
|
|
|
#include "KeyTypes.h"
|
|
|
|
#include "MouseTypes.h"
|
2002-12-23 16:55:21 +03:00
|
|
|
#include "OptionTypes.h"
|
2002-07-10 01:22:31 +04:00
|
|
|
#include "CString.h"
|
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Client interface
|
|
|
|
/*!
|
|
|
|
This interface defines the methods necessary for the server to
|
|
|
|
communicate with a client.
|
|
|
|
*/
|
2004-02-14 17:04:36 +03:00
|
|
|
class IClient : public IScreen {
|
2002-07-10 01:22:31 +04:00
|
|
|
public:
|
2002-07-29 20:07:26 +04:00
|
|
|
//! @name manipulators
|
|
|
|
//@{
|
2002-07-10 01:22:31 +04:00
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Enter screen
|
|
|
|
/*!
|
2004-02-14 17:04:36 +03:00
|
|
|
Enter the screen. The cursor should be warped to \p xAbs,yAbs.
|
|
|
|
\p mask is the expected toggle button state and the client should
|
|
|
|
update its state to match. \p forScreensaver is true iff the
|
|
|
|
screen is being entered because the screen saver is starting.
|
|
|
|
Subsequent clipboard events should report \p seqNum.
|
2002-07-29 20:07:26 +04:00
|
|
|
*/
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual void enter(SInt32 xAbs, SInt32 yAbs,
|
|
|
|
UInt32 seqNum, KeyModifierMask mask,
|
2002-07-14 02:00:38 +04:00
|
|
|
bool forScreensaver) = 0;
|
2002-07-10 01:22:31 +04:00
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Leave screen
|
|
|
|
/*!
|
|
|
|
Leave the screen. Return false iff the user may not leave the
|
|
|
|
client's screen (because, for example, a button is down).
|
|
|
|
*/
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual bool leave() = 0;
|
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Set clipboard
|
|
|
|
/*!
|
|
|
|
Update the client's clipboard. This implies that the client's
|
|
|
|
clipboard is now up to date. If the client's clipboard was
|
2002-07-30 18:59:36 +04:00
|
|
|
already known to be up to date then this may do nothing. \c data
|
|
|
|
has marshalled clipboard data.
|
2002-07-29 20:07:26 +04:00
|
|
|
*/
|
2004-02-15 20:32:11 +03:00
|
|
|
virtual void setClipboard(ClipboardID, const IClipboard*) = 0;
|
2002-07-10 01:22:31 +04:00
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Grab clipboard
|
|
|
|
/*!
|
|
|
|
Grab (i.e. take ownership of) the client's clipboard. Since this
|
|
|
|
is called when another client takes ownership of the clipboard it
|
|
|
|
implies that the client's clipboard is out of date.
|
|
|
|
*/
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual void grabClipboard(ClipboardID) = 0;
|
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Mark clipboard dirty
|
|
|
|
/*!
|
|
|
|
Mark the client's clipboard as dirty (out of date) or clean (up to
|
|
|
|
date).
|
|
|
|
*/
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual void setClipboardDirty(ClipboardID, bool dirty) = 0;
|
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Notify of key press
|
|
|
|
/*!
|
|
|
|
Synthesize key events to generate a press of key \c id. If possible
|
2003-04-27 21:01:14 +04:00
|
|
|
match the given modifier mask. The KeyButton identifies the physical
|
|
|
|
key on the server that generated this key down. The client must
|
|
|
|
ensure that a key up or key repeat that uses the same KeyButton will
|
|
|
|
synthesize an up or repeat for the same client key synthesized by
|
|
|
|
keyDown().
|
2002-07-29 20:07:26 +04:00
|
|
|
*/
|
2003-04-27 21:01:14 +04:00
|
|
|
virtual void keyDown(KeyID id, KeyModifierMask, KeyButton) = 0;
|
2002-07-29 20:07:26 +04:00
|
|
|
|
|
|
|
//! Notify of key repeat
|
|
|
|
/*!
|
|
|
|
Synthesize key events to generate a press and release of key \c id
|
|
|
|
\c count times. If possible match the given modifier mask.
|
|
|
|
*/
|
2003-04-27 21:01:14 +04:00
|
|
|
virtual void keyRepeat(KeyID id, KeyModifierMask,
|
|
|
|
SInt32 count, KeyButton) = 0;
|
2002-07-29 20:07:26 +04:00
|
|
|
|
|
|
|
//! Notify of key release
|
|
|
|
/*!
|
|
|
|
Synthesize key events to generate a release of key \c id. If possible
|
|
|
|
match the given modifier mask.
|
|
|
|
*/
|
2003-04-27 21:01:14 +04:00
|
|
|
virtual void keyUp(KeyID id, KeyModifierMask, KeyButton) = 0;
|
2002-07-29 20:07:26 +04:00
|
|
|
|
|
|
|
//! Notify of mouse press
|
|
|
|
/*!
|
|
|
|
Synthesize mouse events to generate a press of mouse button \c id.
|
|
|
|
*/
|
|
|
|
virtual void mouseDown(ButtonID id) = 0;
|
|
|
|
|
|
|
|
//! Notify of mouse release
|
|
|
|
/*!
|
|
|
|
Synthesize mouse events to generate a release of mouse button \c id.
|
|
|
|
*/
|
|
|
|
virtual void mouseUp(ButtonID id) = 0;
|
|
|
|
|
|
|
|
//! Notify of mouse motion
|
|
|
|
/*!
|
|
|
|
Synthesize mouse events to generate mouse motion to the absolute
|
|
|
|
screen position \c xAbs,yAbs.
|
|
|
|
*/
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual void mouseMove(SInt32 xAbs, SInt32 yAbs) = 0;
|
2002-07-29 20:07:26 +04:00
|
|
|
|
|
|
|
//! Notify of mouse wheel motion
|
|
|
|
/*!
|
|
|
|
Synthesize mouse events to generate mouse wheel motion of \c delta.
|
|
|
|
\c delta is positive for motion away from the user and negative for
|
|
|
|
motion towards the user. Each wheel click should generate a delta
|
|
|
|
of +/-120.
|
|
|
|
*/
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual void mouseWheel(SInt32 delta) = 0;
|
2002-07-29 20:07:26 +04:00
|
|
|
|
|
|
|
//! Notify of screen saver change
|
2002-07-14 02:00:38 +04:00
|
|
|
virtual void screensaver(bool activate) = 0;
|
2002-07-10 01:22:31 +04:00
|
|
|
|
2002-12-23 16:55:21 +03:00
|
|
|
//! Notify of options changes
|
|
|
|
/*!
|
|
|
|
Reset all options to their default values.
|
|
|
|
*/
|
|
|
|
virtual void resetOptions() = 0;
|
|
|
|
|
|
|
|
//! Notify of options changes
|
|
|
|
/*!
|
|
|
|
Set options to given values. Ignore unknown options and don't
|
|
|
|
modify our options that aren't given in \c options.
|
|
|
|
*/
|
|
|
|
virtual void setOptions(const COptionsList& options) = 0;
|
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//@}
|
|
|
|
//! @name accessors
|
|
|
|
//@{
|
2002-07-10 01:22:31 +04:00
|
|
|
|
2002-07-29 20:07:26 +04:00
|
|
|
//! Get client name
|
|
|
|
/*!
|
|
|
|
Return the client's name.
|
|
|
|
*/
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual CString getName() const = 0;
|
|
|
|
|
2004-02-14 17:04:36 +03:00
|
|
|
//@}
|
2002-07-14 02:00:38 +04:00
|
|
|
|
2004-02-14 17:04:36 +03:00
|
|
|
// IScreen overrides
|
|
|
|
virtual void* getEventTarget() const = 0;
|
|
|
|
virtual bool getClipboard(ClipboardID id, IClipboard*) const = 0;
|
2002-07-10 01:22:31 +04:00
|
|
|
virtual void getShape(SInt32& x, SInt32& y,
|
|
|
|
SInt32& width, SInt32& height) const = 0;
|
2002-07-14 02:00:38 +04:00
|
|
|
virtual void getCursorPos(SInt32& x, SInt32& y) const = 0;
|
2002-07-10 01:22:31 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|