st-clipboard: Add the ability to choose the clipboard type
https://bugzilla.gnome.org/show_bug.cgi?id=645019
This commit is contained in:
parent
d2c45f428f
commit
0616261a94
@ -90,7 +90,7 @@ const EntryMenu = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_updatePasteItem: function() {
|
_updatePasteItem: function() {
|
||||||
this._clipboard.get_text(Lang.bind(this,
|
this._clipboard.get_text(St.ClipboardType.CLIPBOARD, Lang.bind(this,
|
||||||
function(clipboard, text) {
|
function(clipboard, text) {
|
||||||
this._pasteItem.setSensitive(text && text != '');
|
this._pasteItem.setSensitive(text && text != '');
|
||||||
}));
|
}));
|
||||||
@ -106,11 +106,11 @@ const EntryMenu = new Lang.Class({
|
|||||||
|
|
||||||
_onCopyActivated: function() {
|
_onCopyActivated: function() {
|
||||||
let selection = this._entry.clutter_text.get_selection();
|
let selection = this._entry.clutter_text.get_selection();
|
||||||
this._clipboard.set_text(selection);
|
this._clipboard.set_text(St.ClipboardType.CLIPBOARD, selection);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onPasteActivated: function() {
|
_onPasteActivated: function() {
|
||||||
this._clipboard.get_text(Lang.bind(this,
|
this._clipboard.get_text(St.ClipboardType.CLIPBOARD, Lang.bind(this,
|
||||||
function(clipboard, text) {
|
function(clipboard, text) {
|
||||||
if (!text)
|
if (!text)
|
||||||
return;
|
return;
|
||||||
|
@ -55,6 +55,7 @@ struct _EventFilterData
|
|||||||
gpointer user_data;
|
gpointer user_data;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static Atom __atom_primary = None;
|
||||||
static Atom __atom_clip = None;
|
static Atom __atom_clip = None;
|
||||||
static Atom __utf8_string = None;
|
static Atom __utf8_string = None;
|
||||||
static Atom __atom_targets = None;
|
static Atom __atom_targets = None;
|
||||||
@ -197,6 +198,9 @@ st_clipboard_init (StClipboard *self)
|
|||||||
dpy = clutter_x11_get_default_display ();
|
dpy = clutter_x11_get_default_display ();
|
||||||
|
|
||||||
/* Only create once */
|
/* Only create once */
|
||||||
|
if (__atom_primary == None)
|
||||||
|
__atom_primary = XInternAtom (dpy, "PRIMARY", 0);
|
||||||
|
|
||||||
if (__atom_clip == None)
|
if (__atom_clip == None)
|
||||||
__atom_clip = XInternAtom (dpy, "CLIPBOARD", 0);
|
__atom_clip = XInternAtom (dpy, "CLIPBOARD", 0);
|
||||||
|
|
||||||
@ -298,9 +302,16 @@ st_clipboard_get_default (void)
|
|||||||
return default_clipboard;
|
return default_clipboard;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static Atom
|
||||||
|
atom_for_clipboard_type (StClipboardType type)
|
||||||
|
{
|
||||||
|
return type == ST_CLIPBOARD_TYPE_CLIPBOARD ? __atom_clip : __atom_primary;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* st_clipboard_get_text:
|
* st_clipboard_get_text:
|
||||||
* @clipboard: A #StCliboard
|
* @clipboard: A #StCliboard
|
||||||
|
* @type: The type of clipboard data you want
|
||||||
* @callback: (scope async): function to be called when the text is retreived
|
* @callback: (scope async): function to be called when the text is retreived
|
||||||
* @user_data: data to be passed to the callback
|
* @user_data: data to be passed to the callback
|
||||||
*
|
*
|
||||||
@ -310,6 +321,7 @@ st_clipboard_get_default (void)
|
|||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
st_clipboard_get_text (StClipboard *clipboard,
|
st_clipboard_get_text (StClipboard *clipboard,
|
||||||
|
StClipboardType type,
|
||||||
StClipboardCallbackFunc callback,
|
StClipboardCallbackFunc callback,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
@ -333,7 +345,7 @@ st_clipboard_get_text (StClipboard *clipboard,
|
|||||||
clutter_x11_trap_x_errors (); /* safety on */
|
clutter_x11_trap_x_errors (); /* safety on */
|
||||||
|
|
||||||
XConvertSelection (dpy,
|
XConvertSelection (dpy,
|
||||||
__atom_clip,
|
atom_for_clipboard_type (type),
|
||||||
__utf8_string, __utf8_string,
|
__utf8_string, __utf8_string,
|
||||||
clipboard->priv->clipboard_window,
|
clipboard->priv->clipboard_window,
|
||||||
CurrentTime);
|
CurrentTime);
|
||||||
@ -344,13 +356,14 @@ st_clipboard_get_text (StClipboard *clipboard,
|
|||||||
/**
|
/**
|
||||||
* st_clipboard_set_text:
|
* st_clipboard_set_text:
|
||||||
* @clipboard: A #StClipboard
|
* @clipboard: A #StClipboard
|
||||||
|
* @type: The type of clipboard that you want to set
|
||||||
* @text: text to copy to the clipboard
|
* @text: text to copy to the clipboard
|
||||||
*
|
*
|
||||||
* Sets text as the current contents of the clipboard.
|
* Sets text as the current contents of the clipboard.
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
st_clipboard_set_text (StClipboard *clipboard,
|
st_clipboard_set_text (StClipboard *clipboard,
|
||||||
|
StClipboardType type,
|
||||||
const gchar *text)
|
const gchar *text)
|
||||||
{
|
{
|
||||||
StClipboardPrivate *priv;
|
StClipboardPrivate *priv;
|
||||||
@ -370,7 +383,8 @@ st_clipboard_set_text (StClipboard *clipboard,
|
|||||||
|
|
||||||
clutter_x11_trap_x_errors ();
|
clutter_x11_trap_x_errors ();
|
||||||
|
|
||||||
XSetSelectionOwner (dpy, __atom_clip, priv->clipboard_window, CurrentTime);
|
XSetSelectionOwner (dpy, atom_for_clipboard_type (type), priv->clipboard_window, CurrentTime);
|
||||||
|
|
||||||
XSync (dpy, FALSE);
|
XSync (dpy, FALSE);
|
||||||
|
|
||||||
clutter_x11_untrap_x_errors ();
|
clutter_x11_untrap_x_errors ();
|
||||||
|
@ -72,6 +72,11 @@ struct _StClipboardClass
|
|||||||
GObjectClass parent_class;
|
GObjectClass parent_class;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
ST_CLIPBOARD_TYPE_PRIMARY,
|
||||||
|
ST_CLIPBOARD_TYPE_CLIPBOARD
|
||||||
|
} StClipboardType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* StClipboardCallbackFunc:
|
* StClipboardCallbackFunc:
|
||||||
* @clipboard: A #StClipboard
|
* @clipboard: A #StClipboard
|
||||||
@ -89,9 +94,11 @@ GType st_clipboard_get_type (void);
|
|||||||
StClipboard* st_clipboard_get_default (void);
|
StClipboard* st_clipboard_get_default (void);
|
||||||
|
|
||||||
void st_clipboard_get_text (StClipboard *clipboard,
|
void st_clipboard_get_text (StClipboard *clipboard,
|
||||||
|
StClipboardType type,
|
||||||
StClipboardCallbackFunc callback,
|
StClipboardCallbackFunc callback,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
void st_clipboard_set_text (StClipboard *clipboard,
|
void st_clipboard_set_text (StClipboard *clipboard,
|
||||||
|
StClipboardType type,
|
||||||
const gchar *text);
|
const gchar *text);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
@ -559,7 +559,10 @@ st_entry_key_press_event (ClutterActor *actor,
|
|||||||
|
|
||||||
clipboard = st_clipboard_get_default ();
|
clipboard = st_clipboard_get_default ();
|
||||||
|
|
||||||
st_clipboard_get_text (clipboard, st_entry_clipboard_callback, actor);
|
st_clipboard_get_text (clipboard,
|
||||||
|
ST_CLIPBOARD_TYPE_CLIPBOARD,
|
||||||
|
st_entry_clipboard_callback,
|
||||||
|
actor);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -576,7 +579,9 @@ st_entry_key_press_event (ClutterActor *actor,
|
|||||||
text = clutter_text_get_selection ((ClutterText*) priv->entry);
|
text = clutter_text_get_selection ((ClutterText*) priv->entry);
|
||||||
|
|
||||||
if (text && strlen (text))
|
if (text && strlen (text))
|
||||||
st_clipboard_set_text (clipboard, text);
|
st_clipboard_set_text (clipboard,
|
||||||
|
ST_CLIPBOARD_TYPE_CLIPBOARD,
|
||||||
|
text);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -595,7 +600,9 @@ st_entry_key_press_event (ClutterActor *actor,
|
|||||||
|
|
||||||
if (text && strlen (text))
|
if (text && strlen (text))
|
||||||
{
|
{
|
||||||
st_clipboard_set_text (clipboard, text);
|
st_clipboard_set_text (clipboard,
|
||||||
|
ST_CLIPBOARD_TYPE_CLIPBOARD,
|
||||||
|
text);
|
||||||
|
|
||||||
/* now delete the text */
|
/* now delete the text */
|
||||||
clutter_text_delete_selection ((ClutterText *) priv->entry);
|
clutter_text_delete_selection ((ClutterText *) priv->entry);
|
||||||
|
Loading…
Reference in New Issue
Block a user