Adding fullscreen patch ref. #88
This commit is contained in:
parent
4dfb6683cd
commit
d8529b66a4
@ -15,6 +15,8 @@ Refer to [https://st.suckless.org/](https://st.suckless.org/) for details on the
|
|||||||
|
|
||||||
### Changelog:
|
### Changelog:
|
||||||
|
|
||||||
|
2022-10-24 - Added the fullscreen patch
|
||||||
|
|
||||||
2022-08-28 - Added the use XftFontMatch patch
|
2022-08-28 - Added the use XftFontMatch patch
|
||||||
|
|
||||||
2022-08-24 - Added the no window decorations patch
|
2022-08-24 - Added the no window decorations patch
|
||||||
@ -174,6 +176,9 @@ Refer to [https://st.suckless.org/](https://st.suckless.org/) for details on the
|
|||||||
- [~force-redraw-after-keypress~](https://lists.suckless.org/hackers/2004/17221.html)
|
- [~force-redraw-after-keypress~](https://lists.suckless.org/hackers/2004/17221.html)
|
||||||
- ~this patch forces the terminal to check for new data on the tty on keypress with the aim of reducing input latency~
|
- ~this patch forces the terminal to check for new data on the tty on keypress with the aim of reducing input latency~
|
||||||
|
|
||||||
|
- [fullscreen](https://st.suckless.org/patches/fullscreen/)
|
||||||
|
- allows the st window to go into fullscreen mode
|
||||||
|
|
||||||
- [gradient](https://st.suckless.org/patches/gradient/)
|
- [gradient](https://st.suckless.org/patches/gradient/)
|
||||||
- adds gradient transparency to st
|
- adds gradient transparency to st
|
||||||
- depends on the alpha patch
|
- depends on the alpha patch
|
||||||
|
@ -401,6 +401,10 @@ static Shortcut shortcuts[] = {
|
|||||||
//{ TERMMOD, XK_, changealphaunfocused, {.f = -0.05} },
|
//{ TERMMOD, XK_, changealphaunfocused, {.f = -0.05} },
|
||||||
#endif // ALPHA_FOCUS_HIGHLIGHT_PATCH
|
#endif // ALPHA_FOCUS_HIGHLIGHT_PATCH
|
||||||
#endif // ALPHA_PATCH
|
#endif // ALPHA_PATCH
|
||||||
|
#if FULLSCREEN_PATCH
|
||||||
|
{ XK_NO_MOD, XK_F11, fullscreen, {.i = 0} },
|
||||||
|
{ MODKEY, XK_Return, fullscreen, {.i = 0} },
|
||||||
|
#endif // FULLSCREEN_PATCH
|
||||||
#if SCROLLBACK_PATCH
|
#if SCROLLBACK_PATCH
|
||||||
{ ShiftMask, XK_Page_Up, kscrollup, {.i = -1}, S_PRI },
|
{ ShiftMask, XK_Page_Up, kscrollup, {.i = -1}, S_PRI },
|
||||||
{ ShiftMask, XK_Page_Down, kscrolldown, {.i = -1}, S_PRI },
|
{ ShiftMask, XK_Page_Down, kscrolldown, {.i = -1}, S_PRI },
|
||||||
|
17
patch/fullscreen_x.c
Normal file
17
patch/fullscreen_x.c
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
void
|
||||||
|
fullscreen(const Arg *arg)
|
||||||
|
{
|
||||||
|
XEvent ev;
|
||||||
|
|
||||||
|
memset(&ev, 0, sizeof(ev));
|
||||||
|
|
||||||
|
ev.xclient.type = ClientMessage;
|
||||||
|
ev.xclient.message_type = xw.netwmstate;
|
||||||
|
ev.xclient.display = xw.dpy;
|
||||||
|
ev.xclient.window = xw.win;
|
||||||
|
ev.xclient.format = 32;
|
||||||
|
ev.xclient.data.l[0] = 2; /* _NET_WM_STATE_TOGGLE */
|
||||||
|
ev.xclient.data.l[1] = xw.netwmfullscreen;
|
||||||
|
|
||||||
|
XSendEvent(xw.dpy, DefaultRootWindow(xw.dpy), False, SubstructureNotifyMask|SubstructureRedirectMask, &ev);
|
||||||
|
}
|
1
patch/fullscreen_x.h
Normal file
1
patch/fullscreen_x.h
Normal file
@ -0,0 +1 @@
|
|||||||
|
static void fullscreen(const Arg *arg);
|
@ -17,6 +17,9 @@
|
|||||||
#if FONT2_PATCH
|
#if FONT2_PATCH
|
||||||
#include "font2.c"
|
#include "font2.c"
|
||||||
#endif
|
#endif
|
||||||
|
#if FULLSCREEN_PATCH
|
||||||
|
#include "fullscreen_x.c"
|
||||||
|
#endif
|
||||||
#if INVERT_PATCH
|
#if INVERT_PATCH
|
||||||
#include "invert.c"
|
#include "invert.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -14,6 +14,9 @@
|
|||||||
#if FONT2_PATCH
|
#if FONT2_PATCH
|
||||||
#include "font2.h"
|
#include "font2.h"
|
||||||
#endif
|
#endif
|
||||||
|
#if FULLSCREEN_PATCH
|
||||||
|
#include "fullscreen_x.h"
|
||||||
|
#endif
|
||||||
#if INVERT_PATCH
|
#if INVERT_PATCH
|
||||||
#include "invert.h"
|
#include "invert.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -180,6 +180,13 @@
|
|||||||
*/
|
*/
|
||||||
#define FONT2_PATCH 0
|
#define FONT2_PATCH 0
|
||||||
|
|
||||||
|
/* This patch adds the ability to toggle st into fullscreen mode.
|
||||||
|
* Two key bindings are defined: F11 which is typical with other applications and Alt+Enter
|
||||||
|
* which matches the default xterm behavior.
|
||||||
|
* https://st.suckless.org/patches/fullscreen/
|
||||||
|
*/
|
||||||
|
#define FULLSCREEN_PATCH 0
|
||||||
|
|
||||||
/* Hide the X cursor whenever a key is pressed and show it back when the mouse is moved in
|
/* Hide the X cursor whenever a key is pressed and show it back when the mouse is moved in
|
||||||
* the terminal window.
|
* the terminal window.
|
||||||
* https://st.suckless.org/patches/hidecursor/
|
* https://st.suckless.org/patches/hidecursor/
|
||||||
|
3
st.h
3
st.h
@ -211,6 +211,9 @@ typedef struct {
|
|||||||
Drawable buf;
|
Drawable buf;
|
||||||
GlyphFontSpec *specbuf; /* font spec buffer used for rendering */
|
GlyphFontSpec *specbuf; /* font spec buffer used for rendering */
|
||||||
Atom xembed, wmdeletewin, netwmname, netwmiconname, netwmpid;
|
Atom xembed, wmdeletewin, netwmname, netwmiconname, netwmpid;
|
||||||
|
#if FULLSCREEN_PATCH
|
||||||
|
Atom netwmstate, netwmfullscreen;
|
||||||
|
#endif // FULLSCREEN_PATCH
|
||||||
#if NETWMICON_PATCH
|
#if NETWMICON_PATCH
|
||||||
Atom netwmicon;
|
Atom netwmicon;
|
||||||
#endif // NETWMICON_PATCH
|
#endif // NETWMICON_PATCH
|
||||||
|
5
x.c
5
x.c
@ -1581,6 +1581,11 @@ xinit(int cols, int rows)
|
|||||||
XChangeProperty(xw.dpy, xw.win, xw.netwmpid, XA_CARDINAL, 32,
|
XChangeProperty(xw.dpy, xw.win, xw.netwmpid, XA_CARDINAL, 32,
|
||||||
PropModeReplace, (uchar *)&thispid, 1);
|
PropModeReplace, (uchar *)&thispid, 1);
|
||||||
|
|
||||||
|
#if FULLSCREEN_PATCH
|
||||||
|
xw.netwmstate = XInternAtom(xw.dpy, "_NET_WM_STATE", False);
|
||||||
|
xw.netwmfullscreen = XInternAtom(xw.dpy, "_NET_WM_STATE_FULLSCREEN", False);
|
||||||
|
#endif // FULLSCREEN_PATCH
|
||||||
|
|
||||||
win.mode = MODE_NUMLOCK;
|
win.mode = MODE_NUMLOCK;
|
||||||
resettitle();
|
resettitle();
|
||||||
xhints();
|
xhints();
|
||||||
|
Loading…
Reference in New Issue
Block a user