forked from kfish/xsel
-
Notifications
You must be signed in to change notification settings - Fork 0
/
README
168 lines (100 loc) · 4.43 KB
/
README
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
XSel -- manipulate the X selection.
Copyright (C) 2001 Conrad Parker <[email protected]>
For updates see https://www.vergenet.net/~conrad/software/xsel/
INTRODUCTION
============
XSel is a command-line program for getting and setting the contents of the
X selection. Normally this is only accessible by manually highlighting
information and pasting it with the middle mouse button.
To read a file into the X selection:
------------------------------------
xsel < file
after which you can paste the file's contents into any X application with
the middle mouse button, as though you had highlighted its text. XSel will
read in the file contents exactly, whereas manual highlighting invariably
breaks lines and transforms tabs into spaces. This is especially handy for
copying in large files.
To write the X selection to a file:
-----------------------------------
xsel > file
after which file will contain exactly the contents of the X selection,
without trailing newlines and spaces and crap.
XSel is more than just cat for the X selection.
Append to the X selection:
--------------------------
xsel --append < file
To follow a growing file:
-------------------------
xsel --follow < file
to make the X selection follow standard input as it grows (like tail -f).
ADVANCED FEATURES
=================
XSel also lets you access some of the more esoteric features of the
X selection:
Delete the contents of the selection
------------------------------------
xsel --delete
Will cause the program in which text is selected to delete that text. This
really works, you can try it on xedit to remotely delete text in the editor
window.
Manipulate the secondary selection
----------------------------------
The X Window System maintains two selections, the usual primary selection
and a secondary, which isn't used much ... XSel lets you use the secondary
selection, for example:
To get and set the secondary selection:
---------------------------------------
xsel --secondary < file
xsel --secondary > file
To swap the primary and secondary selections:
---------------------------------------------
xsel --exchange
So for example you can store useful text in the secondary selection and
retrieve it later.
Manipulate the clipboard selection
----------------------------------
Similarly, X has a clipboard selection. You can use the standard xclipboard
program to manage a history of selected text, and you can use xsel to
actually get text into that clipboard:
xsel --clipboard < file
Make the selection contents persist in memory
---------------------------------------------
Normally the X selection only exists as long as the program it was selected
in is running. Further, some buggy applications tend to forget their
selection text after a little while. If you run:
xsel --keep
after selecting some important text, xsel will copy the text into its own
memory so you can paste it elsewhere even if the original program exits or crashes.
Further information
===================
Naturally all these options have single character equivalents, and
xsel --help
provides usage information. For complete details, see the xsel(1x) man page.
DOWNLOAD
========
New versions of XSel are distributed in source form from:
https://www.vergenet.net/~conrad/software/xsel/
STANDARDS
=========
X11 ICCCM2
----------
XSel conforms to the X Window System Inter-Client Communication Conventions
Manual Version 2.0 (ICCCM2), including correct handling of TARGETS,
MULTIPLE, TIMESTAMP, and DELETE targets, INCR properties and large data
transfers.
My thoughts on ICCCM are available at:
https://web.archive.org/web/20110720132303/https://lists.slug.org.au/archives/slug-chat/2001/July/msg00054.html
(Warning: explicit language).
LICENSE
=======
Copyright (C) 2001 Conrad Parker <[email protected]>
Permission to use, copy, modify, distribute, and sell this software and its
documentation for any purpose is hereby granted without fee, provided that
the above copyright notice appear in all copies and that both that copyright
notice and this permission notice appear in supporting documentation. No
representations are made about the suitability of this software for any
purpose. It is provided "as is" without express or implied warranty.
CONTACT
=======
Please direct any queries, bug reports etc. about XSel to the author,
Conrad Parker [email protected] .