forked from polachok/echinus
-
Notifications
You must be signed in to change notification settings - Fork 0
/
README
288 lines (179 loc) · 5.73 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
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
echinus wm.
==========
0.Installation
1.Configuration file
2.config.h header
3.About panels and pagers
0.Installation
--------------
You need X11 and Xft headers to compile echinus wm and the pkg-config tool.
Packages containing this stuff are probably named libx11-dev and libxft-dev
(note "-dev" suffix). You need libxrandr for multihead support (disabled by
default, pass MULTIHEAD=1 to make in order to enable it). XRandr-enabled
binary still works with single monitor configurations.
# make
# make install
On new install:
% mkdir ~/.echinus
% cp -r CONFDIR ~/.echinus
1.Configuration file
--------------------
Name: ~/.echinus/echinusrc
Main settings
Echinus*deflayout
Layout applied to tag if not explicitly set by tags.layout later.
One of: i - ifloating, f - floating, t - tiled, b - bottomstack, m - maximized.
Echinus*mwfact
Space occupied by master window in tiled layout (fraction of 1).
Echinus*nmaster
Number of clients in master area in tiled layout.
Echinus*sloppy
0 - Click to focus
1 - Sloppy focus for floating clients
2 - Sloppy focus for everything
3 - Sloppy focus + raise on focus
Echinus*modkey
Choose modkey. A for alt, W - winkey, S - shift, C - control
Title settings
Echinus*decoratetiled - boolean (1 or 0)
Draw titles in tiled mode
Echinus*titleposition
Echinus*tagbar
Echinus*tbpos
Were removed for more general interface, see below
Echinus*titlelayout - string
Titlebar consists of 3 parts separated with dashes or
spaces. Left is aligned to left, center to center and
right to right (obviously).
Default value is "N IMC" meaning name on the left
iconify, maximize and close buttons on right (note
2 spaces).
- or ' ' (space) - skip space (space can't be
used as first character)
N - window name
I - iconify
M - maximize
C - close
T - tagbar
Examples:
-T-C - title centered, close button on right
Color settings
Echinus*selected.border
Echinus*normal.border
Echinus*selected.bg
Echinus*normal.bg
Echinus*selected.fg
Echinus*normal.fg
Echinus*selected.button
Echinus*normal.button
border - color of a small border around each window
bg - titlebar background
fg - titlebar foreground
button - button foreground
normal - unfocused window
selected - window in focus
Border settings
Echinus*border
width of the border, in pixels
Button settings
Echinus*button.iconify.pixmap (was: Echinus*button.left.pixmap)
Echinus*button.maximize.pixmap (was: Echinus*button.center.pixmap)
Echinus*button.close.pixmap (was: Echinus*button.right.pixmap)
buttons in the titlebar, left iconifies window, center switch
to monocle (fullscreen) mode, right - close.
~ are not allowed in pathnames.
Opacity
Echinus*opacity
Opacity value for inactive windows, you need xcompmgr running to
see the result.
Terminal app
Echinus*command (was: Echinus*terminal)
Application to run on right window click on root window.
Title
Echinus*title
Titlebar height
Echinus*font
Titlebar font
Tags
Echinus*tags.number
Number of tags
Echinus*tags.name{...}
Names for the tags
Echinus*tags.layout{...}
Layout per tag on start. See deflayout for possible
values
Hacks
Echinus*hidebastards
Set to 1 to hide panels, pagers and others with
togglestruts function.
Keybindings
Format is "[ASCW] + key", where:
A - Alt (mod1)
S - Shift
C - Control
W - Windows key
You can find the list of available keys in keysym.h
and XF86keysym.h files (usually located in
/usr/include/X11/), remove XK_ prefix before use.
Don't miss ' ' (space).
Echinus*togglestruts
Echinus has no bar, but this binding switches the area
on top or bottom which won't be covered by windows in
tiled or monocle mode.
Echinus*togglemonitor
Switch from one monitor to another.
Echinus*focusnext
Echinus*focusprev
Focus next and previous window
Echinus*viewprevtag
View previous tag set
Echinus*quit
Leave echinus
Echinus*restart
Restart echinus
Echinus*killclient
Close window in focus
Echinus*togglefloating
Toggle floating/tiled
Echinus*view#
View tag number #
Echinus*tag#
Tag current window with tag number #
Echinus*toggleview#
Toggle view number #
Echinus*focusview#
Toggle view number # and focus the first client
from it.
Echinus*viewlefttag
Echinus*viewrighttag
View tag on the left(right) of current
Echinus*spawn#: <key> = program
Run specified program. # is less than 64.
Echinus*moveright
Echinus*moveleft
Echinus*moveup
Echinus*movedown
Syntax for this is rather untrivial: x y w h. For example move right for five pixels:
Echinus*moveright: AS + l = +5 0 0 0
Echinus*resizedecx
Echinus*resizedecy
Echinus*resizeincy
Echinus*resizeincx
Same as above, but change second group of values. Resize by y for 5 pixels:
Echinus*resizedecy: AS + v = 0 0 0 -5
Echinus*rule#
Format is "<Window class|Window title> <tag> <isfloating> <hastitle>"
2.config.h header
-----------------
Contains default values of options. You probably don't have
to edit it.
3.About panels and pagers
-------------------------
Echinus supports some parts of EWMH, so if the author of the pager knows
what this magical letters mean it *should* work fine.
Known to work:
fbpanel
ipager
ourico
Known to NOT work:
pypanel