svn commit: trunk/busybox/console-tools
Bernhard Fischer
rep.dot.nop at gmail.com
Tue Mar 13 08:35:41 UTC 2007
On Mon, Mar 12, 2007 at 04:41:07PM -0700, vda at busybox.net wrote:
>Author: vda
>Date: 2007-03-12 16:41:07 -0700 (Mon, 12 Mar 2007)
>New Revision: 18080
>
>Log:
>resize: make it usable in in backticks; have a timeout (if display
>doesn't respond to 'get cursor pos' ESC sequence...)
>
>
>Modified:
> trunk/busybox/console-tools/resize.c
>
>
>Changeset:
>Modified: trunk/busybox/console-tools/resize.c
>===================================================================
>--- trunk/busybox/console-tools/resize.c 2007-03-12 23:34:52 UTC (rev 18079)
>+++ trunk/busybox/console-tools/resize.c 2007-03-12 23:41:07 UTC (rev 18080)
>@@ -11,31 +11,60 @@
>
> #define ESC "\033"
>
>+struct termios old;
>+
>+static void
>+onintr(int sig ATTRIBUTE_UNUSED)
>+{
>+ tcsetattr(STDERR_FILENO, TCSANOW, &old);
>+ exit(1);
>+}
My initial proposal had a timeout-handling already:
http://busybox.net/~aldot/bb/busybox.applet_resize.00c.diff
The timeouthandling was dropped since Rob vetoed it..
To me it looks like the initial timeout proposal would be smaller and
should work equally well, no?
thanks,
>+
>+
> int resize_main(int argc, char **argv);
> int resize_main(int argc, char **argv)
> {
>- struct termios old, new;
>- struct winsize w = {0,0,0,0};
>+ struct termios new;
>+ struct winsize w = { 0,0,0,0 };
> int ret;
>
>- tcgetattr(STDOUT_FILENO, &old); /* fiddle echo */
>+ /* We use _stderr_ in order to make resize usable
>+ * in shell backticks (those redirect stdout away from tty).
>+ * NB: other versions of resize open "/dev/tty"
>+ * and operate on it - should we do the same?
>+ */
>+
>+ tcgetattr(STDERR_FILENO, &old); /* fiddle echo */
> new = old;
> new.c_cflag |= (CLOCAL | CREAD);
> new.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG);
>- tcsetattr(STDOUT_FILENO, TCSANOW, &new);
>+ signal(SIGINT, onintr);
>+ signal(SIGQUIT, onintr);
>+ signal(SIGTERM, onintr);
>+ signal(SIGALRM, onintr);
>+ tcsetattr(STDERR_FILENO, TCSANOW, &new);
>+
> /* save_cursor_pos 7
> * scroll_whole_screen [r
> * put_cursor_waaaay_off [$x;$yH
> * get_cursor_pos [6n
> * restore_cursor_pos 8
> */
>- printf(ESC"7" ESC"[r" ESC"[999;999H" ESC"[6n");
>+ fprintf(stderr, ESC"7" ESC"[r" ESC"[999;999H" ESC"[6n");
>+ alarm(3); /* Just in case terminal won't answer */
> scanf(ESC"[%hu;%huR", &w.ws_row, &w.ws_col);
>- ret = ioctl(STDOUT_FILENO, TIOCSWINSZ, &w);
>- printf(ESC"8");
>- tcsetattr(STDOUT_FILENO, TCSANOW, &old);
>+ fprintf(stderr, ESC"8");
>+
>+ /* BTW, other versions of resize recalculate w.ws_xpixel, ws.ws_ypixel
>+ * by calculating character cell HxW from old values
>+ * (gotten via TIOCGWINSZ) and recomputing *pixel values */
>+ ret = ioctl(STDERR_FILENO, TIOCSWINSZ, &w);
>+
>+ tcsetattr(STDERR_FILENO, TCSANOW, &old);
>+
> if (ENABLE_FEATURE_RESIZE_PRINT)
> printf("COLUMNS=%d;LINES=%d;export COLUMNS LINES;\n",
> w.ws_col, w.ws_row);
>+
> return ret;
> }
>
>_______________________________________________
>busybox-cvs mailing list
>busybox-cvs at busybox.net
>http://busybox.net/cgi-bin/mailman/listinfo/busybox-cvs
>
More information about the busybox
mailing list