2018-01-21 20:15:29 +01:00
# Luke's build of st - the simple (suckless) terminal
2009-05-10 14:17:09 +02:00
2021-02-06 04:33:01 +01:00
The [suckless terminal (st) ](https://st.suckless.org/ ) with some additional
features that make it literally the best terminal emulator ever:
2019-05-08 17:26:11 +02:00
## Unique features (using dmenu)
2019-05-08 17:38:15 +02:00
+ **follow urls** by pressing `alt-l`
+ **copy urls** in the same way with `alt-y`
+ **copy the output of commands** with `alt-o`
2019-05-08 17:26:11 +02:00
## Bindings for
2021-06-03 13:46:08 +02:00
+ **scrollback** with `alt-↑/↓` or `alt-pageup/down` or `shift` while scrolling the
mouse.
2021-02-06 04:33:01 +01:00
+ OR **vim-bindings** : scroll up/down in history with `alt-k` and `alt-j` .
Faster with `alt-u` /`alt-d`.
+ **zoom/change font size** : same bindings as above, but holding down shift as
well. `alt-home` returns to default
2019-05-08 17:38:15 +02:00
+ **copy text** with `alt-c` , **paste** is `alt-v` or `shift-insert`
2019-05-08 17:26:11 +02:00
## Pretty stuff
2009-05-10 14:17:09 +02:00
2020-05-05 19:52:44 +02:00
+ Compatibility with `Xresources` and `pywal` for dynamic colors.
2018-12-03 20:53:04 +01:00
+ Default [gruvbox ](https://github.com/morhetz/gruvbox ) colors otherwise.
2019-05-08 17:26:11 +02:00
+ Transparency/alpha, which is also adjustable from your `Xresources` .
2021-02-06 04:33:01 +01:00
+ Default font is system "mono" at 14pt, meaning the font will match your
system font.
2019-05-08 17:26:11 +02:00
## Other st patches
2021-02-06 04:14:48 +01:00
+ Boxdraw
+ Ligatures
2019-06-03 23:58:12 +02:00
+ font2
2022-08-15 14:02:37 +02:00
+ updated to latest version 0.8.5
2018-01-19 03:33:28 +01:00
2018-01-19 22:32:00 +01:00
## Installation for newbs
2021-01-24 22:48:11 +01:00
You should have xlib header files and libharfbuzz build files installed.
2018-01-19 22:32:00 +01:00
```
2019-04-23 18:45:03 +02:00
git clone https://github.com/LukeSmithxyz/st
cd st
2018-01-19 22:32:00 +01:00
sudo make install
```
2018-02-06 05:33:39 +01:00
2021-02-06 04:33:01 +01:00
Obviously, `make` is required to build. `fontconfig` is required for the
2021-06-03 13:46:08 +02:00
default build, since it asks `fontconfig` for your system monospace font. It
2021-02-06 04:33:01 +01:00
might be obvious, but `libX11` and `libXft` are required as well. Chances are,
you have all of this installed already.
2019-02-02 17:10:43 +01:00
2021-02-06 04:33:01 +01:00
On OpenBSD, be sure to edit `config.mk` first and remove `-lrt` from the
`$LIBS` before compiling.
Be sure to have a composite manager (`xcompmgr`, `picom` , etc.) running if you
want transparency.
2018-11-24 15:17:12 +01:00
2019-01-08 23:50:19 +01:00
## How to configure dynamically with Xresources
2018-11-14 16:31:03 +01:00
2021-02-06 04:33:01 +01:00
For many key variables, this build of `st` will look for X settings set in
either `~/.Xdefaults` or `~/.Xresources` . You must run `xrdb` on one of these
files to load the settings.
2018-11-14 16:31:03 +01:00
For example, you can define your desired fonts, transparency or colors:
```
*.font: Liberation Mono:pixelsize=12:antialias=true:autohint=true;
2019-05-08 03:05:57 +02:00
*.alpha: 0.9
2018-11-14 16:31:03 +01:00
*.color0: #111
...
```
2021-02-19 16:50:35 +01:00
The `alpha` value (for transparency) goes from `0` (transparent) to `1`
(opaque). There is an example `Xdefaults` file in this respository.
2018-11-14 16:31:03 +01:00
### Colors
To be clear about the color settings:
2018-12-13 23:23:38 +01:00
- This build will use gruvbox colors by default and as a fallback.
2018-11-14 16:31:03 +01:00
- If there are Xresources colors defined, those will take priority.
- But if `wal` has run in your session, its colors will take priority.
2019-02-02 17:10:43 +01:00
Note that when you run `wal` , it will negate the transparency of existing windows, but new windows will continue with the previously defined transparency.
2018-11-14 16:31:03 +01:00
## Contact
- Luke Smith < luke @ lukesmith . xyz >
- [https://lukesmith.xyz ](https://lukesmith.xyz )