fix newline mode, add backend for cursor and crlf config in terminal config page

http-comm
Ondřej Hruška 7 years ago
parent 9ac5143228
commit ab921d2523
  1. 2
      front-end
  2. 23
      user/cgi_term_cfg.c
  3. 76
      user/screen.c
  4. 3
      user/screen.h

@ -1 +1 @@
Subproject commit 22101cc000e69f33b388602bbd221a7dfe82c730 Subproject commit 131389b6a7e9cf5253a0f4ef47f338d71c8587ea

@ -120,6 +120,12 @@ cgiTermCfgSetParams(HttpdConnData *connData)
termconf->fn_alt_mode = (bool)n; termconf->fn_alt_mode = (bool)n;
} }
if (GET_ARG("crlf_mode")) {
dbg("CRLF mode: %s", buff);
n = atoi(buff);
termconf->crlf_mode = (bool)n;
}
if (GET_ARG("show_buttons")) { if (GET_ARG("show_buttons")) {
dbg("Show buttons: %s", buff); dbg("Show buttons: %s", buff);
n = atoi(buff); n = atoi(buff);
@ -163,6 +169,17 @@ cgiTermCfgSetParams(HttpdConnData *connData)
} }
} }
if (GET_ARG("cursor_shape")) {
dbg("Cursor shape: %s", buff);
n = atoi(buff);
if (n >= 0 && n <= 6 && n != 1) {
termconf->cursor_shape = (enum CursorShape) n;
} else {
warn("Bad cursor_shape num: %s", buff);
redir_url += sprintf(redir_url, "cursor_shape,");
}
}
if (GET_ARG("term_title")) { if (GET_ARG("term_title")) {
dbg("Terminal title default text: \"%s\"", buff); dbg("Terminal title default text: \"%s\"", buff);
strncpy_safe(termconf->title, buff, 64); // ATTN those must match the values in strncpy_safe(termconf->title, buff, 64); // ATTN those must match the values in
@ -286,6 +303,9 @@ tplTermCfg(HttpdConnData *connData, char *token, void **arg)
else if (streq(token, "fn_alt_mode")) { else if (streq(token, "fn_alt_mode")) {
sprintf(buff, "%d", (int)termconf->fn_alt_mode); sprintf(buff, "%d", (int)termconf->fn_alt_mode);
} }
else if (streq(token, "crlf_mode")) {
sprintf(buff, "%d", (int)termconf->crlf_mode);
}
else if (streq(token, "show_buttons")) { else if (streq(token, "show_buttons")) {
sprintf(buff, "%d", (int)termconf->show_buttons); sprintf(buff, "%d", (int)termconf->show_buttons);
} }
@ -304,6 +324,9 @@ tplTermCfg(HttpdConnData *connData, char *token, void **arg)
else if (streq(token, "default_fg")) { else if (streq(token, "default_fg")) {
sprintf(buff, "%d", termconf->default_fg); sprintf(buff, "%d", termconf->default_fg);
} }
else if (streq(token, "cursor_shape")) {
sprintf(buff, "%d", termconf->cursor_shape);
}
else if (streq(token, "term_title")) { else if (streq(token, "term_title")) {
strncpy_safe(buff, termconf->title, BUFLEN); strncpy_safe(buff, termconf->title, BUFLEN);
} }

@ -49,12 +49,10 @@ static struct {
bool numpad_alt_mode; //!< DECNKM - Numpad Application Mode bool numpad_alt_mode; //!< DECNKM - Numpad Application Mode
bool cursors_alt_mode; //!< DECCKM - Cursors Application mode bool cursors_alt_mode; //!< DECCKM - Cursors Application mode
bool newline_mode; //!< LNM - CR automatically sends LF
bool reverse; //!< DECSCNM - Reverse video bool reverse; //!< DECSCNM - Reverse video
bool insert_mode; //!< IRM - Insert mode (move rest of the line to the right) bool insert_mode; //!< IRM - Insert mode (move rest of the line to the right)
bool cursor_visible; //!< DECTCEM - Cursor visible bool cursor_visible; //!< DECTCEM - Cursor visible
enum CursorShape cursor_shape;
// Vertical margin bounds (inclusive start/end of scrolling region) // Vertical margin bounds (inclusive start/end of scrolling region)
int vm0; int vm0;
@ -164,10 +162,11 @@ terminal_restore_defaults(void)
termconf->fn_alt_mode = SCR_DEF_FN_ALT_MODE; termconf->fn_alt_mode = SCR_DEF_FN_ALT_MODE;
termconf->config_version = TERMCONF_VERSION; termconf->config_version = TERMCONF_VERSION;
termconf->display_cooldown_ms = SCR_DEF_DISPLAY_COOLDOWN_MS; termconf->display_cooldown_ms = SCR_DEF_DISPLAY_COOLDOWN_MS;
termconf->loopback = 0; termconf->loopback = false;
termconf->show_buttons = 1; termconf->show_buttons = true;
termconf->show_config_links = 1; termconf->show_config_links = true;
termconf->def_cursor_shape = CURSOR_BLOCK_BL; termconf->cursor_shape = CURSOR_BLOCK_BL;
termconf->crlf_mode = false;
} }
/** /**
@ -214,7 +213,8 @@ terminal_apply_settings_noclear(void)
// Migrate to v3 // Migrate to v3
if (termconf->config_version < 4) { if (termconf->config_version < 4) {
dbg("termconf: Updating to version 4"); dbg("termconf: Updating to version 4");
termconf->def_cursor_shape = CURSOR_BLOCK_BL; termconf->cursor_shape = CURSOR_BLOCK_BL;
termconf->crlf_mode = false;
changed = 1; changed = 1;
} }
@ -306,8 +306,8 @@ screen_reset_on_resize(void)
void ICACHE_FLASH_ATTR void ICACHE_FLASH_ATTR
screen_reset_sgr(void) screen_reset_sgr(void)
{ {
cursor.fg = termconf_scratch.default_fg; cursor.fg = termconf->default_fg;
cursor.bg = termconf_scratch.default_bg; cursor.bg = termconf->default_bg;
cursor.attrs = 0; cursor.attrs = 0;
cursor.inverse = false; cursor.inverse = false;
} }
@ -329,11 +329,11 @@ screen_reset(void)
cursor.origin_mode = false; cursor.origin_mode = false;
cursor.auto_wrap = true; cursor.auto_wrap = true;
cursor.reverse_wraparound = false; cursor.reverse_wraparound = false;
scr.cursor_shape = termconf->def_cursor_shape; termconf_scratch.cursor_shape = termconf->cursor_shape;
scr.numpad_alt_mode = false; scr.numpad_alt_mode = false;
scr.cursors_alt_mode = false; scr.cursors_alt_mode = false;
scr.newline_mode = false; termconf_scratch.crlf_mode = termconf->crlf_mode;
scr.reverse = false; scr.reverse = false;
scr.vm0 = 0; scr.vm0 = 0;
@ -707,8 +707,8 @@ screen_fill_with_E(void)
sample.c[1] = 0; sample.c[1] = 0;
sample.c[2] = 0; sample.c[2] = 0;
sample.c[3] = 0; sample.c[3] = 0;
sample.fg = termconf_scratch.default_fg; sample.fg = termconf->default_fg;
sample.bg = termconf_scratch.default_bg; sample.bg = termconf->default_bg;
sample.attrs = 0; sample.attrs = 0;
for (unsigned int i = 0; i <= W*H-1; i++) { for (unsigned int i = 0; i <= W*H-1; i++) {
@ -848,8 +848,8 @@ void ICACHE_FLASH_ATTR
screen_cursor_shape(enum CursorShape shape) screen_cursor_shape(enum CursorShape shape)
{ {
NOTIFY_LOCK(); NOTIFY_LOCK();
if (shape == CURSOR_DEFAULT) shape = termconf->def_cursor_shape; if (shape == CURSOR_DEFAULT) shape = termconf->cursor_shape;
scr.cursor_shape = shape; termconf_scratch.cursor_shape = shape;
NOTIFY_DONE(); NOTIFY_DONE();
} }
@ -859,13 +859,13 @@ screen_cursor_blink(bool blink)
{ {
NOTIFY_LOCK(); NOTIFY_LOCK();
if (blink) { if (blink) {
if (scr.cursor_shape == CURSOR_BLOCK) scr.cursor_shape = CURSOR_BLOCK_BL; if (termconf_scratch.cursor_shape == CURSOR_BLOCK) termconf_scratch.cursor_shape = CURSOR_BLOCK_BL;
if (scr.cursor_shape == CURSOR_BAR) scr.cursor_shape = CURSOR_BAR_BL; if (termconf_scratch.cursor_shape == CURSOR_BAR) termconf_scratch.cursor_shape = CURSOR_BAR_BL;
if (scr.cursor_shape == CURSOR_UNDERLINE) scr.cursor_shape = CURSOR_UNDERLINE_BL; if (termconf_scratch.cursor_shape == CURSOR_UNDERLINE) termconf_scratch.cursor_shape = CURSOR_UNDERLINE_BL;
} else { } else {
if (scr.cursor_shape == CURSOR_BLOCK_BL) scr.cursor_shape = CURSOR_BLOCK; if (termconf_scratch.cursor_shape == CURSOR_BLOCK_BL) termconf_scratch.cursor_shape = CURSOR_BLOCK;
if (scr.cursor_shape == CURSOR_BAR_BL) scr.cursor_shape = CURSOR_BAR; if (termconf_scratch.cursor_shape == CURSOR_BAR_BL) termconf_scratch.cursor_shape = CURSOR_BAR;
if (scr.cursor_shape == CURSOR_UNDERLINE_BL) scr.cursor_shape = CURSOR_UNDERLINE; if (termconf_scratch.cursor_shape == CURSOR_UNDERLINE_BL) termconf_scratch.cursor_shape = CURSOR_UNDERLINE;
} }
NOTIFY_DONE(); NOTIFY_DONE();
} }
@ -1182,7 +1182,9 @@ screen_set_reverse_video(bool reverse)
void ICACHE_FLASH_ATTR void ICACHE_FLASH_ATTR
screen_set_newline_mode(bool nlm) screen_set_newline_mode(bool nlm)
{ {
scr.newline_mode = nlm; NOTIFY_LOCK();
termconf_scratch.crlf_mode = nlm;
NOTIFY_DONE();
} }
void ICACHE_FLASH_ATTR void ICACHE_FLASH_ATTR
@ -1231,10 +1233,6 @@ screen_putchar(const char *ch)
case LF: case LF:
screen_cursor_move(1, 0, true); // can scroll screen_cursor_move(1, 0, true); // can scroll
if (scr.newline_mode) {
// like CR
screen_cursor_set_x(0);
}
goto done; goto done;
case BS: case BS:
@ -1436,7 +1434,7 @@ screenSerializeToBuffer(char *buffer, size_t buf_len, void **data)
} while(0) } while(0)
#define bufput_3B(n) do { \ #define bufput_3B(n) do { \
encode3B((u16) n, &lw1); \ encode3B((u32) n, &lw1); \
bufput_c(lw1.lsb); \ bufput_c(lw1.lsb); \
bufput_c(lw1.msb); \ bufput_c(lw1.msb); \
bufput_c(lw1.xsb); \ bufput_c(lw1.xsb); \
@ -1466,17 +1464,19 @@ screenSerializeToBuffer(char *buffer, size_t buf_len, void **data)
bufput_2B(W); bufput_2B(W);
bufput_2B(cursor.y); bufput_2B(cursor.y);
bufput_2B(cursor.x); bufput_2B(cursor.x);
bufput_2B( // 3B has 18 free bits
(scr.cursor_visible ? 1<<0 : 0) | bufput_3B(
(cursor.hanging ? 1<<1 : 0) | (scr.cursor_visible << 0) |
(scr.cursors_alt_mode ? 1<<2 : 0) | (cursor.hanging << 1) |
(scr.numpad_alt_mode ? 1<<3 : 0) | (scr.cursors_alt_mode << 2) |
(termconf->fn_alt_mode ? 1<<4 : 0) | (scr.numpad_alt_mode << 3) |
((mouse_tracking.mode>MTM_NONE) ? 1<<5 : 0) | // disables context menu (termconf_scratch.fn_alt_mode << 4) |
((mouse_tracking.mode>=MTM_NORMAL) ? 1<<6 : 0) | // disables selecting ((mouse_tracking.mode>MTM_NONE) << 5) | // disables context menu
(termconf_scratch.show_buttons ? 1<<7 : 0) | ((mouse_tracking.mode>=MTM_NORMAL) << 6) | // disables selecting
(termconf_scratch.show_config_links ? 1<<8 : 0) | (termconf_scratch.show_buttons << 7) |
((scr.cursor_shape&0x03)<<9) // 9,10,11 - cursor shape based on DECSCUSR (termconf_scratch.show_config_links << 8) |
((termconf_scratch.cursor_shape&0x03) << 9) | // 9,10,11 - cursor shape based on DECSCUSR
(termconf_scratch.crlf_mode << 12)
); );
} }

@ -85,7 +85,8 @@ typedef struct {
bool show_buttons; bool show_buttons;
bool show_config_links; bool show_config_links;
char btn_msg[TERM_BTN_COUNT][TERM_BTN_MSG_LEN]; char btn_msg[TERM_BTN_COUNT][TERM_BTN_MSG_LEN];
enum CursorShape def_cursor_shape; enum CursorShape cursor_shape;
bool crlf_mode;
} TerminalConfigBundle; } TerminalConfigBundle;
// Live config // Live config

Loading…
Cancel
Save