.gitignore | ||
.travis.yml | ||
.Xdefaults | ||
arg.h | ||
config.h | ||
config.mk | ||
LICENSE | ||
Makefile | ||
PKGBUILD | ||
README.md | ||
st-copyout | ||
st.1 | ||
st.c | ||
st.h | ||
st.info | ||
win.h | ||
x.c |
What, why, and how?
-
What is this fork? This is a fork of Luke's st build that replaces the alpha patch with the alphahighlighting patch. This build is kept up to date with lukes build and the latest releases for the alphahighlighting patch. If it's not up to date, just make a pull request and I'll merge it when I feel like it, if you're too lazy to make one, just wait for me to upate it.
-
Why does this fork exist? This fork exists because if you decide not to have big O'l borders and gaps and you use something like unclutter, it can be hard to tell which terminal is currently focused, this makes it easy and pretty. Functionality and looks nice? Impossible.
-
Why don't you make your own build? Because Luke's build is almost perfect, link following, etc, etc, but it wasn't exactly what I wanted so i forked it. Another reason is people are always impoving and updating his build, so all I have to do is keep the patch up to date. EzLyfFoMi
-
How do I use this? Both of the alpha values can be set in the config.h or can be set in .Xresources, so if you do use .Xresources, (please don't use .Xresources) then theres an example in the .Xdefaults file in this repo.
Luke's build of st - the simple (suckless) terminal
The suckless terminal (st) with some additional features that make it literally the best terminal emulator ever:
Unique features (using dmenu)
- follow urls by pressing
alt-l
- copy urls in the same way with
alt-y
- copy the output of commands with
alt-o
Bindings for
- scrollback with
alt-↑/↓
oralt-pageup/down
orshift
while scrolling the mouse - OR vim-bindings: scroll up/down in history with
alt-k
andalt-j
. Faster withalt-u
/alt-d
. - zoom/change font size: same bindings as above, but holding down shift as well.
alt-home
returns to default - copy text with
alt-c
, paste isalt-v
orshift-insert
Pretty stuff
- Compatibility with
Xresources
andpywal
for dynamic colors. TheXdefaults
file shows a usage example. - Default gruvbox colors otherwise.
- Transparency/alpha, which is also adjustable from your
Xresources
. - Default font is system "mono" at 14pt, meaning the font will match your system font.
Other st patches
- Vertcenter
- Scrollback
- font2
- updated to latest version 0.8.2
Installation for newbs
git clone https://github.com/LukeSmithxyz/st
cd st
sudo make install
Users of Arch-based distros can also install it from the AUR as st-luke-git.
Obviously, make
is required to build. fontconfig
is required for the default build, since it asks fontconfig
for your system monospace font. It might be obvious, but libX11
and libXft
are required as well. Chances are, you have all of this installed already.
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
, compton
, etc.) running if you want transparency.
How to configure dynamically with Xresources
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.
For example, you can define your desired fonts, transparency or colors:
*.font: Liberation Mono:pixelsize=12:antialias=true:autohint=true;
*.alpha: 0.92
st.alphaUnfocussed: 0.8
*.color0: #111
...
The alpha
value (for transparency) goes from 0
(transparent) to 1
(opaque).
Colors
To be clear about the color settings:
- This build will use gruvbox colors by default and as a fallback.
- If there are Xresources colors defined, those will take priority.
- But if
wal
has run in your session, its colors will take priority.
Note that when you run wal
, it will negate the transparency of existing windows, but new windows will continue with the previously defined transparency.
Notes on Emojis and Special Characters
If st crashes when viewing emojis, install libxft-bgra from the AUR.
Note that some special characters may appear truncated if too wide. You might want to manually set your prefered emoji/special character font to a lower size in the config.h
file to avoid this. By default, JoyPixels is used at a smaller size than the usual text.
Contact
- Luke Smith luke@lukesmith.xyz
- https://lukesmith.xyz