summaryrefslogtreecommitdiffhomepage
path: root/readme.org
blob: 64663c45608ff0657bf6eecac1a56bf2eced5363 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
#+title: xmobar, a minimalistic status bar

#+begin_export html
<p align="right">
  <a href="http://hackage.haskell.org/package/xmobar">
    <img src="https://img.shields.io/hackage/v/xmobar.svg" alt="hackage"/>
  </a>
  <a href="https://ci.codeberg.org/xmobar/xmobar">
    <img src="https://ci.codeberg.org/api/badges/xmobar/xmobar/status.svg" alt="ci"/>
  </a>
</p>
#+end_export

Xmobar is a minimalistic status bar. It was originally designed and
implemented to work with [[http://xmonad.org][xmonad]], but it is actually usable with any
window manager in X11 and also (via its text output mode) Wayland.

Xmobar was inspired by the [[http://tuomov.iki.fi/software/][Ion3]] status bar, and supports similar
features, like dynamic color management, icons, output templates, and
extensibility through plugins.  It is also able to write to standard
output, in a variety of formats.

[[file:doc/screenshots/xmobar-top.png]]

[[file:doc/screenshots/xmobar-bottom.png]]

[[file:doc/screenshots/xmobar-exwm.png]]

Check [[./changelog.md][the change log]] for our release history.  We also have an IRC
channel, ~#xmobar~, at [[ircs://irc.libera.chat][Libera]].

* Breaking news

  - Starting with version 0.47.1, we are excluding MPD from the extensions
    included with ~all_extensions~ when GHC version is 9.4 or greater, because
    that seems to break cabal compilation.  However, it's been reported that
    in some installations compilation with ~libmpd~ works fine: just add
    explicitly the ~with_mpd~ flag to include MPD and check for yourself.
    Compilation with stack has also been reported to work.  Please see the
    comments in issue #679 for details.
  - Starting with version 0.45, we use cairo/pango as our drawing engine
    (instead of plain X11/Xft).  From a user's point of view, that change
    should be mostly transparent, except for the facts that it's allowed
    fixing quite a few bugs and that your /font names/ in your configuration, if
    you used ~xft~ ones, might need to be adapted to Pango's syntax: please see
    [[./doc/quick-start.org#fonts][this section of the documentation]] for all the details.  If you're
    compiling your own xmobar, there's a new dependency on libpango (see
    [[./doc/compiling.org#c-libraries][C library dependencies]]).

* Installation
  :PROPERTIES:
  :CUSTOM_ID: installation
  :END:
** From your system's package manager

   Xmobar is probably available from your distributions package
   manager!  Most distributions compile xmobar with the =all_extensions=
   flag, so you don't have to.

   - Arch Linux
     #+begin_src shell
       pacman -S xmobar
     #+end_src

   - Debian/Ubuntu based
     #+begin_src shell
       apt install xmobar
     #+end_src

   - OpenSUSE
     #+begin_src shell
       zypper install xmobar
     #+end_src

   - Void Linux
     #+begin_src shell
       xbps-install xmobar
     #+end_src

   - Gentoo
     #+begin_src shell
       emerge --ask xmobar
     #+end_src

   - FreeBSD
     #+begin_src shell
       pkg install hs-xmobar
     #+end_src

** Using cabal or stack

   Xmobar is available from [[http://hackage.haskell.org/package/xmobar/][Hackage]], and you can compile and install it using
   =cabal-install=, making sure the [[doc/compiling.org#c-libraries][required C libraries]] are in place. For a
   full build with all available extensions:

   #+begin_src shell
     # required C librarises
     apt-get install xorg-dev libxrandr-dev libpango1.0-dev
     # optional C libraries for additional plugins
     apt-get install libasound2-dev libxpm-dev libmpd-dev

     cabal install xmobar -fall_extensions
   #+end_src

   Starting with version 0.35.1, xmobar requires at least GHC version
   8.4.x. to build. See [[https://codeberg.org/xmobar/xmobar/issues/461][this issue]] for more information.

   See [[file:doc/compiling.org#optional-features][here]] for a list of optional compilation flags that will enable some
   optional plugins.

   See [[file:doc/compiling.org][compiling]] for full compilation instructions starting from source.

* Running xmobar
** Running xmobar with a configuration file
   You can run xmobar with:

   #+begin_src shell
     xmobar /path/to/config &
   #+end_src

   or

   #+begin_src shell
     xmobar &
   #+end_src

   if you have the default configuration file saved as
   =$XDG_CONFIG_HOME/xmobar/xmobarrc= (defaulting to =~/.config/xmobar/xmobarrc=),
   or =~/.xmobarrc=.

   All the available command line switches and configuration parameters are
   described in [[file:doc/quick-start.org][the quick start guide]] and [[file:doc/plugins.org][the plugins index]].

** Writing your own xmobar in Haskell

   As shown above, one can use ~xmobar~ as a regular program, via its
   configuration file, without having to write any code. It also is possible
   to install xmobar as a library and use it to write your own xmobar using
   Haskell instead of using a configuration file.  (This is very similar to
   how [[http://xmonad.org][xmonad]] works.)  That gives you the ability of using Haskell and its
   libraries to extend xmobar to your heart's content. If you are a
   programmer, take a look [[file:doc/using-haskell.org][here]] to learn more.

** Running xmobar in text mode

   By default, xmobar will run as an X11 application, in a docked window, but
   it is possible to redirect xmobar's output to the standard output,
   optionally with color escape sequences.  In this mode, xmobar can be run
   inside a terminal o console, or its output piped to other applications, and
   there is no need for an X11 display.  See [[./doc/quick-start.org#text-mode][Running xmobar in text mode]] for
   details.  Using this mode, you could [[file:doc/quick-start.org#wayland][pipe xmobar's output to, say, swaybar]],
   and use it in wayland, or, with the [[./etc/xmobar.el][xmobar.el]] package, show it in Emacs's
   tab bar.

* Configuration and further documentation

  - If you want to jump straight into running xmobar, head over to the
    [[./doc/quick-start.org][quick start guide]].

  - If you want to get a detailed overview of all available plugins and
    monitors, visit the [[./doc/plugins.org][plugins index]].

  - For more information on how to use xmobar as a Haskell library see the
    [[file:doc/using-haskell.org][using Haskell guide]].

  - If you want to know how to contribute to the xmobar project, check out
    [[contributing.org][contributing]].

* Authors and credits

  Andrea Rossato originally designed and implemented xmobar up to version
  0.11.1. Since then, it is maintained and developed by [[https://jao.io][jao]], with the help of
  the greater xmobar and Haskell communities.

  In particular, xmobar incorporates patches by Kostas Agnantis, Mohammed
  Alshiekh, Alex Ameen, Axel Angel, Dhananjay Balan, Claudio Bley, Dragos
  Boca, Ben Boeckel, Ivan Brennan, Duncan Burke, Roman Cheplyaka, Patrick
  Chilton, Antoine Eiche, Nathaniel Wesley Filardo, Guy Gastineau, John
  Goerzen, Jonathan Grochowski, Patrick Günther, Reto Hablützel, Juraj Hercek,
  Tomáš Janoušek, Ada Joule, Spencer Janssen, Roman Joost, Pavel Kalugin,
  Jochen Keil, Sam Kirby, Lennart Kolmodin, Krzysztof Kosciuszkiewicz, Dmitry
  Kurochkin, Todd Lunter, Vanessa McHale, Robert J. Macomber, Dmitry Malikov,
  David McLean, Joan Milev, Marcin Mikołajczyk, Dino Morelli, Tony Morris,
  Eric Mrak, Thiago Negri, Edward O'Callaghan, Svein Ove, Martin Perner, Jens
  Petersen, Alexander Polakov, Sibi Prabakaran, Pavan Rikhi, Petr Rockai,
  Andrew Emmanuel Rosa, Sackville-West, Amir Saeid, Markus Scherer, Daniel
  Schüssler, Olivier Schneider, Alexander Shabalin, Valentin Shirokov, Peter
  Simons, Alexander Solovyov, Will Song, John Soo, John Soros, Felix Springer,
  Travis Staton, Artem Tarasov, Samuli Thomasson, Edward Tjörnhammar, Sergei
  Trofimovich, Thomas Tuegel, John Tyree, Jan Vornberger, Anton Vorontsov,
  Daniel Wagner, Zev Weiss, Phil Xiaojun Hu, Nikolay Yakimov, Edward Z. Yang,
  Leo Zhang, Norbert Zeh, and Michał Zielonka.

  Andrea wants to thank Robert Manea and Spencer Janssen for their help in
  understanding how X works. They gave him suggestions on how to solve many
  problems with xmobar.  He also thanks Claus Reinke for making him understand
  existential types (or at least for letting him think he grasps existential
  types...;-).

* License

  This software is released under a BSD-style license. See [[https://codeberg.org/xmobar/xmobar/src/branch/master/license][license]] for more
  details.

  Copyright © 2010-2023 Jose Antonio Ortega Ruiz

  Copyright © 2007-2010 Andrea Rossato