aboutsummaryrefslogtreecommitdiffstats
path: root/st.c
AgeCommit message (Collapse)Author
2018-02-26Move usage() to be with run() in x.cDevin J. Pohly
run/usage/xinit are now all internal to x.c Signed-off-by: Devin J. Pohly <djpohly@gmail.com>
2018-02-26Call xsetenv() in main process instead of childDevin J. Pohly
This makes xsetenv internal to x.c, and allows iso14755's external command to use $WINDOWID instead of having to snprintf it again. (The same benefit will apply to the externalpipe patch.) The xwinid function is no longer needed. Signed-off-by: Devin J. Pohly <djpohly@gmail.com>
2017-09-15base64dec: skip non-printable characters like \r\nSuraj N. Kurapati
Non-printable characters, such as line breaks, in a base64 encoded string violate the "string length must be a multiple of four" rule. This patch pads the result buffer by one extra unit of four bytes, and skips over non-printable characters found in the input string.
2017-07-12Revert "Add bold off SGR"Quentin Rameau
This reverts commit 6cb6d61525931c88971cce323f63e40451a6d365. This wasn't a useful thing after all.
2017-06-03Add bold off SGRQuentin Rameau
2017-03-29Fix commented out codeAlexander Krotov
2017-03-19Support xterm Ms feature to set clipboardosandov@osandov.com
This is used by, e.g., tmux.
2017-01-21Split X-specific code into x.cMichael Forney
2016-12-16Move column and row default numbers into config.hfpqc
2016-11-24Revert "Initial font size issue."Roberto E. Vargas Caballero
This reverts commit 424202798b02554092ba84dd59fb7b79b59b7b75.
2016-11-24Fixed 'missing glyph doesn't use fontconfig config substitutions' bugSpencer Phippen
XftFontMatch does display-specific font configuration (commit 528241a). Nice. Unfortunately, when we switched from FcFontMatch, we also stopped storing the post-Fc{Config,Default}Substitute FcPattern for future lookups. The result is that if a glyph isn't found in the primary font, secondary font lookups use the original FcPattern, not the configured one. If you have custom fontconfig rules (like me), this can be disappointing. I basically just copied the guts out of XftFontMatch[1] and saved the intermediate configured FcPattern. Could be related to the bug that inspired commit 4242027. [1]: https://cgit.freedesktop.org/xorg/lib/libXft/tree/src/xftfont.c
2016-11-14Initial font size issue.ian@remmler.org
Hi, When I specify a font by point size (I'm using "Inconsolata:size=12"), characters that are substituted from another font because they are not in the main one appear too small. Doing a zoom reset fixes it. For example: Before: http://i.imgur.com/G4Mfv4X.png After: http://i.imgur.com/PMDhfQA.png I found that adding the pixel size (acquired from the initial font load) to the pattern then reloading the font fixes the problem. I'm not sure if this is a proper fix, though.
2016-11-14Make strdump(), csidump(), print to stderrpl@ninthfloor.org
The two functions strdump(), csidump() are called to show errors and their output is introduced by a message printed to stderr. Thus, it it more consistent to have them print to stderr. Moreover stderr is unbuffered (at least on Linux), making problems immediately visible.
2016-10-23Do not use color when font attributes are supportedQuentin Rameau
If fontconfig gives us a font without the attributes we asked for, display an alternative color instead.
2016-10-18Add support for iso14755Quentin Rameau
We launch dmenu for getting a codepoint, then convert it and send it to the terminal.
2016-09-14Add parsing of DCS q sequencesRoberto E. Vargas Caballero
These sequences are used to operate with sixels, but they are still str sequences, so they are finished with \a, ST or with a C1 control code. This patch also disables utf8 handling for the case of sixels.
2016-09-13Add support for enabling/disabling utfRoberto E. Vargas Caballero
There are some ocasions where we want to disable the enconding/decoding of utf8, mainly because it adds an important overhead. This is partial patch for ESC % G and ESC % @, where they modified the way that st reads and write from/to the serial line, but it does not modifies how it interacts with the X window part.
2016-06-03Use XftFontMatch in place of FcFontMatch.Christoph Lohmann
git am -s didn't like your patch: From: Mark Edgar <medgar123@gmail.com> XftFontMatch calls XftDefaultSubstitute which configures various match properties according to the user's configured Xft defaults (xrdb) as well as according to the current display and screen. Most importantly, the screen DPI is computed [1]. Without this, st uses a "default" DPI of 75 [2]. [1]: https://cgit.freedesktop.org/xorg/lib/libXft/tree/src/xftdpy.c?id=libXft-2.3.2#n535 [2]: https://cgit.freedesktop.org/fontconfig/tree/src/fcdefault.c?id=2.11.1#n255
2016-06-03delete clipboard properties after pasting themv4hn
https://tronche.com/gui/x/icccm/sec-2.html#s-2.4 specifies: > Once all the data in the selection has been retrieved, > the requestor should delete the property in the SelectionNotify request Most Clipboard-Owners ignore whether or not the property is already set, so this is mostly a cosmetic change to keep the windows property list clean. However, at least synergy decides to wait for the requestor to delete the properties if they are already set by a previous paste (from synergy). Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-04-15Remove stupid assignation in memcpy()Roberto E. Vargas Caballero
2016-03-09st: Fix off-by-one error when calculating character width.Tor Andersson
LEN(str) is one larger than strlen(str) because it also counts the zero terminator. The original code would include the .notdef glyph (since it'll try to encode character 0, which gets encoded to the .notdef glyph) when measuring the average dimensions of printable ascii characters. This causes problems with fonts like GNU Unifont where the .notdef glyph is not the same width as the usual half-width characters. Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-03-08Fix vertical character alignment in some casesTon van den Heuvel
The y-position of a character found by asking fontconfig for a matching font does not take the border pixels into account, resulting in a slightly misaligned vertical position. Signed-off-by: Ton van den Heuvel <tonvandenheuvel@gmail.com> Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-03-08Measure the single advance width with a heuristic methodRyusei Yamaguchi
This fix is needed to use dual-width fonts, which have double-width glyphs (e.g. CJK unified ideographs). Signed-off-by: Ryusei Yamaguchi <mandel59@gmail.com> Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-03-07xtermclear() is now done by xdrawglyphfontspecs()Christoph Lohmann
Thanks Ton van den Heuvel for the proposal!
2016-02-01Fix forgotten bracket and duplicate option in usage()Quentin Rameau
Scratch the preceding patch, this one is more correct (don't forget to 'git am --scissors' ;)) -- >8 -- Also reformat the strings in a saner layout Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-01-30Extract ttyresize() out of cresize()Quentin Rameau
This way we can call cresize() to set the terminal size before creating a tty or spawning a process, which will start with the correct size. Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-01-30Ok, no need for a separate version function.Christoph Lohmann
This is just redundant metadata. Please add Java comment meta classes too.
2016-01-30Add -n option for setting WM_CLASS instance nameQuentin Rameau
Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-01-30Reformat usage and separate version from itQuentin Rameau
Signed-off-by: Christoph Lohmann <20h@r-36.net>
2016-01-28Enforce a terminal size to reduce race conditions in too efficient apps.Christoph Lohmann
dvtm is too fast in starting up. It will then have a race condition in finding the right. terminal size.
2016-01-14Height is height.Christoph Lohmann
2016-01-01Bump year.Christoph Lohmann
2015-12-20Fixing the XClassHint setting in st.Christoph Lohmann
2015-11-21Avoid recursive call to ttywrite from ttyreadRoberto E. Vargas Caballero
Ttyread() calls to ttywrite, so if we check for reading before that for writing in ttywrite we can get a circular call sequence.
2015-11-06Introduce lim in all ttywrite() checks.Christoph Lohmann
2015-11-06Fix ttywrite()Roberto E. Vargas Caballero
ttywrite was assuming that if it could not write then it could read, but this is not necessarily true, there are some situations where you cannot read or write. The correct behaviour is to detect if you can read or/and write.
2015-11-01Now the mshortcuts are even more consistent.Ivan Tham
Keep everyone happy Signed-off-by: Christoph Lohmann <20h@r-36.net>
2015-10-31Now the Shortcuts are more consistent.Christoph Lohmann
Keep the debile happy.
2015-10-11fix bug where first selection snaps to linesJason Woofenden
2015-10-06Fix the cursor colors selectionQuentin Rameau
Signed-off-by: Christoph Lohmann <20h@r-36.net>
2015-10-06Normalize the whole color selection in xdrawcursor.Christoph Lohmann
2015-10-06Fix the cursor color when over selection.Quentin Rameau
If we want to show a custom selected cursor color, we must not set the revert attribute to the drawn glyph. Signed-off-by: Christoph Lohmann <20h@r-36.net>
2015-10-05Snowman is everywhere.Christoph Lohmann
2015-10-05The definition of the reverse cursor is now up to the user.Christoph Lohmann
2015-10-05Fixing the cursor movement in selections.Christoph Lohmann
Before the fix the cursor wouldn't obey if it's in a selection. If it is inside it will now change to the reverse. This patch also adds that the defaultcs will be reversed for the manually drawn cursors.
2015-10-05When the cursor is moved, clear the selection.Christoph Lohmann
2015-10-05Reverse the cursor on selection.Christoph Lohmann
2015-10-05More style changes. We forgot some switches.Christoph Lohmann
2015-10-05Small style change.Christoph Lohmann
2015-09-25Fix extra bracketed paste markers when pasting >8kbdequis
Before this patch, when pasting over BUFSIZE (8192 bytes here), st would do the following: \e[200~...8192 bytes...\e[201~\e[200~...remaining bytes...\e[201~ With this patch, the start marker is only sent when the offset is 0 (at the beginning of selnotify) and the end marker is only sent when the remaining bytes to read are 0 (at the end). For short pastes, both conditions are true in the same iteration. For long pastes, it removes the extra markers in the middle, keeping the intended wrapping: \e[200~...8192 bytes......remaining bytes...\e[201~ Signed-off-by: Christoph Lohmann <20h@r-36.net>