2009-05-16 17:32:36 +02:00
|
|
|
|
i3 User’s Guide
|
|
|
|
|
===============
|
|
|
|
|
Michael Stapelberg <michael+i3@stapelberg.de>
|
2012-04-08 20:34:31 +02:00
|
|
|
|
April 2012
|
2011-05-28 21:58:58 +02:00
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
This document contains all the information you need to configure and use the i3
|
2011-05-28 21:58:58 +02:00
|
|
|
|
window manager. If it does not, please contact us on IRC (preferred) or post your
|
|
|
|
|
question(s) on the mailing list.
|
2009-05-16 17:32:36 +02:00
|
|
|
|
|
2010-03-07 21:12:59 +01:00
|
|
|
|
== Default keybindings
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
For the "too long; didn’t read" people, here is an overview of the default
|
2010-03-07 21:12:59 +01:00
|
|
|
|
keybindings (click to see the full size image):
|
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
*Keys to use with mod (alt):*
|
2010-03-07 21:12:59 +01:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
image:keyboard-layer1.png["Keys to use with mod (alt)",width=600,link="keyboard-layer1.png"]
|
2010-03-07 21:12:59 +01:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
*Keys to use with Shift+mod:*
|
2010-03-07 21:12:59 +01:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
image:keyboard-layer2.png["Keys to use with Shift+mod",width=600,link="keyboard-layer2.png"]
|
2010-03-07 21:12:59 +01:00
|
|
|
|
|
2010-03-15 18:23:12 +01:00
|
|
|
|
The red keys are the modifiers you need to press (by default), the blue keys
|
|
|
|
|
are your homerow.
|
2009-06-13 20:10:49 +02:00
|
|
|
|
|
2009-06-01 14:59:25 +02:00
|
|
|
|
== Using i3
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
Throughout this guide, the keyword +mod+ will be used to refer to the
|
2011-07-28 22:51:34 +02:00
|
|
|
|
configured modifier. This is the alt key (Mod1) by default, with windows (Mod4)
|
2011-05-28 21:58:58 +02:00
|
|
|
|
being a popular alternative.
|
|
|
|
|
|
2010-03-15 18:23:12 +01:00
|
|
|
|
=== Opening terminals and moving around
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
One very basic operation is opening a new terminal. By default, the keybinding
|
2011-07-28 22:51:34 +02:00
|
|
|
|
for this is mod+Enter, that is Alt+Enter in the default configuration. By
|
2011-05-28 21:58:58 +02:00
|
|
|
|
pressing mod+Enter, a new terminal will be opened. It will fill the whole
|
2010-03-16 20:28:43 +01:00
|
|
|
|
space available on your screen.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
image:single_terminal.png[Single terminal]
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
If you now open another terminal, i3 will place it next to the current one,
|
|
|
|
|
splitting the screen size in half. Depending on your monitor, i3 will put the
|
2011-07-29 13:31:37 +02:00
|
|
|
|
created window beside the existing window (on wide displays) or below the
|
|
|
|
|
existing window (rotated displays).
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
image:two_terminals.png[Two terminals]
|
|
|
|
|
|
2011-07-29 13:31:37 +02:00
|
|
|
|
To move the focus between the two terminals, you can use the direction keys
|
|
|
|
|
which you may know from the editor +vi+. However, in i3, your homerow is used
|
|
|
|
|
for these keys (in +vi+, the keys are shifted to the left by one for
|
|
|
|
|
compatibility with most keyboard layouts). Therefore, +mod+J+ is left, +mod+K+
|
|
|
|
|
is down, +mod+L+ is up and `mod+;` is right. So, to switch between the
|
|
|
|
|
terminals, use +mod+K+ or +mod+L+. Of course, you can also use the arrow keys.
|
2011-05-28 21:58:58 +02:00
|
|
|
|
|
|
|
|
|
At the moment, your workspace is split (it contains two terminals) in a
|
|
|
|
|
specific direction (horizontal by default). Every window can be split
|
|
|
|
|
horizontally or vertically again, just like the workspace. The terminology is
|
|
|
|
|
"window" for a container that actually contains an X11 window (like a terminal
|
|
|
|
|
or browser) and "split container" for containers that consist of one or more
|
|
|
|
|
windows.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
TODO: picture of the tree
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
To split a window vertically, press +mod+v+. To split it horizontally, press
|
|
|
|
|
+mod+h+.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
=== Changing the container layout
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
A split container can have one of the following layouts:
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2009-10-23 19:53:36 +02:00
|
|
|
|
default::
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Windows are sized so that every window gets an equal amount of space in the
|
2009-10-23 19:53:36 +02:00
|
|
|
|
container.
|
|
|
|
|
stacking::
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Only the focused window in the container is displayed. You get a list of
|
2009-10-23 19:53:36 +02:00
|
|
|
|
windows at the top of the container.
|
|
|
|
|
tabbed::
|
|
|
|
|
The same principle as +stacking+, but the list of windows at the top is only
|
2010-03-16 20:28:43 +01:00
|
|
|
|
a single line which is vertically split.
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
2011-08-27 15:28:11 +02:00
|
|
|
|
To switch modes, press +mod+e+ for default, +mod+s+ for stacking and
|
2011-07-28 22:51:34 +02:00
|
|
|
|
+mod+w+ for tabbed.
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
|
|
|
|
image:modes.png[Container modes]
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
=== Toggling fullscreen mode for a window
|
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
To display a window in fullscreen mode or to go out of fullscreen mode again,
|
|
|
|
|
press +mod+f+.
|
2011-05-28 21:58:58 +02:00
|
|
|
|
|
2011-07-29 13:31:37 +02:00
|
|
|
|
There is also a global fullscreen mode in i3 in which the client will span all
|
2012-01-27 23:32:25 +01:00
|
|
|
|
available outputs (the command is +fullscreen global+).
|
2010-03-08 02:02:35 +01:00
|
|
|
|
|
2009-06-01 14:59:25 +02:00
|
|
|
|
=== Opening other applications
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Aside from opening applications from a terminal, you can also use the handy
|
2011-07-28 22:51:34 +02:00
|
|
|
|
+dmenu+ which is opened by pressing +mod+d+ by default. Just type the name
|
|
|
|
|
(or a part of it) of the application which you want to open. The corresponding
|
|
|
|
|
application has to be in your +$PATH+ for this to work.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Additionally, if you have applications you open very frequently, you can
|
2010-03-15 18:23:12 +01:00
|
|
|
|
create a keybinding for starting the application directly. See the section
|
2011-07-28 22:51:34 +02:00
|
|
|
|
<<configuring>> for details.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
=== Closing windows
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
If an application does not provide a mechanism for closing (most applications
|
2009-06-01 14:59:25 +02:00
|
|
|
|
provide a menu, the escape key or a shortcut like +Control+W+ to close), you
|
2011-07-28 22:51:34 +02:00
|
|
|
|
can press +mod+Shift+q+ to kill a window. For applications which support
|
2009-06-01 14:59:25 +02:00
|
|
|
|
the WM_DELETE protocol, this will correctly close the application (saving
|
|
|
|
|
any modifications or doing other cleanup). If the application doesn’t support
|
2010-03-16 20:28:43 +01:00
|
|
|
|
the WM_DELETE protocol your X server will kill the window and the behaviour
|
|
|
|
|
depends on the application.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
=== Using workspaces
|
|
|
|
|
|
|
|
|
|
Workspaces are an easy way to group a set of windows. By default, you are on
|
|
|
|
|
the first workspace, as the bar on the bottom left indicates. To switch to
|
2011-05-28 21:58:58 +02:00
|
|
|
|
another workspace, press +mod+num+ where +num+ is the number of the workspace
|
2009-06-01 14:59:25 +02:00
|
|
|
|
you want to use. If the workspace does not exist yet, it will be created.
|
|
|
|
|
|
|
|
|
|
A common paradigm is to put the web browser on one workspace, communication
|
2010-03-21 01:50:10 +01:00
|
|
|
|
applications (+mutt+, +irssi+, ...) on another one, and the ones with which you
|
|
|
|
|
work, on the third one. Of course, there is no need to follow this approach.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
If you have multiple screens, a workspace will be created on each screen at
|
|
|
|
|
startup. If you open a new workspace, it will be bound to the screen you
|
|
|
|
|
created it on. When you switch to a workspace on another screen, i3 will set
|
|
|
|
|
focus to that screen.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
=== Moving windows to workspaces
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
To move a window to another workspace, simply press +mod+Shift+num+ where
|
2009-06-01 14:59:25 +02:00
|
|
|
|
+num+ is (like when switching workspaces) the number of the target workspace.
|
|
|
|
|
Similarly to switching workspaces, the target workspace will be created if
|
|
|
|
|
it does not yet exist.
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
=== Resizing
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
The easiest way to resize a container is by using the mouse: Grab the border
|
|
|
|
|
and move it to the wanted size.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2009-10-23 19:53:36 +02:00
|
|
|
|
See <<resizingconfig>> for how to configure i3 to be able to resize
|
|
|
|
|
columns/rows with your keyboard.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
=== Restarting i3 inplace
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
To restart i3 inplace (and thus get into a clean state if there is a bug, or
|
2011-05-28 21:58:58 +02:00
|
|
|
|
to upgrade to a newer version of i3) you can use +mod+Shift+r+.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
=== Exiting i3
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
To cleanly exit i3 without killing your X server, you can use +mod+Shift+e+.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
=== Floating
|
|
|
|
|
|
2010-03-15 18:23:12 +01:00
|
|
|
|
Floating mode is the opposite of tiling mode. The position and size of a window
|
2010-03-16 20:28:43 +01:00
|
|
|
|
are not managed by i3, but by you. Using this mode violates the tiling
|
2009-06-01 14:59:25 +02:00
|
|
|
|
paradigm but can be useful for some corner cases like "Save as" dialog
|
2011-05-28 21:58:58 +02:00
|
|
|
|
windows, or toolbar windows (GIMP or similar). Those windows usually set the
|
|
|
|
|
appropriate hint and are opened in floating mode by default.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-08-29 16:04:42 +02:00
|
|
|
|
You can toggle floating mode for a window by pressing +mod+Shift+Space+. By
|
2010-03-16 20:28:43 +01:00
|
|
|
|
dragging the window’s titlebar with your mouse you can move the window
|
2010-03-25 03:26:59 +01:00
|
|
|
|
around. By grabbing the borders and moving them you can resize the window. You
|
|
|
|
|
can also do that by using the <<floating_modifier>>.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2010-03-25 03:26:59 +01:00
|
|
|
|
For resizing floating windows with your keyboard, see <<resizingconfig>>.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Floating windows are always on top of tiling windows.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
== Tree
|
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
i3 stores all information about the X11 outputs, workspaces and layout of the
|
|
|
|
|
windows on them in a tree. The root node is the X11 root window, followed by
|
|
|
|
|
the X11 outputs, then dock areas and a content container, then workspaces and
|
2011-11-13 11:51:58 +01:00
|
|
|
|
finally the windows themselves. In previous versions of i3 we had multiple lists
|
2011-07-28 22:51:34 +02:00
|
|
|
|
(of outputs, workspaces) and a table for each workspace. That approach turned
|
|
|
|
|
out to be complicated to use (snapping), understand and implement.
|
2011-05-28 21:58:58 +02:00
|
|
|
|
|
|
|
|
|
=== The tree consists of Containers
|
|
|
|
|
|
|
|
|
|
The building blocks of our tree are so called +Containers+. A +Container+ can
|
|
|
|
|
host a window (meaning an X11 window, one that you can actually see and use,
|
|
|
|
|
like a browser). Alternatively, it could contain one or more +Containers+. A
|
|
|
|
|
simple example is the workspace: When you start i3 with a single monitor, a
|
|
|
|
|
single workspace and you open two terminal windows, you will end up with a tree
|
|
|
|
|
like this:
|
|
|
|
|
|
|
|
|
|
image::tree-layout2.png["layout2",float="right"]
|
|
|
|
|
image::tree-shot4.png["shot4",title="Two terminals on standard workspace"]
|
|
|
|
|
|
|
|
|
|
=== Orientation and Split Containers
|
|
|
|
|
|
|
|
|
|
[[OrientationSplit]]
|
|
|
|
|
|
|
|
|
|
It is only natural to use so-called +Split Containers+ in order to build a
|
|
|
|
|
layout when using a tree as data structure. In i3, every +Container+ has an
|
|
|
|
|
orientation (horizontal, vertical or unspecified). So, in our example with the
|
|
|
|
|
workspace, the default orientation of the workspace +Container+ is horizontal
|
|
|
|
|
(most monitors are widescreen nowadays). If you change the orientation to
|
2011-07-28 22:51:34 +02:00
|
|
|
|
vertical (+mod+v+ in the default config) and *then* open two terminals, i3 will
|
2011-05-28 21:58:58 +02:00
|
|
|
|
configure your windows like this:
|
|
|
|
|
|
|
|
|
|
image::tree-shot2.png["shot2",title="Vertical Workspace Orientation"]
|
|
|
|
|
|
|
|
|
|
An interesting new feature of the tree branch is the ability to split anything:
|
|
|
|
|
Let’s assume you have two terminals on a workspace (with horizontal
|
|
|
|
|
orientation), focus is on the right terminal. Now you want to open another
|
|
|
|
|
terminal window below the current one. If you would just open a new terminal
|
|
|
|
|
window, it would show up to the right due to the horizontal workspace
|
2011-07-28 22:51:34 +02:00
|
|
|
|
orientation. Instead, press +mod+v+ to create a +Vertical Split Container+ (to
|
|
|
|
|
open a +Horizontal Split Container+, use +mod+h+). Now you can open a new
|
2011-05-28 21:58:58 +02:00
|
|
|
|
terminal and it will open below the current one:
|
|
|
|
|
|
|
|
|
|
image::tree-layout1.png["Layout",float="right"]
|
|
|
|
|
image::tree-shot1.png["shot",title="Vertical Split Container"]
|
|
|
|
|
|
|
|
|
|
unfloat::[]
|
|
|
|
|
|
|
|
|
|
You probably guessed it already: There is no limit on how deep your hierarchy
|
|
|
|
|
of splits can be.
|
|
|
|
|
|
2011-06-10 01:36:33 +02:00
|
|
|
|
=== Focus parent
|
2011-05-28 21:58:58 +02:00
|
|
|
|
|
|
|
|
|
Let’s stay with our example from above. We have a terminal on the left and two
|
|
|
|
|
vertically split terminals on the right, focus is on the bottom right one. When
|
|
|
|
|
you open a new terminal, it will open below the current one.
|
|
|
|
|
|
|
|
|
|
So, how can you open a new terminal window to the *right* of the current one?
|
2011-06-10 01:36:33 +02:00
|
|
|
|
The solution is to use +focus parent+, which will focus the +Parent Container+ of
|
2011-05-28 21:58:58 +02:00
|
|
|
|
the current +Container+. In this case, you would focus the +Vertical Split
|
|
|
|
|
Container+ which is *inside* the horizontally oriented workspace. Thus, now new
|
|
|
|
|
windows will be opened to the right of the +Vertical Split Container+:
|
|
|
|
|
|
2011-06-10 01:36:33 +02:00
|
|
|
|
image::tree-shot3.png["shot3",title="Focus parent, then open new terminal"]
|
2011-05-28 21:58:58 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
[[configuring]]
|
2009-05-16 17:32:36 +02:00
|
|
|
|
== Configuring i3
|
|
|
|
|
|
2009-06-01 14:59:25 +02:00
|
|
|
|
This is where the real fun begins ;-). Most things are very dependant on your
|
2010-03-16 20:28:43 +01:00
|
|
|
|
ideal working environment so we can’t make reasonable defaults for them.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
While not using a programming language for the configuration, i3 stays
|
2010-03-16 20:28:43 +01:00
|
|
|
|
quite flexible in regards to the things you usually want your window manager
|
2009-06-01 14:59:25 +02:00
|
|
|
|
to do.
|
|
|
|
|
|
|
|
|
|
For example, you can configure bindings to jump to specific windows,
|
2010-03-16 20:28:43 +01:00
|
|
|
|
you can set specific applications to start on specific workspaces, you can
|
|
|
|
|
automatically start applications, you can change the colors of i3, and you
|
|
|
|
|
can bind your keys to do useful things.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2010-03-07 00:00:04 +01:00
|
|
|
|
To change the configuration of i3, copy +/etc/i3/config+ to +\~/.i3/config+
|
|
|
|
|
(or +~/.config/i3/config+ if you like the XDG directory scheme) and edit it
|
|
|
|
|
with a text editor.
|
2009-10-11 14:43:56 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
On first start (and on all following starts, unless you have a configuration
|
|
|
|
|
file), i3 will offer you to create a configuration file. You can tell the
|
|
|
|
|
wizard to use either Alt (Mod1) or Windows (Mod4) as modifier in the config
|
|
|
|
|
file. Also, the created config file will use the key symbols of your current
|
|
|
|
|
keyboard layout. To start the wizard, use the command +i3-config-wizard+.
|
|
|
|
|
Please note that you must not have +~/.i3/config+, otherwise the wizard will
|
|
|
|
|
exit.
|
|
|
|
|
|
2010-03-07 00:00:04 +01:00
|
|
|
|
=== Comments
|
2009-10-11 14:43:56 +02:00
|
|
|
|
|
2010-03-07 00:00:04 +01:00
|
|
|
|
It is possible and recommended to use comments in your configuration file to
|
|
|
|
|
properly document your setup for later reference. Comments are started with
|
2010-03-16 20:28:43 +01:00
|
|
|
|
a # and can only be used at the beginning of a line:
|
2010-03-07 00:00:04 +01:00
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
-------------------
|
|
|
|
|
# This is a comment
|
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
|
|
=== Fonts
|
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
i3 uses X core fonts (not Xft) for rendering window titles. You can use
|
|
|
|
|
+xfontsel(1)+ to generate such a font description. To see special characters
|
|
|
|
|
(Unicode), you need to use a font which supports the ISO-10646 encoding.
|
2010-03-07 00:00:04 +01:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
If i3 cannot open the configured font, it will output an error in the logfile
|
|
|
|
|
and fall back to a working font.
|
|
|
|
|
|
2010-03-07 00:00:04 +01:00
|
|
|
|
*Syntax*:
|
|
|
|
|
------------------------------
|
|
|
|
|
font <X core font description>
|
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
--------------------------------------------------------------
|
|
|
|
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
|
|
|
|
--------------------------------------------------------------
|
2009-05-16 17:32:36 +02:00
|
|
|
|
|
2010-03-25 03:26:59 +01:00
|
|
|
|
[[keybindings]]
|
|
|
|
|
|
2009-05-16 17:32:36 +02:00
|
|
|
|
=== Keyboard bindings
|
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
A keyboard binding makes i3 execute a command (see below) upon pressing a
|
|
|
|
|
specific key. i3 allows you to bind either on keycodes or on keysyms (you can
|
|
|
|
|
also mix your bindings, though i3 will not protect you from overlapping ones).
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
* A keysym (key symbol) is a description for a specific symbol, like "a"
|
|
|
|
|
or "b", but also more strange ones like "underscore" instead of "_". These
|
|
|
|
|
are the ones you use in Xmodmap to remap your keys. To get the current
|
2012-03-22 13:10:36 +01:00
|
|
|
|
mapping of your keys, use +xmodmap -pke+. To interactively enter a key and
|
|
|
|
|
see what keysym it is configured to, use +xev+.
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
* Keycodes do not need to have a symbol assigned (handy for custom vendor
|
|
|
|
|
hotkeys on some notebooks) and they will not change their meaning as you
|
|
|
|
|
switch to a different keyboard layout (when using +xmodmap+).
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
My recommendation is: If you often switch keyboard layouts but you want to keep
|
2010-03-21 01:50:10 +01:00
|
|
|
|
your bindings in the same physical location on the keyboard, use keycodes.
|
|
|
|
|
If you don’t switch layouts, and want a clean and simple config file, use
|
|
|
|
|
keysyms.
|
2009-05-16 17:32:36 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
2009-08-19 12:59:13 +02:00
|
|
|
|
----------------------------------
|
|
|
|
|
bindsym [Modifiers+]keysym command
|
2011-04-18 23:06:32 +02:00
|
|
|
|
bindcode [Modifiers+]keycode command
|
2009-08-19 12:59:13 +02:00
|
|
|
|
----------------------------------
|
2009-05-16 17:32:36 +02:00
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
--------------------------------
|
|
|
|
|
# Fullscreen
|
2011-12-23 12:56:26 +01:00
|
|
|
|
bindsym mod+f fullscreen
|
2009-05-16 17:32:36 +02:00
|
|
|
|
|
|
|
|
|
# Restart
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+Shift+r restart
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
|
|
|
|
# Notebook-specific hotkeys
|
2011-04-18 23:06:32 +02:00
|
|
|
|
bindcode 214 exec /home/michael/toggle_beamer.sh
|
2009-05-16 17:32:36 +02:00
|
|
|
|
--------------------------------
|
|
|
|
|
|
2009-05-26 17:37:56 +02:00
|
|
|
|
Available Modifiers:
|
|
|
|
|
|
|
|
|
|
Mod1-Mod5, Shift, Control::
|
|
|
|
|
Standard modifiers, see +xmodmap(1)+
|
|
|
|
|
|
|
|
|
|
Mode_switch::
|
|
|
|
|
Unlike other window managers, i3 can use Mode_switch as a modifier. This allows
|
|
|
|
|
you to remap capslock (for example) to Mode_switch and use it for both: typing
|
|
|
|
|
umlauts or special characters 'and' having some comfortably reachable key
|
|
|
|
|
bindings. For example, when typing, capslock+1 or capslock+2 for switching
|
|
|
|
|
workspaces is totally convenient. Try it :-).
|
|
|
|
|
|
2010-03-25 03:26:59 +01:00
|
|
|
|
[[floating_modifier]]
|
|
|
|
|
|
2009-06-24 20:31:00 +02:00
|
|
|
|
=== The floating modifier
|
|
|
|
|
|
|
|
|
|
To move floating windows with your mouse, you can either grab their titlebar
|
|
|
|
|
or configure the so called floating modifier which you can then press and
|
2010-03-16 20:28:43 +01:00
|
|
|
|
click anywhere in the window itself to move it. The most common setup is to
|
|
|
|
|
use the same key you use for managing windows (Mod1 for example). Then
|
|
|
|
|
you can press Mod1, click into a window using your left mouse button, and drag
|
|
|
|
|
it to the position you want.
|
2009-06-24 20:31:00 +02:00
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
When holding the floating modifier, you can resize a floating window by
|
|
|
|
|
pressing the right mouse button on it and moving around while holding it. If
|
2011-10-29 23:58:32 +02:00
|
|
|
|
you hold the shift button as well, the resize will be proportional (the aspect
|
|
|
|
|
ratio will be preserved).
|
2010-03-13 00:59:16 +01:00
|
|
|
|
|
2009-06-24 20:31:00 +02:00
|
|
|
|
*Syntax*:
|
|
|
|
|
--------------------------------
|
|
|
|
|
floating_modifier <Modifiers>
|
|
|
|
|
--------------------------------
|
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
*Example*:
|
2009-06-24 20:31:00 +02:00
|
|
|
|
--------------------------------
|
|
|
|
|
floating_modifier Mod1
|
|
|
|
|
--------------------------------
|
|
|
|
|
|
2012-02-16 15:36:46 +01:00
|
|
|
|
=== Constraining floating window size
|
|
|
|
|
|
|
|
|
|
The maximum and minimum dimensions of floating windows can be specified. If
|
|
|
|
|
either dimension of +floating_maximum_size+ is specified as -1, that dimension
|
|
|
|
|
will be unconstrained with respect to its maximum value. If either dimension of
|
|
|
|
|
+floating_maximum_size+ is undefined, or specified as 0, i3 will use a default
|
|
|
|
|
value to constrain the maximum size. +floating_minimum_size+ is treated in a
|
|
|
|
|
manner analogous to +floating_maximum_size+.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------------------------
|
|
|
|
|
floating_minimum_size <width> x <height>
|
|
|
|
|
floating_maximum_size <width> x <height>
|
|
|
|
|
----------------------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
--------------------------------------
|
|
|
|
|
floating_minimum_size 75 x 50
|
|
|
|
|
floating_maximum_size -1 x -1
|
|
|
|
|
--------------------------------------
|
|
|
|
|
|
2011-07-29 01:12:06 +02:00
|
|
|
|
=== Orientation for new workspaces
|
|
|
|
|
|
|
|
|
|
New workspaces get a reasonable default orientation: Wide-screen monitors
|
|
|
|
|
(anything wider than high) get horizontal orientation, rotated monitors
|
|
|
|
|
(anything higher than wide) get vertical orientation.
|
|
|
|
|
|
2011-07-29 13:31:37 +02:00
|
|
|
|
With the +default_orientation+ configuration directive, you can override that
|
2011-07-29 01:12:06 +02:00
|
|
|
|
behaviour.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------------------------------
|
|
|
|
|
default_orientation <horizontal|vertical|auto>
|
|
|
|
|
----------------------------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
----------------------------
|
|
|
|
|
default_orientation vertical
|
|
|
|
|
----------------------------
|
|
|
|
|
|
2009-10-23 19:53:36 +02:00
|
|
|
|
=== Layout mode for new containers
|
|
|
|
|
|
2011-06-10 15:14:42 +02:00
|
|
|
|
This option determines in which mode new containers on workspace level will
|
|
|
|
|
start.
|
|
|
|
|
///////////////////////////////
|
|
|
|
|
See also <<stack-limit>>.
|
|
|
|
|
//////////////////////////////
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------------------------------------
|
2011-06-10 15:14:42 +02:00
|
|
|
|
workspace_layout <default|stacking|tabbed>
|
2009-10-23 19:53:36 +02:00
|
|
|
|
---------------------------------------------
|
2011-06-10 15:14:42 +02:00
|
|
|
|
/////////////////////////////////////////////
|
|
|
|
|
new_container stack-limit <cols|rows> <value>
|
|
|
|
|
/////////////////////////////////////////////
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
*Example*:
|
2009-10-23 19:53:36 +02:00
|
|
|
|
---------------------
|
2011-06-10 15:14:42 +02:00
|
|
|
|
workspace_layout tabbed
|
2009-11-08 12:45:05 +01:00
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
|
|
=== Border style for new windows
|
|
|
|
|
|
2012-06-10 21:30:14 +02:00
|
|
|
|
This option determines which border style new windows will have. The default is
|
|
|
|
|
"normal".
|
2009-11-08 12:45:05 +01:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------------------------------------
|
2011-08-29 15:17:31 +02:00
|
|
|
|
new_window <normal|1pixel|none>
|
2009-11-08 12:45:05 +01:00
|
|
|
|
---------------------------------------------
|
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
*Example*:
|
2009-11-08 12:45:05 +01:00
|
|
|
|
---------------------
|
2011-05-28 21:58:58 +02:00
|
|
|
|
new_window 1pixel
|
2009-10-23 19:53:36 +02:00
|
|
|
|
---------------------
|
2009-06-24 20:31:00 +02:00
|
|
|
|
|
2011-07-31 23:38:08 +02:00
|
|
|
|
=== Arbitrary commands for specific windows (for_window)
|
|
|
|
|
|
|
|
|
|
With the +for_window+ command, you can let i3 execute any command when it
|
|
|
|
|
encounters a specific window. This can be used to set windows to floating or to
|
|
|
|
|
change their border style, for example.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
-----------------------------
|
2011-09-11 23:15:14 +02:00
|
|
|
|
for_window <criteria> command
|
2011-07-31 23:38:08 +02:00
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
------------------------------------------------
|
|
|
|
|
# enable floating mode for all XTerm windows
|
2011-08-03 20:47:29 +02:00
|
|
|
|
for_window [class="XTerm"] floating enable
|
2011-07-31 23:38:08 +02:00
|
|
|
|
|
|
|
|
|
# Make all urxvts use a 1-pixel border:
|
|
|
|
|
for_window [class="urxvt"] border 1pixel
|
|
|
|
|
|
|
|
|
|
# A less useful, but rather funny example:
|
|
|
|
|
# makes the window floating as soon as I change
|
|
|
|
|
# directory to ~/work
|
2011-08-03 20:47:29 +02:00
|
|
|
|
for_window [title="x200: ~/work"] floating enable
|
2011-07-31 23:38:08 +02:00
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
2011-08-29 16:04:42 +02:00
|
|
|
|
The valid criteria are the same as those for commands, see <<command_criteria>>.
|
|
|
|
|
|
2009-06-13 20:10:49 +02:00
|
|
|
|
=== Variables
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
As you learned in the section about keyboard bindings, you will have
|
2009-06-13 20:10:49 +02:00
|
|
|
|
to configure lots of bindings containing modifier keys. If you want to save
|
2010-03-16 20:28:43 +01:00
|
|
|
|
yourself some typing and be able to change the modifier you use later,
|
|
|
|
|
variables can be handy.
|
2009-06-13 20:10:49 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
--------------
|
2010-04-13 21:05:04 +02:00
|
|
|
|
set $name value
|
2009-06-13 20:10:49 +02:00
|
|
|
|
--------------
|
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
*Example*:
|
2009-06-13 20:10:49 +02:00
|
|
|
|
------------------------
|
|
|
|
|
set $m Mod1
|
2009-08-19 12:59:13 +02:00
|
|
|
|
bindsym $m+Shift+r restart
|
2009-06-13 20:10:49 +02:00
|
|
|
|
------------------------
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Variables are directly replaced in the file when parsing. There is no fancy
|
2009-06-13 20:10:49 +02:00
|
|
|
|
handling and there are absolutely no plans to change this. If you need a more
|
2010-03-16 20:28:43 +01:00
|
|
|
|
dynamic configuration you should create a little script which generates a
|
2010-03-15 18:23:12 +01:00
|
|
|
|
configuration file and run it before starting i3 (for example in your
|
2011-07-28 22:51:34 +02:00
|
|
|
|
+~/.xsession+ file).
|
2009-06-13 20:10:49 +02:00
|
|
|
|
|
2009-05-16 17:32:36 +02:00
|
|
|
|
=== Automatically putting clients on specific workspaces
|
|
|
|
|
|
2009-12-07 10:25:12 +01:00
|
|
|
|
[[assign_workspace]]
|
|
|
|
|
|
2011-09-11 23:15:05 +02:00
|
|
|
|
To automatically make a specific window show up on a specific workspace, you
|
|
|
|
|
can use an *assignment*. You can match windows by using any criteria,
|
|
|
|
|
see <<command_criteria>>. It is recommended that you match on window classes
|
|
|
|
|
(and instances, when appropriate) instead of window titles whenever possible
|
|
|
|
|
because some applications first create their window, and then worry about
|
|
|
|
|
setting the correct title. Firefox with Vimperator comes to mind. The window
|
|
|
|
|
starts up being named Firefox, and only when Vimperator is loaded does the
|
|
|
|
|
title change. As i3 will get the title as soon as the application maps the
|
2011-07-29 13:31:37 +02:00
|
|
|
|
window (mapping means actually displaying it on the screen), you’d need to have
|
|
|
|
|
to match on 'Firefox' in this case.
|
2009-05-16 17:32:36 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
2009-07-21 16:43:20 +02:00
|
|
|
|
------------------------------------------------------------
|
2011-09-11 23:15:05 +02:00
|
|
|
|
assign <criteria> [→] workspace
|
2009-07-21 16:43:20 +02:00
|
|
|
|
------------------------------------------------------------
|
2009-05-16 17:32:36 +02:00
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
----------------------
|
2011-09-11 23:15:05 +02:00
|
|
|
|
# Assign URxvt terminals to workspace 2
|
|
|
|
|
assign [class="URxvt"] 2
|
|
|
|
|
|
|
|
|
|
# Same thing, but more precise (exact match instead of substring)
|
|
|
|
|
assign [class="^URxvt$"] 2
|
|
|
|
|
|
|
|
|
|
# Same thing, but with a beautiful arrow :)
|
|
|
|
|
assign [class="^URxvt$"] → 2
|
|
|
|
|
|
|
|
|
|
# Assignment to a named workspace
|
|
|
|
|
assign [class="^URxvt$"] → work
|
|
|
|
|
|
|
|
|
|
# Start urxvt -name irssi
|
|
|
|
|
assign [class="^URxvt$" instance="^irssi$"] → 3
|
2009-05-16 17:32:36 +02:00
|
|
|
|
----------------------
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2010-03-15 18:23:12 +01:00
|
|
|
|
Note that the arrow is not required, it just looks good :-). If you decide to
|
2011-05-28 21:58:58 +02:00
|
|
|
|
use it, it has to be a UTF-8 encoded arrow, not `->` or something like that.
|
2010-03-15 18:23:12 +01:00
|
|
|
|
|
2011-09-11 23:15:05 +02:00
|
|
|
|
To get the class and instance, you can use +xprop+. After clicking on the
|
|
|
|
|
window, you will see the following output:
|
|
|
|
|
|
2011-12-24 15:36:11 +01:00
|
|
|
|
*xprop*:
|
2011-09-11 23:15:05 +02:00
|
|
|
|
-----------------------------------
|
|
|
|
|
WM_CLASS(STRING) = "irssi", "URxvt"
|
|
|
|
|
-----------------------------------
|
|
|
|
|
|
|
|
|
|
The first part of the WM_CLASS is the instance ("irssi" in this example), the
|
|
|
|
|
second part is the class ("URxvt" in this example).
|
|
|
|
|
|
|
|
|
|
Should you have any problems with assignments, make sure to check the i3
|
|
|
|
|
logfile first (see http://i3wm.org/docs/debugging.html). It includes more
|
|
|
|
|
details about the matching process and the window’s actual class, instance and
|
|
|
|
|
title when starting up.
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
=== Automatically starting applications on i3 startup
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-07-12 12:24:01 +02:00
|
|
|
|
By using the +exec+ keyword outside a keybinding, you can configure
|
|
|
|
|
which commands will be performed by i3 on initial startup. +exec+
|
|
|
|
|
commands will not run when restarting i3, if you need a command to run
|
|
|
|
|
also when restarting i3 you should use the +exec_always+
|
|
|
|
|
keyword. These commands will be run in order.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
2011-07-12 12:24:01 +02:00
|
|
|
|
-------------------
|
2011-10-25 23:21:09 +02:00
|
|
|
|
exec [--no-startup-id] command
|
|
|
|
|
exec_always [--no-startup-id] command
|
2011-07-12 12:24:01 +02:00
|
|
|
|
-------------------
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
--------------------------------
|
2011-10-21 23:22:02 +02:00
|
|
|
|
exec chromium
|
2011-07-12 12:24:01 +02:00
|
|
|
|
exec_always ~/my_script.sh
|
2011-10-25 23:21:09 +02:00
|
|
|
|
|
|
|
|
|
# Execute the terminal emulator urxvt, which is not yet startup-notification aware.
|
|
|
|
|
exec --no-startup-id urxvt
|
2009-06-01 14:59:25 +02:00
|
|
|
|
--------------------------------
|
|
|
|
|
|
2011-10-25 23:21:09 +02:00
|
|
|
|
The flag --no-startup-id is explained in <<exec>>.
|
|
|
|
|
|
2009-12-07 10:25:12 +01:00
|
|
|
|
[[workspace_screen]]
|
|
|
|
|
|
2010-03-25 03:26:59 +01:00
|
|
|
|
=== Automatically putting workspaces on specific screens
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
If you assign clients to workspaces, it might be handy to put the
|
2010-03-15 18:23:12 +01:00
|
|
|
|
workspaces on specific screens. Also, the assignment of workspaces to screens
|
2010-03-16 20:28:43 +01:00
|
|
|
|
will determine which workspace i3 uses for a new screen when adding screens
|
2010-03-15 18:23:12 +01:00
|
|
|
|
or when starting (e.g., by default it will use 1 for the first screen, 2 for
|
|
|
|
|
the second screen and so on).
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------------------
|
2011-10-27 23:45:34 +02:00
|
|
|
|
workspace <workspace> output <output>
|
2009-08-19 12:59:13 +02:00
|
|
|
|
----------------------------------
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
The 'output' is the name of the RandR output you attach your screen to. On a
|
2010-03-02 13:35:43 +01:00
|
|
|
|
laptop, you might have VGA1 and LVDS1 as output names. You can see the
|
|
|
|
|
available outputs by running +xrandr --current+.
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-10-27 23:45:34 +02:00
|
|
|
|
If you use named workspaces, they must be quoted:
|
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
*Examples*:
|
|
|
|
|
---------------------------
|
2010-03-02 13:35:43 +01:00
|
|
|
|
workspace 1 output LVDS1
|
|
|
|
|
workspace 5 output VGA1
|
2011-10-27 23:45:34 +02:00
|
|
|
|
workspace "2: vim" output VGA1
|
2009-08-19 12:59:13 +02:00
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
|
|
=== Changing colors
|
|
|
|
|
|
2011-07-29 13:31:37 +02:00
|
|
|
|
You can change all colors which i3 uses to draw the window decorations.
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
--------------------------------------------
|
2012-01-22 12:22:15 +01:00
|
|
|
|
colorclass border background text indicator
|
2009-08-19 12:59:13 +02:00
|
|
|
|
--------------------------------------------
|
|
|
|
|
|
|
|
|
|
Where colorclass can be one of:
|
|
|
|
|
|
|
|
|
|
client.focused::
|
|
|
|
|
A client which currently has the focus.
|
|
|
|
|
client.focused_inactive::
|
|
|
|
|
A client which is the focused one of its container, but it does not have
|
|
|
|
|
the focus at the moment.
|
|
|
|
|
client.unfocused::
|
|
|
|
|
A client which is not the focused one of its container.
|
2009-09-06 22:40:11 +02:00
|
|
|
|
client.urgent::
|
|
|
|
|
A client which has its urgency hint activated.
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2010-09-25 03:01:56 +02:00
|
|
|
|
You can also specify the color to be used to paint the background of the client
|
|
|
|
|
windows. This color will be used to paint the window on top of which the client
|
|
|
|
|
will be rendered.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
-----------------------
|
|
|
|
|
client.background color
|
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
|
|
Only clients that do not cover the whole area of this window expose the color
|
|
|
|
|
used to paint it. If you use a color other than black for your terminals, you
|
|
|
|
|
most likely want to set the client background color to the same color as your
|
|
|
|
|
terminal program's background color to avoid black gaps between the rendered
|
2011-12-23 16:29:26 +01:00
|
|
|
|
area of the terminal and the i3 border.
|
2010-09-25 03:01:56 +02:00
|
|
|
|
|
2010-03-15 18:23:12 +01:00
|
|
|
|
Colors are in HTML hex format (#rrggbb), see the following example:
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-08-27 16:47:36 +02:00
|
|
|
|
*Examples (default colors)*:
|
2012-01-22 12:22:15 +01:00
|
|
|
|
---------------------------------------------------------
|
|
|
|
|
# class border backgr. text indicator
|
|
|
|
|
client.focused #4c7899 #285577 #ffffff #2e9ef4
|
|
|
|
|
client.focused_inactive #333333 #5f676a #ffffff #484e50
|
|
|
|
|
client.unfocused #333333 #222222 #888888 #292d2e
|
|
|
|
|
client.urgent #2f343a #900000 #ffffff #900000
|
|
|
|
|
---------------------------------------------------------
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
Note that for the window decorations, the color around the child window is the
|
|
|
|
|
background color, and the border color is only the two thin lines at the top of
|
2009-12-15 19:11:01 +01:00
|
|
|
|
the window.
|
|
|
|
|
|
2012-01-22 12:22:15 +01:00
|
|
|
|
The indicator color is used for indicating where a new window will be opened.
|
|
|
|
|
For horizontal split containers, the right border will be painted in indicator
|
|
|
|
|
color, for vertical split containers, the bottom border. This only applies to
|
|
|
|
|
single windows within a split container, which are otherwise indistinguishable
|
|
|
|
|
from single windows outside of a split container.
|
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
=== Interprocess communication
|
|
|
|
|
|
2010-03-15 18:23:12 +01:00
|
|
|
|
i3 uses unix sockets to provide an IPC interface. This allows third-party
|
2010-03-21 01:50:10 +01:00
|
|
|
|
programs to get information from i3, such as the current workspaces
|
|
|
|
|
(to display a workspace bar), and to control i3.
|
2010-03-15 18:23:12 +01:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
The IPC socket is enabled by default and will be created in
|
2011-12-18 18:53:21 +01:00
|
|
|
|
+/tmp/i3-%u.XXXXXX/ipc-socket.%p+ where +%u+ is your UNIX username, +%p+ is
|
|
|
|
|
the PID of i3 and XXXXXX is a string of random characters from the portable
|
|
|
|
|
filename character set (see mkdtemp(3)).
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
You can override the default path through the environment-variable +I3SOCK+ or
|
2011-08-25 14:11:31 +02:00
|
|
|
|
by specifying the +ipc-socket+ directive. This is discouraged, though, since i3
|
2011-12-18 18:53:21 +01:00
|
|
|
|
does the right thing by default. If you decide to change it, it is strongly
|
|
|
|
|
recommended to set this to a location in your home directory so that no other
|
|
|
|
|
user can create that directory.
|
2011-01-11 04:39:48 +01:00
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
*Examples*:
|
|
|
|
|
----------------------------
|
2011-12-18 18:53:21 +01:00
|
|
|
|
ipc-socket ~/.i3/i3-ipc.sock
|
2009-08-19 12:59:13 +02:00
|
|
|
|
----------------------------
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
You can then use the +i3-msg+ application to perform any command listed in
|
|
|
|
|
the next section.
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-07-29 00:26:30 +02:00
|
|
|
|
=== Focus follows mouse
|
2010-01-29 21:58:28 +01:00
|
|
|
|
|
2012-06-10 21:30:14 +02:00
|
|
|
|
By default, window focus follows your mouse movements. However, if you have a
|
|
|
|
|
setup where your mouse usually is in your way (like a touchpad on your laptop
|
|
|
|
|
which you do not want to disable completely), you might want to disable 'focus
|
|
|
|
|
follows mouse' and control focus only by using your keyboard. The mouse will
|
|
|
|
|
still be useful inside the currently active window (for example to click on
|
|
|
|
|
links in your browser window).
|
2010-01-29 21:58:28 +01:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------------
|
|
|
|
|
focus_follows_mouse <yes|no>
|
|
|
|
|
----------------------------
|
|
|
|
|
|
2011-07-29 00:26:30 +02:00
|
|
|
|
*Example*:
|
2010-01-29 21:58:28 +01:00
|
|
|
|
----------------------
|
|
|
|
|
focus_follows_mouse no
|
|
|
|
|
----------------------
|
|
|
|
|
|
2011-07-29 00:26:30 +02:00
|
|
|
|
=== Popups during fullscreen mode
|
|
|
|
|
|
|
|
|
|
When you are in fullscreen mode, some applications still open popup windows
|
|
|
|
|
(take Xpdf for example). This is because these applications may not be aware
|
|
|
|
|
that they are in fullscreen mode (they do not check the corresponding hint).
|
|
|
|
|
There are two things which are possible to do in this situation:
|
|
|
|
|
|
|
|
|
|
1. Just ignore the popup (don’t map it). This won’t interrupt you while you are
|
|
|
|
|
in fullscreen. However, some apps might react badly to this (deadlock until
|
|
|
|
|
you go out of fullscreen).
|
|
|
|
|
2. Leave fullscreen mode. This is the default.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
-------------------------------------------------
|
|
|
|
|
popup_during_fullscreen <ignore|leave_fullscreen>
|
|
|
|
|
-------------------------------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
------------------------------
|
|
|
|
|
popup_during_fullscreen ignore
|
|
|
|
|
------------------------------
|
|
|
|
|
|
2011-08-28 14:54:58 +02:00
|
|
|
|
=== Focus wrapping
|
|
|
|
|
|
|
|
|
|
When being in a tabbed or stacked container, the first container will be
|
|
|
|
|
focused when you use +focus down+ on the last container -- the focus wraps. If
|
|
|
|
|
however there is another stacked/tabbed container in that direction, focus will
|
|
|
|
|
be set on that container. This is the default behaviour so you can navigate to
|
|
|
|
|
all your windows without having to use +focus parent+.
|
|
|
|
|
|
|
|
|
|
If you want the focus to *always* wrap and you are aware of using +focus
|
|
|
|
|
parent+ to switch to different containers, you can use the
|
|
|
|
|
+force_focus_wrapping+ configuration directive. After enabling it, the focus
|
|
|
|
|
will always wrap.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
-----------------------------
|
|
|
|
|
force_focus_wrapping <yes|no>
|
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
------------------------
|
|
|
|
|
force_focus_wrapping yes
|
|
|
|
|
------------------------
|
|
|
|
|
|
2011-09-20 00:18:40 +02:00
|
|
|
|
=== Forcing Xinerama
|
|
|
|
|
|
|
|
|
|
As explained in-depth in <http://i3wm.org/docs/multi-monitor.html>, some X11
|
|
|
|
|
video drivers (especially the nVidia binary driver) only provide support for
|
|
|
|
|
Xinerama instead of RandR. In such a situation, i3 must be told to use the
|
|
|
|
|
inferior Xinerama API explicitly and therefore don’t provide support for
|
|
|
|
|
reconfiguring your screens on the fly (they are read only once on startup and
|
|
|
|
|
that’s it).
|
|
|
|
|
|
|
|
|
|
For people who do cannot modify their +~/.xsession+ to add the
|
|
|
|
|
+--force-xinerama+ commandline parameter, a configuration option is provided:
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
-----------------------
|
|
|
|
|
force_xinerama <yes|no>
|
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
------------------
|
|
|
|
|
force_xinerama yes
|
|
|
|
|
------------------
|
|
|
|
|
|
|
|
|
|
Also note that your output names are not descriptive (like +HDMI1+) when using
|
|
|
|
|
Xinerama, instead they are counted up, starting at 0: +xinerama-0+, +xinerama-1+, …
|
|
|
|
|
|
2011-10-18 00:17:56 +02:00
|
|
|
|
=== Automatic back-and-forth when switching to the current workspace
|
|
|
|
|
|
|
|
|
|
This configuration directive enables automatic +workspace back_and_forth+ (see
|
|
|
|
|
<<back_and_forth>>) when switching to the workspace that is currently focused.
|
|
|
|
|
|
|
|
|
|
For instance: Assume you are on workspace "1: www" and switch to "2: IM" using
|
|
|
|
|
mod+2 because somebody sent you a message. You don’t need to remember where you
|
|
|
|
|
came from now, you can just press mod+2 again to switch back to "1: www".
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
--------------------------------------
|
|
|
|
|
workspace_auto_back_and_forth <yes|no>
|
|
|
|
|
--------------------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
---------------------------------
|
|
|
|
|
workspace_auto_back_and_forth yes
|
|
|
|
|
---------------------------------
|
|
|
|
|
|
2011-10-21 00:38:34 +02:00
|
|
|
|
== Configuring i3bar
|
|
|
|
|
|
|
|
|
|
The bar at the bottom of your monitor is drawn by a separate process called
|
|
|
|
|
i3bar. Having this part of "the i3 user interface" in a separate process has
|
|
|
|
|
several advantages:
|
|
|
|
|
|
|
|
|
|
1. It is a modular approach. If you don’t need a workspace bar at all, or if
|
|
|
|
|
you prefer a different one (dzen2, xmobar, maybe even gnome-panel?), you can
|
|
|
|
|
just remove the i3bar configuration and start your favorite bar instead.
|
|
|
|
|
2. It follows the UNIX philosophy of "Make each program do one thing well".
|
|
|
|
|
While i3 manages your windows well, i3bar is good at displaying a bar on
|
|
|
|
|
each monitor (unless you configure it otherwise).
|
|
|
|
|
3. It leads to two separate, clean codebases. If you want to understand i3, you
|
|
|
|
|
don’t need to bother with the details of i3bar and vice versa.
|
|
|
|
|
|
|
|
|
|
That said, i3bar is configured in the same configuration file as i3. This is
|
|
|
|
|
because it is tightly coupled with i3 (in contrary to i3lock or i3status which
|
|
|
|
|
are useful for people using other window managers). Therefore, it makes no
|
|
|
|
|
sense to use a different configuration place when we already have a good
|
|
|
|
|
configuration infrastructure in place.
|
|
|
|
|
|
|
|
|
|
Configuring your workspace bar starts with opening a +bar+ block. You can have
|
|
|
|
|
multiple bar blocks to use different settings for different outputs (monitors):
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
---------------------------
|
|
|
|
|
bar {
|
|
|
|
|
status_command i3status
|
|
|
|
|
}
|
|
|
|
|
---------------------------
|
|
|
|
|
|
2011-11-24 21:53:29 +01:00
|
|
|
|
=== i3bar command
|
|
|
|
|
|
|
|
|
|
By default i3 will just pass +i3bar+ and let your shell handle the execution,
|
|
|
|
|
searching your +$PATH+ for a correct version.
|
|
|
|
|
If you have a different +i3bar+ somewhere or the binary is not in your +$PATH+ you can
|
|
|
|
|
tell i3 what to execute.
|
|
|
|
|
|
|
|
|
|
The specified command will be passed to +sh -c+, so you can use globbing and
|
|
|
|
|
have to have correct quoting etc.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------
|
|
|
|
|
i3bar_command command
|
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
-------------------------------------------------
|
|
|
|
|
bar {
|
|
|
|
|
i3bar_command /home/user/bin/i3bar
|
|
|
|
|
}
|
|
|
|
|
-------------------------------------------------
|
|
|
|
|
|
2011-12-30 00:59:32 +01:00
|
|
|
|
[[status_command]]
|
2011-10-21 00:38:34 +02:00
|
|
|
|
=== Statusline command
|
|
|
|
|
|
|
|
|
|
i3bar can run a program and display every line of its +stdout+ output on the
|
|
|
|
|
right hand side of the bar. This is useful to display system information like
|
|
|
|
|
your current IP address, battery status or date/time.
|
|
|
|
|
|
|
|
|
|
The specified command will be passed to +sh -c+, so you can use globbing and
|
|
|
|
|
have to have correct quoting etc.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------
|
|
|
|
|
status_command command
|
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
-------------------------------------------------
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
status_command i3status --config ~/.i3status.conf
|
|
|
|
|
}
|
2011-10-21 00:38:34 +02:00
|
|
|
|
-------------------------------------------------
|
|
|
|
|
|
|
|
|
|
=== Display mode
|
|
|
|
|
|
|
|
|
|
You can have i3bar either be visible permanently at one edge of the screen
|
|
|
|
|
(+dock+ mode) or make it show up when you press your modifier key (+hide+
|
2012-01-08 13:52:45 +01:00
|
|
|
|
mode). The modifier key can be configured using the +modifier+ option.
|
2011-10-21 00:38:34 +02:00
|
|
|
|
|
|
|
|
|
The hide mode maximizes screen space that can be used for actual windows. Also,
|
|
|
|
|
i3bar sends the +SIGSTOP+ and +SIGCONT+ signals to the statusline process to
|
|
|
|
|
save battery power.
|
|
|
|
|
|
2012-01-08 13:52:45 +01:00
|
|
|
|
The default is dock mode; in hide mode, the default modifier is Mod4 (usually
|
|
|
|
|
the windows key).
|
2011-10-21 00:38:34 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------
|
|
|
|
|
mode <dock|hide>
|
2012-01-08 13:52:45 +01:00
|
|
|
|
modifier <Modifier>
|
2011-10-21 00:38:34 +02:00
|
|
|
|
----------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
----------------
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
mode hide
|
2012-01-08 13:52:45 +01:00
|
|
|
|
modifier Mod1
|
2011-11-16 00:42:41 +01:00
|
|
|
|
}
|
2011-10-21 00:38:34 +02:00
|
|
|
|
----------------
|
|
|
|
|
|
2012-01-08 13:52:45 +01:00
|
|
|
|
Available modifiers are Mod1-Mod5, Shift, Control (see +xmodmap(1)+).
|
|
|
|
|
|
2011-12-30 00:59:32 +01:00
|
|
|
|
[[i3bar_position]]
|
2011-10-21 00:38:34 +02:00
|
|
|
|
=== Position
|
|
|
|
|
|
|
|
|
|
This option determines in which edge of the screen i3bar should show up.
|
|
|
|
|
|
|
|
|
|
The default is bottom.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------------
|
|
|
|
|
position <top|bottom>
|
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
---------------------
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
position top
|
|
|
|
|
}
|
2011-10-21 00:38:34 +02:00
|
|
|
|
---------------------
|
|
|
|
|
|
2011-10-21 23:22:02 +02:00
|
|
|
|
=== Output(s)
|
|
|
|
|
|
|
|
|
|
You can restrict i3bar to one or more outputs (monitors). The default is to
|
|
|
|
|
handle all outputs. Restricting the outputs is useful for using different
|
|
|
|
|
options for different outputs by using multiple 'bar' blocks.
|
|
|
|
|
|
2011-11-13 13:54:10 +01:00
|
|
|
|
To make a particular i3bar instance handle multiple outputs, specify the output
|
|
|
|
|
directive multiple times.
|
|
|
|
|
|
2011-10-21 23:22:02 +02:00
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------
|
|
|
|
|
output <output>
|
|
|
|
|
---------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
-------------------------------
|
|
|
|
|
# big monitor: everything
|
|
|
|
|
bar {
|
2011-11-16 00:42:41 +01:00
|
|
|
|
# The display is connected either via HDMI or via DisplayPort
|
|
|
|
|
output HDMI2
|
|
|
|
|
output DP2
|
|
|
|
|
status_command i3status
|
2011-10-21 23:22:02 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# laptop monitor: bright colors and i3status with less modules.
|
|
|
|
|
bar {
|
2011-11-16 00:42:41 +01:00
|
|
|
|
output LVDS1
|
|
|
|
|
status_command i3status --config ~/.i3status-small.conf
|
|
|
|
|
colors {
|
|
|
|
|
background #000000
|
|
|
|
|
statusline #ffffff
|
|
|
|
|
}
|
2011-10-21 23:22:02 +02:00
|
|
|
|
}
|
|
|
|
|
-------------------------------
|
|
|
|
|
|
2011-10-21 20:50:40 +02:00
|
|
|
|
=== Tray output
|
|
|
|
|
|
|
|
|
|
i3bar by default provides a system tray area where programs such as
|
|
|
|
|
NetworkManager, VLC, Pidgin, etc. can place little icons.
|
|
|
|
|
|
|
|
|
|
You can configure on which output (monitor) the icons should be displayed or
|
|
|
|
|
you can turn off the functionality entirely.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
-------------------------
|
2012-04-01 16:07:15 +02:00
|
|
|
|
tray_output <none|primary|output>
|
2011-10-21 20:50:40 +02:00
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
-------------------------
|
|
|
|
|
# disable system tray
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
tray_output none
|
|
|
|
|
}
|
2011-10-21 20:50:40 +02:00
|
|
|
|
|
2012-04-01 16:07:15 +02:00
|
|
|
|
# show tray icons on the primary monitor
|
|
|
|
|
tray_output primary
|
|
|
|
|
|
2011-10-21 20:50:40 +02:00
|
|
|
|
# show tray icons on the big monitor
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
tray_output HDMI2
|
|
|
|
|
}
|
2011-10-21 20:50:40 +02:00
|
|
|
|
-------------------------
|
|
|
|
|
|
2012-04-01 16:07:15 +02:00
|
|
|
|
Note that you might not have a primary output configured yet. To do so, run:
|
|
|
|
|
-------------------------
|
|
|
|
|
xrandr --output <output> --primary
|
|
|
|
|
-------------------------
|
|
|
|
|
|
2011-10-21 00:38:34 +02:00
|
|
|
|
=== Font
|
|
|
|
|
|
|
|
|
|
Specifies the font (again, X core font, not Xft, just like in i3) to be used in
|
|
|
|
|
the bar.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------------
|
|
|
|
|
font <font>
|
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
--------------------------------------------------------------
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
|
|
|
|
}
|
2011-10-21 00:38:34 +02:00
|
|
|
|
--------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
=== Workspace buttons
|
|
|
|
|
|
|
|
|
|
Specifies whether workspace buttons should be shown or not. This is useful if
|
|
|
|
|
you want to display a statusline-only bar containing additional information.
|
|
|
|
|
|
|
|
|
|
The default is to show workspace buttons.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
--------------------------
|
|
|
|
|
workspace_buttons <yes|no>
|
|
|
|
|
--------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
--------------------
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
workspace_buttons no
|
|
|
|
|
}
|
2011-10-21 00:38:34 +02:00
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
|
|
=== Colors
|
|
|
|
|
|
|
|
|
|
As with i3, colors are in HTML hex format (#rrggbb). The following colors can
|
|
|
|
|
be configured at the moment:
|
|
|
|
|
|
|
|
|
|
background::
|
|
|
|
|
Background color of the bar.
|
|
|
|
|
statusline::
|
|
|
|
|
Text color to be used for the statusline.
|
2011-10-23 14:17:32 +02:00
|
|
|
|
focused_workspace::
|
2012-01-20 22:36:50 +01:00
|
|
|
|
Border, background and text color for a workspace button when the workspace
|
2011-10-21 00:38:34 +02:00
|
|
|
|
has focus.
|
2011-10-23 14:17:32 +02:00
|
|
|
|
active_workspace::
|
2012-01-20 22:36:50 +01:00
|
|
|
|
Border, background and text color for a workspace button when the workspace
|
2011-10-21 00:38:34 +02:00
|
|
|
|
is active (visible) on some output, but the focus is on another one.
|
|
|
|
|
You can only tell this apart from the focused workspace when you are
|
|
|
|
|
using multiple monitors.
|
2011-10-23 14:17:32 +02:00
|
|
|
|
inactive_workspace::
|
2012-01-20 22:36:50 +01:00
|
|
|
|
Border, background and text color for a workspace button when the workspace
|
2011-10-21 00:38:34 +02:00
|
|
|
|
does not have focus and is not active (visible) on any output. This
|
|
|
|
|
will be the case for most workspaces.
|
2011-10-23 14:17:32 +02:00
|
|
|
|
urgent_workspace::
|
2012-01-20 22:36:50 +01:00
|
|
|
|
Border, background and text color for a workspace button when the workspace
|
2011-10-21 00:38:34 +02:00
|
|
|
|
window with the urgency hint set.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------------------------
|
|
|
|
|
colors {
|
|
|
|
|
background <color>
|
|
|
|
|
statusline <color>
|
|
|
|
|
|
2012-01-20 22:36:50 +01:00
|
|
|
|
colorclass <border> <background> <text>
|
2011-10-21 00:38:34 +02:00
|
|
|
|
}
|
|
|
|
|
----------------------------------------
|
|
|
|
|
|
2012-01-20 22:36:50 +01:00
|
|
|
|
*Example (default colors)*:
|
2011-10-21 00:38:34 +02:00
|
|
|
|
--------------------------------------
|
2011-11-16 00:42:41 +01:00
|
|
|
|
bar {
|
|
|
|
|
colors {
|
|
|
|
|
background #000000
|
|
|
|
|
statusline #ffffff
|
|
|
|
|
|
2012-01-20 22:36:50 +01:00
|
|
|
|
focused_workspace #4c7899 #285577 #ffffff
|
|
|
|
|
active_workspace #333333 #5f676a #ffffff
|
|
|
|
|
inactive_workspace #333333 #222222 #888888
|
|
|
|
|
urgent_workspace #2f343a #900000 #ffffff
|
2011-11-16 00:42:41 +01:00
|
|
|
|
}
|
2011-10-21 00:38:34 +02:00
|
|
|
|
}
|
|
|
|
|
--------------------------------------
|
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
== List of commands
|
|
|
|
|
|
2011-08-28 18:02:49 +02:00
|
|
|
|
Commands are what you bind to specific keypresses. You can also issue commands
|
|
|
|
|
at runtime without pressing a key by using the IPC interface. An easy way to
|
|
|
|
|
do this is to use the +i3-msg+ utility:
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
--------------------------
|
|
|
|
|
# execute this on your shell to make the current container borderless
|
|
|
|
|
i3-msg border none
|
|
|
|
|
--------------------------
|
|
|
|
|
|
|
|
|
|
Commands can be chained by using +;+ (a semicolon). So, to move a window to a
|
|
|
|
|
specific workspace and immediately switch to that workspace, you can configure
|
|
|
|
|
the following keybinding:
|
|
|
|
|
|
|
|
|
|
*Example*:
|
2012-01-09 19:57:04 +01:00
|
|
|
|
--------------------------------------------------------
|
|
|
|
|
bindsym mod+x move container to workspace 3; workspace 3
|
|
|
|
|
--------------------------------------------------------
|
2011-08-28 18:02:49 +02:00
|
|
|
|
|
2011-08-29 16:04:42 +02:00
|
|
|
|
[[command_criteria]]
|
|
|
|
|
|
2011-08-28 18:02:49 +02:00
|
|
|
|
Furthermore, you can change the scope of a command, that is, which containers
|
|
|
|
|
should be affected by that command, by using various criteria. These are
|
|
|
|
|
prefixed in square brackets to every command. If you want to kill all windows
|
|
|
|
|
which have the class Firefox, use:
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
------------------------------------
|
|
|
|
|
bindsym mod+x [class="Firefox"] kill
|
2011-09-11 22:17:13 +02:00
|
|
|
|
|
|
|
|
|
# same thing, but case-insensitive
|
|
|
|
|
bindsym mod+x [class="(?i)firefox"] kill
|
2011-08-28 18:02:49 +02:00
|
|
|
|
------------------------------------
|
|
|
|
|
|
|
|
|
|
The criteria which are currently implemented are:
|
|
|
|
|
|
|
|
|
|
class::
|
|
|
|
|
Compares the window class (the second part of WM_CLASS)
|
|
|
|
|
instance::
|
|
|
|
|
Compares the window instance (the first part of WM_CLASS)
|
2011-09-18 17:06:52 +02:00
|
|
|
|
window_role::
|
|
|
|
|
Compares the window role (WM_WINDOW_ROLE).
|
2011-08-28 18:02:49 +02:00
|
|
|
|
id::
|
|
|
|
|
Compares the X11 window ID, which you can get via +xwininfo+ for example.
|
|
|
|
|
title::
|
|
|
|
|
Compares the X11 window title (_NET_WM_NAME or WM_NAME as fallback).
|
2012-01-25 00:00:27 +01:00
|
|
|
|
urgent::
|
|
|
|
|
Compares the urgent state of the window. Can be "latest" or "oldest".
|
|
|
|
|
Matches the latest or oldest urgent window, respectively.
|
|
|
|
|
(The following aliases are also available: newest, last, recent, first)
|
2011-09-30 20:46:59 +02:00
|
|
|
|
con_mark::
|
2011-08-28 18:02:49 +02:00
|
|
|
|
Compares the mark set for this container, see <<vim_like_marks>>.
|
|
|
|
|
con_id::
|
|
|
|
|
Compares the i3-internal container ID, which you can get via the IPC
|
|
|
|
|
interface. Handy for scripting.
|
|
|
|
|
|
2011-09-18 17:06:52 +02:00
|
|
|
|
The criteria +class+, +instance+, +role+, +title+ and +mark+ are actually
|
|
|
|
|
regular expressions (PCRE). See +pcresyntax(3)+ or +perldoc perlre+ for
|
|
|
|
|
information on how to use them.
|
2011-08-28 18:02:49 +02:00
|
|
|
|
|
2011-10-25 23:21:09 +02:00
|
|
|
|
[[exec]]
|
|
|
|
|
|
2011-10-25 23:18:40 +02:00
|
|
|
|
=== Executing applications (exec)
|
|
|
|
|
|
|
|
|
|
What good is a window manager if you can’t actually start any applications?
|
|
|
|
|
The exec command starts an application by passing the command you specify to a
|
|
|
|
|
shell. This implies that you can use globbing (wildcards) and programs will be
|
|
|
|
|
searched in your $PATH.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
------------------------------
|
|
|
|
|
exec [--no-startup-id] command
|
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
------------------------------
|
|
|
|
|
# Start the GIMP
|
|
|
|
|
bindsym mod+g exec gimp
|
|
|
|
|
|
|
|
|
|
# Start the terminal emulator urxvt which is not yet startup-notification-aware
|
2011-11-15 21:20:54 +01:00
|
|
|
|
bindsym mod+Return exec --no-startup-id urxvt
|
2011-10-25 23:18:40 +02:00
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
|
|
The +--no-startup-id+ parameter disables startup-notification support for this
|
|
|
|
|
particular exec command. With startup-notification, i3 can make sure that a
|
|
|
|
|
window appears on the workspace on which you used the exec command. Also, it
|
|
|
|
|
will change the X11 cursor to +watch+ (a clock) while the application is
|
|
|
|
|
launching. So, if an application is not startup-notification aware (most GTK
|
|
|
|
|
and Qt using applications seem to be, though), you will end up with a watch
|
|
|
|
|
cursor for 60 seconds.
|
|
|
|
|
|
2011-07-29 01:12:19 +02:00
|
|
|
|
=== Splitting containers
|
|
|
|
|
|
|
|
|
|
The split command makes the current window a split container. Split containers
|
|
|
|
|
can contain multiple windows. Every split container has an orientation, it is
|
|
|
|
|
either split horizontally (a new window gets placed to the right of the current
|
|
|
|
|
one) or vertically (a new window gets placed below the current one).
|
|
|
|
|
|
|
|
|
|
If you apply this command to a split container with the same orientation,
|
|
|
|
|
nothing will happen. If you use a different orientation, the split container’s
|
|
|
|
|
orientation will be changed (if it does not have more than one window).
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------------------
|
|
|
|
|
split <vertical|horizontal>
|
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
|
|
*Example*:
|
2011-08-07 18:03:29 +02:00
|
|
|
|
------------------------------
|
|
|
|
|
bindsym mod+v split vertical
|
|
|
|
|
bindsym mod+h split horizontal
|
|
|
|
|
------------------------------
|
2011-07-29 01:12:19 +02:00
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
=== Manipulating layout
|
|
|
|
|
|
2011-07-29 13:31:37 +02:00
|
|
|
|
Use +layout default+, +layout stacking+ or +layout tabbed+ to change the
|
|
|
|
|
current container layout to default, stacking or tabbed layout, respectively.
|
|
|
|
|
|
|
|
|
|
To make the current window (!) fullscreen, use +fullscreen+, to make
|
2011-06-10 02:06:47 +02:00
|
|
|
|
it floating (or tiling again) use +floating enable+ respectively +floating disable+
|
|
|
|
|
(or +floating toggle+):
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
--------------
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+s layout stacking
|
|
|
|
|
bindsym mod+l layout default
|
|
|
|
|
bindsym mod+w layout tabbed
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
|
|
|
|
# Toggle fullscreen
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+f fullscreen
|
2010-03-08 02:02:35 +01:00
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
# Toggle floating/tiling
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+t floating toggle
|
2009-08-19 12:59:13 +02:00
|
|
|
|
--------------
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
=== Focusing/Moving containers
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2012-01-08 13:02:59 +01:00
|
|
|
|
To change the focus, use the focus command: +focus left+, +focus right+, +focus
|
|
|
|
|
down+ and +focus up+.
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-07-04 17:09:52 +02:00
|
|
|
|
There are a few special parameters you can use for the focus command:
|
|
|
|
|
|
|
|
|
|
parent::
|
|
|
|
|
Sets focus to the +Parent Container+ of the current +Container+.
|
|
|
|
|
child::
|
|
|
|
|
The opposite of +focus parent+, sets the focus to the last focused
|
|
|
|
|
child container.
|
|
|
|
|
floating::
|
|
|
|
|
Sets focus to the last focused floating container.
|
|
|
|
|
tiling::
|
|
|
|
|
Sets focus to the last focused tiling container.
|
|
|
|
|
mode_toggle::
|
|
|
|
|
Toggles between floating/tiling containers.
|
2012-01-08 13:02:59 +01:00
|
|
|
|
output::
|
|
|
|
|
Followed by a direction or an output name, this will focus the
|
|
|
|
|
corresponding output.
|
2011-07-04 17:09:52 +02:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
For moving, use +move left+, +move right+, +move down+ and +move up+.
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-10-27 22:52:39 +02:00
|
|
|
|
*Syntax*:
|
|
|
|
|
-----------------------------------
|
|
|
|
|
focus <left|right|down|up>
|
|
|
|
|
focus <parent|child|floating|tiling|mode_toggle>
|
2012-01-08 13:02:59 +01:00
|
|
|
|
focus output <<left|right|down|up>|output>
|
2011-10-27 22:52:39 +02:00
|
|
|
|
move <left|right|down|up> [<px> px]
|
2012-03-23 13:39:17 +01:00
|
|
|
|
move [absolute] position [[<px> px] [<px> px]|center]
|
2011-10-27 22:52:39 +02:00
|
|
|
|
-----------------------------------
|
|
|
|
|
|
|
|
|
|
Note that the amount of pixels you can specify for the +move+ command is only
|
|
|
|
|
relevant for floating containers. The default amount is 10 pixels.
|
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
*Examples*:
|
|
|
|
|
----------------------
|
2011-10-27 22:52:39 +02:00
|
|
|
|
# Focus container on the left, bottom, top, right:
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+j focus left
|
|
|
|
|
bindsym mod+k focus down
|
|
|
|
|
bindsym mod+l focus up
|
|
|
|
|
bindsym mod+semicolon focus right
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-07-04 17:09:52 +02:00
|
|
|
|
# Focus parent container
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+u focus parent
|
2011-07-04 17:09:52 +02:00
|
|
|
|
|
|
|
|
|
# Focus last floating/tiling container
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+g focus mode_toggle
|
2011-07-04 17:09:52 +02:00
|
|
|
|
|
2012-01-08 13:02:59 +01:00
|
|
|
|
# Focus the output right to the current one
|
|
|
|
|
bindsym mod+x focus output right
|
|
|
|
|
|
|
|
|
|
# Focus the big output
|
|
|
|
|
bindsym mod+x focus output HDMI-2
|
|
|
|
|
|
2011-10-27 22:52:39 +02:00
|
|
|
|
# Move container to the left, bottom, top, right:
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+j move left
|
|
|
|
|
bindsym mod+k move down
|
|
|
|
|
bindsym mod+l move up
|
|
|
|
|
bindsym mod+semicolon move right
|
2011-10-27 22:52:39 +02:00
|
|
|
|
|
|
|
|
|
# Move container, but make floating containers
|
|
|
|
|
# move more than the default
|
|
|
|
|
bindsym mod+j move left 20 px
|
2012-03-23 13:39:17 +01:00
|
|
|
|
|
|
|
|
|
# Move floating container to the center
|
|
|
|
|
# of all outputs
|
|
|
|
|
bindsym mod+c move absolute position center
|
2009-08-19 12:59:13 +02:00
|
|
|
|
----------------------
|
|
|
|
|
|
2011-08-25 14:11:31 +02:00
|
|
|
|
=== Changing (named) workspaces/moving to workspaces
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
To change to a specific workspace, use the +workspace+ command, followed by the
|
2011-07-28 22:51:34 +02:00
|
|
|
|
number or name of the workspace. To move containers to specific workspaces, use
|
2012-01-09 19:57:04 +01:00
|
|
|
|
+move container to workspace+.
|
2011-05-28 21:58:58 +02:00
|
|
|
|
|
2011-06-10 16:03:59 +02:00
|
|
|
|
You can also switch to the next and previous workspace with the commands
|
|
|
|
|
+workspace next+ and +workspace prev+, which is handy, for example, if you have
|
|
|
|
|
workspace 1, 3, 4 and 9 and you want to cycle through them with a single key
|
2012-01-08 17:30:48 +01:00
|
|
|
|
combination. To restrict those to the current output, use +workspace
|
|
|
|
|
next_on_output+ and +workspace prev_on_output+. Similarly, you can use +move
|
2012-05-09 23:45:12 +02:00
|
|
|
|
container to workspace next+, +move container to workspace prev+ to move a
|
|
|
|
|
container to the next/previous workspace and +move container to workspace current+
|
|
|
|
|
(the last one makes sense only when used with criteria).
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2011-10-18 00:17:56 +02:00
|
|
|
|
[[back_and_forth]]
|
|
|
|
|
To switch back to the previously focused workspace, use +workspace
|
|
|
|
|
back_and_forth+.
|
|
|
|
|
|
2011-08-08 23:28:19 +02:00
|
|
|
|
To move a container to another xrandr output such as +LVDS1+ or +VGA1+, you can
|
2012-01-10 23:10:59 +01:00
|
|
|
|
use the +move container to output+ command followed by the name of the target
|
|
|
|
|
output. You may also use +left+, +right+, +up+, +down+ instead of the xrandr
|
|
|
|
|
output name to move to the next output in the specified direction.
|
|
|
|
|
|
|
|
|
|
To move a whole workspace to another xrandr output such as +LVDS1+ or +VGA1+,
|
|
|
|
|
you can use the +move workspace to output+ command followed by the name of the
|
|
|
|
|
target output. You may also use +left+, +right+, +up+, +down+ instead of the
|
|
|
|
|
xrandr output name to move to the next output in the specified direction.
|
2011-08-08 23:28:19 +02:00
|
|
|
|
|
2012-05-09 23:45:12 +02:00
|
|
|
|
*Syntax*:
|
|
|
|
|
-----------------------------------
|
|
|
|
|
workspace <next|prev|next_on_output|prev_on_output>
|
|
|
|
|
workspace back_and_forth
|
|
|
|
|
workspace <name>
|
|
|
|
|
workspace number <number>
|
|
|
|
|
|
|
|
|
|
move [window|container] [to] workspace <name>
|
|
|
|
|
move [window|container] [to] workspace number <number>
|
|
|
|
|
move [window|container] [to] workspace <prev|next|current>
|
|
|
|
|
-----------------------------------
|
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
*Examples*:
|
|
|
|
|
-------------------------
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+1 workspace 1
|
|
|
|
|
bindsym mod+2 workspace 2
|
2009-08-19 12:59:13 +02:00
|
|
|
|
...
|
|
|
|
|
|
2012-01-09 19:57:04 +01:00
|
|
|
|
bindsym mod+Shift+1 move container to workspace 1
|
|
|
|
|
bindsym mod+Shift+2 move container to workspace 2
|
2009-08-19 12:59:13 +02:00
|
|
|
|
...
|
2011-10-18 00:17:56 +02:00
|
|
|
|
|
|
|
|
|
# switch between the current and the previously focused one
|
|
|
|
|
bindsym mod+b workspace back_and_forth
|
2012-01-10 23:10:59 +01:00
|
|
|
|
|
|
|
|
|
# move the whole workspace to the next output
|
|
|
|
|
bindsym mod+x move workspace to output right
|
2012-05-09 23:45:12 +02:00
|
|
|
|
|
|
|
|
|
# move firefox to current workspace
|
|
|
|
|
bindsym mod+F1 [class="Firefox"] move workspace current
|
2009-08-19 12:59:13 +02:00
|
|
|
|
-------------------------
|
|
|
|
|
|
2011-08-25 14:11:31 +02:00
|
|
|
|
==== Named workspaces
|
|
|
|
|
|
|
|
|
|
Workspaces are identified by their name. So, instead of using numbers in the
|
|
|
|
|
workspace command, you can use an arbitrary name:
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
-------------------------
|
|
|
|
|
bindsym mod+1 workspace mail
|
|
|
|
|
...
|
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
|
|
If you want the workspace to have a number *and* a name, just prefix the
|
|
|
|
|
number, like this:
|
|
|
|
|
|
|
|
|
|
*Example*:
|
|
|
|
|
-------------------------
|
|
|
|
|
bindsym mod+1 workspace 1: mail
|
|
|
|
|
bindsym mod+2 workspace 2: www
|
|
|
|
|
...
|
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
|
|
Note that the workspace will really be named "1: mail". i3 treats workspace
|
|
|
|
|
names beginning with a number in a slightly special way. Normally, named
|
|
|
|
|
workspaces are ordered the way they appeared. When they start with a number, i3
|
2012-04-08 19:17:46 +02:00
|
|
|
|
will order them numerically. Also, you will be able to use +workspace number 1+
|
|
|
|
|
to switch to the workspace which begins with number 1, regardless of which name
|
|
|
|
|
it has. This is useful in case you are changing the workspace’s name
|
|
|
|
|
dynamically.
|
2011-08-25 14:11:31 +02:00
|
|
|
|
|
2012-04-08 20:34:31 +02:00
|
|
|
|
=== Renaming workspaces
|
|
|
|
|
|
|
|
|
|
You can rename workspaces. This might be useful to start with the default
|
|
|
|
|
numbered workspaces, do your work, and rename the workspaces afterwards to
|
|
|
|
|
reflect what’s actually on them.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
rename workspace <old_name> to <new_name>
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
------------------------------------------------
|
|
|
|
|
i3-msg 'rename workspace 5 to 6'
|
|
|
|
|
i3-msg 'rename workspace 1 to "1: www"'
|
|
|
|
|
i3-msg 'rename workspace "1: www" to "10: www"'
|
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
2009-10-23 19:53:36 +02:00
|
|
|
|
[[resizingconfig]]
|
|
|
|
|
|
2011-06-10 15:16:05 +02:00
|
|
|
|
=== Resizing containers/windows
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
2011-06-10 15:16:05 +02:00
|
|
|
|
If you want to resize containers/windows using your keyboard, you can use the
|
2011-08-28 17:51:37 +02:00
|
|
|
|
+resize+ command:
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------------------------------------------------
|
|
|
|
|
resize <grow|shrink> <direction> [<px> px] [or <ppt> ppt]
|
|
|
|
|
---------------------------------------------------------
|
|
|
|
|
|
2012-04-08 15:59:49 +02:00
|
|
|
|
Direction can either be one of +up+, +down+, +left+ or +right+. Or you can be
|
|
|
|
|
less specific and use +width+ or +height+, in which case i3 will take/give
|
|
|
|
|
space from all the other containers. The optional pixel argument specifies by
|
|
|
|
|
how many pixels a *floating container* should be grown or shrunk (the default
|
|
|
|
|
is 10 pixels). The ppt argument means percentage points and specifies by how
|
|
|
|
|
many percentage points a *tiling container* should be grown or shrunk (the
|
|
|
|
|
default is 10 percentage points).
|
2011-08-28 17:51:37 +02:00
|
|
|
|
|
|
|
|
|
I recommend using the resize command inside a so called +mode+:
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
|
|
|
|
.Example: Configuration file, defining a mode for resizing
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
mode "resize" {
|
|
|
|
|
# These bindings trigger as soon as you enter the resize mode
|
|
|
|
|
|
2012-04-08 15:59:49 +02:00
|
|
|
|
# Pressing left will shrink the window’s width.
|
|
|
|
|
# Pressing right will grow the window’s width.
|
|
|
|
|
# Pressing up will shrink the window’s height.
|
|
|
|
|
# Pressing down will grow the window’s height.
|
|
|
|
|
bindsym j resize shrink width 10 px or 10 ppt
|
|
|
|
|
bindsym k resize grow height 10 px or 10 ppt
|
|
|
|
|
bindsym l resize shrink height 10 px or 10 ppt
|
|
|
|
|
bindsym semicolon resize grow width 10 px or 10 ppt
|
|
|
|
|
|
|
|
|
|
# same bindings, but for the arrow keys
|
|
|
|
|
bindsym Left resize shrink width 10 px or 10 ppt
|
|
|
|
|
bindsym Down resize grow height 10 px or 10 ppt
|
|
|
|
|
bindsym Up resize shrink height 10 px or 10 ppt
|
|
|
|
|
bindsym Right resize grow width 10 px or 10 ppt
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
2011-08-28 17:51:37 +02:00
|
|
|
|
# back to normal: Enter or Escape
|
|
|
|
|
bindsym Return mode "default"
|
|
|
|
|
bindsym Escape mode "default"
|
2009-10-23 19:53:36 +02:00
|
|
|
|
}
|
2010-01-26 22:48:12 +01:00
|
|
|
|
|
|
|
|
|
# Enter resize mode
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+r mode "resize"
|
2009-10-23 19:53:36 +02:00
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
|
2009-06-01 14:59:25 +02:00
|
|
|
|
=== Jumping to specific windows
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
Often when in a multi-monitor environment, you want to quickly jump to a
|
|
|
|
|
specific window. For example, while working on workspace 3 you may want to
|
|
|
|
|
jump to your mail client to email your boss that you’ve achieved some
|
|
|
|
|
important goal. Instead of figuring out how to navigate to your mailclient,
|
2011-05-28 21:58:58 +02:00
|
|
|
|
it would be more convenient to have a shortcut. You can use the +focus+ command
|
2011-07-28 22:51:34 +02:00
|
|
|
|
with criteria for that.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
----------------------------------------------------
|
2011-05-28 21:58:58 +02:00
|
|
|
|
[class="class"] focus
|
|
|
|
|
[title="title"] focus
|
2009-06-01 14:59:25 +02:00
|
|
|
|
----------------------------------------------------
|
|
|
|
|
|
|
|
|
|
*Examples*:
|
2011-05-28 21:58:58 +02:00
|
|
|
|
------------------------------------------------
|
2009-06-01 14:59:25 +02:00
|
|
|
|
# Get me to the next open VIM instance
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+a [class="urxvt" title="VIM"] focus
|
2011-05-28 21:58:58 +02:00
|
|
|
|
------------------------------------------------
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2009-10-23 19:53:36 +02:00
|
|
|
|
=== VIM-like marks (mark/goto)
|
|
|
|
|
|
2009-12-07 10:25:12 +01:00
|
|
|
|
[[vim_like_marks]]
|
|
|
|
|
|
2009-10-23 19:53:36 +02:00
|
|
|
|
This feature is like the jump feature: It allows you to directly jump to a
|
|
|
|
|
specific window (this means switching to the appropriate workspace and setting
|
|
|
|
|
focus to the windows). However, you can directly mark a specific window with
|
2010-03-21 01:50:10 +01:00
|
|
|
|
an arbitrary label and use it afterwards. You do not need to ensure that your
|
|
|
|
|
windows have unique classes or titles, and you do not need to change your
|
|
|
|
|
configuration file.
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
|
|
|
|
As the command needs to include the label with which you want to mark the
|
2010-03-16 20:28:43 +01:00
|
|
|
|
window, you cannot simply bind it to a key. +i3-input+ is a tool created
|
|
|
|
|
for this purpose: It lets you input a command and sends the command to i3. It
|
|
|
|
|
can also prefix this command and display a custom prompt for the input dialog.
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
|
|
|
|
*Syntax*:
|
2011-05-28 21:58:58 +02:00
|
|
|
|
------------------------------
|
2011-07-28 22:51:34 +02:00
|
|
|
|
mark identifier
|
2011-05-28 21:58:58 +02:00
|
|
|
|
[con_mark="identifier"] focus
|
|
|
|
|
------------------------------
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
2011-07-28 22:51:34 +02:00
|
|
|
|
*Example (in a terminal)*:
|
|
|
|
|
------------------------------
|
|
|
|
|
$ i3-msg mark irssi
|
|
|
|
|
$ i3-msg '[con_mark="irssi"] focus'
|
|
|
|
|
------------------------------
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
///////////////////////////////////////////////////////////////////
|
|
|
|
|
TODO: make i3-input replace %s
|
2009-10-23 19:53:36 +02:00
|
|
|
|
*Examples*:
|
|
|
|
|
---------------------------------------
|
|
|
|
|
# Read 1 character and mark the current window with this character
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+m exec i3-input -p 'mark ' -l 1 -P 'Mark: '
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
|
|
|
|
# Read 1 character and go to the window with the character
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+g exec i3-input -p 'goto ' -l 1 -P 'Goto: '
|
2009-10-23 19:53:36 +02:00
|
|
|
|
---------------------------------------
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Alternatively, if you do not want to mess with +i3-input+, you could create
|
|
|
|
|
seperate bindings for a specific set of labels and then only use those labels.
|
2011-05-28 21:58:58 +02:00
|
|
|
|
///////////////////////////////////////////////////////////////////
|
2010-03-16 20:28:43 +01:00
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
=== Changing border style
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
To change the border of the current client, you can use +border normal+ to use the normal
|
|
|
|
|
border (including window title), +border 1pixel+ to use a 1-pixel border (no window title)
|
|
|
|
|
and +border none+ to make the client borderless.
|
|
|
|
|
|
|
|
|
|
There is also +border toggle+ which will toggle the different border styles.
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
*Examples*:
|
2011-05-28 21:58:58 +02:00
|
|
|
|
----------------------------
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+t border normal
|
|
|
|
|
bindsym mod+y border 1pixel
|
|
|
|
|
bindsym mod+u border none
|
2011-05-28 21:58:58 +02:00
|
|
|
|
----------------------------
|
2009-08-19 12:59:13 +02:00
|
|
|
|
|
2009-10-23 19:53:36 +02:00
|
|
|
|
[[stack-limit]]
|
|
|
|
|
|
2011-05-28 21:58:58 +02:00
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
TODO: not yet implemented
|
2009-10-23 19:53:36 +02:00
|
|
|
|
=== Changing the stack-limit of a container
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
If you have a single container with a lot of windows inside it (say, more than
|
2009-10-23 19:53:36 +02:00
|
|
|
|
10), the default layout of a stacking container can get a little unhandy.
|
2011-05-28 21:58:58 +02:00
|
|
|
|
Depending on your screen’s size, you might end up with only half of the title
|
|
|
|
|
lines being actually used, wasting a lot of screen space.
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Using the +stack-limit+ command, you can limit the number of rows or columns
|
2009-10-23 19:53:36 +02:00
|
|
|
|
in a stacking container. i3 will create columns or rows (depending on what
|
|
|
|
|
you limited) automatically as needed.
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
--------------------------------
|
|
|
|
|
stack-limit <cols|rows> <value>
|
|
|
|
|
--------------------------------
|
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
-------------------
|
|
|
|
|
# I always want to have two window titles in one line
|
|
|
|
|
stack-limit cols 2
|
|
|
|
|
|
|
|
|
|
# Not more than 5 rows in this stacking container
|
|
|
|
|
stack-limit rows 5
|
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
|
|
image:stacklimit.png[Container limited to two columns]
|
2011-05-28 21:58:58 +02:00
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
2009-10-23 19:53:36 +02:00
|
|
|
|
|
2009-08-19 12:59:13 +02:00
|
|
|
|
=== Reloading/Restarting/Exiting
|
|
|
|
|
|
|
|
|
|
You can make i3 reload its configuration file with +reload+. You can also
|
|
|
|
|
restart i3 inplace with the +restart+ command to get it out of some weird state
|
|
|
|
|
(if that should ever happen) or to perform an upgrade without having to restart
|
2011-07-28 22:51:34 +02:00
|
|
|
|
your X session. To exit i3 properly, you can use the +exit+ command,
|
2010-03-21 01:50:10 +01:00
|
|
|
|
however you don’t need to (simply killing your X session is fine as well).
|
2009-06-01 14:59:25 +02:00
|
|
|
|
|
|
|
|
|
*Examples*:
|
2009-08-19 12:59:13 +02:00
|
|
|
|
----------------------------
|
2011-07-28 22:51:34 +02:00
|
|
|
|
bindsym mod+Shift+r restart
|
|
|
|
|
bindsym mod+Shift+w reload
|
|
|
|
|
bindsym mod+Shift+e exit
|
2009-08-19 12:59:13 +02:00
|
|
|
|
----------------------------
|
2009-12-07 10:25:12 +01:00
|
|
|
|
|
2011-12-22 00:15:32 +01:00
|
|
|
|
=== Scratchpad
|
|
|
|
|
|
|
|
|
|
There are two commands to use any existing window as scratchpad window. +move
|
|
|
|
|
scratchpad+ will move a window to the scratchpad workspace. This will make it
|
|
|
|
|
invisible until you show it again. There is no way to open that workspace.
|
|
|
|
|
Instead, when using +scratchpad show+, the window will be shown again, as a
|
|
|
|
|
floating window, centered on your current workspace (using +scratchpad show+ on
|
|
|
|
|
a visible scratchpad window will make it hidden again, so you can have a
|
|
|
|
|
keybinding to toggle).
|
|
|
|
|
|
|
|
|
|
As the name indicates, this is useful for having a window with your favorite
|
|
|
|
|
editor always at hand. However, you can also use this for other permanently
|
|
|
|
|
running applications which you don’t want to see all the time: Your music
|
|
|
|
|
player, alsamixer, maybe even your mail client…?
|
|
|
|
|
|
|
|
|
|
*Syntax*:
|
|
|
|
|
---------------
|
|
|
|
|
move scratchpad
|
|
|
|
|
|
|
|
|
|
scratchpad show
|
|
|
|
|
---------------
|
|
|
|
|
|
|
|
|
|
*Examples*:
|
|
|
|
|
------------------------------------------------
|
|
|
|
|
# Make the currently focused window a scratchpad
|
|
|
|
|
bindsym mod+Shift+minus move scratchpad
|
|
|
|
|
|
|
|
|
|
# Show the first scratchpad window
|
|
|
|
|
bindsym mod+minus scratchpad show
|
|
|
|
|
|
|
|
|
|
# Show the sup-mail scratchpad window, if any.
|
|
|
|
|
bindsym mod4+s [title="^Sup ::"] scratchpad show
|
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
2009-12-07 10:25:12 +01:00
|
|
|
|
[[multi_monitor]]
|
|
|
|
|
|
2010-03-25 03:26:59 +01:00
|
|
|
|
== Multiple monitors
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
As you can see in the goal list on the website, i3 was specifically developed
|
2010-03-15 18:23:12 +01:00
|
|
|
|
with support for multiple monitors in mind. This section will explain how to
|
|
|
|
|
handle multiple monitors.
|
2009-12-07 10:25:12 +01:00
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
When you have only one monitor, things are simple. You usually start with
|
2009-12-07 10:25:12 +01:00
|
|
|
|
workspace 1 on your monitor and open new ones as you need them.
|
|
|
|
|
|
|
|
|
|
When you have more than one monitor, each monitor will get an initial
|
2010-03-21 01:50:10 +01:00
|
|
|
|
workspace. The first monitor gets 1, the second gets 2 and a possible third
|
|
|
|
|
would get 3. When you switch to a workspace on a different monitor, i3 will
|
|
|
|
|
switch to that monitor and then switch to the workspace. This way, you don’t
|
|
|
|
|
need shortcuts to switch to a specific monitor, and you don’t need to remember
|
|
|
|
|
where you put which workspace. New workspaces will be opened on the currently
|
|
|
|
|
active monitor. It is not possible to have a monitor without a workspace.
|
|
|
|
|
|
|
|
|
|
The idea of making workspaces global is based on the observation that most
|
|
|
|
|
users have a very limited set of workspaces on their additional monitors.
|
|
|
|
|
They are often used for a specific task (browser, shell) or for monitoring
|
|
|
|
|
several things (mail, IRC, syslog, …). Thus, using one workspace on one monitor
|
|
|
|
|
and "the rest" on the other monitors often makes sense. However, as you can
|
|
|
|
|
create an unlimited number of workspaces in i3 and tie them to specific
|
|
|
|
|
screens, you can have the "traditional" approach of having X workspaces per
|
|
|
|
|
screen by changing your configuration (using modes, for example).
|
2009-12-07 10:25:12 +01:00
|
|
|
|
|
|
|
|
|
=== Configuring your monitors
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
To help you get going if you have never used multiple monitors before, here is
|
|
|
|
|
a short overview of the xrandr options which will probably be of interest to
|
|
|
|
|
you. It is always useful to get an overview of the current screen configuration.
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Just run "xrandr" and you will get an output like the following:
|
2010-03-21 01:50:10 +01:00
|
|
|
|
-------------------------------------------------------------------------------
|
2009-12-07 10:25:12 +01:00
|
|
|
|
$ xrandr
|
|
|
|
|
Screen 0: minimum 320 x 200, current 1280 x 800, maximum 8192 x 8192
|
|
|
|
|
VGA1 disconnected (normal left inverted right x axis y axis)
|
|
|
|
|
LVDS1 connected 1280x800+0+0 (normal left inverted right x axis y axis) 261mm x 163mm
|
|
|
|
|
1280x800 60.0*+ 50.0
|
|
|
|
|
1024x768 85.0 75.0 70.1 60.0
|
|
|
|
|
832x624 74.6
|
|
|
|
|
800x600 85.1 72.2 75.0 60.3 56.2
|
|
|
|
|
640x480 85.0 72.8 75.0 59.9
|
|
|
|
|
720x400 85.0
|
|
|
|
|
640x400 85.1
|
|
|
|
|
640x350 85.1
|
|
|
|
|
--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
Several things are important here: You can see that +LVDS1+ is connected (of
|
2010-03-16 20:28:43 +01:00
|
|
|
|
course, it is the internal flat panel) but +VGA1+ is not. If you have a monitor
|
|
|
|
|
connected to one of the ports but xrandr still says "disconnected", you should
|
2009-12-07 10:25:12 +01:00
|
|
|
|
check your cable, monitor or graphics driver.
|
|
|
|
|
|
2010-03-21 01:50:10 +01:00
|
|
|
|
The maximum resolution you can see at the end of the first line is the maximum
|
|
|
|
|
combined resolution of your monitors. By default, it is usually too low and has
|
|
|
|
|
to be increased by editing +/etc/X11/xorg.conf+.
|
2009-12-07 10:25:12 +01:00
|
|
|
|
|
|
|
|
|
So, say you connected VGA1 and want to use it as an additional screen:
|
|
|
|
|
-------------------------------------------
|
|
|
|
|
xrandr --output VGA1 --auto --left-of LVDS1
|
|
|
|
|
-------------------------------------------
|
2010-03-16 20:28:43 +01:00
|
|
|
|
This command makes xrandr try to find the native resolution of the device
|
2009-12-07 10:25:12 +01:00
|
|
|
|
connected to +VGA1+ and configures it to the left of your internal flat panel.
|
|
|
|
|
When running "xrandr" again, the output looks like this:
|
2010-03-21 01:50:10 +01:00
|
|
|
|
-------------------------------------------------------------------------------
|
2009-12-07 10:25:12 +01:00
|
|
|
|
$ xrandr
|
|
|
|
|
Screen 0: minimum 320 x 200, current 2560 x 1024, maximum 8192 x 8192
|
|
|
|
|
VGA1 connected 1280x1024+0+0 (normal left inverted right x axis y axis) 338mm x 270mm
|
|
|
|
|
1280x1024 60.0*+ 75.0
|
|
|
|
|
1280x960 60.0
|
|
|
|
|
1152x864 75.0
|
|
|
|
|
1024x768 75.1 70.1 60.0
|
|
|
|
|
832x624 74.6
|
|
|
|
|
800x600 72.2 75.0 60.3 56.2
|
|
|
|
|
640x480 72.8 75.0 66.7 60.0
|
|
|
|
|
720x400 70.1
|
|
|
|
|
LVDS1 connected 1280x800+1280+0 (normal left inverted right x axis y axis) 261mm x 163mm
|
|
|
|
|
1280x800 60.0*+ 50.0
|
|
|
|
|
1024x768 85.0 75.0 70.1 60.0
|
|
|
|
|
832x624 74.6
|
|
|
|
|
800x600 85.1 72.2 75.0 60.3 56.2
|
|
|
|
|
640x480 85.0 72.8 75.0 59.9
|
|
|
|
|
720x400 85.0
|
|
|
|
|
640x400 85.1
|
|
|
|
|
640x350 85.1
|
2010-03-21 01:50:10 +01:00
|
|
|
|
-------------------------------------------------------------------------------
|
2009-12-07 10:25:12 +01:00
|
|
|
|
Please note that i3 uses exactly the same API as xrandr does, so it will see
|
|
|
|
|
only what you can see in xrandr.
|
|
|
|
|
|
|
|
|
|
See also <<presentations>> for more examples of multi-monitor setups.
|
|
|
|
|
|
|
|
|
|
=== Interesting configuration for multi-monitor environments
|
|
|
|
|
|
|
|
|
|
There are several things to configure in i3 which may be interesting if you
|
|
|
|
|
have more than one monitor:
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
1. You can specify which workspace should be put on which screen. This
|
|
|
|
|
allows you to have a different set of workspaces when starting than just
|
2009-12-07 10:25:12 +01:00
|
|
|
|
1 for the first monitor, 2 for the second and so on. See
|
|
|
|
|
<<workspace_screen>>.
|
|
|
|
|
2. If you want some applications to generally open on the bigger screen
|
|
|
|
|
(MPlayer, Firefox, …), you can assign them to a specific workspace, see
|
|
|
|
|
<<assign_workspace>>.
|
|
|
|
|
3. If you have many workspaces on many monitors, it might get hard to keep
|
|
|
|
|
track of which window you put where. Thus, you can use vim-like marks to
|
|
|
|
|
quickly switch between windows. See <<vim_like_marks>>.
|
|
|
|
|
|
|
|
|
|
== i3 and the rest of your software world
|
|
|
|
|
|
|
|
|
|
=== Displaying a status line
|
|
|
|
|
|
|
|
|
|
A very common thing amongst users of exotic window managers is a status line at
|
2010-03-16 20:28:43 +01:00
|
|
|
|
some corner of the screen. It is an often superior replacement to the widget
|
2009-12-07 10:25:12 +01:00
|
|
|
|
approach you have in the task bar of a traditional desktop environment.
|
|
|
|
|
|
|
|
|
|
If you don’t already have your favorite way of generating such a status line
|
|
|
|
|
(self-written scripts, conky, …), then i3status is the recommended tool for
|
2010-03-16 20:28:43 +01:00
|
|
|
|
this task. It was written in C with the goal of using as few syscalls as
|
2011-07-31 15:39:18 +02:00
|
|
|
|
possible to reduce the time your CPU is woken up from sleep states. Because
|
|
|
|
|
i3status only spits out text, you need to combine it with some other tool, like
|
2011-12-30 00:59:32 +01:00
|
|
|
|
i3bar. See <<status_command>> for how to display i3status in i3bar.
|
2011-07-31 15:39:18 +02:00
|
|
|
|
|
|
|
|
|
Regardless of which application you use to display the status line, you
|
|
|
|
|
want to make sure that it registers as a dock window using EWMH hints. i3 will
|
|
|
|
|
position the window either at the top or at the bottom of the screen, depending
|
2011-12-30 00:59:32 +01:00
|
|
|
|
on which hint the application sets. With i3bar, you can configure its position,
|
|
|
|
|
see <<i3bar_position>>.
|
2009-12-07 10:25:12 +01:00
|
|
|
|
|
|
|
|
|
=== Giving presentations (multi-monitor)
|
|
|
|
|
|
|
|
|
|
When giving a presentation, you typically want the audience to see what you see
|
|
|
|
|
on your screen and then go through a series of slides (if the presentation is
|
|
|
|
|
simple). For more complex presentations, you might want to have some notes
|
|
|
|
|
which only you can see on your screen, while the audience can only see the
|
|
|
|
|
slides.
|
|
|
|
|
|
|
|
|
|
[[presentations]]
|
|
|
|
|
==== Case 1: everybody gets the same output
|
2010-03-16 20:28:43 +01:00
|
|
|
|
This is the simple case. You connect your computer to the video projector,
|
2009-12-07 10:25:12 +01:00
|
|
|
|
turn on both (computer and video projector) and configure your X server to
|
|
|
|
|
clone the internal flat panel of your computer to the video output:
|
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
xrandr --output VGA1 --mode 1024x768 --same-as LVDS1
|
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
i3 will then use the lowest common subset of screen resolutions, the rest of
|
2010-03-16 20:28:43 +01:00
|
|
|
|
your screen will be left untouched (it will show the X background). So, in
|
2009-12-07 10:25:12 +01:00
|
|
|
|
our example, this would be 1024x768 (my notebook has 1280x800).
|
|
|
|
|
|
|
|
|
|
==== Case 2: you can see more than your audience
|
|
|
|
|
This case is a bit harder. First of all, you should configure the VGA output
|
|
|
|
|
somewhere near your internal flat panel, say right of it:
|
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
xrandr --output VGA1 --mode 1024x768 --right-of LVDS1
|
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
Now, i3 will put a new workspace (depending on your settings) on the new screen
|
|
|
|
|
and you are in multi-monitor mode (see <<multi_monitor>>).
|
|
|
|
|
|
2010-03-16 20:28:43 +01:00
|
|
|
|
Because i3 is not a compositing window manager, there is no ability to
|
|
|
|
|
display a window on two screens at the same time. Instead, your presentation
|
2010-03-15 18:23:12 +01:00
|
|
|
|
software needs to do this job (that is, open a window on each screen).
|