|
|
@ -1421,7 +1421,8 @@ tsetattr(int *attr, int l) {
|
|
|
|
case 4:
|
|
|
|
case 4:
|
|
|
|
term.c.attr.mode |= ATTR_UNDERLINE;
|
|
|
|
term.c.attr.mode |= ATTR_UNDERLINE;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 5:
|
|
|
|
case 5: /* slow blink */
|
|
|
|
|
|
|
|
case 6: /* rapid blink */
|
|
|
|
term.c.attr.mode |= ATTR_BLINK;
|
|
|
|
term.c.attr.mode |= ATTR_BLINK;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 7:
|
|
|
|
case 7:
|
|
|
@ -1438,6 +1439,7 @@ tsetattr(int *attr, int l) {
|
|
|
|
term.c.attr.mode &= ~ATTR_UNDERLINE;
|
|
|
|
term.c.attr.mode &= ~ATTR_UNDERLINE;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 25:
|
|
|
|
case 25:
|
|
|
|
|
|
|
|
case 26:
|
|
|
|
term.c.attr.mode &= ~ATTR_BLINK;
|
|
|
|
term.c.attr.mode &= ~ATTR_BLINK;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 27:
|
|
|
|
case 27:
|
|
|
@ -1744,7 +1746,7 @@ csihandle(void) {
|
|
|
|
case 'X': /* ECH -- Erase <n> char */
|
|
|
|
case 'X': /* ECH -- Erase <n> char */
|
|
|
|
DEFAULT(csiescseq.arg[0], 1);
|
|
|
|
DEFAULT(csiescseq.arg[0], 1);
|
|
|
|
tclearregion(term.c.x, term.c.y, term.c.x + csiescseq.arg[0],
|
|
|
|
tclearregion(term.c.x, term.c.y, term.c.x + csiescseq.arg[0],
|
|
|
|
term.c.y, 0);
|
|
|
|
term.c.y, 1);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 'P': /* DCH -- Delete <n> char */
|
|
|
|
case 'P': /* DCH -- Delete <n> char */
|
|
|
|
DEFAULT(csiescseq.arg[0], 1);
|
|
|
|
DEFAULT(csiescseq.arg[0], 1);
|
|
|
@ -2206,9 +2208,11 @@ tresize(int col, int row) {
|
|
|
|
/* free unneeded rows */
|
|
|
|
/* free unneeded rows */
|
|
|
|
i = 0;
|
|
|
|
i = 0;
|
|
|
|
if(slide > 0) {
|
|
|
|
if(slide > 0) {
|
|
|
|
/* slide screen to keep cursor where we expect it -
|
|
|
|
/*
|
|
|
|
|
|
|
|
* slide screen to keep cursor where we expect it -
|
|
|
|
* tscrollup would work here, but we can optimize to
|
|
|
|
* tscrollup would work here, but we can optimize to
|
|
|
|
* memmove because we're freeing the earlier lines */
|
|
|
|
* memmove because we're freeing the earlier lines
|
|
|
|
|
|
|
|
*/
|
|
|
|
for(/* i = 0 */; i < slide; i++) {
|
|
|
|
for(/* i = 0 */; i < slide; i++) {
|
|
|
|
free(term.line[i]);
|
|
|
|
free(term.line[i]);
|
|
|
|
free(term.alt[i]);
|
|
|
|
free(term.alt[i]);
|
|
|
@ -2456,8 +2460,7 @@ xloadfonts(char *fontstr, int fontsize) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void
|
|
|
|
xunloadfonts(void)
|
|
|
|
xunloadfonts(void) {
|
|
|
|
{
|
|
|
|
|
|
|
|
int i, ip;
|
|
|
|
int i, ip;
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
/*
|
|
|
@ -2487,8 +2490,7 @@ xunloadfonts(void)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void
|
|
|
|
xzoom(const Arg *arg)
|
|
|
|
xzoom(const Arg *arg) {
|
|
|
|
{
|
|
|
|
|
|
|
|
xunloadfonts();
|
|
|
|
xunloadfonts();
|
|
|
|
xloadfonts(usedfont, usedfontsize + arg->i);
|
|
|
|
xloadfonts(usedfont, usedfontsize + arg->i);
|
|
|
|
cresize(0, 0);
|
|
|
|
cresize(0, 0);
|
|
|
@ -3109,8 +3111,10 @@ kpress(XEvent *ev) {
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void
|
|
|
|
cmessage(XEvent *e) {
|
|
|
|
cmessage(XEvent *e) {
|
|
|
|
/* See xembed specs
|
|
|
|
/*
|
|
|
|
http://standards.freedesktop.org/xembed-spec/xembed-spec-latest.html */
|
|
|
|
* See xembed specs
|
|
|
|
|
|
|
|
* http://standards.freedesktop.org/xembed-spec/xembed-spec-latest.html
|
|
|
|
|
|
|
|
*/
|
|
|
|
if(e->xclient.message_type == xw.xembed && e->xclient.format == 32) {
|
|
|
|
if(e->xclient.message_type == xw.xembed && e->xclient.format == 32) {
|
|
|
|
if(e->xclient.data.l[1] == XEMBED_FOCUS_IN) {
|
|
|
|
if(e->xclient.data.l[1] == XEMBED_FOCUS_IN) {
|
|
|
|
xw.state |= WIN_FOCUSED;
|
|
|
|
xw.state |= WIN_FOCUSED;
|
|
|
@ -3126,8 +3130,7 @@ cmessage(XEvent *e) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void
|
|
|
|
cresize(int width, int height)
|
|
|
|
cresize(int width, int height) {
|
|
|
|
{
|
|
|
|
|
|
|
|
int col, row;
|
|
|
|
int col, row;
|
|
|
|
|
|
|
|
|
|
|
|
if(width != 0)
|
|
|
|
if(width != 0)
|
|
|
|