aboutsummaryrefslogtreecommitdiffstats
path: root/src/frame.c
diff options
context:
space:
mode:
authorKaroly Lorentey2003-12-29 07:16:26 +0000
committerKaroly Lorentey2003-12-29 07:16:26 +0000
commit0a1258976b3ac8f6ffc56115def6bd2e5b76f8bc (patch)
tree350c7e580c8d856ec227d350cf396dacac4ce20a /src/frame.c
parent04c3243c2a25812c6d0a324d29b8fd1d5acaa715 (diff)
downloademacs-0a1258976b3ac8f6ffc56115def6bd2e5b76f8bc.tar.gz
emacs-0a1258976b3ac8f6ffc56115def6bd2e5b76f8bc.zip
Bugfix festival.
lib-src/emacsclient.c (main_argc, main_argv): New variables. (main): Initialize them. (fail): Use them. (window_change, copy_from_to): Don't kill if emacs_pid is zero. (pty_conversation): Watch the command socket, too. Read emacs_pid here. Emacs and emacsclient could deadlock if Emacs tried to do a reset_sys_modes before sending its pid. lisp/server.el: Automatically delete the client frame when done editing. (server-frames): New variable. (server-process-filter, server-sentinel, server-buffer-done): Use it. (server-process-filter): Do a redisplay before evaluating other parameters. (Prevents "emacsclient -h -e '(delete-frame)'" from messing up the system. src/dispextern.h: Update prototypes. src/dispnew.c (window_change_signal): Do nothing if !term_initted. (init_display): Set the frame size from the tty data after term_init. src/emacs.c (main): Make sure things that init_sys_modes needs are initialized before init_display (which calls init_sys_modes now). (sort_args): Use xfree, not free. (shut_down_emacs) [!EMACS_HAVE_TTY_PGRP]: Use reset_all_sys_modes instead of reset_sys_modes. src/frame.c (make_terminal_frame): Sigh. Move terminal initialization back to the middle of frame setup. Handle errors by making sure that the delete_tty() called from term_init() will see and delete this frame. (Fdelete_frame): Kill the frame before calling delete_tty(). Fix condition for tty deletion. src/keyboard.c (Fset_input_mode): Use reset_sys_modes on the current terminal only. src/lisp.h: Remove duplicate prototypes. src/msdos.c (croak): use reset_all_sys_modes(). src/sysdeps.c (init_baud_rate): Added tty parameter, use it instead of CURTTY. (child_setup_tty): Reset sigio on stdin, not CURTTY(). (reset_sigio): Added fd parameter, put explicit fcntl there. (request_sigio, unrequest_sigio)[FASYNC]: Simply block/unblock the SIGIO signal, don't touch the file params. There are multiple ttys now, and we can't disable the SIGIO from emacsclient. (get_tty_size)[VMS]: Use tty_out instead of CURTTY(). (reset_sys_modes): Don't call cursor_to, clear_end_of_line; call cmgoto and tty_clear_end_of_line instead. The frame may already be dead. Updated reset_sigio call. src/term.c (clear_and_of_line): Separate tty-dependent stuff to tty_clear_end_of_line() for reset_sys_modes. (tty_clear_end_of_line): New function. (term_init): Added frame parameter, don't use selected_frame. Set the frame's output_data.tty value (in case there is an error later). Set the frame size in Wcm, not in the frame. Only free the termcap buffer if there is a termcap-related error. Call init_sys_modes last, not first. (deleting_tty): New variable. (delete_tty): Use it for handling recursive calls. Free deleted tty, except its Wcm (there is still a dangling reference somewhere). git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-19
Diffstat (limited to 'src/frame.c')
-rw-r--r--src/frame.c49
1 files changed, 32 insertions, 17 deletions
diff --git a/src/frame.c b/src/frame.c
index 8f8dea8fa75..9a532bfdd2d 100644
--- a/src/frame.c
+++ b/src/frame.c
@@ -485,13 +485,6 @@ make_terminal_frame (tty_name, tty_type)
485 register struct frame *f; 485 register struct frame *f;
486 Lisp_Object frame; 486 Lisp_Object frame;
487 char name[20]; 487 char name[20];
488 struct tty_output *tty;
489
490 /* init_term may throw an error, so create the tty first. */
491 if (initialized)
492 tty = term_init (tty_name, tty_type);
493 else
494 tty = term_dummy_init ();
495 488
496#ifdef MULTI_KBOARD 489#ifdef MULTI_KBOARD
497 if (!initial_kboard) 490 if (!initial_kboard)
@@ -550,9 +543,23 @@ make_terminal_frame (tty_name, tty_type)
550#ifdef MAC_OS8 543#ifdef MAC_OS8
551 make_mac_terminal_frame (f); 544 make_mac_terminal_frame (f);
552#else 545#else
553 f->output_method = output_termcap; 546 {
554 f->output_data.tty = tty; 547 struct tty_output *tty;
555 f->output_data.tty->top_frame = frame; 548 f->output_method = output_termcap;
549
550 if (initialized)
551 {
552 /* Note that term_init may signal an error, but then it is its
553 responsibility to make sure this frame is deleted. */
554 f->output_data.tty = term_init (frame, tty_name, tty_type);
555 }
556 else
557 {
558 /* init_display() will reinitialize the terminal with correct values after dump. */
559 f->output_data.tty = term_dummy_init ();
560 }
561 }
562
556#ifdef CANNOT_DUMP 563#ifdef CANNOT_DUMP
557 FRAME_FOREGROUND_PIXEL(f) = FACE_TTY_DEFAULT_FG_COLOR; 564 FRAME_FOREGROUND_PIXEL(f) = FACE_TTY_DEFAULT_FG_COLOR;
558 FRAME_BACKGROUND_PIXEL(f) = FACE_TTY_DEFAULT_BG_COLOR; 565 FRAME_BACKGROUND_PIXEL(f) = FACE_TTY_DEFAULT_BG_COLOR;
@@ -1383,25 +1390,33 @@ The functions are run with one arg, the frame to be deleted. */)
1383 1390
1384 if (FRAME_TERMCAP_P (f)) 1391 if (FRAME_TERMCAP_P (f))
1385 { 1392 {
1386 /* See if the terminal needs to be closed. */
1387 Lisp_Object tail, frame1; 1393 Lisp_Object tail, frame1;
1388 int delete = 1; 1394 int delete = 1;
1395 struct tty_output *tty = FRAME_TTY (f);
1396
1397 /* delete_tty will call us recursively, so better kill the
1398 frame now. */
1399 f->output_data.nothing = 0;
1389 1400
1401 /* See if the terminal needs to be closed. */
1390 FOR_EACH_FRAME (tail, frame1) 1402 FOR_EACH_FRAME (tail, frame1)
1391 { 1403 {
1392 if (!FRAME_LIVE_P (XFRAME (frame1)) && 1404 if (frame1 != frame
1393 FRAME_TERMCAP_P (XFRAME (frame1)) && 1405 && FRAME_LIVE_P (XFRAME (frame1))
1394 FRAME_TTY (XFRAME (frame1)) == FRAME_TTY (f)) 1406 && FRAME_TERMCAP_P (XFRAME (frame1))
1407 && FRAME_TTY (XFRAME (frame1)) == FRAME_TTY (f))
1395 { 1408 {
1396 delete = 0; 1409 delete = 0;
1397 break; 1410 break;
1398 } 1411 }
1399 } 1412 }
1400 if (delete) 1413 if (delete)
1401 delete_tty (FRAME_TTY (f)); 1414 delete_tty (tty);
1415 }
1416 else
1417 {
1418 f->output_data.nothing = 0;
1402 } 1419 }
1403
1404 f->output_data.nothing = 0;
1405 1420
1406 /* If we've deleted the last_nonminibuf_frame, then try to find 1421 /* If we've deleted the last_nonminibuf_frame, then try to find
1407 another one. */ 1422 another one. */