summaryrefslogtreecommitdiff
path: root/st.c
Commit message (Collapse)AuthorAgeFilesLines
* Add parsing of DCS q sequencesRoberto E. Vargas Caballero2016-09-141-23/+45
| | | | | | 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.
* Add support for enabling/disabling utfRoberto E. Vargas Caballero2016-09-131-17/+62
| | | | | | | 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.
* Use XftFontMatch in place of FcFontMatch.Christoph Lohmann2016-06-031-4/+1
| | | | | | | | | | | | | | 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
* delete clipboard properties after pasting themv4hn2016-06-031-2/+1
| | | | | | | | | | | | | | 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>
* Remove stupid assignation in memcpy()Roberto E. Vargas Caballero2016-04-151-2/+2
|
* st: Fix off-by-one error when calculating character width.Tor Andersson2016-03-091-2/+2
| | | | | | | | | | | | 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>
* Fix vertical character alignment in some casesTon van den Heuvel2016-03-081-1/+1
| | | | | | | | | 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>
* Measure the single advance width with a heuristic methodRyusei Yamaguchi2016-03-081-1/+7
| | | | | | | | 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>
* xtermclear() is now done by xdrawglyphfontspecs()Christoph Lohmann2016-03-071-13/+0
| | | | Thanks Ton van den Heuvel for the proposal!
* Fix forgotten bracket and duplicate option in usage()Quentin Rameau2016-02-011-6/+8
| | | | | | | | | | 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>
* Extract ttyresize() out of cresize()Quentin Rameau2016-01-301-4/+4
| | | | | | | 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>
* Ok, no need for a separate version function.Christoph Lohmann2016-01-301-8/+1
| | | | This is just redundant metadata. Please add Java comment meta classes too.
* Add -n option for setting WM_CLASS instance nameQuentin Rameau2016-01-301-15/+19
| | | | Signed-off-by: Christoph Lohmann <20h@r-36.net>
* Reformat usage and separate version from itQuentin Rameau2016-01-301-8/+16
| | | | Signed-off-by: Christoph Lohmann <20h@r-36.net>
* Enforce a terminal size to reduce race conditions in too efficient apps.Christoph Lohmann2016-01-281-0/+2
| | | | | dvtm is too fast in starting up. It will then have a race condition in finding the right. terminal size.
* Height is height.Christoph Lohmann2016-01-141-1/+1
|
* Bump year.Christoph Lohmann2016-01-011-1/+1
|
* Fixing the XClassHint setting in st.Christoph Lohmann2015-12-201-1/+1
|
* Avoid recursive call to ttywrite from ttyreadRoberto E. Vargas Caballero2015-11-211-2/+2
| | | | | Ttyread() calls to ttywrite, so if we check for reading before that for writing in ttywrite we can get a circular call sequence.
* Introduce lim in all ttywrite() checks.Christoph Lohmann2015-11-061-4/+4
|
* Fix ttywrite()Roberto E. Vargas Caballero2015-11-061-18/+20
| | | | | | | 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.
* Now the mshortcuts are even more consistent.Ivan Tham2015-11-011-5/+5
| | | | | | Keep everyone happy Signed-off-by: Christoph Lohmann <20h@r-36.net>
* Now the Shortcuts are more consistent.Christoph Lohmann2015-10-311-2/+2
| | | | Keep the debile happy.
* fix bug where first selection snaps to linesJason Woofenden2015-10-111-2/+3
|
* Fix the cursor colors selectionQuentin Rameau2015-10-061-3/+2
| | | | Signed-off-by: Christoph Lohmann <20h@r-36.net>
* Normalize the whole color selection in xdrawcursor.Christoph Lohmann2015-10-061-11/+22
|
* Fix the cursor color when over selection.Quentin Rameau2015-10-061-1/+2
| | | | | | | 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>
* Snowman is everywhere.Christoph Lohmann2015-10-051-0/+2
|
* The definition of the reverse cursor is now up to the user.Christoph Lohmann2015-10-051-12/+3
|
* Fixing the cursor movement in selections.Christoph Lohmann2015-10-051-13/+31
| | | | | | 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.
* When the cursor is moved, clear the selection.Christoph Lohmann2015-10-051-0/+1
|
* Reverse the cursor on selection.Christoph Lohmann2015-10-051-0/+3
|
* More style changes. We forgot some switches.Christoph Lohmann2015-10-051-33/+33
|
* Small style change.Christoph Lohmann2015-10-051-4/+4
|
* Fix extra bracketed paste markers when pasting >8kbdequis2015-09-251-2/+2
| | | | | | | | | | | | | | | | | | | | 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>
* dup() -> dup2()FRIGN2015-09-221-2/+1
| | | | | | | gcc would warn about an unused result. We know it is 0 and dup() can't fail in these circumstances, as we closed fd0 previously. Using dup2() to do the same saves one line and shuts gcc up, bringing us a clean build back.
* Fix copy of line with len = 0Roberto E. Vargas Caballero2015-09-101-1/+4
| | | | | | | When a line has no any character linelen is 0, so last = &term.line[y][MIN(lastx, linelen-1)] generated a pointer to the end of the previous line. The best thing we can do in this case is to add a newline, because we don't have a glyph to print (and consult its state of wrapping).
* Expose cursor shape in config.def.hJan Christoph Ebersbach2015-09-081-1/+1
| | | | Signed-off-by: Christoph Lohmann <20h@r-36.net>
* Add key to send a break to the serial lineRoberto E. Vargas Caballero2015-09-081-0/+9
|
* Making st.1 more descriptive about -l and fix -l in st.c.Christoph Lohmann2015-09-071-1/+1
|
* Reordering and adding control codes.Christoph Lohmann2015-08-311-2/+21
| | | | For completeness and documentation add all C1 control codes.
* Merge branch 'master' of ssh://suckless.org/gitrepos/stChristoph Lohmann2015-08-301-2/+2
|\
| * Do not mark as invalid UTF8 control codesRoberto E. Vargas Caballero2015-08-181-2/+2
| | | | | | | | | | | | wcwidth() returns -1 for all the non visible characters, but it doesn't necessarilly mean that they are incorrect. It only means that they are not printable.
* | Don't read if we chunked the input data.Christoph Lohmann2015-08-301-1/+2
|/
* Adding mouse colour/shape settingsAlex Kozadaev2015-07-281-4/+16
|
* Adding -T to the usage too.Christoph Lohmann2015-07-241-2/+4
|
* Add -T, as recommended by Dmitrij D. CzarkoffChristoph Lohmann2015-07-241-0/+1
|
* Fix type for write(2) return variable.Quentin Rameau2015-07-241-1/+2
| | | | | | | | | | | | A little fix in xwrite(). >From 3727d2e3344b57128ab51c7839795204f1f839ff Mon Sep 17 00:00:00 2001 From: Quentin Rameau <quinq@fifth.space> Date: Fri, 24 Jul 2015 11:40:46 +0200 Subject: [PATCH] Fix type for write(2) return variable. The allocated lengh of s fits into an integer so we can safely use ssize_t here.
* Fix style in execshRoberto E. Vargas Caballero2015-07-241-2/+1
|
* Make the comment for the IM XFilter more understandable.Christoph Lohmann2015-07-101-3/+3
|
© 2025 Stefan Weigl-Bosker