aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMiles Bader <[email protected]>2007-10-11 16:24:58 +0000
committerMiles Bader <[email protected]>2007-10-11 16:24:58 +0000
commitc73bd236f75b742ad4642ec94798987ae6e3e1e8 (patch)
treeef5edc8db557fc1d25a17c379e4ae63a38b3ba5c /src
parentecb21060d5c1752d41d7a742be565c59b5fcb855 (diff)
parent58ade22bf16a9ec2ff0aee6c59d8db4d1703e94f (diff)
Merge from emacs--devo--0
Patches applied: * emacs--devo--0 (patch 866-879) - Merge multi-tty branch - Update from CVS - Merge from emacs--rel--22 Revision: [email protected]/emacs--unicode--0--patch-257
Diffstat (limited to 'src')
-rw-r--r--src/.arch-inventory3
-rw-r--r--src/.gdbinit4
-rw-r--r--src/ChangeLog29202
-rw-r--r--src/ChangeLog.1027934
-rw-r--r--src/Makefile.in80
-rw-r--r--src/abbrev.c3
-rw-r--r--src/alloc.c530
-rw-r--r--src/alloca.c517
-rw-r--r--src/buffer.c96
-rw-r--r--src/buffer.h2
-rw-r--r--src/callint.c54
-rw-r--r--src/callproc.c283
-rw-r--r--src/cm.c216
-rw-r--r--src/cm.h118
-rw-r--r--src/coding.c57
-rw-r--r--src/coding.h11
-rw-r--r--src/config.in7
-rw-r--r--src/data.c74
-rw-r--r--src/dispextern.h96
-rw-r--r--src/dispnew.c389
-rw-r--r--src/emacs.c46
-rw-r--r--src/eval.c21
-rw-r--r--src/fileio.c16
-rw-r--r--src/floatfns.c9
-rw-r--r--src/fns.c27
-rw-r--r--src/fontset.c3
-rw-r--r--src/frame.c582
-rw-r--r--src/frame.h125
-rw-r--r--src/fringe.c27
-rw-r--r--src/gtkutil.c199
-rw-r--r--src/image.c70
-rw-r--r--src/indent.c117
-rw-r--r--src/indent.h32
-rw-r--r--src/insdel.c13
-rw-r--r--src/keyboard.c1231
-rw-r--r--src/keyboard.h43
-rw-r--r--src/keymap.c57
-rw-r--r--src/keymap.h1
-rw-r--r--src/lisp.h307
-rw-r--r--src/lread.c60
-rw-r--r--src/m/ibms390x.h17
-rw-r--r--src/m/sh3el.h9
-rw-r--r--src/macfns.c145
-rw-r--r--src/macmenu.c6
-rw-r--r--src/macterm.c149
-rw-r--r--src/macterm.h7
-rw-r--r--src/makefile.w32-in32
-rw-r--r--src/marker.c9
-rw-r--r--src/minibuf.c12
-rw-r--r--src/msdos.c24
-rw-r--r--src/prefix-args.c1
-rw-r--r--src/print.c26
-rw-r--r--src/process.c26
-rw-r--r--src/process.h2
-rw-r--r--src/puresize.h2
-rw-r--r--src/regex.c19
-rw-r--r--src/s/cygwin.h6
-rw-r--r--src/s/darwin.h6
-rw-r--r--src/s/hpux.h10
-rw-r--r--src/s/ms-w32.h4
-rw-r--r--src/scroll.c52
-rw-r--r--src/search.c6
-rw-r--r--src/sound.c1
-rw-r--r--src/sysdep.c723
-rw-r--r--src/syssignal.h1
-rw-r--r--src/term.c2648
-rw-r--r--src/termchar.h203
-rw-r--r--src/termhooks.h513
-rw-r--r--src/terminal.c566
-rw-r--r--src/termopts.h5
-rw-r--r--src/w32.c14
-rw-r--r--src/w32console.c158
-rw-r--r--src/w32fns.c49
-rw-r--r--src/w32inevt.c4
-rw-r--r--src/w32inevt.h2
-rw-r--r--src/w32menu.c9
-rw-r--r--src/w32proc.c6
-rw-r--r--src/w32term.c275
-rw-r--r--src/w32term.h17
-rw-r--r--src/widget.c4
-rw-r--r--src/window.c115
-rw-r--r--src/window.h4
-rw-r--r--src/xdisp.c442
-rw-r--r--src/xfaces.c67
-rw-r--r--src/xfns.c386
-rw-r--r--src/xmenu.c68
-rw-r--r--src/xselect.c65
-rw-r--r--src/xsmfns.c9
-rw-r--r--src/xterm.c606
-rw-r--r--src/xterm.h11
90 files changed, 37124 insertions, 33079 deletions
diff --git a/src/.arch-inventory b/src/.arch-inventory
index fe99529135..c21e38d47d 100644
--- a/src/.arch-inventory
+++ b/src/.arch-inventory
@@ -3,7 +3,10 @@ source ^\.(gdbinit|dbxinit)$
# Auto-generated files, which ignore
precious ^(config\.stamp|config\.h|epaths\.h|buildobj\.lst)$
+precious ^(TAGS-LISP)$
+precious ^(buildobj\.lst)$
backup ^(stamp-oldxmenu|prefix-args|temacs|emacs|emacs-[0-9.]*)$
+backup ^(bootstrap-emacs)$
# arch-tag: 277cc7ae-b3f5-44af-abf1-84c073164543
diff --git a/src/.gdbinit b/src/.gdbinit
index a54f9d7b28..2c3750bd8d 100644
--- a/src/.gdbinit
+++ b/src/.gdbinit
@@ -1021,7 +1021,7 @@ define xbacktrace
xgettype (*$bt->function)
if $type == Lisp_Symbol
xprintsym (*$bt->function)
- printf " (0x%x)\n", *$bt->args
+ printf " (0x%x)\n", $bt->args
else
printf "0x%x ", *$bt->function
if $type == Lisp_Vectorlike
@@ -1138,7 +1138,7 @@ end
tbreak init_sys_modes
commands
silent
- xgetptr Vwindow_system
+ xgetptr Vinitial_window_system
set $tem = (struct Lisp_Symbol *) $ptr
xgetptr $tem->xname
set $tem = (struct Lisp_String *) $ptr
diff --git a/src/ChangeLog b/src/ChangeLog
index e2ff82ff97..4160a53e9d 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,3 +1,1281 @@
+2007-10-08 Martin Rudalics <[email protected]>
+
+ * keyboard.c (kbd_buffer_get_event): Break loop waiting for input
+ when there's an unread command event.
+
+ * frame.c (focus_follows_mouse): Moved here from frame.el to allow
+ window autoselection act appropriately when leaving selected frame.
+ (syms_of_frame): Initialize focus_follows_mouse.
+ * frame.h (focus_follows_mouse): Extern it.
+ * macterm.c (XTread_socket): When focus_follows_mouse is nil
+ make SELECT_WINDOW_EVENT only if we don't leave the selected
+ frame.
+ * msdos.c (dos_rawgetc): Likewise.
+ * w32term.c (w32_read_socket): Likewise.
+ * xterm.c (handle_one_xevent): Likewise.
+ * xdisp.c (syms_of_xdisp): In doc-string of
+ mouse-autoselect-window mention focus-follows-mouse.
+
+2007-10-08 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_load_query_font): Fix missing return value.
+ [USE_CG_DRAWING] (mac_define_fringe_bitmap, mac_destroy_fringe_bitmap):
+ Add BLOCK_INPUT.
+
+2007-10-08 Richard Stallman <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): Implement documented behavior
+ for cursor-in-non-selected-windows = t.
+
+2007-10-08 Jason Rumney <[email protected]>
+
+ * w32.c (w32_get_resource): Always close registry keys.
+
+2007-10-08 Jason Rumney <[email protected]>
+
+ * makefile.w32-in (LIBS): Add COMCTL32.
+
+ * w32fns.c (globals_of_w32fns): Init common controls.
+
+2007-10-08 Richard Stallman <[email protected]>
+
+ * image.c (our_memory_buffer): Renamed from omfib_buffer.
+
+2007-10-08 Richard Stallman <[email protected]>
+
+ * buffer.c (Foverlays_at): Doc fix.
+
+2007-10-08 Stefan Monnier <[email protected]>
+
+ * fns.c (Fplist_put): Preserve uneven tail data.
+
+2007-10-08 Peter O'Gorman <[email protected]> (tiny change)
+
+ * termhooks.h (enum event_kind): Remove trailing comma.
+
+ * frame.h (enum): Remove trailing comma.
+
+2007-10-08 Dhuvra Krishnamurthy <[email protected]> (tiny change)
+
+ * w32proc.c (delete_child): Don't terminate threads of zombies.
+
+2007-10-08 Martin Rudalics <[email protected]>
+
+ * keyboard.h (struct kboard): New elt Vlast_repeatable_command.
+
+ * keyboard.c (syms_of_keyboard): Set up new Lisp variable
+ last-repeatable-command.
+ (init_kboard): Initialize Vlast_repeatable_command.
+ (command_loop_1): Set it to real_this_command unless that was
+ bound to an input event.
+ (mark_kboards): Mark it.
+
+2007-10-08 Richard Stallman <[email protected]>
+
+ * eval.c (condition-case): Doc fix.
+
+2007-10-08 Masatake YAMATO <[email protected]>
+
+ * xfaces.c (tty_supports_face_attributes_p): Fix code
+ for LFACE_INVERSE_INDEX and LFACE_BACKGROUND_INDEX; code
+ was copied and not edited.
+
+2007-10-09 Stefan Monnier <[email protected]>
+
+ Add new `input-decode-map' keymap and use it for temrinal
+ escape sequences.
+ * keyboard.h (struct kboard): Add Vinput_decode_map.
+ Remove Vlocal_key_translation_map.
+ * keyboard.c (read_key_sequence): Add support for input-decode-map.
+ (init_kboard): Init input-decode-map.
+ Replace local-key-translation-map back with key-translation-map.
+ (syms_of_keyboard): Declare input-decode-map.
+ Remove local-key-translation-map. Update docstrings.
+ (mark_kboards): Mark Vinput_decode_map.
+ Don't mark Vlocal_key_translation_map.
+ * keymap.c (Fdescribe_buffer_bindings): Describe input-decode-map.
+ Replace local-key-translation-map back with key-translation-map.
+ * term.c (term_get_fkeys_1, CONDITIONAL_REASSIGN):
+ Bind in input-decode-map rather than function-key-map.
+
+ * lisp.h (XSETPSEUDOVECTOR): Don't set the tag anymore.
+ This was made redundant by the previous introduction of XSETPVECTYPE.
+
+2007-10-09 Richard Stallman <[email protected]>
+
+ * image.c (free_bitmap_record): Rename from Free_Bitmap_Record.
+
+2007-09-29 Richard Stallman <[email protected]>
+
+ * eval.c (internal_condition_case_2, internal_condition_case_1)
+ (internal_condition_case): Reenable abort if x_catching_errors ()
+ to see if that really happens and why.
+
+2007-10-06 Andreas Schwab <[email protected]>
+
+ * fileio.c (Fwrite_region): Ignore EINVAL error from fsync.
+
+2007-10-04 Juanma Barranquero <[email protected]>
+
+ * image.c (syms_of_image) <image-types>: Fix typo in docstring.
+
+2007-10-03 Stefan Monnier <[email protected]>
+
+ * frame.h (struct frame): Don't try to GC-mark menu_bar_items_used.
+
+2007-10-02 Stefan Monnier <[email protected]>
+
+ * window.h (struct window):
+ * window.c (struct save_window_data, struct saved_window):
+ * termhooks.h (struct terminal):
+ * process.h (struct Lisp_Process):
+ * frame.h (struct frame):
+ * buffer.h (struct buffer):
+ * lisp.h (struct Lisp_Vector, struct Lisp_Char_Table)
+ (struct Lisp_Bool_Vector, struct Lisp_Subr, struct Lisp_Hash_Table):
+ The size field of (pseudo)vectors is now unsigned.
+ (ARRAY_MARK_FLAG, PSEUDOVECTOR_FLAG): Simplify accordingly.
+
+ * lisp.h (struct Lisp_Hash_Table): Move non-traced elements at the end.
+ Turn `count' into an integer.
+
+ * fns.c (make_hash_table, hash_put, hash_remove, hash_clear)
+ (sweep_weak_table, sweep_weak_hash_tables, Fhash_table_count):
+ * print.c (print_object) <HASH_TABLE_P>: `count' is an int.
+ * alloc.c (allocate_hash_table): Use ALLOCATE_PSEUDOVECTOR.
+ (mark_object) <HASH_TABLE_P>: Use mark_vectorlike.
+
+ * alloc.c (allocate_pseudovector): New fun.
+ (ALLOCATE_PSEUDOVECTOR): New macro.
+ (allocate_window, allocate_terminal, allocate_frame)
+ (allocate_process): Use it.
+ (mark_vectorlike): New function.
+ (mark_object) <FRAMEP, WINDOWP, BOOL_VECTOR_P, VECTORP>: Use it.
+ (mark_terminals): Use it.
+ (Fmake_bool_vector, Fmake_char_table, make_sub_char_table)
+ (Fmake_byte_code): Use XSETPVECTYPE.
+
+ * frame.c (Fframe_parameters): Minor simplification.
+
+ * insdel.c (adjust_markers_for_insert): Generalize assertion checks.
+
+ * marker.c (Fmarker_buffer): Make test for odd case into a failure.
+
+ * buffer.c (Fget_buffer_create, init_buffer_once):
+ * lread.c (defsubr):
+ * window.c (Fcurrent_window_configuration): Use XSETPVECTYPE.
+
+ * lisp.h (ARRAY_MARK_FLAG, PSEUDOVECTOR_FLAG): Don't let them be
+ defined differently in the m/*.h files.
+ (XCHAR_TABLE, XBOOL_VECTOR): Add assertion checking.
+ (XSETPVECTYPE): New macro.
+ (XSETPSEUDOVECTOR): Use it.
+
+ * buffer.c (syms_of_buffer) <local-abbrev-table>: Move from abbrev.c.
+ (DEFVAR_PER_BUFFER, defvar_per_buffer): Move from lisp.h and lread.c.
+
+ * lisp.h (defvar_per_buffer, DEFVAR_PER_BUFFER):
+ * lread.c (defvar_per_buffer):
+ * abbrev.c (syms_of_abbrev) <local-abbrev-tabl>: Move to buffer.c.
+
+ * window.c (candidate_window_p): Only consider as visible frames that
+ are on the same terminal.
+
+ * m/ibms390x.h (MARKBIT): Remove unused macro.
+
+2007-10-01 Juanma Barranquero <[email protected]>
+
+ * lread.c (Fload): Fix typo in docstring.
+
+2007-10-01 Micha,Ak(Bl Cadilhac <[email protected]>
+
+ * floatfns.c (Fexpt): Manually check for overflows, so that a power
+ of a non-zero value can't yield zero.
+
+2007-09-29 Stefan Monnier <[email protected]>
+
+ * term.c (term_clear_mouse_face, term_mouse_highlight)
+ (tty_write_glyphs_with_face): Only define is HAVE_GPM.
+
+ * print.c (safe_debug_print): Use XHASH.
+
+ * lisp.h (DECL_ALIGN, USE_LSB_TAG): Move logic to before definition of
+ Lisp elements such as tags.
+ (XHASH): New macro.
+ (EQ): Use it.
+ (SREF, SSET, STRING_COPYIN): Use SDATA.
+ (VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): Remove.
+
+ * alloc.c (mark_terminal): Remove left-over declaration.
+ (enum mem_type): Replace all vector subtypes -> MEM_TYPE_VECTORLIKE.
+ (allocate_vectorlike): Remove type argument. Adjust callers.
+ (live_vector_p, mark_maybe_pointer, valid_lisp_object_p):
+ Only handle the one remaining MEM_TYPE_VECTORLIKE.
+
+ * alloc.c (MALLOC_BLOCK_INPUT, MALLOC_UNBLOCK_INPUT): New macros
+ to avoid unnecessary BLOCK_INPUTs when SYNC_INPUT is used.
+ (xmalloc, xrealloc, xfree, lisp_malloc, lisp_free, lisp_align_malloc)
+ (lisp_align_free, make_interval, allocate_string, allocate_string_data)
+ (make_float, Fcons, allocate_vectorlike, Fmake_symbol, allocate_misc):
+ Use them.
+
+ * xfaces.c (load_face_font, free_realized_face, clear_face_gcs):
+ Don't let signal handlers run when a GC is freed but not yet NULL'ed.
+ (x_free_gc): Remove BLOCK_INPUT since it's now redundant.
+
+2007-09-28 Dan Nicolaescu <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): Delete server.elc, it is not
+ loaded by default.
+
+2007-09-28 Stefan Monnier <[email protected]>
+
+ * term.c (Fgpm_mouse_start): Don't signal an error if already activated
+ on this tty.
+ (Fgpm_mouse_stop): Only deactivate if it was activated on this tty.
+
+ * term.c (mouse_face_window): Rename from Qmouse_face_window.
+ Update all users.
+ (handle_one_term_event): Use Gpm_DrawPointer.
+ (Fgpm_mouse_start): Rename from Fterm_open_connection.
+ Signal errors instead of returning nil. Always return nil.
+ (Fgpm_mouse_stop): Rename from Fterm_close_connection.
+ Make it a noop if gpm-mouse was not activated.
+ (syms_of_term): Update names.
+
+2007-09-27 Stefan Monnier <[email protected]>
+
+ * sysdep.c (narrow_foreground_group, widen_foreground_group): Static.
+ (init_sys_modes): Check that gpm_tty is the current tty.
+
+ * alloc.c (allocate_terminal): Set the vector size to only count the
+ lisp fields. Initialize those to nil.
+ (mark_object): Don't treat terminals specially.
+ (mark_terminal): Remove.
+ (mark_terminals): Use mark_object instead.
+
+ * termhooks.h (struct terminal): Move all Lisp_Object fields traced by
+ the GC to the beginning.
+
+ * indent.h:
+ * indent.c: Use EMACS_INT for ints coming from Elisp data.
+
+ * indent.c (Fmove_to_column): Use EMACS_INT for buffer positions.
+
+2007-09-25 Jason Rumney <[email protected]>
+
+ * frame.c (make_terminal_frame): Remove special case for WINDOWSNT.
+
+ * w32console.c (create_w32cons_output): Remove.
+
+ * term.c (init_tty): Call init_sys_modes on WINDOWSNT also.
+
+ * sysdep.c (init_sys_modes): Use set_terminal_modes_hook.
+ (reset_sys_modes): Use reset_terminal_modes_hook.
+
+2007-09-24 Stefan Monnier <[email protected]>
+
+ * eval.c (do_autoload): Don't output any message.
+
+2007-09-24 Juri Linkov <[email protected]>
+
+ * emacs.c (standard_args): Change priority of "--no-splash"
+ from 40 to 3. Add "--no-desktop" with the same priority.
+
+2007-09-23 Dmitry Antipov <[email protected]>
+
+ * alloc.c (gc_sweep): Check cons cell mark bits word by word
+ and optimize the case where they are all 1.
+
+2007-09-23 Johannes Weiner <[email protected]>
+
+ * lisp.h (abs): Define if not defined.
+ * keyboard.c, sound.c, w32term.c, xfaces.c, xterm.c:
+ Don't define `abs', since it's defined in lisp.h.
+
+2007-09-22 Eli Zaretskii <[email protected]>
+
+ * term.c (DEV_TTY): New macro. Provide a definition for
+ MS-Windows.
+ (FRAME_TERMCAP_P) [WINDOWSNT]: Don't define to zero.
+ (Fcontrolling_tty_p, Fresume_tty, dissociate_if_controlling_tty)
+ (init_tty): Use DEV_TTY instead of "/dev/tty".
+ [WINDOWSNT]: No need to protect from NAME arg being null.
+
+2007-09-21 Dan Nicolaescu <[email protected]>
+
+ * term.c (Fsuspend_tty): Run suspend-tty-functions before cleaning
+ up the tty state.
+
+2007-09-21 Stefan Monnier <[email protected]>
+
+ * termhooks.h (term_gpm): Delete. Use gpm_tty's NULLness instead.
+ (gpm_tty): Change its type.
+ * term.c (term_gpm): Delete. Use gpm_tty's NULLness instead.
+ (gpm_tty): Change its type and initialize it.
+ (Fterm_open_connection): Check the frame is indeed a tty.
+ Use the new gpm_tty.
+ (Fterm_close_connection): Use the new gpm_tty.
+ * keyboard.c (tty_read_avail_input): Use the new gpm_tty.
+ * sysdep.c (init_sys_modes): term_gpm -> gpm_tty.
+
+2007-09-21 Juanma Barranquero <[email protected]>
+
+ * w32term.c (x_draw_glyph_string): Use strike_through_color, not
+ underline_color, to draw strike-through.
+
+2007-09-21 Stefan Monnier <[email protected]>
+
+ * lisp.h (allocate_terminal): Declare.
+
+ * window.c (candidate_window_p): Consider frames that are being placed
+ by the user as somewhere between visible and iconified.
+ (window_loop): Prefer windows on the current frame.
+ (Fselect_window): Move the use of select-frame to the beginning so we
+ can just delegate all the work (it'll call us back anyway).
+
+ * frame.c (Qdisplay_environment_variable):
+ * frame.h (Qdisplay_environment_variable): Delete.
+
+ * .gdbinit (xbacktrace): Print the arg's address rather than the value
+ of the first arg, since that value may be a union.
+
+ * callproc.c (child_setup, getenv_internal): Use the frame's `display'
+ parameter rather than Qdisplay_environment_variable. If all else
+ fails, look for DISPLAY in initial-environment.
+
+2007-09-21 Glenn Morris <[email protected]>
+
+ * Makefile.in (emacstool): Remove target.
+ (lisp, shortlisp): Remove termdev.elc.
+
+2007-09-21 Markus Triska <[email protected]>
+
+ * xterm.c (x_delete_display): Compile session management conditionally.
+
+2007-09-20 Stefan Monnier <[email protected]>
+
+ * callproc.c (getenv_internal_1): New function.
+ (getenv_internal): Use it.
+ (Fgetenv_internal): Use it. Accept an env-list as optional arg.
+
+ * terminal.c (get_terminal): Don't accept ints to represent terminals.
+ (Fterminal_name, Fterminal_parameters, Fterminal_parameter)
+ (Fset_terminal_parameter): Work with dead terminals as well.
+ (Fmodify_terminal_parameters): Remove.
+
+ * terminal.c (get_terminal): Handle terminals.
+ Make sure the terminal returned is live.
+ (create_terminal): Use allocate_terminal.
+ (mark_terminals): Move to alloc.c.
+ (delete_terminal): Use terminal->name as liveness status.
+ NULL out fields after freeing their contents.
+ Don't deallocate the object.
+ (Fframe_terminal): Use FRAME_TERMINAL. Return the terminal object
+ rather than an int.
+ (Fterminal_live_p): Accept non-integer arguments.
+ (Fterminal_list): Return terminal objects rather than an ints.
+
+ * alloc.c (enum mem_type): New member for `terminal' objects.
+ (allocate_terminal): New function.
+ (mark_maybe_pointer, valid_lisp_object_p, mark_object):
+ Handle terminals.
+ (mark_terminal): New fun.
+ (mark_terminals): Move from terminal.c.
+
+ * term.c (get_tty_terminal): Don't treat output_initial specially.
+ (Fsuspend_tty, Fresume_tty): Use terminal objects rather than ints.
+ (delete_tty): Use terminal->name as liveness status.
+
+ * termhooks.h (struct terminal): Make it into a pseudovector.
+ Remove `deleted' replaced by checking `name's nullness.
+
+ * print.c (print_object): Handle terminals.
+
+ * lisp.h (enum pvec_type): New `terminal' pseudovector.
+ (XTERMINAL, XSETTERMINAL, TERMINALP, GC_TERMINALP): New macros.
+
+ * frame.c (make_terminal_frame):
+ * keyboard.c (tty_read_avail_input):
+ * w32term.c (x_delete_terminal):
+ * xfns.c (Fx_create_frame, x_create_tip_frame):
+ * xterm.c (x_delete_terminal): Use terminal->name as liveness status.
+
+2007-09-20 Glenn Morris <[email protected]>
+
+ * process.c (Fmake_network_process): Doc fix.
+
+2007-09-19 Jason Rumney <[email protected]>
+
+ * dispextern.h (w32_init_fringe, mac_init_fringe): Declare rif argument.
+
+2007-09-19 Micha,Ak(Bl Cadilhac <[email protected]>
+
+ * coding.c (detect_eol_type, detect_eol_type_in_2_octet_form):
+ Fix a C warning regarding variable constness.
+
+ * xterm.c (handle_one_xevent): Fix a C warning.
+
+2007-09-18 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fx_focus_frame): Rename from Fw32_focus_frame.
+
+2007-09-17 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (gdpy_def): New variable.
+ (xg_initialize): Initialize gdpy_def.
+ (xg_display_close): If no other display exists, set gdpy_def to a
+ new connection.
+
+2007-09-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_image_for_pixmap): Always create a GdkPixbuf
+ when we have no file name for the icon.
+ (xg_tool_bar_expose_callback): Remove.
+ (xg_create_tool_bar): Don't connect expose signal to
+ xg_tool_bar_expose_callback.
+ (xg_get_file_with_chooser): Move GCPRO1 after declarations.
+
+2007-09-16 Andreas Schwab <[email protected]>
+
+ * alloc.c (reset_malloc_hooks): Set the hooks to the previous
+ values instead of zapping them.
+
+2007-09-14 Glenn Morris <[email protected]>
+
+ * fringe.c (init_fringe_bitmap) <swap_nibble>: Move to file scope.
+ * gtkutil.c (xg_separator_p) <separator_names>: Move to file scope.
+ * image.c (our_memory_fill_input_buffer) <buffer>: Move to file
+ scope and rename to omfib_buffer for clarity.
+ (gif_load) <interlace_start, interlace_increment>: Move to file scope.
+
+2007-09-14 Kenichi Handa <[email protected]>
+
+ * xterm.c (handle_one_xevent): Skip decoding if nbytes is zero.
+
+2007-09-13 Jason Rumney <[email protected]>
+
+ * fringe.c (w32_init_fringe, mac_init_fringe): Add rif argument.
+
+ * w32term.c (w32_term_init): Pass rif to w32_init_fringe.
+
+ * macterm.c (mac_initialize): Don't call mac_init_fringe here.
+ (mac_term_init): Call here instead, passing rif.
+
+2007-09-13 Glenn Morris <[email protected]>
+
+ * s/hpux.h: No longer define `static' as nothing.
+
+2007-09-13 Johan Bockg,Ae(Brd <[email protected]>
+
+ * callint.c (Fcall_interactively): Remove unused var `fun'.
+
+2007-09-12 Romain Francoise <[email protected]>
+
+ * window.c (prefer_window_split_horizontally, display_buffer):
+ Revert 2007-09-08 change.
+
+2007-09-12 Glenn Morris <[email protected]>
+
+ * alloca.c: Remove file.
+ * Makefile.in (alloca): Do not undef.
+ (allocaobj, alloca.o): Remove.
+ (otherobj): Remove allocaobj.
+ * keyboard.c (command_loop_1): Remove #ifdef C_ALLOCA block.
+ * regex.c (C_ALLOCA): Remove all references and code that was only
+ used when this was defined.
+ * search.c (boyer_moore): Remove #ifdef C_ALLOCA block.
+ * xmenu.c (xmenu_show): Remove #ifdef C_ALLOCA block.
+ * m/ibms390x.h, m/sh3el.h (C_ALLOCA): Remove references to this.
+
+ * Makefile.in (SOURCES, unlock, relock): Delete.
+
+ * gtkutil.c (cnt): Rename to menu_grab_callback_cnt for clarity.
+ (menu_grab_callback): All uses changed.
+
+ * xselect.c (cnt): Rename to x_reply_selection_request_cnt for clarity.
+ (x_reply_selection_request): All uses changed.
+
+2007-09-11 Stefan Monnier <[email protected]>
+
+ * lread.c (load_warn_old_style_backquotes): Change message to look
+ better when it appears in the middle of byte-compiler messages.
+
+2007-09-10 Dan Nicolaescu <[email protected]>
+
+ * s/darwin.h (MULTI_KBOARD): Only define for Carbon.
+
+ * xterm.c (x_create_terminal): Add comment.
+
+ * term.c (clear_tty_hooks, set_tty_hooks): Add comments.
+
+2007-09-10 Richard Stallman <[email protected]>
+
+ * xterm.c (x_term_init): Give error if can't open DISPLAY_NAME.
+
+2007-09-10 Micha,Ak(Bl Cadilhac <[email protected]>
+
+ * lisp.h (struct Lisp_Subr): Rename `prompt' field to `intspec'.
+ (DEFUN): Document `intspec', use it instead of `prompt'.
+
+ * eval.c (Fcommandp): Change `->prompt' to `->intspec'.
+
+ * data.c (Finteractive_form): If the interactive specification starts
+ with a `(', use it as a Lisp form.
+
+ * fileio.c (Fset_file_modes): Add an interactive spec that reads a file
+ name and file modes.
+
+ * callint.c (Fcall_interactively): Comment fixes.
+
+2007-09-10 Stefan Monnier <[email protected]>
+
+ * callint.c (Fcall_interactively): Use Finteractive_form also for subrs
+ and compiled functions.
+
+2007-09-08 Fredrik Axelsson <[email protected]>
+
+ * window.c (prefer_window_split_horizontally): New variable.
+ (display_buffer): Consider splitting window horizontally depending
+ on prefer_window_split_horizontally.
+
+2007-09-08 Eli Zaretskii <[email protected]>
+
+ * sysdep.c [WINDOWSNT]: Don't include sysselect.h.
+
+2007-09-07 Stefan Monnier <[email protected]>
+
+ * s/cygwin.h (GC_MARK_STACK): Enable conservative stack marking.
+
+ * frame.c (x_set_frame_parameters): Check number is positive before
+ using XFASTINT.
+
+ * window.c (freeze_window_start): Don't presume selected_window holds
+ a window object.
+ (Fdisplay_buffer): Remove `register' since `buffer' needs to be gcpro'd.
+
+2007-09-07 Angelo Graziosi <[email protected]> (tiny change)
+
+ * term.c (dissociate_if_controlling_tty): Call setsid on CYGWIN.
+
+2007-09-07 Stefan Monnier <[email protected]>
+
+ * window.c (Vsplit_window_preferred_function): New var.
+ (Fdisplay_buffer): Use it.
+ (syms_of_window): Export, and initialize it.
+
+2007-09-06 Pixel <[email protected]> (tiny change)
+
+ * image.c (gif_load): Fix bug: Handle nonexistent colormap.
+
+2007-09-06 Glenn Morris <[email protected]>
+
+ * gtkutil.c (menu_grab_callback) <cnt>:
+ * xselect.c (x_reply_selection_request) <cnt>: Move static
+ variable to file scope.
+
+2007-09-06 Stefan Monnier <[email protected]>
+
+ * xdisp.c (redisplay_internal): Make sure Elisp code always sees
+ consistent values of selected_frame and selected_window.
+
+2007-09-04 Jason Rumney <[email protected]>
+
+ * w32console.c (initialize_w32_display): Zero unused hooks.
+
+2007-09-04 Dan Nicolaescu <[email protected]>
+
+ * term.c (Vsuspend_tty_functions, Vresume_tty_functions)
+ (syms_of_term, Fsuspend_tty, Fresume_tty): Undo previous change.
+
+2007-09-04 Jason Rumney <[email protected]>
+
+ * term.c (init_tty) [WINDOWSNT]: Add hooks that are not accessible
+ in w32console.c. Set up input. Remove XXX comments that have been
+ confirmed as correct.
+
+ * s/ms-w32.h (MULTI_KBOARD): Define.
+
+ * w32console.c (one_and_only_w32cons): Remove.
+ (initialize_w32_display): Take terminal argument.
+
+ * term.c (init_tty) [WINDOWSNT]: Pass terminal to
+ initialize_w32_display.
+ (init_tty) [MULTI_KBOARD]: Include this code on WINDOWSNT too.
+
+ * termhooks.h (enum event_kind) <HORIZ_WHEEL_EVENT>: New event.
+
+ * keyboard.c (discard_mouse_events): Discard it.
+ (make_lispy_event): Translate it to a lisp event.
+ (lispy_wheel_names): Add wheel-left and right events.
+ (syms_of_keyboard): Enlarge wheel_syms.
+
+ * w32fns.c (w32_wnd_proc) <WM_DROPFILES>: Merge with WM_MOUSEWHEEL.
+ <WM_MOUSEHWHEEL>: Pass new system message to lisp.
+
+ * w32term.h (WM_MOUSEHWHEEL): Define if system headers don't.
+
+ * w32term.c (construct_mouse_wheel): Make HORIZ_WHEEL_EVENT
+ from WM_MOUSEHWHEEL.
+ (w32_read_socket) <WM_MOUSEHWHEEL>: Treat as WM_MOUSEWHEEL.
+
+ * w32fns.c (x_create_tip_frame) [MULTI_KBOARD]: Get keyboard from
+ terminal.
+
+ * w32term.c (w32_create_terminal) [MULTI_KBOARD]: Create a new
+ keyboard for the terminal.
+
+2007-09-04 Dan Nicolaescu <[email protected]>
+
+ * term.c (Vsuspend_tty_hook): Rename from Vsuspend_tty_functions.
+ (Vresume_tty_hook): Rename from Vresume_tty_functions.
+ (syms_of_term): Rename suspend-tty-functions to suspend-tty-hook
+ and resume-tty-function to resume-tty-hook.
+ (Fsuspend_tty, Fresume_tty): Use new names.
+
+2007-09-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Handle stock name as a named icon
+ if it starts with "n:".
+
+2007-08-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Initialize wbutton to NULL.
+
+2007-08-31 Stefan Monnier <[email protected]>
+
+ * frame.h:
+ * frame.c (Qterm_environment_variable): Remove.
+ (syms_of_frame): Don't init and staticpro it.
+
+ * callproc.c (getenv_internal): Remove special case for $TERM.
+
+ * callproc.c (Vinitial_environment): New variable.
+ (set_initial_environment): Initialize it.
+ (syms_of_callproc): Declare it.
+ (child_setup): Don't mess with TERM via Qterm_environment_variable; the
+ TERM under which a process runs is never related to the TERM in which
+ Emacs is running.
+
+2007-08-29 Dan Nicolaescu <[email protected]>
+
+ * config.in (HAVE_WINDOW_SYSTEM): Don't undef MULTI_KBOARD here...
+ * s/darwin.h: ... do it here.
+
+2007-08-29 Stefan Monnier <[email protected]>
+
+ * lisp.h (set_initial_environment): Rename from set_global_environment.
+
+ * Makefile.in (${etc}DOC): Re-add a ${EXEEXT} which seems to have been
+ removed by mistake on the multi-tty branch.
+
+ * frame.c (make_terminal_frame): Yet Another Int/Lisp_Object Mixup.
+ (Fmodify_frame_parameters): Return a value.
+
+ * image.c (png_load): Comment-out var only used in commented-out code.
+
+ * term.c (mark_ttys): Don't bother checking top_frame (incorrectly)
+ before passing it to mark_object.
+
+ * xfaces.c (internal_resolve_face_name): Return a value.
+ (internal_resolve_face_name, resolve_face_name_error): Comment out.
+
+ * xfns.c (check_x_display_info): Yet Another Int/Lisp_Object Mixup.
+ (x_icon): Comment-out var only used in commented-out code.
+
+2007-08-29 Romain Francoise <[email protected]>
+
+ * keyboard.c (Fset_input_mode): Don't call `Fset_quit_char' if
+ QUIT hasn't been provided.
+
+2007-08-29 Dan Nicolaescu <[email protected]>
+
+ * callproc.c (child_setup, getenv_internal): Use the
+ display-environment-variable and term-environment-variable frame
+ params.
+ (set_initial_environment): Initialise Vprocess_environment.
+
+ * config.in: Disable multi-keyboard support on a mac.
+
+ * frame.c (Qterm_environment_variable)
+ (Qdisplay_environment_variable): New variables.
+ (syms_of_frame): Intern and staticpro them.
+ (Fmake_terminal_frame): Disable output method test.
+
+ * frame.h: Declare them here.
+
+ * macfns.c (x_set_mouse_color): Get rif from the frame.
+ (x_set_tool_bar_lines): Don't use updating_frame.
+ (mac_window): Add 2 new parameters for consistency with other systems.
+ (Fx_create_frame): Fix doc string. Rename the parameter. Set the
+ frame parameters following what is done in X11 and w32. Don't use
+ FRAME_MAC_DISPLAY_INFO.
+ (Fx_open_connection, start_hourglass): Remove window-system check.
+ (x_create_tip_frame): Get the keyboard from the terminal.
+
+ * macmenu.c: Reorder includes.
+ (Fx_popup_menu): Use terminal specific mouse_position_hook.
+
+ * macterm.c (XTset_terminal_modes, XTreset_terminal_modes): Add a
+ terminal parameter.
+ (x_clear_frame): Add a frame parameter.
+ (note_mouse_movement): Get rif from the frame.
+ (mac_term_init): Initialize the terminal.
+ (mac_initialize): Make static and move terminal initialization ...
+ (mac_create_terminal): ... to this new function.
+
+ * macterm.h (struct mac_display_info): Add terminal.
+ (mac_initialize): Delete declaration.
+
+ * puresize.h (BASE_PURESIZE): Increase base value to 1164000.
+
+ * sysdep.c: Comment out text after #endif.
+
+ * term.c (init_tty): Only use terminal->kboard when MULTI_KBOARD
+ is defined. Better initialize ttys in windows. Use terminal
+ specific mouse_position_hook.
+
+ * termhooks.h (union display_info): Add mac_display_info.
+
+ * w32fns.c (Fx_create_frame): Use kboard from the terminal.
+ Set the default minibuffer frame, window_system and the rest of the
+ frame parameters following what is done in X11.
+
+ * w32term.c (w32_initialize): Make static.
+
+ * xselect.c (x_handle_selection_clear): Only access
+ terminal->kboard when MULTI_KBOARD is defined.
+
+ * s/darwin.h (SYSTEM_PURESIZE_EXTRA): Define here.
+ (SYSTEM_PURESIZE_EXTRA): Only define on Carbon.
+
+2007-08-29 Jason Rumney <[email protected]>
+
+ * frame.c (Fdelete_frame): Only get kboard when MULTI_KBOARD defined.
+ (make_terminal_frame) [WINDOWSNT]: Initialize terminal.
+
+ * fringe.c (w32_init_fringe w32_reset_fringes) [HAVE_NTGUI]:
+ (mac_init_fringe) [MAC_OS]: Get rif from selected_frame.
+
+ * keyboard.c (restore_kboard_configuration): Only define when
+ MULTI_KBOARD defined.
+
+ * makefile.w32-in: Update dependancies from Makefile.in
+ (OBJ1): Add terminal.$(O)
+
+ * term.c (dissociate_if_controlling_tty) [WINDOWSNT]:
+ Don't define function body.
+ (init_tty) [WINDOWSNT]: Use selected_frame for initializing.
+
+ * termhooks.h (display_info) [WINDOWSNT]: Add w32.
+
+ * w32.c (request_sigio, unrequest_sigio): Remove.
+
+ * w32console.c (w32con_move_cursor, w32con_clear_to_end)
+ (w32con_clear_frame, w32con_clear_end_of_line)
+ (w32con_ins_del_lines, w32con_insert_glyphs, w32con_write_glyphs)
+ (w32con_delete_glyphs, w32con_set_terminal_window)
+ (scroll_line, w32_sys_ring_bell): Add frame arg.
+ (w32con_set_terminal_modes, w32con_reset_terminal_modes):
+ Add terminal arg.
+ (PICK_FRAME): Remove.
+ (w32con_write_glyphs): Use frame specific terminal coding.
+ (one_and_only_w32cons): New global variable.
+ (initialize_w32_display): Use it for storing hooks.
+ (create_w32cons_output): New function.
+
+ * w32inevt.c, w32inevt.h (w32_console_read_socket): Make first
+ arg a frame.
+
+ * w32fns.c (x_create_tip_frame): Set terminal and ref count.
+ Set window_system.
+ (x_set_tool_bar_lines): Don't use updating_frame.
+ (Fx_create_frame): Set terminal and ref count.
+ (Fx_open_connection): Remove window-system check.
+
+ * w32menu.c (Fx_popup_menu): Use terminal specific mouse_position_hook.
+
+ * w32term.c (w32_term_init): Call add_keyboard_wait_descriptor.
+ (w32_set_terminal_modes, w32_reset_terminal_modes): Add terminal arg.
+ (x_clear_frame, x_delete_glyphs, w32_ring_bell, x_ins_del_lines):
+ Add frame arg.
+ (x_delete_terminal, w32_create_terminal): New functions.
+ (w32_term_init): Create a terminal.
+ (w32_initialize): Move terminal specific initialization to
+ w32_create_terminal.
+
+ * w32term.h (x_output): Remove foreground_pixel and background_pixel.
+ (w32_clear_rect, w32_clear_area): Use background from frame.
+ (w32_display_info): Add terminal.
+ (w32_sys_ring_bell, x_delete_display): Declare here.
+
+ * xdisp.c (display_menu_bar) [HAVE_NTGUI]: Check frame type.
+
+ * s/ms-w32.h (SYSTEM_PURESIZE_EXTRA): Bump to 50k.
+
+2007-08-29 Kalle Olavi Niemitalo <[email protected]> (tiny change)
+
+ * keyboard.c (interrupt_signal, handle_interrupt, Fset_quit_char):
+ Fix get_named_tty calls for the controlling tty.
+
+2007-08-29 ARISAWA Akihiro <[email protected]> (tiny change)
+
+ * term.c (dissociate_if_controlling_tty)[USG]: Fix parse error.
+
+2007-08-29 Yoshiaki Kasahara <[email protected]> (tiny change)
+
+ * term.c (tty_insert_glyphs): Add missing first parameter.
+
+2007-08-29 Karoly Lorentey <[email protected]>
+
+ * buffer.c (Fbuffer_list, Fbury_buffer):
+ Take frame->buried_buffer_list into account.
+
+ * cm.c (current_tty): New variable, for cmputc().
+ (cmputc): Use it.
+ (cmcheckmagic): Add tty parameter, look up terminal streams there.
+ (calccost): Add tty parameter. Use emacs_tputs() instead of tputs().
+ (cmgoto): Add tty parameter. Pass it on to calccost().
+ Use emacs_tputs() instead of tputs().
+
+ * cm.h (emacs_tputs): New macro to set current_tty, and then call
+ tputs().
+ (current_tty): New variable, for cmputc().
+ (cmcheckmagic, cmputc, cmgoto): Add prototypes.
+
+ * eval.c (unwind_to_catch): Don't call x_fully_uncatch_errors.
+ (internal_condition_case, internal_condition_case_1)
+ (internal_condition_case_2): Don't abort when x_catching_errors.
+
+ * fns.c (Fyes_or_no_p): Don't try to open an X dialog on tty terminals.
+ (Fy_or_n_p): Likewise. Use temporarily_switch_to_single_kboard to
+ prevent crashes caused by bogus longjmps in read_char.
+
+ * keymap.h (Fset_keymap_parent): Add EXFUN.
+
+ * macterm.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL)
+ * w32term.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL):
+ Remove redundant definition.
+
+ * macfns.c (x_set_mouse_color, x_make_gc):
+ Use FRAME_BACKGROUND_PIXEL and FRAME_FOREGROUND_PIXEL.
+
+ * w32term.c (x_free_frame_resources):
+ Use FRAME_BACKGROUND_PIXEL and FRAME_FOREGROUND_PIXEL.
+ (w32_initialize): Use the accessor macros for terminal characteristics.
+
+ * macterm.c (mac_initialize): Use Fset_input_interrupt_mode.
+ Use the accessor macros for terminal characteristics.
+ * msdos.c (internal_terminal_init): Use the accessor macros for
+ terminal characteristics.
+ (ScreenVisualBell, internal_terminal_init):
+ Use FRAME_BACKGROUND_PIXEL and FRAME_FOREGROUND_PIXEL.
+
+ * termopts.h (no_redraw_on_reenter): Declare.
+
+ * alloc.c (emacs_blocked_malloc): Disable mallopt call.
+ (mark_terminals, mark_ttys): Declare.
+ (Fgarbage_collect): Call them.
+ (mark_object): Mark buried_buffer_list.
+
+ * prefix-args.c: Include stdlib.h for exit.
+
+ * syssignal.h: Add comment.
+
+ * indent.c: Include stdio.h.
+
+ * window.h (Vinitial_window_system): Declare.
+ (Vwindow_system): Delete declaration.
+
+ * fontset.c (Finternal_char_font): Use FRAME_RIF.
+
+ * image.c (lookup_image): Don't initialize `c' until the xasserts
+ have been run.
+
+ * gtkutil.c (xg_create_frame_widgets): Use FRAME_BACKGROUND_PIXEL and
+ FRAME_FOREGROUND_PIXEL.
+
+ * print.c (print_preprocess): Don't lose print_depth levels while
+ iterating.
+
+ * widget.c (update_from_various_frame_slots):
+ Use FRAME_BACKGROUND_PIXEL and FRAME_FOREGROUND_PIXEL.
+
+ * window.c (set_window_buffer): Don't call clear_mouse_face on tty
+ frames.
+ (window_internal_height): Remove bogus make_number call.
+ (init_window_once): Call make_terminal_frame with two zero parameters.
+
+ * fileio.c (Fread_file_name): Update comment.
+
+ * callint.c (Fcall_interactively):
+ Use temporarily_switch_to_single_kboard instead of single_kboard_state.
+ Make sure it is correctly unwound.
+
+ * xsmfns.c (x_session_close): New function.
+
+ * coding.h (terminal_coding, safe_terminal_coding, keyboard_coding):
+ Delete declarations.
+
+ * xterm.h: Remove declaration for x_fully_uncatch_errors.
+ (x_output): Remove background_pixel and foreground_pixel fields.
+ (x_display_info): Add new field TERMINAL. Remove KBOARD field.
+ (x_delete_device):
+ (x_session_close): Declare.
+
+ * lread.c: Include setjmp.h. Update declaration of `read_char'.
+ (read_filtered_event): Call `read_char' with a local
+ `wrong_kboard_jmpbuf'.
+
+ * minibuf.c (read_minibuf): Call temporarily_switch_to_single_kboard.
+ Don't call single_kboard_state. Use FRAME_RIF.
+
+ * process.c (Fmake_network_process): Don't unrequest_sigio on modern
+ systems.
+
+ * lisp.h (set_process_environment): Rename to `set_global_environment'.
+ (Fframe_with_environment, Fset_input_meta_mode)
+ (Fset_quit_char): EXFUN.
+ (x_create_device, tty_output, terminal, tty_display_info): Declare.
+ (init_sys_modes, reset_sys_modes): Update prototypes.
+ (init_all_sys_modes, reset_all_sys_modes): New prototypes.
+
+ * keyboard.h (struct kboard): Add new fields Vlocal_function_key_map,
+ Vlocal_key_translation_map, and Vkeyboard_translate_table.
+ (Vfunction_key_map, Vkeyboard_translate_table, single_kboard_state):
+ Delete declarations.
+ (Vfunction_key_map, Vkey_translation_map, push_kboard, pop_kboard)
+ (temporarily_switch_to_single_kboard, tty_read_avail_input):
+ New declarations.
+
+ * emacs.c (main): Don't call init_sys_modes(), the new term_init()
+ already does that during init_display(). Call syms_of_keymap
+ before syms_of_keyboard. Call `syms_of_terminal'.
+ Call set_initial_environment, not set_process_environment.
+ (shut_down_emacs): Call reset_all_sys_modes() instead of
+ reset_sys_modes().
+
+ * xfaces.c (x_free_gc): Protect xassert with GLYPH_DEBUG.
+ (internal_resolve_face_name, resolve_face_name_error): New functions.
+ (resolve_face_name): Protect against loops and errors thrown by Fget.
+ (realize_default_face): Don't use FRAME_FONT unless frame is an X frame.
+ (Ftty_supports_face_attributes_p): Update tty_capable_p call.
+
+ * scroll.c: Replace CURTTY() with local variables throughout the
+ file (where applicable).
+ (calculate_scrolling, calculate_direct_scrolling)
+ (scrolling_1, scroll_cost): Use the accessor macros for terminal
+ characteristics.
+
+ * keymap.c (Vfunction_key_map): Remove.
+ (Fdescribe_buffer_bindings): Update references to Vfunction_key_map.
+ (syms_of_keymap): Remove DEFVAR for Vfunction_key_map.
+ (Vkey_translation_map): Remove.
+ (syms_of_keymap): Remove DEFVAR for key-translation-map.
+ (Fdescribe_buffer_bindings):
+ (read_key_sequence, init_kboard, syms_of_keyboard, mark_kboards):
+ Update for terminal-local key-translation-map.
+
+ * Makefile.in (callproc.o): Update dependencies.
+ (lisp, shortlisp): Add termdev.elc.
+ (obj): Add terminal.o.
+ (terminal.o): Add dependencies.
+ [HAVE_CARBON]: Make terminal.o depend on macgui.h.
+ (data.o, fns.o): Add termhooks.h dependency.
+ (SOME_MACHINE_LISP): Add dnd.elc.
+ (minibuf.o): Fix typo.
+ Update dependencies.
+
+ * data.c (do_symval_forwarding, store_symval_forwarding)
+ (find_symbol_value): Use the selected frame's keyboard, not
+ current_kboard.
+
+ * .gdbinit (init_sys_modes): Use Vinitial_window_system instead of
+ Vwindow_system.
+
+ * xmenu.c (Fx_menu_bar_open) [USE_X_TOOLKIT, USE_GTK]: Rename from
+ Fmenu_bar_open.
+ (syms_of_xmenu): Update defsubr.
+ (mouse_position_for_popup, Fx_popup_menu)
+ (Fx_popup_dialog, x_activate_menubar, update_frame_menubar)
+ (set_frame_menubar, free_frame_menubar)
+ (create_and_show_popup_menu, xmenu_show, )
+ (create_and_show_dialog, xdialog_show, xmenu_show): Abort if not
+ an X frame.
+
+ * xselect.c (x_own_selection): Abort if not an X frame.
+ (some_frame_on_display): Check if it is an X frame.
+ (x_handle_selection_clear): Deal with MULTI_KBOARD.
+
+ * coding.c: Include frame.h and termhooks.h.
+ (terminal_coding, keyboard_coding): Delete.
+ (Fset_terminal_coding_system_internal):
+ (Fset_keyboard_coding_system_internal):
+ (Fkeyboard_coding_system):
+ (Fterminal_coding_system): Add a terminal parameter.
+ Get terminal_coding from the terminal.
+ (init_coding_once): Don't call setup_coding_system here.
+
+ * dispextern.h (set_scroll_region, turn_off_insert)
+ (turn_off_highlight, background_highlight, clear_end_of_line_raw)
+ (tty_clear_end_of_line, tty_setup_colors)
+ (delete_tty, updating_frame)
+ (produce_special_glyphs, produce_glyphs, write_glyphs)
+ (insert_glyphs): Remove.
+ (raw_cursor_to, clear_to_end, tty_turn_off_insert)
+ (tty_turn_off_highlight, get_tty_size): Add declaration.
+ (tabs_safe_p, init_baud_rate, get_tty_terminal): Update prototypes.
+
+ * frame.h (enum output_method): Add output_initial.
+ (struct x_output): Delete.
+ (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL):
+ Access foreground_pixel and background_pixel directly from the frame.
+ (tty_display): Delete.
+ (struct frame): Add buried_buffer_list, foreground_pixel,
+ background_pixel and terminal. Delete kboard
+ (union output_data): Add tty.
+ (FRAME_KBOARD): Get the kboard from the terminal.
+ (FRAME_INITIAL_P): New macro.
+ (Qtty, Qtty_type, Qterminal, Qterminal_live_p, Qenvironment)
+ (Qterm_environment_variable, Qdisplay_environment_variable)
+ (make_terminal_frame, Qburied_buffer_list, Qwindow_system):
+ New declarations.
+
+ * termchar.h (tty_output, tty_display_info): New structures.
+ (tty_list): Declare.
+ (FRAME_TTY, CURTTY): New macros.
+ (must_write_spaces, min_padding_speed, fast_clear_end_of_line)
+ (line_ins_del_ok, char_ins_del_ok, scroll_region_ok)
+ (scroll_region_cost, memory_below_frame, fast_clear_end_of_line)
+ (dont_calculate_costs, no_redraw_on_reenter): Remove declarations.
+
+ * callproc.c: Include frame.h and termhooks.h, for terminal
+ parameters.
+ (add_env): New function.
+ (child_setup): Use it.
+ (child_setup, getenv_internal): Handle the new Vprocess_environment.
+ (getenv_internal): Fix get_terminal_param call.
+ (Fgetenv_internal, egetenv): Update doc.
+ (syms_of_callproc): Initialize Vprocess_environment to nil.
+ Register and initialize them. Remove obsolete defvars. Update doc
+ strings.
+ (child_setup): Handle Vlocal_environment_variables.
+ (getenv_internal): Add terminal parameter.
+ Handle Vlocal_environment_variables.
+ (Fgetenv_internal): Add terminal parameter.
+ (child_setup, getenv_internal, Fgetenv_internal): Store the local
+ environment in a frame (not terminal) parameter. Update doc strings.
+ (set_initial_environment): Rename from set_global_environment.
+ Store Emacs environment in initial frame parameter.
+
+ * xdisp.c (redisplay_internal): Update references to
+ `previous_terminal_frame'.
+ (display_mode_line, Fformat_mode_line): Replace calls to
+ `push_frame_kboard' with `push_kboard'.
+ (get_glyph_string_clip_rects): Add extra parentheses and
+ braces to prevent compiler warnings.
+ (calc_pixel_width_or_height): Add xassert to check that the
+ frame is alive. Don't call `lookup_image' on a termcap frame.
+ (message2_nolog, message3_nolog, redisplay_internal)
+ (set_vertical_scroll_bar, redisplay_window, check_x_display_info)
+ (x_set_scroll_bar_foreground, x_set_scroll_bar_background)
+ (Fx_create_frame, Fxw_display_color_p, Fx_display_grayscale_p)
+ (Fx_display_pixel_width, Fx_display_pixel_height)
+ (Fx_display_planes, Fx_display_color_cells)
+ (Fx_server_max_request_size, Fx_server_vendor, Fx_server_version)
+ (Fx_display_screens, Fx_display_mm_height, Fx_display_mm_width)
+ (Fx_display_backing_store, Fx_display_visual_class)
+ (Fx_display_save_under, Fx_close_connection, x_create_tip_frame):
+ Use FRAME_TERMINAL_P, FRAME_WINDOW_P, FRAME_TTY and FRAME_RIF.
+
+ * xfns.c (x_set_foreground_color x_set_background_color)
+ (x_set_mouse_color, x_set_cursor_color, x_make_gc):
+ Use FRAME_BACKGROUND_PIXEL and FRAME_FOREGROUND_PIXEL.
+ (Fx_create_frame, x_create_tip_frame, build_string, x_window)
+ (Fx_create_frame, x_create_tip_frame): Don't create frames on a
+ terminal that is being deleted.
+ (Fx_create_frame): Use `store_frame_param' to set `window-system'
+ frame parameter, and make sure it overrides any user-supplied setting.
+ (Fx_close_connection, Fx_synchronize): Unify argument names with
+ the rest of the DEFUNs.
+
+ * dispnew.c (Fsend_string_to_terminal): Update call to
+ `get_tty_terminal'.
+ (Fredraw_frame, Fsend_string_to_terminal)
+ (Fsend_string_to_terminal, init_display): Use FRAME_RIF,
+ FRAME_TERMCAP_P and FRAME_TTY.
+ (window_change_signal): Don't believe width/height values that are
+ impossibly small.
+ (Vinitial_window_system): Rename from Vwindow_system.
+ (termscript, Wcm, rif): Delete.
+
+ * termhooks.h (struct terminal): New struct containing the
+ previously global text display hooks and new members NAME,
+ DELETED and PARAM_ALIST.
+ (FRAME_TERMINAL, TERMINAL_TERMINAL_CODING)
+ (TERMINAL_KEYBOARD_CODING, TERMINAL_ACTIVE_P, FRAME_WINDOW_P)
+ (FRAME_RIF): New macros.
+ (get_terminal_param, get_device): New declarations.
+ (termscript): Delete declaration.
+
+ * xterm.c (x_initialize): Use Fset_input_interrupt_mode.
+ (XTflash, x_free_frame_resources, x_scroll_bar_create)
+ (x_scroll_bar_set_handle): Use FRAME_BACKGROUND_PIXEL and
+ FRAME_FOREGROUND_PIXEL.
+ (x_fully_uncatch_errors): Disable definition.
+ (x_scroll_bar_expose): Fix reference to foreground pixel.
+ (XTread_socket): Disable loop on all X displays.
+ (x_delete_terminal): Don't set terminal->deleted and let
+ delete_terminal delete the frames on the terminal.
+ (x_delete_display): Doc update to reflect changes in
+ delete_terminal.
+ (x_display_info) <terminal>: Move member earlier in the struct.
+ (deleting_tty): Remove old variable.
+ (Fsuspend_tty): Call clear_tty_hooks.
+ (Fresume_tty, init_tty): Call set_tty_hooks.
+ (Ftty_display_color_p, Ftty_display_color_cells): Don't throw
+ errors on X frames.
+ (x_catch_errors_unwind): Abort if x_error_message is NULL.
+ (handle_one_xevent): Initialize `f' to NULL.
+ (x_delete_terminal, x_create_terminal): New functions.
+ (XTset_terminal_modes, XTreset_terminal_modes)
+ (XTread_socket, x_connection_closed, x_term_init)
+ (x_term_init, x_delete_display): Add terminal parameter.
+ (x_term_init) [!HAVE_GTK_MULTIDISPLAY]: Refuse to create secondary
+ X connections.
+
+ * frame.c (Fframep): Deal with output_initial.
+ (Qbuffer_predicate, Qbuffer_list, Qburied_buffer_list, Qtty)
+ (Qtty_type, Qwindow_system, Qenvironment)
+ (Qterm_environment_variable, Qdisplay_environment_variable): New vars.
+ (x_set_screen_gamma, store_frame_param): Fix compilation errors.
+ (make_terminal_frame): Don't create frames on a terminal that is
+ being deleted.
+ (make_terminal_frame): Use FRAME_BACKGROUND_PIXEL and
+ FRAME_FOREGROUND_PIXEL.
+ (store_frame_param): Check for found_for_frame before calling XFRAME.
+ (Fmake_terminal_frame): Handle NULL tty names correctly.
+ (syms_of_frame): Enhance doc string of `default-frame-alist'.
+ (Fdelete_frame): Remove unused variable `count'.
+ (Qenvironment): New variable.
+ (Fdelete_frame): Don't allow other frames to refer to a deleted
+ frame in their 'environment parameter.
+ (Fframe_with_environment): New function.
+ (syms_of_frame): Defsubr it. Initialize and staticpro Qenvironment.
+ (get_future_frame_param): New function.
+ (Fmake_terminal_frame): Use it.
+ (x_set_frame_parameters, x_set_screen_gamma): Use FRAME_RIF.
+
+ * sysdep.c (init_sys_modes, reset_sys_modes): Update for renames.
+ * sysdep.c (reset_sys_modes): Update for renames.
+
+ * keyboard.c (tty_read_avail_input): New function.
+ (Fset_input_interrupt_mode, Fset_output_flow_control): New functions.
+ (syms_of_keyboard): Defsubr them.
+ (Fset_input_meta_mode, Fset_quit_char): New functions.
+ (Fset_input_mode): Split to above functions.
+
+ (read_char_minibuf_menu_prompt): Add wrong_kboard_jmpbuf
+ parameter. Use it in call to `read_char'.
+ (read_char): Declare. Update call to `read_char_minibuf_menu_prompt'.
+ Set wrong_kboard_jmpbuf correctly in recursive calls.
+ Use current_kboard to access Vkeyboard_translate_table.
+ Enhance comment before extra longjmp to wrong_kboard_jmpbuf.
+ Add wrong_kboard_jmpbuf parameter to allow for recursive calls.
+ Update longjmp invocations. Remember the original current_kboard,
+ and longjmp to `wrong_kboard_jmpbuf' when a filter, timer or sentinel
+ changes it. Comment out unnecessary calls to
+ `record_single_kboard_state' and `any_kboard_state'.
+ Update recursive calls.
+ (wrong_kboard_jmpbuf): Remove global variable.
+ (read_key_sequence): Remove unused variable wrong_kboard_jmpbuf.
+ Handle deleted interrupted_kboards correctly; that is a legal
+ case. Add `wrong_kboard_jmpbuf' local variable. Update setjmp
+ and read_char calls. Abort if interrupted_kboard died in read_char.
+ (any_kboard_state, single_kboard_state)
+ (push_frame_kboard): Remove function.
+ (pop_kboard): Switch out of single_kboard mode if the kboard has
+ been deleted. Remove unused variable. Help debugging by not
+ changing current_kboard unnecessarily. Set current_kboard to the
+ kboard of the selected frame when the stored kboard object has
+ been deleted before pop_kboard.
+ (temporarily_switch_to_single_kboard): Change first parameter to a
+ frame pointer. Throw an error when caller wants to change kboards
+ while in single_kboard mode. Don't push_kboard if we weren't in
+ single kboard state. Don't pop_kboard if we popped into any
+ kboard state.
+ (restore_kboard_configuration): Abort if pop_kboard changed the
+ kboard in single_kboard mode. Call pop_kboard only after setting
+ up single_kboard mode.
+ (Frecursive_edit): Switch to single_kboard mode only in nested
+ command loops.
+ (cmd_error, command_loop, command_loop_1, timer_check):
+ Comment out unnecessary call to `any_kboard_state' and
+ `record_single_kboard_state'.
+ (delete_kboard): Exit single_kboard mode if we have just deleted
+ that kboard. Use FRAME_KBOARD.
+ (interrupt_signal): Use `Fkill_emacs' to exit Emacs, not
+ `fatal_error_signal'.
+ (record_single_kboard_state): Don't push_kboard if we weren't in
+ single kboard state. Don't pop_kboard if we popped into any
+ kboard state.
+ (push_frame_kboard): Rename to push_kboard.
+ (kbd_buffer_get_event): Use FRAME_TERMINAL.
+ (read_avail_input): Read input from all terminals.
+ (mark_kboards): Also mark Vkeyboard_translate_table.
+ (kbd_buffer_store_event_hold): Simplify condition.
+ (read_key_sequence): Reinitialize fkey and keytran at each replay.
+ (Vkeyboard_translate_table): Move to struct kboard.
+ (init_kboard): Initialize Vkeyboard_translate_table.
+ (syms_of_keyboard): Use DEFVAR_KBOARD to define
+ Vkeyboard_translate_table. Update doc strings. Update docs of
+ local-function-key-map and function-key-map.
+
+ * terminal.c: New file.
+
+ * term.c: Include errno.h.
+ (Vring_bell_function, device_list, initial_device)
+ (next_device_id, ring_bell, update_begin, update_end)
+ (set_terminal_window, cursor_to, raw_cursor_to)
+ (clear_to_end, clear_frame, clear_end_of_line)
+ (write_glyphs, insert_glyphs, delete_glyphs, ins_del_lines)
+ (Fdisplay_name, create_device, delete_device): Move to terminal.c.
+ (syms_of_term): Move their initialization to terminal.c.
+ (get_tty_terminal, Fdisplay_tty_type, Ftty_display_color_p)
+ (Ftty_display_color_cells)
+ (Ftty_no_underline, Fsuspend_tty, Fresume_tty, create_tty_output)
+ (clear_tty_hooks, set_tty_hooks)
+ (init_tty, maybe_fatal): New functions.
+ (Ftty_type): Return nil if terminal is not on a tty instead of
+ throwing an error. Doc update.
+ (syms_of_term) <Vsuspend_tty_functions, Vresume_tty_functions>:
+ Doc update. Initialize new subrs and variables.
+ (delete_tty): Use terminal->deleted.
+ (tty_set_terminal_modes): Rename from set_terminal_modes.
+ (tty_reset_terminal_modes): Rename from reset_terminal_modes.
+ (set_scroll_region): Rename to `tty_set_scroll_region'.
+ (turn_on_insert): Rename to `tty_turn_on_insert'.
+ (turn_off_insert): Rename to `tty_turn_off_insert'.
+ (turn_off_highlight): Rename to `tty_turn_off_highlight'.
+ (turn_on_highlight): Rename to `tty_turn_on_highlight'.
+ (toggle_highligh): Rename to `tty_toggle_highlight'.
+ (background_highlight): Rename to `tty_background_highlight'.
+ (highlight_if_desired): Rename to `tty_highlight_if_desired'.
+ (tty_ring_bell, tty_update_end, tty_set_terminal_window)
+ (tty_set_scroll_region, tty_background_highlight)
+ (tty_cursor_to, tty_raw_cursor_to, tty_clear_to_end)
+ (tty_clear_frame, tty_clear_end_of_line, tty_write_glyphs)
+ (tty_insert_glyphs, tty_delete_glyphs, tty_ins_del_lines)
+ (term_get_fkeys, tty_setup_colors, dissociate_if_controlling_tty):
+ Add static modifier.
+ (tty_reset_terminal_modes, tty_set_terminal_window)
+ (tty_set_scroll_region, tty_background_highlight)
+ (tty_highlight_if_desired, tty_cursor_to)
+ (tty_raw_cursor_to, tty_clear_to_end, tty_clear_frame)
+ (tty_clear_end_of_line, tty_write_glyphs, tty_insert_glyphs)
+ (tty_delete_glyphs, tty_ins_del_lines, turn_on_face): Update for
+ renames.
+
2007-08-28 Jan Dj,Ad(Brv <[email protected]>
* keyboard.c: Qrtl is new.
@@ -205,8 +1483,7 @@
For consistency, run after_insert_file_functions iff something
got inserted. Move signal_after_change and update_compositions
after code running after_insert_file_functions. Make sure that
- undo_list doesn't record intermediate steps of the decoding
- process.
+ undo_list doesn't record intermediate steps of the decoding process.
2007-08-07 YAMAMOTO Mitsuharu <[email protected]>
@@ -395,8 +1672,8 @@
2007-07-17 Glenn Morris <[email protected]>
* abbrev.c (abbrev_check_chars): New function.
- (Fdefine_global_abbrev, Fdefine_mode_abbrev): Call
- abbrev_check_chars to check abbrev characters are word
+ (Fdefine_global_abbrev, Fdefine_mode_abbrev):
+ Call abbrev_check_chars to check abbrev characters are word
constituents. Doc fix.
2007-07-17 Stefan Monnier <[email protected]>
@@ -427,6 +1704,10 @@
customizable variable. Rather explicitly check whether the
height of the window that shall be splitted is at least as large
as split_height_threshold.
+ (Fwindow_full_width_p): New defun.
+ (syms_of_window): Defsubr it.
+
+ * window.h: Add EXFUN for Fwindow_full_width_p.
2007-07-14 Jason Rumney <[email protected]>
@@ -1141,27921 +2422,14 @@
* gtkutil.c (xg_update_menubar, create_menus): Create empty
submenu for menu bar items.
-2007-04-24 Chong Yidong <[email protected]>
-
- * Branch for 22.1.
-
-2007-04-24 Chong Yidong <[email protected]>
-
- * xdisp.c (redisplay_window): Use BEG_UNCHANGED and END_UNCHANGED
- values of the actual window.
-
-2007-04-23 Richard Stallman <[email protected]>
-
- * process.c (Fstart_process): Doc fix.
-
-2007-04-23 Eli Zaretskii <[email protected]>
-
- * process.c (Fstart_process): Doc fix.
-
-2007-04-22 Richard Stallman <[email protected]>
-
- * abbrev.c (Fdefine_abbrev): Doc fix.
-
- * keymap.c (Fdefine_key): Minor doc fix.
-
-2007-04-21 Glenn Morris <[email protected]>
-
- * keymap.c (Fdefine_key): Fix info ref in doc string.
-
-2007-04-20 Glenn Morris <[email protected]>
-
- * sysdep.c (init_system_name): Don't accept localhost.localdomain.
-
-2007-04-19 Juanma Barranquero <[email protected]>
-
- * minibuf.c (Fminibuffer_contents, Fminibuffer_contents_no_properties)
- (Fminibuffer_completion_contents, Fdelete_minibuffer_contents):
- Doc fixes.
-
-2007-04-16 Chong Yidong <[email protected]>
-
- * dispnew.c (adjust_frame_glyphs_for_frame_redisplay):
- Set garbaged flag in presence of window margins.
- (showing_window_margins_p): New function.
-
- * xdisp.c (cursor_row_p): Only end row on newline if it's a
- display string. Suggested by Lennart Borgman.
-
-2007-04-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * alloc.c (mem_insert): Set min_heap_address and max_heap_address
- if they are not yet initialized.
-
-2007-04-15 Chong Yidong <[email protected]>
-
- * xdisp.c (redisplay_window): When deciding whether or not to
- recenter, don't use the reset values of BEG_UNCHANGED and
- END_UNCHANGED.
-
-2007-04-13 Kim F. Storm <[email protected]>
-
- * buffer.c (Fkill_buffer): gcpro BUF during kill_buffer_processes
- and check that buffer is still alive upon return.
-
-2007-04-13 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c [!TARGET_API_MAC_CARBON]: Include Displays.h.
- (mac_screen_config_changed): New variable.
- (mac_handle_dm_notification, init_dm_notification_handler)
- (mac_get_screen_info): New functions.
- [MAC_OS8] (main): Call init_dm_notification_handler.
- (mac_initialize) [MAC_OSX]: Likewise.
- (XTread_socket): Call mac_get_screen_info if screen config changed.
- (mac_initialized): Make static.
- (mac_initialize_display_info): Remove function.
- (mac_term_init): Call mac_get_screen_info. Add partial contents of
- mac_initialize_display_info.
-
-2007-04-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (xrm_get_preference_database, Fmac_get_preference)
- [TARGET_API_MAC_CARBON]: Use CFPreferencesAppSynchronize.
-
- * macterm.c [TARGET_API_MAC_CARBON] (mac_post_mouse_moved_event):
- Use GetGlobalMouse instead of GetMouse and LocalToGlobal.
- (mac_initialize_display_info) [MAC_OSX]: Use CGRectZero.
- (mac_initialize_display_info) [!MAC_OSX]: dpyinfo->height and
- dpyinfo->width are those of whole screen.
-
-2007-04-10 Chong Yidong <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Don't decrement
- glyph pointer before start of glyph row.
-
-2007-04-09 YAMAMOTO Mitsuharu <[email protected]>
-
- * s/darwin.h (__restrict, struct kboard): Remove outdated workarounds.
- (C_SWITCH_SYSTEM): Remove `-I../mac/src'.
-
-2007-04-09 Martin Rudalics <[email protected]>
-
- * indent.c (Fmove_to_column): Set next_boundary with correct start pt.
-
-2007-04-08 Richard Stallman <[email protected]>
-
- * xdisp.c (syms_of_xdisp) <message-log-max>: Default 100.
-
-2007-04-07 Chong Yidong <[email protected]>
-
- * editfns.c (Ftranspose_regions): Validate interval before setting
- text properties.
-
-2007-04-03 Eli Zaretskii <[email protected]>
-
- * emacs.c (main): Fix instructions for building Emacs for profiling.
-
-2007-04-03 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_update_menubar): Call g_list_next after moving
- menu bar item.
-
-2007-04-02 Juanma Barranquero <[email protected]>
-
- * print.c (Fprin1_to_string): Use macro SPECPDL_INDEX.
-
-2007-04-01 Chong Yidong <[email protected]>
-
- * keymap.c (Fcommand_remapping): New optional argument.
- (where_is_internal): Use new keymaps argument.
- (Fkey_binding): Caller changed.
-
- * keyboard.c (command_loop_1): Caller changed.
-
-2007-03-31 Eli Zaretskii <[email protected]>
-
- * window.c (Fget_lru_window): Doc fix.
-
-2007-03-30 Chong Yidong <[email protected]>
-
- * undo.c (Fprimitive_undo): Give clearer error message when trying
- to change text properties outside accessible part of buffer.
-
-2007-03-29 Kim F. Storm <[email protected]>
-
- * process.c (wait_reading_process_output) [HAVE_PTYS]:
- When EIO happens, clear channel from descriptor masks before raising
- SIGCHLD signal to avoid busy loop between read and sigchld_handler.
- (sigchld_handler): Remove sleep (2007-03-11 & 2007-03-26 changes).
-
-2007-03-29 Juanma Barranquero <[email protected]>
-
- * buffer.c (Fset_buffer_major_mode): Check that BUFFER is valid.
-
- * process.c (Fformat_network_address): Return nil when the
- argument vector contains invalid values.
-
-2007-03-28 YAMAMOTO Mitsuharu <[email protected]>
-
- * gmalloc.c [HAVE_GTK_AND_PTHREAD]: Define USE_PTHREAD.
- [USE_PTHREAD]: Include pthread.h.
- (malloc_init_once_control, _malloc_mutex) [USE_PTHREAD]: New variables.
- (malloc_initialize_1): New function created from __malloc_initialize.
- (__malloc_initialize): Use it.
- (LOCK, UNLOCK): New macros to make malloc etc. thread safe.
- (_malloc_internal, _free_internal, _realloc_internal): Use them.
-
- * lread.c (readchar): Extend BLOCK_INPUT block to ferror/clearerr.
-
-2007-03-27 Juanma Barranquero <[email protected]>
-
- * process.c (Fformat_network_address): Make args array big enough
- to format IPv6 addresses.
-
-2007-03-27 Glenn Morris <[email protected]>
-
- * m/hp800.h: Restore HP-UX support (removed 2007-01-29).
-
-2007-03-26 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (Fx_display_mm_height, Fx_display_mm_width): Scale whole
- screen size in pixels by millimeters per pixel of main display.
-
- * macselect.c (get_scrap_target_type_list, x_own_selection):
- Move assignments outside predicate macros.
- (Vselection_converter_alist): Doc fix.
-
- * macterm.c (create_text_encoding_info_alist): Move assignments
- outside predicate macros.
- (mac_initialize_display_info) [MAC_OSX]: dpyinfo->height and
- dpyinfo->width are those of whole screen.
-
-2007-03-26 Sam Steingold <[email protected]>
-
- * process.c (sigchld_handler): Delay by 1ms instead of 1s to
- alleviate sluggishness (the original problem is still fixed).
-
-2007-03-25 Kim F. Storm <[email protected]>
-
- * intervals.c (merge_properties): Use explicit loop instead of
- Fplist_member to avoid QUIT. Don't use Fcdr.
- (intervals_equal): Likewise. Rewrite loop to perform length check
- on the fly rather than calling Flength. Don't use Fcar.
-
-2007-03-24 Eli Zaretskii <[email protected]>
-
- * editfns.c (Fgoto_char): Doc fix.
-
- * indent.c (Findent_to): Doc fix.
-
-2007-03-24 Chong Yidong <[email protected]>
-
- * editfns.c (Ftranspose_regions): Use set_text_properties_1
- instead of Fset_text_properties to avoid GC. Signal after change.
-
-2007-03-24 Eli Zaretskii <[email protected]>
-
- * xfns.c (Fx_show_tip): Doc fix.
-
- * macfns.c (Fx_show_tip): Doc fix.
-
- * w32fns.c (Fx_show_tip): Doc fix.
-
-2007-03-23 Kim F. Storm <[email protected]>
-
- * intervals.c (merge_properties, intervals_equal):
- Use Fplist_member instead of Fmemq to find properties.
-
-2007-03-23 Glenn Morris <[email protected]>
-
- * unexhp9k800.c: Restore file with clarified legal status.
- * m/sr2k.h: Restore since dependency unexhp9k800.c is restored.
-
-2007-03-22 Chong Yidong <[email protected]>
-
- * widget.c (EmacsFrameSetCharSize): Catch X errors.
-
-2007-03-22 Kenichi Handa <[email protected]>
-
- * fileio.c (Fcopy_file): Call barf_or_query_if_file_exists with
- non-encoded file name.
- (Frename_file): Likewise.
- (Fadd_name_to_file): Likewise.
- (Fmake_symbolic_link): Likewise.
-
-2007-03-20 YAMAMOTO Mitsuharu <[email protected]>
-
- * Makefile.in (alloca.o, gtkutil.o): Depend on systime.h.
- (dired.o, editfns.o, fileio.o, msdos.o): Depend on atimer.h.
- (dosfns.o, window.o, fns.o, macselect.o): Depend on atimer.h and
- systime.h.
- (term.o, print.o, lread.o): Depend on blockinput.h, atimer.h, and
- systime.h.
- (macfns.o): Remove duplicate dependency on systime.h.
-
- * dispnew.c (Fopen_termscript): Add BLOCK_INPUT around fclose.
- (Fsend_string_to_terminal): Add BLOCK_INPUT around fwrite.
-
- * fileio.c (do_auto_save_unwind): Add BLOCK_INPUT around fclose.
- (Fdo_auto_save): Add BLOCK_INPUT around fwrite.
-
- * keyboard.c (record_char): Add BLOCK_INPUT around fwrite.
- (Fopen_dribble_file): Add BLOCK_INPUT around fclose.
-
- * lread.c: Include blockinput.h.
- (readchar, Fget_file_char): Add BLOCK_INPUT around getc.
- (unreadchar): Add BLOCK_INPUT around ungetc.
- (load_unwind): Add BLOCK_INPUT around fclose.
-
- * print.c: Include blockinput.h.
- (Fredirect_debugging_output): Add BLOCK_INPUT around fclose.
-
- * process.c (Fmake_network_process) [HAVE_GETADDRINFO]:
- Clear immediate_quit before calling freeaddrinfo.
- Add BLOCK_INPUT around freeaddrinfo.
-
- * term.c: Include blockinput.h.
- (write_glyphs, insert_glyphs): Add BLOCK_INPUT around fwrite.
-
-2007-03-19 Richard Stallman <[email protected]>
-
- * keyboard.c (NUM_RECENT_KEYS): Bump up to 300.
-
- * buffer.c (syms_of_buffer): Doc fix.
-
-2007-03-18 Chong Yidong <[email protected]>
-
- * image.c (pbm_load): Signal error for invalid image size.
-
-2007-03-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (note_mouse_movement): Don't return immediately for
- LeaveNotify case.
-
- * macmenu.c (popup_activated_flag): New variable.
- (x_activate_menubar, mac_menu_show): Set it during menu tracking.
- (popup_activated): New function.
-
- * xdisp.c (redisplay_internal, note_mouse_highlight):
- Check popup_activated for MAC_OS.
-
-2007-03-17 Juanma Barranquero <[email protected]>
-
- * buffer.c (syms_of_buffer) <buffer-display-table>: Doc fix.
- Reported by Nikolaj Schumacher <[email protected]>.
-
-2007-03-17 Richard Stallman <[email protected]>
-
- * dired.c (file_name_completion): gcpro NAME.
-
-2007-03-17 Chong Yidong <[email protected]>
-
- * xdisp.c (try_window_id): Increment matrix positions if the
- buffer's byte count has increased, but not the character count.
-
-2007-03-12 Andreas Schwab <[email protected]>
-
- * lisp.h: Declare check_obarray.
-
- * process.c (Fdelete_process): Properly handle deletion of first
- element of deleted_pid_list.
- (create_process): Declare pid as pid_t.
-
-2007-03-12 Kim F. Storm <[email protected]>
-
- * process.c (sigchld_handler): Change type of pid to pid_t.
- Scan deleted_pid_list explicitly to avoid using Fmember which don't
- know about mark bits and make_fixnum_or_float which may malloc.
- Reported by Andreas Schwab.
-
- * keyboard.c (read_key_sequence): Store original event into keybuf
- when replaying sequence with local keymap(s) from string.
-
-2007-03-12 Glenn Morris <[email protected]>
-
- * editfns.c (Fdecode_time, Fencode_time): Doc fix ("daylight
- savings" to "daylight saving").
-
-2007-03-11 Sam Steingold <[email protected]>
-
- * process.c (sigchld_handler): Sleep before wait3 to avoid a busyloop.
-
-2007-03-11 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (Fx_server_vendor): Change vendor string to "Apple Inc.".
-
-2007-03-10 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c [USE_CARBON_EVENTS] (mac_handle_mouse_event):
- Ignore mouse wheel movement on title bar or tool bar.
-
-2007-03-10 Chong Yidong <[email protected]>
-
- * keyboard.c (help_form_saved_window_configs): New var.
- (read_char_help_form_unwind): New function.
- (read_char): Don't restore window configuration if a mouse click
- arrives while the help form is being displayed.
-
-2007-03-10 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Don't automatically select a new window
- start for a contination line during mouse-click.
-
-2007-03-09 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): Ignore buttons > 3 for the tool bar.
-
-2007-03-09 Juanma Barranquero <[email protected]>
-
- * keymap.c (Fdescribe_buffer_bindings): Check that BUFFER is valid.
-
-2007-03-08 Richard Stallman <[email protected]>
-
- * keyboard.c (syms_of_keyboard): Doc fix.
-
-2007-03-08 Chong Yidong <[email protected]>
-
- * minibuf.c (Ftry_completion): Don't short circuit if
- completion-ignore-case is non-nil.
-
-2007-03-07 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (mac_set_scroll_bar_width, mac_frame_parm_handlers):
- Undo 2006-03-06 changes.
-
- * macterm.c (XTset_vertical_scroll_bar) [MAC_OSX]: Don't show scroll
- bar if its width is smaller than that of Aqua small scroll bar.
-
-2007-03-07 Stefan Monnier <[email protected]>
-
- * minibuf.c (read_minibuf): Bind inhibit-read-only a bit longer so as
- to handle correctly prompts with read-only property.
-
-2007-03-06 Jan Dj,Ad(Brv <[email protected]>
-
- * sound.c (wav_play): Check header->data_length to see how much we
- shall read.
- (alsa_period_size): Convert ALSA period size in frames to bytes.
- (alsa_write): Return if frames is zero.
-
-2007-03-06 Kenichi Handa <[email protected]>
-
- * xselect.c (Vselection_coding_system): Documentation improved.
-
-2007-03-05 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (x_scroll_bar_create, XTread_socket): Replace #if
- USE_TOOLKIT_SCROLL_BARS with #ifdef USE_TOOLKIT_SCROLL_BARS.
- (x_set_window_size): Call SET_FRAME_GARBAGED. Clear window if
- internal border width has changed.
-
- * macterm.h (struct mac_output): New member `internal_border_width'.
-
-2007-03-04 Richard Stallman <[email protected]>
-
- * window.c (Fdisplay_buffer): Doc fix.
-
-2007-03-03 Glenn Morris <[email protected]>
-
- * Makefile.in: Don't clear out LIB_X11_LIB, since XFT_LIBS does
- not include -lX11 on Solaris.
-
-2007-03-02 Stuart D. Herring <[email protected]>
-
- * keymap.c (Fkey_binding): Don't consider one-element lists as events.
-
-2007-03-01 Kenichi Handa <[email protected]>
-
- * process.c (send_process_object): Check the process status and
- signal an error if something is wrong.
-
-2007-02-28 Chong Yidong <[email protected]>
-
- * insdel.c (Fcombine_after_change_execute): Return nil if
- combine_after_change_buffer has been invalidated.
-
-2007-02-25 Dan Nicolaescu <[email protected]>
-
- * m/xtensa.h: New file.
-
-2007-02-24 Nick Roberts <[email protected]>
-
- * .gdbinit (xprintstr): Ensure GDB (> 6.6) prints symbol name
- as strings and not character arrays.
-
-2007-02-24 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_drag)
- (x_set_toolkit_scroll_bar_thumb): Add bar->min_handle as margin to
- scroll bar handle size in order to avoid `scroll backward' problem.
- (x_scroll_bar_create, XTset_vertical_scroll_bar)
- [USE_TOOLKIT_SCROLL_BARS]: Initialize bar->min_handle.
-
- * macterm.h (struct scroll_bar) [USE_TOOLKIT_SCROLL_BARS]:
- New member `min_handle'.
-
-2007-02-23 Kim F. Storm <[email protected]>
-
- * print.c (print): Reset print_number_index if Vprint_number_table
- is nil.
-
-2007-02-23 Eli Zaretskii <[email protected]>
-
- * w32.c (stat, get_long_basename, is_unc_volume): Use _mbspbrk
- instead of strpbrk.
-
-2007-02-23 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (mac_menu_show): Call unbind_to early. Use variable
- `menu_item_selection' as in W32 version.
- [TARGET_API_MAC_CARBON] (mac_handle_dialog_event): Add explicit
- braces to avoid ambiguous `else'.
-
- * macterm.c (mac_display_info_for_display): Remove function.
- (mac_flush_display_optional) [USE_CG_DRAWING]: New function.
- (x_redisplay_interface) [USE_CG_DRAWING]: Set it as handler for
- flush_display_optional.
- [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_press):
- New argument MOUSE_POS. All uses changed. Set bar->dragging to
- negative integer if scroll bar handle is pressed.
- [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_release):
- Negative bar->dragging means scroll bar handle is not dragged.
- [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_drag): Get initial
- offset of scroll bar handle from negative bar->dragging.
- (XTread_socket) [USE_TOOLKIT_SCROLL_BARS]: Modifiers for scroll
- bar click is compared against mapped one. Set down/up_modifier
- for scroll bar click event with control key.
-
- * macterm.h (x_display_info_for_display): Remove extern.
- (SCROLL_BAR_UNPACK, SET_SCROLL_BAR_CONTROL_HANDLE): Don't limit
- value to be unpacked to 32-bit on LP64 model.
-
-2007-02-23 Kenichi Handa <[email protected]>
-
- * process.c (send_process_object_unwind): New function.
- (send_process_object): New function.
- (Fprocess_send_region): Call send_process_object.
- (Fprocess_send_string): Likewise.
-
-2007-02-22 Jason Rumney <[email protected]>
-
- * w32menu.c (w32_menu_show): Mark the frame's menu as inactive
- when popup menu finishes.
-
- * w32fns.c (menubar_in_use): New flag.
- (w32_wnd_proc) <WM_INITMENU, WM_EXITMENULOOP, WM_TIMER, WM_COMMAND>:
- Use it.
-
- * w32menu.c (Fx_popup_menu): Don't free menu strings here.
- (w32_menu_show): Do it here instead.
-
- * w32fns.c (w32_wnd_proc) <WM_INITMENU>: Set menubar_active frame
- parameter.
-
- * w32menu.c (current_popup_menu): Make available globally.
- (menubar_selection_callback): Free menu strings before pushing the
- menu event into the keyboard buffer. Remove menu_command_in_progress.
-
- * w32fns.c (current_popup_menu): Use from w32menu.c.
- (w32_wnd_proc) <WM_EXITMENULOOP, WM_TIMER>: Use menubar_active
- and current_popup_menu to determine whether a menubar menu has
- been cancelled.
-
- * w32term.h (w32_output): Remove menu_command_in_progress.
-
-2007-02-22 Kim F. Storm <[email protected]>
-
- * dispnew.c (update_frame, update_single_window): Set force_p here if
- redisplay_dont_pause is set or Vredisplay_preemption_period is nil...
- (update_window, update_frame_1): ... instead of here.
- (update_text_area): Clear mouse face on header lines.
-
-2007-02-21 Kim F. Storm <[email protected]>
-
- * minibuf.c (Fassoc_string): Doc fix. Allow symbol for KEY too.
-
-2007-02-21 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (WINDOW_RESOURCE, TERM_WINDOW_RESOURCE): Remove macros.
- [USE_MAC_TSM] (mac_handle_text_input_event): Remove unused variable
- `mapped_modifiers'.
- (XTread_socket) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1020]: Use Keyboard
- Layout Services routines to get current Unicode keyboard layout.
-
-2007-02-20 Chong Yidong <[email protected]>
-
- * frame.c (x_set_screen_gamma): Apply gamma value to the frame's
- bgcolor.
-
-2007-02-19 Kim F. Storm <[email protected]>
-
- * minibuf.c (Fassoc_string): Allow symbols as keys.
-
- * w32term.c (w32_set_scroll_bar_thumb): Don't resize scroll-bar
- handle while dragging, except when we get close to eob.
- Fix position and size calculations so we don't scroll backwards
- just by clicking on the handle.
-
-2007-02-17 YAMAMOTO Mitsuharu <[email protected]>
-
- * Makefile.in (${emacsapp}Contents/Resources/Emacs.rsrc)
- [HAVE_CARBON]: Remove target.
- (macosx-app) [HAVE_CARBON]: Don't depend on it.
-
-2007-02-17 Juanma Barranquero <[email protected]>
-
- * callproc.c (syms_of_callproc) <doc-directory>:
- <configure-info-directory>:
- (Fgetenv_internal): Fix typos in docstrings.
-
- * doc.c (Fsubstitute_command_keys): Fix typo in docstring.
-
-2007-02-16 Andreas Schwab <[email protected]>
-
- * frame.c (Fmodify_frame_parameters): Return a value.
-
- * editfns.c (Fformat): Add support for '+' flag.
- * doprnt.c (doprnt1): Likewise. Fix overflow checking.
-
-2007-02-14 Chong Yidong <[email protected]>
-
- * s/umips.h: Unused file removed.
-
-2007-02-14 Juanma Barranquero <[email protected]>
-
- * xfaces.c (Fcolor_distance): Don't continue checking a color for
- errors after it has been correctly parsed as an RGB list.
-
-2007-02-14 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (do_ewmh_fullscreen): Also check for _NET_WM_STATE_FULLSCREEN.
-
-2007-02-13 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (Fx_focus_frame): Move current process to foreground if
- it is not.
- [TARGET_API_MAC_CARBON] (Fx_file_dialog): Replace #if MAC_OSX with
- #ifdef MAC_OSX.
- (Fmac_set_font_panel_visible_p) [USE_MAC_FONT_PANEL]: Rename from
- Fmac_set_font_panel_visibility. All uses changed. Rename argument
- VISIBLE to FLAG.
-
- * macterm.c (MakeMeTheFrontProcess) [MAC_OSX]: Remove function.
- (mac_initialize) [MAC_OSX]: Call SetFrontProcess instead of
- MakeMeTheFrontProcess.
-
-2007-02-12 Chong Yidong <[email protected]>
-
- * frame.c (x_set_screen_gamma): Clear face cache.
-
-2007-02-11 Juanma Barranquero <[email protected]>
-
- * buffer.c (Fgenerate_new_buffer_name, Fbuffer_modified_tick):
- Reflow docstrings.
-
-2007-02-10 Eli Zaretskii <[email protected]>
-
- * window.c (Fwindow_height, Fwindow_hscroll)
- (Fwindow_redisplay_end_trigger, Fwindow_point, Fwindow_start)
- (Fwindow_end, Fwindow_display_table, Fwindow_text_height):
- Document the effect of WINDOW arg being nil.
-
-2007-02-08 Kim F. Storm <[email protected]>
-
- * minibuf.c (read_minibuf): Fix 2007-01-30 change.
- Use Qlambda as interim value of Vminibuffer_completing_file_name.
- (Fcompleting_read): Use non-filename maps if value is Qlambda (or Qnil).
- (syms_of_minibuf) <minibuffer-completing-file-name>: Document lambda.
-
-2007-02-07 Juanma Barranquero <[email protected]>
-
- * makefile.w32-in ($(TRES)): Use literal "../nt/emacs.rc" instead
- of $(ALL_DEPS).
-
-2007-02-07 Eli Zaretskii <[email protected]>
-
- * makefile.w32-in ($(TRES)): Depend on stamp_BLD, since $(TRES) is
- put into $(BLD).
-
-2007-02-06 Chong Yidong <[email protected]>
-
- * frame.c (Fmodify_frame_parameters): Don't bind
- Qinhibit_default_face_x_resources, which has no effect.
- (Qinhibit_default_face_x_resources): Symbol deleted.
-
-2007-02-03 Eli Zaretskii <[email protected]>
-
- * indent.c (Fmove_to_column): Document that the argument COLUMN is
- taken from prefix numeric argument.
-
-2007-02-03 Juanma Barranquero <[email protected]>
-
- * lread.c (syms_of_lread) <load-history>: Doc fix.
-
-2007-01-29 Andreas Seltenreich <[email protected]> (tiny change)
-
- * xterm.c [!USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_expose):
- Use the foreground color of the scroll-bar face when drawing
- the scroll-bar's border.
-
-2007-02-02 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (do_ewmh_fullscreen): Check that what != NULL before
- calling wm_supports.
-
-2007-02-01 Juanma Barranquero <[email protected]>
-
- * lread.c (syms_of_lread) <user-init-file>: Doc fix.
- Wording by Eli Zaretskii.
-
-2007-01-31 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): Initialize h/vmargin to 0.
-
-2007-01-30 Richard Stallman <[email protected]>
-
- * minibuf.c (read_minibuf):
- Save and clear Vminibuffer_completing_file_name.
- (read_minibuf_unwind): Restore it.
- (Vminibuffer_completion_table, Qminibuffer_completion_table)
- (Vminibuffer_completion_predicate, Qminibuffer_completion_predicate)
- (Vminibuffer_completion_confirm, Qminibuffer_completion_confirm)
- (Vminibuffer_completing_file_name): Definitions moved up.
-
-2007-01-29 Chong Yidong <[email protected]>
-
- * m/hp800.h: Restore, removing HP-UX support.
-
-2007-01-29 Jan Dj,Ad(Brv <[email protected]>
-
- * Makefile.in: Use a variable, XFT_LIBS, instead #define LIB_X11_LIB.
-
-2007-01-28 Richard Stallman <[email protected]>
-
- * minibuf.c (Ftry_completion, Fall_completions)
- (Fcompleting_read, Ftest_completion):
- Rename arg ALIST or TABLE to COLLECTION.
-
-2007-01-27 Chong Yidong <[email protected]>
-
- * unexhp9k800.c: Remove due to lack of legal papers.
-
- * m/sr2k.h, m/hp800.h: Remove due to dependence on above.
-
-2007-01-27 Eli Zaretskii <[email protected]>
-
- * keyboard.c (Fthis_command_keys, Fthis_command_keys_vector): Doc fix.
-
- * minibuf.c (Fcompleting_read): Doc fix.
-
-2007-01-26 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_initialize): Call XftInit if HAVE_XFT.
-
- * Makefile.in: Use XFT_LIBS if defined.
-
-2007-01-26 YAMAMOTO Mitsuharu <[email protected]>
-
- * alloc.c (BLOCK_INPUT_ALLOC, UNBLOCK_INPUT_ALLOC): Use
- BLOCK_INPUT/UNBLOCK_INPUT.
-
- * blockinput.h (interrupt_input_blocked): Declare volatile.
-
- * keyboard.c (interrupt_input_blocked): Declare volatile.
-
- * syssignal.h (SIGNAL_THREAD_CHECK): Use pthread_equal.
-
-2007-01-24 Kim F. Storm <[email protected]>
-
- * keymap.c (describe_map): Don't consider prefix keys to be shadowed.
-
-2007-01-23 Juanma Barranquero <[email protected]>
-
- * editfns.c (Finsert_char): Doc fix.
- (Fget_internal_run_time, Fdecode_time): Fix typos in docstrings.
-
-2007-01-22 YAMAMOTO Mitsuharu <[email protected]>
-
- * macselect.c [TARGET_API_MAC_CARBON] (mac_do_receive_drag):
- Don't pass keyboard modifiers to mac_store_drag_event, but put
- them as kEventParamKeyModifiers Apple event parameter.
-
-2007-01-21 Chong Yidong <[email protected]>
-
- * xdisp.c (try_window): Revert previous change.
-
- * dispnew.c (update_text_area): Revert 2006-09-17 change.
- Always redraw non-mode-line rows with mouse-face.
-
-2007-01-20 Chong Yidong <[email protected]>
-
- * xdisp.c (try_window): Clear mouse-face highlights first.
-
- * window.c (set_window_buffer): Revert 2006-11-22 change.
-
-2007-01-20 Eli Zaretskii <[email protected]>
-
- * .gdbinit (ppt, xtype, xmisctype, xint, xptr, xmarker, xframe)
- (xbuffer, xcons, xcar, xcdr): Fix doc strings.
-
-2007-01-20 Chong Yidong <[email protected]>
-
- * keyboard.c (read_key_sequence): Extract local map only if the
- given position is in an accessible buffer region.
-
-2007-01-19 Nick Roberts <[email protected]>
-
- * .gdbinit: Reformat documentation so that first sentence
- displays properly with "help user-defined" (like apropos).
-
-2007-01-18 Bruno Haible <[email protected]> (tiny change)
-
- * epaths.in: Move PATH_DOC from local/info to local/share/info.
-
-2007-01-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (create_and_show_dialog) [TARGET_API_MAC_CARBON]:
- Create movable modal window instead of movable alert window.
- (create_and_show_dialog) [!MAC_OSX]: Use DeactivateControl instead
- of DisableControl.
-
- * macselect.c (Fmac_resume_apple_event): Set error number when
- descriptor type of reply is non-null.
-
-2007-01-14 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (create_and_show_dialog) [TARGET_API_MAC_CARBON]:
- Use DisableControl for disabled items. Set default button to first
- enabled one. Use icon of application in execution.
-
-2007-01-13 Eli Zaretskii <[email protected]>
-
- * process.c (Fdelete_process, Fprocess_id, sigchld_handler):
- Copy PID into EMACS_INT to avoid GCC warnings.
-
- * fns.c (maybe_resize_hash_table): Copy new size of hash table
- into EMACS_INT to avoid GCC warnings.
-
- * editfns.c (Fuser_uid, Fuser_real_uid): Copy values returned by
- geteuid and getuid into EMACS_INT to avoid GCC warnings.
-
- * dired.c (Ffile_attributes): Fix last change.
-
-2007-01-12 Eli Zaretskii <[email protected]>
-
- * dired.c (Ffile_attributes): Copy some members of `struct stat'
- into int's to avoid GCC warnings about limited range of short in
- arguments to FIXNUM_OVERFLOW_P.
-
-2007-01-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (HAVE_DIALOGS): Define if TARGET_API_MAC_CARBON.
- (mac_handle_dialog_event, install_dialog_event_handler)
- (create_and_show_dialog) [TARGET_API_MAC_CARBON]: New functions.
- (DIALOG_LEFT_MARGIN, DIALOG_TOP_MARGIN, DIALOG_RIGHT_MARGIN)
- (DIALOG_BOTTOM_MARGIN, DIALOG_MIN_INNER_WIDTH)
- (DIALOG_MAX_INNER_WIDTH, DIALOG_BUTTON_BUTTON_HORIZONTAL_SPACE)
- (DIALOG_BUTTON_BUTTON_VERTICAL_SPACE, DIALOG_BUTTON_MIN_WIDTH)
- (DIALOG_TEXT_MIN_HEIGHT, DIALOG_TEXT_BUTTONS_VERTICAL_SPACE)
- (DIALOG_ICON_WIDTH, DIALOG_ICON_HEIGHT, DIALOG_ICON_LEFT_MARGIN)
- (DIALOG_ICON_TOP_MARGIN) [TARGET_API_MAC_CARBON]: New macros.
- (mac_dialog) [TARGET_API_MAC_CARBON]: Remove function.
- (mac_dialog_show) [TARGET_API_MAC_CARBON]: Use create_and_show_dialog.
-
- * macterm.c (x_free_frame_resources) [USE_CG_DRAWING]:
- Call mac_prepare_for_quickdraw.
- (quit_char, make_ctrl_char) [TARGET_API_MAC_CARBON]: Move externs
- outside #ifdef MAC_OSX.
- (mac_quit_char_key_p) [TARGET_API_MAC_CARBON]: Move function
- outside #ifdef MAC_OSX.
- (mac_check_bundle) [MAC_OSX]: Remove unused function.
-
- * macterm.h (mac_quit_char_key_p): Move extern outside #ifdef MAC_OSX.
- (HOURGLASS_WIDTH, HOURGLASS_HEIGHT): Parenthesize definitions.
-
-2007-01-11 Jan Dj,Ad(Brv <[email protected]>
-
- * alloc.c (BLOCK_INPUT_ALLOC, UNBLOCK_INPUT_ALLOC): Use pthread_equal,
- block/unblock SIGIO.
-
-2007-01-10 Stefan Monnier <[email protected]>
-
- * editfns.c (Fformat): Allow integer-format to work with floats of size
- larger than most-positive-fixnum (but still smaller than MAXINT).
-
- * dired.c (Ffile_attributes): Use floats for large uids/gids.
-
-2007-01-09 Eli Zaretskii <[email protected]>
-
- * emacs.c (syms_of_emacs) <path-separator>: Doc fix.
-
-2007-01-09 YAMAMOTO Mitsuharu <[email protected]>
-
- * callproc.c (Fcall_process_region) [HAVE_MKSTEMP]: Add BLOCK_INPUT
- around mkstemp.
-
- * image.c (XDrawLine) [MAC_OS]: Remove macro.
- (XCreateGC_pixmap) [!HAVE_NTGUI]: Likewise.
- (x_disable_image) [!HAVE_NTGUI]: Use XCreateGC instead of
- XCreateGC_pixmap.
-
- * macgui.h (Display): Typedef to opaque type.
-
- * macmenu.c (mac_dialog_modal_filter) [MAC_OSX]: New function.
- (Fx_popup_dialog) [MAC_OSX]: Use standard alert if called from
- Fmessage_box, Fyes_or_no_p, or Fy_or_n_p.
- [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030] (menu_quit_handler):
- Use mac_quit_char_key_p.
-
- * macterm.c (XDrawLine): Rename from mac_draw_line_to_pixmap.
- (XCreateGC): Change type of 2nd argument to void *.
- (XFreeGC) [USE_CG_DRAWING && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
- Fix last change.
- (mac_to_emacs_modifiers): Change return type to int.
- [USE_CARBON_EVENTS] (mac_event_to_emacs_modifiers): Likewise.
- (mac_mapped_modifiers): New function.
- (XTread_socket): Use it.
- [USE_TSM] (mac_handle_text_input_event): Likewise.
- (do_window_update) [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw.
- (mac_quit_char_modifiers, mac_quit_char_keycode) [MAC_OSX]:
- Remove variables.
- (mac_determine_quit_char_modifiers, init_quit_char_handler)
- [MAC_OSX]: Remove functions.
- (make_ctrl_char) [MAC_OSX]: Add extern.
- (mac_quit_char_key_p) [MAC_OSX]: New function.
- (mac_initialize) [MAC_OSX]: Don't call init_quit_char_handler.
-
- * macterm.h (FONT_MAX_WIDTH): Remove unused macro.
- (XCreateGC): Change type in extern.
- (XDrawLine): Rename from mac_draw_line_to_pixmap.
- (mac_quit_char_key_p) [MAC_OSX]: Add extern.
-
-2007-01-08 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c (init_keyboard): Initialize interrupt_input_blocked and
- interrupt_input_pending.
-
- * xterm.h (x_display_info): New: net_supported_atoms,
- nr_net_supported_atoms and net_supported_window.
-
- * xterm.c (last_user_time): New variable.
- (handle_one_xevent): Set last_user_time from events that have Time.
- Set net_supported_window to 0 when reparented.
- (wm_supports): New function.
- (do_ewmh_fullscreen): Use wm_supports to check for _NET_WM_STATE.
- (x_term_init): Initialize net_supported_atoms, nr_net_supported_atoms
- and net_supported_window.
-
-2007-01-05 Kim F. Storm <[email protected]>
-
- * indent.c (Fvertical_motion): Fix it overshoot check for overlay
- strings without embedded newlines immediately followed by newline.
-
-2007-01-05 YAMAMOTO Mitsuharu <[email protected]>
-
- * editfns.c (Fformat_time_string, Fdecode_time, Fencode_time)
- (Fcurrent_time_string, Fcurrent_time_zone): Add BLOCK_INPUT around
- gmtime/localtime/emacs_memftimeu/mktime.
-
- * mac.c (Fmac_set_file_creator): Use MAC_EMACS_CREATOR_CODE
- instead of 'EMAx'.
- [!MAC_OSX] (sys_open, sys_creat, sys_fopen): Likewise.
-
- * macgui.h (struct _XGC) [USE_CG_DRAWING
- && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: New members cg_fore_color
- and cg_back_color.
-
- * macmenu.c (Vshow_help_function) [TARGET_API_MAC_CARBON]: Add extern.
- (restore_show_help_function, menu_target_item_handler)
- [TARGET_API_MAC_CARBON]: New functions.
- (install_menu_target_item_handler): New function.
- (add_menu_item) [TARGET_API_MAC_CARBON]: Set help string as menu
- item property.
-
- * macterm.c (CG_SET_FILL_COLOR_MAYBE_WITH_CGCOLOR)
- (CG_SET_FILL_COLOR_WITH_GC_FOREGROUND)
- (CG_SET_FILL_COLOR_WITH_GC_BACKGROUND)
- (CG_SET_STROKE_COLOR_MAYBE_WITH_CGCOLOR)
- (CG_SET_STROKE_COLOR_WITH_GC_FOREGROUND): New macros.
- (mac_cg_color_space_rgb) [USE_CG_DRAWING]: New variable.
- (mac_cg_color_black) [USE_CG_DRAWING
- && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: New variable.
- (init_cg_color) [USE_CG_DRAWING]: New function.
- (mac_draw_line, mac_draw_rectangle) [USE_CG_DRAWING]: Use
- CG_SET_STROKE_COLOR_WITH_GC_FOREGROUND instead of CG_SET_STROKE_COLOR.
- (mac_erase_rectangle, mac_clear_window, mac_draw_cg_image)
- (mac_fill_rectangle, mac_draw_image_string_cg) [USE_CG_DRAWING]:
- Use CG_SET_FILL_COLOR_WITH_GC_FOREGROUND or
- CG_SET_FILL_COLOR_WITH_GC_BACKGROUND instead of CG_SET_FILL_COLOR.
- (mac_draw_string_common) [MAC_OSX && USE_ATSUI]: Likewise.
- (XCreateGC, XFreeGC, XSetForeground, XSetBackground) [USE_CG_DRAWING
- && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: Use gc->cg_fore_color and/or
- gc->cg_back_color.
- (install_drag_handler, remove_drag_handler): Make extern.
- (install_menu_target_item_handler): Add extern.
- (install_window_handler): Call install_menu_target_item_handler.
- [MAC_OS8] (main): Use MAC_EMACS_CREATOR_CODE instead of 'EMAx'.
- (mac_initialize) [USE_CG_DRAWING]: Call init_cg_color.
-
- * macterm.h (MAC_EMACS_CREATOR_CODE): New enumerator.
-
-2007-01-04 Juanma Barranquero <[email protected]>
-
- * window.c (Fwindow_end): Fix use of >= operator.
-
-2007-01-03 Richard Stallman <[email protected]>
-
- * window.c (Fwindow_end): Check BUF_OVERLAY_MODIFF like BUF_MODIFF.
-
-2007-01-02 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.h (xg_menu_item_cb_data_): Remove highlight_id and
- unhighlight_id.
-
- * gtkutil.c (menuitem_highlight_callback): Invoked widget is the
- parent of the menu item. Get menu item widget from event.
- (xg_create_one_menuitem, xg_update_menu_item): highlight_id and
- unhighlight_id has been removed.
- (create_menus): Connect enter/leave-notify-event to the menu instead
- of individual items.
-
-2006-12-31 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): Connect create-menu-proxy with
- xg_tool_bar_menu_proxy.
- (xg_tool_bar_menu_proxy): New function.
- (xg_tool_bar_proxy_callback): New function.
-
-2006-12-30 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_tool_bar_button_cb): Save last modifier on widget.
- (xg_tool_bar_callback): Remove check for button.
- (update_frame_tool_bar): Put an event box in the tool bar and a button
- in the event box. Attach enter/leave-notify-event to the event box.
-
-2006-12-30 Richard Stallman <[email protected]>
-
- * keymap.c (Fdefine_key): Doc fix.
-
-2006-12-29 Kim F. Storm <[email protected]>
-
- * frame.h (struct frame): New member minimize_tool_bar_window_p.
-
- * xdisp.c (auto_resize_tool_bars_p): Replace with ...
- (Vauto_resize_tool_bars): ... this.
- (syms_of_xdisp): DEFVAR_LISP and initialize it. Update doc string
- to describe new value `grow-only', and use of C-l.
- (display_tool_bar_line): Only use default face for border below
- toolbar if not grow-only (to get acceptable visual appearence).
- Explicitly set visible_height for empty toolbar lines.
- (redisplay_tool_bar): Handle `grow-only' setting. Check and clear
- minimize_tool_bar_window_p flag.
-
- * window.c (Frecenter): Set minimize_tool_bar_window_p flag
- when called without arg to redraw with minimum toolbar height.
- Update doc string.
-
-2006-12-29 Jason Rumney <[email protected]>
-
- * s/ms-w32.h (tzname): Do not define in msvc8.
- (utime): Do not define in msvc8.
-
- * regex.c (regerror): Change parameter name err_code.
-
-2006-12-26 Richard Stallman <[email protected]>
-
- * search.c (Fsearch_forward): Doc fix.
-
- * callint.c (Finteractive): Doc fix.
-
-2006-12-25 Kim F. Storm <[email protected]>
-
- * s/ms-w32.h (BROKEN_DATAGRAM_SOCKETS): Define it.
-
-2006-12-23 Eli Zaretskii <[email protected]>
-
- * keyboard.c (some_mouse_moved): Fix last change.
-
-2006-12-22 Eli Zaretskii <[email protected]>
-
- * callproc.c (syms_of_callproc) <shell-file-name>: Doc fix.
-
-2006-12-22 Mark Davies <[email protected]>
-
- * m/amdx86-64.h, m/hp800.h: Add support for NetBSD.
- * m/sh3el.h: New file.
-
-2006-12-22 Eli Zaretskii <[email protected]>
-
- * makefile.w32-in (emacs, temacs): Depend on stamp_BLD instead of
- $(BLD).
- ($(OBJ0) $(OBJ1) $(WIN32OBJ)): New dependency on stamp_BLD.
- (bootstrap-temacs): Pass $(XMFLAGS) to sub-make.
- ($(OBJ0) $(OBJ1) $(WIN32OBJ)): Add lastfile.$(O) and firstfile.$(O).
- (clean): Delete stamp_BLD.
-
-2006-12-22 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (mac_update_title_bar) [TARGET_API_MAC_CARBON]:
- Call mac_update_proxy_icon also when buffer modification flag changed.
- [TARGET_API_MAC_CARBON] (mac_update_proxy_icon): Don't update alias,
- but compare FSRef/FSSpec of resolved alias.
-
-2006-12-21 Kim F. Storm <[email protected]>
-
- * w32.c (_sys_wait_accept): Fix handle leak.
-
-2006-12-20 Jan Dj,Ad(Brv <[email protected]>
-
- * sound.c: Include <alsa/asoundlib.h> if ALSA_SUBDIR_INCLUDE is
- defined.
-
-2006-12-20 Kim F. Storm <[email protected]>
-
- * s/ms-w32.h (BROKEN_NON_BLOCKING_CONNECT): Define it.
-
-2006-12-19 Juanma Barranquero <[email protected]>
-
- * keyboard.c (syms_of_keyboard) <double-click-time>:
- * mac.c (Fmac_code_convert_string):
- * search.c (Fsearch_forward): Doc fixes.
-
-2006-12-19 Kim F. Storm <[email protected]>
-
- Rework 2006-12-04 change. A SIGUSR1 (SIGUSR2) signal now generates
- a sigusr1 event instead of [signal usr1] sequence, and signal events
- are now supposed to be handled via special-event-map.
-
- * keyboard.c (kbd_buffer_store_event_hold): Undo 2006-12-04 change.
- (make_lispy_event): Don't generate Qsignal prefix for code 0.
- Abort if signal code is unknown.
- (store_user_signal_events): Don't make Qsignal prefix (code 0).
- (Qsignal): Move declaration back to process.c.
- (syms_of_keyboard): Don't intern or staticpro it here.
-
- * process.c (Qsignal): Declare here.
- (syms_of_process): Intern or staticpro it.
-
- * emacs.c (main): Rename user signals to sigusr1 and sigusr2.
-
- * .gdbinit: Pass on SIGUSR1 and SIGUSR2 to Emacs.
-
-2006-12-19 Juanma Barranquero <[email protected]>
-
- * buffer.c (syms_of_buffer) <buffer-display-table>:
- <scroll-up-aggressively, scroll-down-aggressively>: Doc fixes.
-
-2006-12-17 Richard Stallman <[email protected]>
-
- * fileio.c (Fread_file_name_internal): Pass Vread_file_name_predicate
- to Ffile_name_completion.
-
- * dired.c (file_name_completion): New arg PREDICATE. Some cleanup.
- (Ffile_name_completion): New arg PREDICATE.
-
-2006-12-17 Juanma Barranquero <[email protected]>
-
- * buffer.c (Fkill_buffer): Doc fix.
- (syms_of_buffer) <kill-buffer-query-functions>: Doc fix.
-
-2006-12-16 Juanma Barranquero <[email protected]>
-
- * minibuf.c (Ftry_completion): Check that obarray buckets are symbols.
-
-2006-12-16 Eli Zaretskii <[email protected]>
-
- * w32fns.c (w32-window-exists-p): New function.
- (syms_of_w32fns): Defsubr it.
-
- * prefix-args.c [STDC_HEADERS]: Include stdlib.h.
-
-2006-12-16 Juanma Barranquero <[email protected]>
-
- * minibuf.c (Ftry_completion): Use `check_obarray' if ALIST is a vector.
-
-2006-12-15 Eli Zaretskii <[email protected]>
-
- * emacs.c (USAGE3): Clarify documentation of --color.
-
-2006-12-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (wakeup_from_rne_enabled_p) [TARGET_API_MAC_CARBON]:
- New variable.
- (ENABLE_WAKEUP_FROM_RNE, DISABLE_WAKEUP_FROM_RNE): New macros.
- [!MAC_OSX] (select): Use them.
- [MAC_OSX] (select_and_poll_event, sys_select): Likewise.
- (mac_wakeup_from_rne) [TARGET_API_MAC_CARBON]: New function.
-
- * macfns.c (mac_atsu_font_face_attributes) [USE_ATSUI]: Add extern.
- (Fmac_atsu_font_face_attributes) [USE_ATSUI]: New function.
- (syms_of_macfns) [USE_ATSUI]: Defsubr it.
-
- * macselect.c [TARGET_API_MAC_CARBON] (mac_do_receive_drag):
- Use mac_wakeup_from_rne instead of mac_post_mouse_moved_event.
-
- * macterm.c (mac_query_char_extents) [USE_ATSUI]: Don't call
- ATSUGetGlyphBounds if not necessary.
- (Vmac_atsu_font_table) [USE_ATSUI]: Remove variable.
- (syms_of_macterm) [USE_ATSUI]: Don't defvar it.
- (fm_get_style_from_font, atsu_find_font_from_family_name)
- (atsu_find_font_family_name, mac_atsu_font_face_attributes)
- [USE_ATSUI]: New functions.
- (init_font_name_table) [USE_ATSUI]: Use atsu_find_font_family_name.
- (mac_load_query_font) [USE_ATSUI]: Use atsu_find_font_from_family_name.
- Don't get metrics for Latin-1 right half characters.
- (mac_load_query_font): Don't load font if space width is not positive.
- [TARGET_API_MAC_CARBON] (mac_store_event_ref_as_apple_event):
- Use mac_wakeup_from_rne instead of mac_post_mouse_moved_event.
- (XTread_socket): Call SelectWindow when unfocused frame is clicked.
-
- * macterm.h (mac_wakeup_from_rne) [TARGET_API_MAC_CARBON]: Add extern.
-
-2006-12-15 Kim F. Storm <[email protected]>
-
- * keyboard.c (ignore_mouse_drag_p): New global var.
- (some_mouse_moved): Return 0 if it is non-zero.
- (make_lispy_event): Generate click event on mouse up if
- ignore_mouse_drag_p is non-zero, even if mouse moved.
- Clear ignore_mouse_drag_p on mouse down/up.
-
- * xdisp.c (redisplay_window): Set ignore_mouse_drag_p if tool-bar
- is resized to avoid generating a mouse drag event.
-
-2006-12-14 Juanma Barranquero <[email protected]>
-
- * w32fns.c (w32_wnd_proc): Force non-tooltip frames to respect the
- minimum tracking size. Remove non-working old hack to do the same.
-
-2006-12-14 YAMAMOTO Mitsuharu <[email protected]>
-
- * emacs.c (handle_user_signal): Move function to keyboard.c.
- (main): Use add_user_signal for SIGUSR1 and SIGUSR2.
-
- * keyboard.c (make_lispy_event): Use find_user_signal_name.
- (read_avail_input): Store pending user signal events.
- (struct user_signal_info): New struct.
- (user_signals): New variable.
- (add_user_signal, store_user_signal_events)
- (find_user_signal_name): New functions.
- (handle_user_signal): Move function from emacs.c. Don't store
- USER_SIGNAL_EVENT here, but increment number of pending signals.
-
- * keyboard.h (add_user_signals): Add extern.
-
-2006-12-11 Juanma Barranquero <[email protected]>
-
- * buffer.c (syms_of_buffer) <cursor-in-non-selected-windows>:
- <default-scroll-up-aggressively, default-scroll-down-aggressively>:
- <line-spacing, left-margin>: Doc fixes.
-
- * xdisp.c (syms_of_xdisp) <mode-line-inverse-video>: Doc fix.
-
-2006-12-10 Kim F. Storm <[email protected]>
-
- * xdisp.c (show_mouse_face): Never use text cursor in tool-bar.
-
-2006-12-10 Juanma Barranquero <[email protected]>
-
- * abbrev.c (syms_of_abbrev) <last-abbrev-text>:
- * buffer.c (syms_of_buffer) <default-major-mode>:
- * keymap.c (Flookup_key):
- * lread.c (Feval_buffer, Feval_region):
- * macterm.c (syms_of_macterm) <x-use-underline-position-properties>:
- <x-underline-at-descent-line, mac-emulate-three-button-mouse>:
- * marker.c (Fmarker_insertion_type):
- * minibuf.c (syms_of_minibuf) <minibuffer-completion-table>:
- * msdos.c (syms_of_msdos) <delete-exited-processes>:
- * w32term.c (syms_of_w32term) <x-use-underline-position-properties>:
- <x-underline-at-descent-line>:
- * xdisp.c (format-mode-line):
- * xterm.c (syms_of_xterm) <x-use-underline-position-properties>:
- <x-underline-at-descent-line>: Doc fixes.
-
-2006-12-10 Andreas Schwab <[email protected]>
-
- * systime.h (EMACS_GET_TIME): Remove check for
- HAVE_STRUCT_TIMEZONE which is never defined.
-
-2006-12-10 Alan Mackenzie <[email protected]>
-
- * syntax.c (Fpartial_parse_sexp): Correct Docco: Elt 8 of the
- result is now neither the last elt nor optional for OLDSTATE.
-
-2006-12-09 Eli Zaretskii <[email protected]>
-
- * process.c (Fsignal_process): Doc fix. Use XFLOAT_DATA to
- extract the process ID from a Lisp float.
-
-2006-12-09 Chong Yidong <[email protected]>
-
- * xterm.c (XTframe_raise_lower): Comment out _NET_ACTIVE_WINDOW code.
-
-2006-12-08 Eli Zaretskii <[email protected]>
-
- * frame.h (PIX_TYPE): Redefine as `unsigned long', for 64-bit
- platforms where long is 64-bit.
-
- * msdos.h (PIX_TYPE): Redefine as `unsigned long'.
-
-2006-12-08 NAKAJI Hiroyuki <[email protected]> (tiny change)
-
- * m/amdx86-64.h: Add support for Solaris 10 on x86-64.
-
-2006-12-08 Kenichi Handa <[email protected]>
-
- * xterm.c (x_query_font): Use xstricmp instead off strcasecmp.
-
-2006-12-08 Juanma Barranquero <[email protected]>
-
- * emacs.c (syms_of_emacs) <system-type>: Doc fix.
-
-2006-12-07 Kim F. Storm <[email protected]>
-
- * process.c (parse_signal): Use xstricmp instead of strcasecmp.
- (Fsignal_process): Don't use strncasecmp.
-
-2006-12-05 Glenn Morris <[email protected]>
-
- * abbrev.c (Qforce): New Lisp_Object.
- (Fdefine_abbrev): Do not overwrite non-system abbrevs with system
- abbrevs, unless 'force is applied.
- (syms_of_abbrev): Add Qforce.
-
-2006-12-04 Kim F. Storm <[email protected]>
-
- * process.c (parse_signal): Rename macro from handle_signal.
- (Fsignal_process): Also accept lower-case variants of signal
- names (to align with signal names generated by Emacs itself).
-
- * emacs.c (handle_USR1_signal, handle_USR2_signal): Replace by...
- (handle_user_signal): ... this, which generates two USER_SIGNAL_EVENTs
- first with code == 0 [signal] and one with code == sig number.
- (main): Use it as handler for SIGUR1 and SIGUSR2.
-
- * keyboard.c (kbd_buffer_store_event_hold): Don't throw-on-input
- if first event in [signal xxx] sequence.
- (lispy_user_signals, Qusr1_signal, Qusr2_signal): Remove.
- (syms_of_keyboard): Don't intern and staticpro them.
- (Qsignal): Declare here.
- (syms_of_keyboard): Intern and staticpro it.
- (make_lispy_event): Use it. Intern symbols on the fly for other
- USER_SIGNAL_EVENTs events.
-
- * process.c (Qsignal): Declare extern.
- (syms_of_process): Don't intern/staticpro it here.
-
- * process.c (read_process_output): Abort if carryover < 0.
-
-2006-12-04 YAMAMOTO Mitsuharu <[email protected]>
-
- * config.in: Regenerate.
-
- * fileio.c [__NetBSD__]: Don't define `unix'.
- (Funix_sync, syms_of_fileio): Use `#ifdef HAVE_SYNC' instead of
- `#ifdef unix'.
-
-2006-12-04 Glenn Morris <[email protected]>
-
- * Makefile.in (version): New variable, set by configure.
- (bootstrapclean, mostlyclean): Also remove emacs-${version}.
-
-2006-12-03 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): Handle modifying a toolbar item
- without an image.
-
-2006-12-01 Eli Zaretskii <[email protected]>
-
- * w32fns.c (Fw32_shell_execute): Doc fix.
-
-2006-11-30 Chong Yidong <[email protected]>
-
- * xdisp.c (move_it_to): Correctly count tab glyphs for continued
- lines ending in tab.
-
-2006-11-30 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_raise_frame): Move setting of _NET_ACTIVE_WINDOW
- property ...
- (XTframe_raise_lower): ... to here.
-
-2006-11-30 Kenichi Handa <[email protected]>
-
- * regex.c (regex_compile): Fix previous change.
-
-2006-11-29 Juanma Barranquero <[email protected]>
-
- * sound.c (Fplay_sound_internal): Remove spurious newline in docstring.
-
-2006-11-28 Chong Yidong <[email protected]>
-
- * config.in: Regenerate.
-
-2006-11-28 Kenichi Handa <[email protected]>
-
- * regex.c (regex_compile): Don't call SET_LIST_BIT with a
- multibyte character.
-
-2006-11-27 Chong Yidong <[email protected]>
-
- * s/aix4-2.h: Undefine _NO_PROTO. Suggested by Joe Buehler.
-
-2006-11-27 Kim F. Storm <[email protected]>
-
- * window.c (set_window_buffer): Refactor recent changes.
-
-2006-11-27 Jason Rumney <[email protected]>
-
- * w32term.c (w32_msg_worker): Declare correctly.
- (w32_initialize): Don't cast w32_msg_worker.
-
- * w32fns.c (w32_msg_worker): Define as WINAPI and arg as void pointer.
-
-2006-11-26 Chong Yidong <[email protected]>
-
- * m/amdx86-64.h: Look for standard libs in /usr/lib64 only if that
- directory exists.
-
-2006-11-25 Eli Zaretskii <[email protected]>
-
- * w16select.c (Fw16_set_clipboard_data): Fix the call to sit_for
- as per the calling sequence change on 2006-07-11.
-
-2006-11-25 Chong Yidong <[email protected]>
-
- * window.c (set_window_buffer): Use BLOCK_INPUT.
-
-2006-11-24 Juanma Barranquero <[email protected]>
-
- * fns.c (substring_both): Add missing address operator.
-
-2006-11-24 Stefan Monnier <[email protected]>
-
- * fns.c: Use AREF/ASIZE macros.
- (concat): Provide the full ANSI prototype.
-
-2006-11-24 Juanma Barranquero <[email protected]>
-
- * buffer.c (syms_of_buffer) <buffer-undo-list>: Doc fix.
-
-2006-11-23 William Smith <[email protected]> (tiny change)
-
- * strftime.c (HAVE_SYS__MBSTATE_T_H): Fix typo.
-
-2006-11-22 Alfred M. Szmidt <[email protected]> (tiny change)
-
- * s/openbsd.h (LD_SWITCH_SYSTEM): Remove /usr/pkg/lib and
- /usr/pkg/lib from the library search path.
- (LD_SWITCH_X_DEFAULT): New macro.
-
-2006-11-22 Chong Yidong <[email protected]>
-
- * window.c (set_window_buffer): Clear mouse highlight if it is in
- this window.
-
-2006-11-21 Chong Yidong <[email protected]>
-
- * xfaces.c (realize_default_face): Check if the default font name
- exists on this display before trying to use it.
-
-2006-11-21 Richard Stallman <[email protected]>
-
- * fileio.c: Break line before &&, not after.
-
-2006-11-20 Eli Zaretskii <[email protected]>
-
- * fns.c (concat) [!__GNUC__]: Add prototype.
-
-2006-11-20 Kenichi Handa <[email protected]>
-
- * fileio.c (Fread_file_name_internal): Use SBYTES (not SCHARS) to
- check the tailing slash of a filename.
-
-2006-11-20 KOBAYASHI Yasuhiro <[email protected]> (tiny change)
-
- * indent.c (Fvertical_motion): Include composition in the case of
- overshoot expected.
-
-2006-11-19 Andreas Schwab <[email protected]>
-
- * xfaces.c (Fdisplay_supports_face_attributes_p): Initialize supports.
-
- * xmenu.c (Fx_popup_menu): Initialize selection.
-
-2006-11-18 Andreas Schwab <[email protected]>
-
- * s/gnu-linux.h (GC_MARK_SECONDARY_STACK): Update call to mark_memory.
-
-2006-11-17 Tetsurou Okazaki <[email protected]> (tiny change)
-
- * xterm.c (do_ewmh_fullscreen): Declare variable before XSETFRAME
- to avoid gcc 2.96 error.
-
-2006-11-17 NIIMI Satoshi <[email protected]> (tiny change)
-
- * search.c (simple_search): In the loop of backward searching,
- check also the byte position against the limit.
-
-2006-11-14 Romain Francoise <[email protected]>
-
- * minibuf.c (Fcompleting_read): Fix typo in docstring.
-
-2006-11-14 Kenichi Handa <[email protected]>
-
- * coding.c (code_convert_region): Initialize coding->heading_ascii.
- (decode_coding_string, code_convert_region): Likewise.
-
-2006-11-14 YAMAMOTO Mitsuharu <[email protected]>
-
- * config.in: Regenerate.
-
- * macfns.c (Fx_display_mm_height, Fx_display_mm_width)
- [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
- && MAC_OS_X_VERSION_MIN_REQUIRED == 1020]: Check if
- CGDisplayScreenSize is available.
-
- * macmenu.c (menu_quit_handler, install_menu_quit_handler):
- Replace `#ifdef HAVE_CANCELMENUTRACKING' with
- `#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1030'.
- (install_menu_quit_handler) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
- && MAC_OS_X_VERSION_MIN_REQUIRED == 1020]: Check if
- CancelMenuTracking is available.
-
- * macterm.c [USE_CG_TEXT_DRAWING] (mac_draw_image_string_cg)
- [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
- && MAC_OS_X_VERSION_MIN_REQUIRED == 1020]: Check if
- CGContextShowGlyphsWithAdvances is available.
-
-2006-11-13 Jason Rumney <[email protected]>
-
- * s/ms-w32.h: Define HAVE_INET_SOCKETS.
-
-2006-11-13 Nozomu Ando <[email protected]>
-
- * alloc.c (mark_memory): New argument OFFSET. All uses changed.
- Fix address calculations for case END < START.
- (mark_stack): Impose Lisp_Object alignment on jmp_buf.
-
-2006-11-12 Juanma Barranquero <[email protected]>
-
- * coding.c (Fencode_sjis_char, Fencode_big5_char):
- Improve argument/docstring consistency.
-
- * editfns.c (Fmessage): Doc fixes.
-
- * process.c (syms_of_process) <delete-exited-processes>: Doc fix.
-
-2006-11-12 Chong Yidong <[email protected]>
-
- * xmenu.c (popup_activated): Define outside HAVE_MENUS.
-
-2006-11-12 Romain Francoise <[email protected]>
-
- * xselect.c (selection-coding-system): Fix docstring.
-
-2006-11-12 Juanma Barranquero <[email protected]>
-
- * category.c (Fchar_category_set): Improve arg/docstring consistency.
-
- * data.c (Flogxor):
- * fns.c (Frandom, Flength, Fsafe_length, Fstring_bytes)
- (Fstring_equal, Fcompare_strings, Fstring_lessp, Fcopy_sequence)
- (Fstring_make_unibyte): Fix typos in docstrings.
-
-2006-11-10 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h (struct x_display_info): Fix indentation.
-
- * xterm.c (do_ewmh_fullscreen, XTfullscreen_hook): New functions.
- (x_check_fullscreen): Call do_ewmh_fullscreen.
- (x_initialize): Set fullscreen_hook to XTfullscreen_hook.
-
- * frame.c (x_set_fullscreen): Call fullscreen_hook if set.
-
- * term.c: Define fullscreen_hook.
- (syms_of_term): Initialize fullscreen_hook to NULL.
-
- * termhooks.h: Add fullscreen_hook.
-
-2006-11-08 Juanma Barranquero <[email protected]>
-
- * bytecode.c (Fbyte_code):
- * data.c (Fmakunbound): Use SYMBOL_CONSTANT_P macro.
-
-2006-11-06 Juanma Barranquero <[email protected]>
-
- * lread.c (syms_of_lread):
- * xsmfns.c (syms_of_xsmfns): Fix typo in docstring.
-
-2006-11-06 Martin Rudalics <[email protected]>
-
- * macmenu.c (Fmenu_or_popup_active_p): Define outside HAVE_MENUS.
-
- * w32menu.c (Fmenu_or_popup_active_p): Define outside HAVE_MENUS.
- Return nil if building without menus.
-
- * xmenu.c (Fmenu_or_popup_active_p): Define outside HAVE_MENUS.
- Return nil if building without menus.
-
-2006-11-05 Mark Davies <[email protected]> (tiny change)
-
- * s/netbsd.h (POSIX_SIGNALS): Define.
-
-2006-11-05 Martin Rudalics <[email protected]>
-
- * macmenu.c (Fmenu_or_popup_active_p): New function.
- (syms_of_macmenu): Defsubr it.
-
- * w32menu.c (Fmenu_or_popup_active_p): New function.
- (syms_of_w32menu): Defsubr it.
- (popup_activated_flag, popup_activated): Remove.
-
- * xdisp.c (note_mouse_highlight) [HAVE_NTGUI]: Don't bother to
- check popup_activated.
-
- * xmenu.c (Fmenu_or_popup_active_p): New function.
- (syms_of_xmenu): Defsubr it.
-
-2006-11-05 YAMAMOTO Mitsuharu <[email protected]>
-
- * unexmacosx.c (malloc_cookie): Remove unused variable.
- (region_list_head, region_list_tail, lca, nlc, infile_lc_highest_addr)
- (text_seg_lowest_offset, mh, curr_header_offset, infd, outfd)
- (emacs_zone, data_segment_old_fileoff, data_segment_scp)
- (num_unexec_regions, unexec_regions): Make variables static.
- (print_regions, find_emacs_zone_regions): Make static.
- (unexec_region_info): New typedef.
- (unexec_regions): Change type from vm_range_t[] to unexec_region_info[].
- All uses changed.
- (unexec_regions_recorder): Subtract size of trailing null pages from
- filesize. Show filesize.
- (unexec_regions_merge): Don't merge if null pages of preceding region
- is not too small. Use long format in printf.
- (copy_segment, copy_data_segment): Show filesize.
- (copy_data_segment): Write filesize bytes of region data.
- Adjust filesize in segment command accordingly.
- (dump_it): Use long format in printf.
-
-2006-11-05 Juanma Barranquero <[email protected]>
-
- * dosfns.c (Finsert_startup_screen):
- * fns.c (Ffeaturep, syms_of_fns):
- * frame.c (syms_of_frame): Fix typos in docstrings.
-
- * unexcw.c (unexec): Fix typo in output message.
-
-2006-11-04 Ralf Angeli <[email protected]>
-
- * w32fns.c (w32_createwindow): Remove code for handling -geometry
- command line option and `initial-frame-alist' which is superfluous
- after the last change to `w32_createwindow'.
-
-2006-11-04 Slawomir Nowaczyk <[email protected]> (tiny change)
-
- * w32proc.c (sys_wait): Only wait for processes with fd<0.
- Others should be handled by sys_select instead. Fixes problems
- with (progn (start-process "" nil "ls") (call-process "ls")).
-
-2006-11-04 Giorgos Keramidas <[email protected]> (tiny change)
-
- * xmenu.c (Fmenu_bar_open): Declare variable before BLOCK_INPUT to
- avoid gcc 2.95 error.
-
-2006-11-04 Chong Yidong <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): If icon image is invalid and
- wicon is null, insert an empty button.
-
-2006-11-03 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_raise_frame): Send _NET_ACTIVE_WINDOW when raising the
- window.
-
-2006-11-02 Juanma Barranquero <[email protected]>
-
- * emacs.c (Fkill_emacs): Fix typo in docstring.
-
-2006-11-02 Nozomu Ando <[email protected]>
-
- * unexmacosx.c (mach_header, segment_command, vm_region, section)
- [_LP64]: New defines.
- (VM_REGION_BASIC_INFO_COUNT, VM_REGION_BASIC_INFO, LC_SEGMENT)
- (MH_MAGIC) [_LP64]: Redefine.
- (delta): Remove variable.
- (curr_file_offset, pagesize): New variables.
- (ROUNDUP_TO_PAGE_BOUNDARY): New macro.
- (data_segment_old_fileoff): Initialize explicitly.
- (print_region, unexec_regions_recorder, print_load_command_name)
- (copy_segment, copy_data_segment): Use long format in printf.
- (MAX_UNEXEC_REGIONS): Increase to 400.
- (unexec_regions_recorder): Don't warn too many regions here.
- (find_emacs_zone_regions): Warn too many regions here.
- (print_load_command_name) [_LP64]: Show correct load command name.
- (copy_segment, copy_data_segment): Use variable `curr_file_offset'.
- Show starting virtual memory address. Don't show ending file offset.
- (copy_symtab, copy_dysymtab, copy_twolevelhints): New argument DELTA.
- (dump_it): Use new local variable `linkedit_delta' and pass to them.
- Error if trying to handle multiple DATA segments.
- (unexec): Initialize variable `pagesize'.
-
-2006-11-01 Juanma Barranquero <[email protected]>
-
- * eval.c (Fcatch): Doc fix.
-
-2006-10-31 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c [MAC_OS] (image_load_qt_1, xpm_scan, xpm_make_color_table_v)
- (xpm_put_color_table_v, xpm_get_color_table_v, xpm_make_color_table_h)
- (xpm_put_color_table_h, xpm_get_color_table_h, xpm_str_to_color_key)
- (xpm_load_image): Add const qualifier to arguments.
- [MAC_OS] (xpm_color_key_strings): Make static const.
-
- * mac.c (create_apple_event_from_event_ref)
- (create_apple_event_from_drag_ref, skip_white_space, parse_comment)
- (parse_include_file, parse_binding, parse_component)
- (parse_resource_name, parse_value, parse_resource_line)
- (xrm_merge_string_database, xrm_get_resource)
- (xrm_get_preference_database): Add const qualifier to arguments.
- [MAC_OSX] (sys_select): Make variable `context' static const.
-
- * macfns.c (mac_color_map): Make static const.
- (mac_color_map_lookup): Add const qualifier to arguments.
-
- * macmenu.c (install_menu_quit_handler): Make variable `typesList'
- static const.
- (name_is_separator): Add const qualifier to arguments.
-
- * macselect.c (init_service_handler): Make variable `specs' static
- const.
-
- * macterm.c (mac_create_bitmap_from_bitmap_data): Make variable
- `swap_nibbles' static const.
- (atsu_get_text_layout_with_text_ptr): Make variables `lengths',
- `tags', `sizes', `values' static const.
- (mac_draw_string_common): Make variables `context' static.
- Make variables `tags', `sizes', and `values' static const.
- (pcm_get_status, x_detect_focus_change, x_scroll_bar_handle_click)
- (xlfdpat_create, xlfdpat_block_match_1, xlfdpat_match)
- (mac_to_x_fontname, parse_x_font_name, add_mac_font_name)
- (mac_do_list_fonts, is_fully_specified_xlfd, do_grow_window)
- (mac_store_event_ref_as_apple_event, mac_make_rdb): Add const
- qualifier to arguments.
- (xlfd_scalable_fields, keycode_to_xkeysym_table)
- (fn_keycode_to_keycode_table): Make static const.
- (mac_load_query_font): Make variables `tags', `sizes', `values',
- `types', and `selectors' static const.
- (mac_handle_command_event, mac_handle_window_event):
- Make variables `names' and `types' static const.
- (init_command_handler, install_window_handler): Make variables
- `specs*' static const.
- (mac_handle_font_event, mac_handle_text_input_event)
- (mac_store_service_event): Make variables `names' and `types'
- const. Make variables `names_*' and `types_*' static const.
-
- * macterm.h (create_apple_event_from_event_ref)
- (create_apple_event_from_drag_ref, xrm_merge_string_database)
- (xrm_get_resource, xrm_get_preference_database): Add const
- qualifier to arguments in externs.
-
-2006-10-31 Kenichi Handa <[email protected]>
-
- * xfns.c (xic_create_xfontset): Fix previous change.
-
-2006-10-30 Chong Yidong <[email protected]>
-
- * s/openbsd.h (LD_SWITCH_SYSTEM): Add /usr/pkg/lib and
- /usr/pkg/lib to library search path.
-
-2006-10-29 Mark Davies <[email protected]> (tiny change)
-
- * ralloc.c (relinquish): Use a long for excess space counter to
- handle 64-bit case correctly.
-
-2006-10-29 Jeramey Crawford <[email protected]>
-
- * m/amdx86-64.h: Add defines for OpenBSD x86-64.
-
-2006-10-29 Juanma Barranquero <[email protected]>
-
- * window.c (Fdisplay_buffer): Fix typo in docstring.
-
-2006-10-27 Ben North <[email protected]> (tiny change)
-
- * w32term.c (x_draw_glyph_string_foreground): Set background mode
- to TRANSPARENT before using overstrike to simulate bold faces.
-
- * xfaces.c (best_matching_font): Fix logic to decide whether to
- use overstriking to simulate bold-face (it was reversed).
-
-2006-10-23 Kim F. Storm <[email protected]>
-
- * xdisp.c (remember_mouse_glyph): Do nothing if glyphs are not
- initialized.
-
- * keyboard.c (read_char): Make an element (t . EVENT) in
- unread-command-events add EVENT to the current command's key sequence.
- (syms_of_keyboard) <unread-command-events>: Update doc.
-
-2006-10-21 Richard Stallman <[email protected]>
-
- * minibuf.c (Vread_expression_map): Define here.
- (Qread_expression_history): New variable.
- (syms_of_minibuf): Initialize them.
- (Feval_minibuffer): Use Vread_expression_map and
- Qread_expression_history.
-
-2006-10-21 Kenichi Handa <[email protected]>
-
- * xfns.c (xic_create_fontsetname): If ADSTYLE field is not a wild
- card, change it to "*".
- (xic_create_xfontset): Call XCreateFontSet for each single
- fontname in fontsetname.
-
-2006-10-19 Chong Yidong <[email protected]>
-
- * callint.c (callint_message): Convert to a Lisp string.
- (syms_of_callint): Initialize it.
- (callint_message_size): Var deleted.
- (Fcall_interactively): Use Fformat instead of doprnt to construct
- prompt string.
-
-2006-10-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * xdisp.c (display_mode_line): Clear enabled_p flag on mode-line row.
-
-2006-10-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (Vmac_carbon_version_string) [TARGET_API_MAC_CARBON]:
- New variable.
- (syms_of_macfns) [TARGET_API_MAC_CARBON]: Defvar it.
-
-2006-10-19 Jan Dj,Ad(Brv <[email protected]>
-
- * xselect.c (x_handle_selection_request): If the converted_selection
- is nil or XCDR (converted_selection) is nil, decline the request.
-
-2006-10-16 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (get_utf8_string): Remove warnings with casts.
- (xg_tool_bar_button_cb): Ditto.
- (xg_tool_bar_callback): Ditto.
-
-2006-10-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * dispnew.c (adjust_frame_glyphs_for_frame_redisplay): Remove unused
- variable ch_dim.
- (adjust_frame_glyphs_for_window_redisplay): Likewise. Don't allocate
- menu bar window matrices on non-X systems.
-
- * mac.c (Fmac_get_preference, Fmac_code_convert_string): Add GCPROs.
-
- * macterm.c (mac_query_char_extents): Don't return glyph ID if layout
- adjustment is needed.
- (mac_load_query_font): Check if width and height are positive.
-
-2006-10-14 Richard Stallman <[email protected]>
-
- * sysdep.c (init_sys_modes): Delete DEFVAR_LISP in the wrong place.
-
-2006-10-13 Chong Yidong <[email protected]>
-
- * xdisp.c (decode_mode_spec): Ignore %c and %l constructs in frame
- title.
-
-2006-10-12 Chong Yidong <[email protected]>
-
- * keymap.c (Fkey_binding): Check Lisp_Object types before doing
- XCAR and XINT.
-
-2006-10-12 Romain Francoise <[email protected]>
-
- * image.c (xbm_read_bitmap_data): Delete extra semicolon.
-
-2006-10-10 Stefan Monnier <[email protected]>
-
- * eval.c: Include xterm.h for x_fully_uncatch_errors and friends.
-
- * dispextern.h: Declare x_create_bitmap_from_xpm_data.
-
- * xterm.c (x_check_expected_move): Remove unused var `count'.
-
- * xmenu.c (syms_of_xmenu): Use Ffset rather than Fdefalias, since
- Fdefalias is not declared in any *.h file.
-
-2006-10-09 Chong Yidong <[email protected]>
-
- * dispnew.c (sit_for): Sit forever if TIMEOUT is t.
-
- * keyboard.c (command_loop_1): Handle non-number values of
- `minibuffer-message-timeout'.
- (Fexecute_extended_command): Fix typo.
-
- * minibuf.c (temp_echo_area_glyphs): Sit for
- `minibuffer-message-timeout' seconds.
-
-2006-10-08 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_draw_image_string, mac_draw_image_string_16):
- Add argument OVERSTRIKE_P.
- (mac_draw_string_common, mac_draw_image_string_cg): Likewise.
- Support overstrike.
- (mac_draw_string, mac_draw_string_16): Remove functions.
- (x_draw_glyph_string_foreground): Use overstrike when needed.
- (x_draw_composite_glyph_string_foreground): Likewise.
- Use mac_draw_image_string_16 instead of mac_draw_string_16.
- (mac_load_query_font): Rename from XLoadQueryFont. Take argument
- F instead of DPY. All uses changed. Don't save/restore font.
-
-2006-10-07 Ralf Angeli <[email protected]>
-
- * w32fns.c (w32_createwindow): Honour left and top positions if
- supplied explicitly.
-
-2006-10-06 Kim F. Storm <[email protected]>
-
- * xdisp.c (pos_visible_p): Fix value when EOB is visible.
-
-2006-10-05 Chong Yidong <[email protected]>
-
- * frame.c (Qinhibit_face_set_after_frame_default): New var.
- (syms_of_frame): Initialize it.
- (x_set_frame_parameters): Avoid resetting :font attributes to the
- new-frame defaults.
-
-2006-10-03 Stefan Monnier <[email protected]>
-
- * lisp.h (clear_regexp_cache): Declare.
-
- * search.c (compile_pattern): Only check `cp->syntax_table' if needed.
- (compile_pattern_1): Remember `used_syntax' in `cp->syntax_table'.
- (clear_regexp_cache): Only flush those regexps which depend on
- a syntax-table.
-
- * regex.c (regex_compile): Set the new `used_syntax' bit.
-
- * regex.h: Remove file local variables.
- (struct re_pattern_buffer): New field `used_syntax'.
-
-2006-10-03 Kim F. Storm <[email protected]>
-
- * process.c (list_processes_1): Run sentinels before removing dead
- processes. Also remove `closed' network connections.
-
-2006-10-01 Stefan Monnier <[email protected]>
-
- * xdisp.c (handle_fontified_prop): Don't fontify at EOB.
-
-2006-09-30 Eli Zaretskii <[email protected]>
-
- * config.in: Regenerated.
-
-2006-09-29 Juri Linkov <[email protected]>
-
- * buffer.c (syms_of_buffer): Reorder coding systems in the
- docstring of %z to the real order displayed in the modeline.
-
-2006-09-28 Stefan Monnier <[email protected]>
-
- * keymap.c (Fdefine_key): Yet another int/Lisp_Object mixup (YAILOM).
-
-2006-09-26 Chong Yidong <[email protected]>
-
- * indent.c (Fvertical_motion): Do move back if the Lisp string
- being displayed contains newlines.
-
-2006-09-26 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_compute_glyph_string_overhangs, XLoadQueryFont)
- [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw before QDTextBounds.
-
-2006-09-26 Kenichi Handa <[email protected]>
-
- * keymap.c (Fsingle_key_description): For an invalid char, return
- "Invalid char code NNNNN".
-
-2006-09-25 Chong Yidong <[email protected]>
-
- * callint.c (Fcall_interactively): Doc fix.
-
-2006-09-25 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (x_underline_at_descent_line): New variable.
- (syms_of_macterm): DEFVAR_BOOL it.
- (x_draw_glyph_string): Use it.
- (XLoadQueryFont): Calculate min_bounds.descent and max_bounds.descent.
-
-2006-09-25 Kenichi Handa <[email protected]>
-
- * keymap.c (Fsingle_key_description): Return unique names for
- generic characters.
-
-2006-09-24 Richard Stallman <[email protected]>
-
- * search.c (compile_pattern_1): Don't BLOCK_INPUT.
-
-2006-09-24 Eli Zaretskii <[email protected]>
-
- * makefile.w32-in ($(BLD)/fns.$(O), $(BLD)/w32proc.$(O)):
- Depend on nt/inc/langinfo.h and nt/inc/nl_types.h.
-
- * w32proc.c (nl_langinfo): New function.
-
- * w32fns.c (w32-pass-alt-to-system, w32-alt-is-meta)
- (w32-pass-lwindow-to-system, w32-enable-num-lock)
- (w32-enable-caps-lock, w32-scroll-lock-modifier)
- (w32-lwindow-modifier, w32-rwindow-modifier)
- (w32-apps-modifier, w32-mouse-button-tolerance): Doc fix.
-
-2006-09-23 Juanma Barranquero <[email protected]>
-
- * minibuf.c (Finternal_complete_buffer, Fread_minibuffer)
- (Fdisplay_completion_list): Fix typos in docstrings.
-
-2006-09-23 Romain Francoise <[email protected]>
-
- * s/gnu-linux.h (MAIL_USE_FLOCK): Check for HAVE_LIBLOCKFILE too.
-
-2006-09-23 Kenichi Handa <[email protected]>
-
- * keymap.c (Fmap_keymap): Docstring mentions about generic character.
-
-2006-09-22 Stefan Monnier <[email protected]>
-
- * regex.c (analyse_first): For eight-bit-control chars, mark both the
- char's value and its leading byte in the fastmap.
- (re_search_2): When fast-scanning without translation, be careful to
- check that we only match the leading byte of a multibyte char.
-
- * charset.h (PREV_CHAR_BOUNDARY): Make it work from within a char's
- byte sequence.
- (AT_CHAR_BOUNDARY): New macro.
-
-2006-09-22 Kenichi Handa <[email protected]>
-
- * fns.c (optimize_sub_char_table): Don't optimize a sub-char-table
- whose default value is non-nil.
-
-2006-09-22 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_file_with_chooser): Only show C-l help for
- Gtk+ versions < 2.10.
-
- * xfns.c (syms_of_xfns): Fix typo in help text for
- x-gtk-file-dialog-help-text.
-
-2006-09-21 Kim F. Storm <[email protected]>
-
- * fns.c (Fmemq): Refill doc string.
- (Fmemql): New defun, like memq but using eql.
- (syms_of_fns): Defsubr it.
-
-2006-09-20 Kim F. Storm <[email protected]>
-
- * xdisp.c (pos_visible_p): CHARPOS < 0 means return info for
- last visible glyph in window.
-
- * window.c (Fset_window_hscroll, Fwindow_line_height):
- Doc fix. Use "off-window" instead of "off-screen".
- (Fpos_visible_in_window_p): Likewise.
- If POS is t, return info for last visible glyph in window.
-
-2006-09-19 Chong Yidong <[email protected]>
-
- * search.c (struct regexp_cache): New entry syntax_table.
- (compile_pattern_1): Set it.
- (syms_of_search): Initialize it.
- (compile_pattern): Require the syntax_table entry of the cache
- element to match the current syntax table entry.
-
-2006-09-19 Stefan Monnier <[email protected]>
-
- * window.c (Fwindow_end): Fix recent change.
-
-2006-09-19 Kim F. Storm <[email protected]>
-
- * window.c (Fset_window_hscroll, Fpos_visible_in_window_p):
- Doc fix. Use "off-screen" instead of "invisible".
- (Fwindow_line_height): Make line numbers 0-based. Make line arg
- optional; if nil, use current cursor row. Handle text terminals
- properly. Return nil if non-interactive or pseudo-window.
-
-2006-09-19 Stefan Monnier <[email protected]>
-
- * keymap.c: Include alloca.h if available.
- (Fkey_binding): Only use AREF after checking it's a vector.
- Remove unused var `window'.
-
-2006-09-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * emacs.c (shut_down_emacs) [!subprocesses]: Don't set
- inhibit_sentinels.
-
- * mac.c [!MAC_OSX] (select): Fix argument name.
-
- * macmenu.c (enum mac_menu_kind, min_menu_id): New enumerator and
- menu ID for Apple menu.
- (menubar_selection_callback): Remove function.
- (find_and_call_menu_selection): New function from xmenu.c.
- (x_activate_menubar): Use it.
- (set_frame_menubar): Don't use f->output_data.mac->menubar_active.
-
- * macterm.c (menubar_selection_callback): Remove extern.
- (M_APPLE): Change to 234.
- (do_apple_menu) [!TARGET_API_MAC_CARBON]: Make non-static.
- (do_menu_choice): Remove function.
-
- * macterm.h (struct mac_output): Remove member menubar_active.
- (do_menu_choice): Remove extern.
- (do_apple_menu) [!TARGET_API_MAC_CARBON]: Add extern.
-
-2006-09-18 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (syms_of_xfns): Rename x_gtk_show_chooser_help_text to
- x_gtk_file_dialog_help_text.
-
- * gtkutil.c (xg_uses_old_file_dialog): Rename x-use-old-gtk-file-dialog
- to x-gtk-use-old-file-dialog.
- (xg_get_file_with_chooser): Rename x_gtk_show_chooser_help_text to
- x_gtk_file_dialog_help_text.
-
- * xfns.c (syms_of_xfns): Ditto.
-
-2006-09-18 Kim F. Storm <[email protected]>
-
- * window.c (Fwindow_line_visibility): Remove.
- (Fwindow_line_height): New defun replacing it.
- (syms_of_window): Defsubr it.
-
-2006-09-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (SELECT_USE_CFSOCKET) [MAC_OSX]: Set default to 1.
- [MAC_OSX] (sys_select) [SELECT_USE_CFSOCKET]: Fix pointer type.
-
-2006-09-17 Jay Belanger <[email protected]>
-
- * gmalloc.c:
- * md5.c:
- * md5.h:
- * strftime.c: Replace "GNU Library General Public License" by "GNU
- General Public License" throughout.
-
-2006-09-17 Kim F. Storm <[email protected]>
-
- * dispnew.c (update_text_area): Undo 2000-07-18 change.
- Always redrawing whole row if line has mouse-face in it causes
- excessive flickering of the mode line.
-
-2006-09-17 Chong Yidong <[email protected]>
-
- * search.c (clear_regexp_cache): New function.
-
- * syntax.c (Fmodify_syntax_entry): Clear regexp cache.
-
-2006-09-16 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_file_with_chooser):
- Check x-gtk-show-chooser-help-text before adding the help text.
-
- * xfns.c (syms_of_xfns): New variable: x-gtk-show-chooser-help-text.
-
- * gtkutil.c (get_utf8_string): Try harder to convert to UTF8. Gtk+
- will simply crash if we fail.
-
-2006-09-16 Richard Stallman <[email protected]>
-
- * regex.c (re_compile_pattern): Set gl_state.current_syntax_table.
-
-2006-09-15 Kim F. Storm <[email protected]>
-
- * window.c (Fwindow_line_visibility): New defun for line-move-partial.
- (syms_of_window): Defsubr it.
- (Fwindow_end): Use window's buffer rather than current buffer.
-
-2006-09-15 Jay Belanger <[email protected]>
-
- * COPYING: Replace "Library Public License" by "Lesser Public
- License" throughout.
-
-2006-09-15 David Kastrup <[email protected]>
-
- * Makefile.in (keymap.o): Add "keymap.h" and "window.h" dependencies.
-
- * keymap.c: include "window.h".
- (Fcommand_remapping): New optional POSITION argument.
- (Fkey_binding): New optional POSITION argument. Completely rework
- handling of mouse clicks to get the same order of keymaps as
- `read-key-sequence' and heed POSITION. Also temporarily switch
- buffers to location of mouse click and back.
-
- * keyboard.c (command_loop_1): Adjust call of `Fcommand_remapping'
- for additional argument.
- (parse_menu_item): Adjust call of `Fkey_binding' for additional
- argument.
- (read_key_sequence): If there are both `local-map' and `keymap'
- text properties at some buffer position, heed both.
-
- * keymap.h: Declare additional optional arguments of
- `Fcommand_remapping' and `Fkey_binding'.
-
-2006-09-15 Juanma Barranquero <[email protected]>
-
- * indent.c (Fcurrent_column, Findent_to): Fix typos in docstring.
-
-2006-09-14 Andreas Schwab <[email protected]>
-
- * print.c: Whitespace fixup.
-
-2006-09-14 Kim F. Storm <[email protected]>
-
- * xdisp.c (produce_image_glyph): Automatically crop wide images at
- right window edge so we can draw the cursor on the same row to
- avoid confusing redisplay by placing the cursor outside the visible
- window area.
-
-2006-09-13 YAMAMOTO Mitsuharu <[email protected]>
-
- * xterm.c (x_initialize): Don't install Xt event timer here.
- (x_timeout_atimer_activated_flag): New var.
- (x_activate_timeout_atimer): New function to install Xt timer.
- (x_send_scroll_bar_event, x_process_timeouts): Use it.
-
- * xmenu.c (x_menu_set_in_use, popup_activate_callback)
- (create_and_show_popup_menu, create_and_show_dialog): Use it.
-
- * xterm.h (x_activate_timeout_atimer): Add prototype.
-
-2006-09-13 Richard Stallman <[email protected]>
-
- * print.c (print_string): When printcharfun is t,
- copy string contents and call strout on the copy.
-
- * keyboard.c (read_char): If end_time specified, don't put the
- event into this_command_keys.
- (read_key_sequence): If Voverriding_terminal_local_map is specified,
- don't check Voverriding_local_map at all.
-
-2006-09-12 Stefan Monnier <[email protected]>
-
- * textprop.c (Fnext_property_change, Fnext_single_property_change)
- (Fprevious_property_change, Fprevious_single_property_change):
- Avoid changing limit, so we can correctly catch the case where the
- property is constant up to limit.
-
-2006-09-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (mac_window) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
- * macterm.c (XTread_socket) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
- Undo 2006-09-08 change.
-
-2006-09-11 Chong Yidong <[email protected]>
-
- * keymap.c (Fkey_binding): Use string position for string objects.
-
-2006-09-11 Kim F. Storm <[email protected]>
-
- * keymap.c (Fkey_binding): Fix last change.
-
- * editfns.c (Fmessage): Recommend using (message "%s" ...).
-
-2006-09-10 Chong Yidong <[email protected]>
-
- * keymap.c (Fkey_binding): Check for local keymap for mouse click
- events.
-
-2006-09-10 Kim F. Storm <[email protected]>
-
- * keyboard.c (Finput_pending_p): Check Vunread_input_method_events
- and Vunread_post_input_method_events.
-
- * dispnew.c (Fredisplay): Document return value.
-
-2006-09-10 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (Fx_close_connection): Call xg_display_close when USE_GTK.
-
- * gtkutil.c (xg_display_close): Always change default display if needed,
- check for < Gtk+ version 2.10 before calling gdk_display_close.
-
-2006-09-10 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c [MAC_OSX] (sys_select): Check argument `nfds' more rigidly.
- Make variable `ofds' static. Remove variable `maxfd'.
-
- * macfns.c (Fx_file_dialog): Remove unused variable `f'.
- Call check_mac.
-
- * macmenu.c (Vmenu_updating_frame, syms_of_macmenu):
- * w32menu.c (Vmenu_updating_frame, syms_of_w32menu):
- Apply 2006-09-08 change for xmenu.c.
-
- * xfns.c (Fx_file_dialog): Call check_x.
-
-2006-09-10 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_window_cursor_type): Use hollow cursor on
- non-transparent images.
-
-2006-09-09 Eli Zaretskii <[email protected]>
-
- * editfns.c (Fsystem_name): Mention "host" in the doc string.
- (syms_of_editfns) <system-name>: Likewise.
-
-2006-09-08 Martin Rudalics <[email protected]>
-
- * xdisp.c (mouse_autoselect_window): Remove.
- (Vmouse_autoselect_window): New variable. DEFVAR_LISP it.
-
- * dispextern.h (mouse_autoselect_window): Remove extern.
- (Vmouse_autoselect_window): Add extern.
-
- * macterm.c (XTread_socket): Test Vmouse_autoselect_window
- instead of mouse_autoselect_window.
-
- * msdos.c (dos_rawgetc): Likewise.
-
- * w32term.c (w32_read_socket): Likewise.
-
- * xterm.c (handle_one_xevent): Likewise.
-
-2006-09-08 Richard Stallman <[email protected]>
-
- * xdisp.c (Vmenu_updating_frame): Define here.
- (syms_of_xdisp): DEFVAR it here.
- (update_menu_bar): Always return hooks_run.
- Set Vmenu_updating_frame.
-
- * xdisp.c (redisplay_internal): Test Vinhibit_redisplay
- before calculating SELECTED_FRAME.
-
- * xmenu.c (Vmenu_updating_frame): Don't define here.
- (syms_of_xmenu): Don't DEFVAR it here.
-
- * xterm.c (x_error_quitter): For BadName error, just return.
-
- * eval.c (find_handler_clause): Give up on debugger if INPUT_BLOCKED_P.
-
- * casetab.c (init_casetab_once): Call set_case_table.
-
- * emacs.c (shut_down_emacs): Set inhibit_sentinels.
-
- * process.c (inhibit_sentinels): New variable.
- (exec_sentinel): Test inhibit_sentinels.
- (init_process): Initialize it.
-
- * process.h (inhibit_sentinels): Add decl.
-
- * search.c (looking_at_1, string_match_1, search_command):
- Make syntax table's canon table point to eqv table.
-
-2006-09-08 Andreas Schwab <[email protected]>
-
- * print.c (strout): Fix whitespace.
-
-2006-09-08 Kim F. Storm <[email protected]>
-
- * xterm.c (x_draw_glyph_string): Fix 2006-08-24 change.
-
-2006-09-08 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c [!MAC_OSX]: Don't include keyboard.h.
- [!MAC_OSX] (select): Try detect_input_pending before ReceiveNextEvent
- in the same BLOCK_INPUT block, in case that some input has already
- been read asynchronously. Pretend to be interrupted by a signal
- if some input is available.
- [MAC_OSX] (select_and_poll_event, sys_select): Likewise.
- (SELECT_POLLING_PERIOD_USEC) [SELECT_USE_CFSOCKET]: Change to 100000.
- Now used for ReceiveNextEvent timeout instead of select timeout.
- (EVENT_CLASS_SOCK) [SELECT_USE_CFSOCKET]: Remove macro.
- [SELECT_USE_CFSOCKET] (socket_callback): Add non-blocking connect
- support. Quit event loop.
- [MAC_OSX] (sys_select) [SELECT_USE_CFSOCKET]: Add non-blocking
- connect support. Reuse previously allocated CFRunLoopSource.
- (Fmac_process_hi_command) [TARGET_API_MAC_CARBON]: New function.
- (syms_of_mac) [TARGET_API_MAC_CARBON]: Defsubr it.
-
- * macfns.c (mac_window) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
- Specify kWindowAsyncDragAttribute.
-
- * macterm.c (mac_handle_origin_change, mac_handle_size_change)
- (mac_get_ideal_size): New functions.
- (x_set_offset, x_set_window_size, x_make_frame_visible)
- (do_zoom_window, mac_handle_window_event, XTread_socket): Use them.
- (install_window_handler, mac_handle_window_event)
- [USE_CARBON_EVENTS]: Handle kEventWindowGetIdealSize and
- kEventWindowBoundsChanged.
- (XTread_socket) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: Don't call
- DragWindow.
-
-2006-09-07 Andreas Schwab <[email protected]>
-
- * m/ibms390x.h (START_FILES, LIB_STANDARD): Override to
- use lib64 instead of lib.
-
-2006-09-06 Stefan Monnier <[email protected]>
-
- * Makefile.in: Avoid double quotes when possible.
-
-2006-09-06 Kenichi Handa <[email protected]>
-
- * editfns.c (Fformat_time_string): Use make_unibyte_string to make
- a Lisp string from the result of emacs_memftimeu call.
-
-2006-09-06 Kim F. Storm <[email protected]>
-
- * xdisp.c (pos_visible_p): Remove exact_mode_line_heights_p arg;
- so calculate heights even when pos-visible-in-window-p is called
- with partially = t. Don't overshoot last_visible_y in move_it_to.
- Return row height and row number in new rowh and vpos args.
- (cursor_row_fully_visible_p): First line is always "fully visible".
- (try_window): Don't clear matrix if vscrolled.
-
- * lisp.h (pos_visible_p): Update prototype.
-
- * window.c (Fpos_visible_in_window_p): Adapt to new pos_visible_p.
- Return row height and row number for partially visible rows.
- Modify return value to a 2 element list for fully visible rows and
- 6 for partially visible row.
- (window_scroll_pixel_based): Use pos_visible_p directly instead of
- Fpos_visible_in_window_p. Fix auto vscrolling for partially
- visible lines. Only vscroll backwards if already vscrolled
- forwards. Unconditionally vscroll forwards if PT is first (and
- only) line. Set new window start instead of scrolling at
- start/end of tall line.
-
-2006-09-05 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (install_window_handler, mac_handle_window_event)
- [USE_CARBON_EVENTS]: Handle kEventWindowClose.
- [USE_MAC_TSM] (mac_handle_text_input_event): Set modifiers for
- ASCII keystroke event.
-
-2006-09-04 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_file_with_chooser): Don't mention specific keys in
- the file chooser message. Only call gtk_file_chooser_set_current_name
- when action is SAVE.
-
-2006-09-04 Andreas Schwab <[email protected]>
-
- * Makefile.in: Double all single and back quotes in C-style
- comments to help fontifier.
-
-2006-09-03 Jason Rumney <[email protected]>
-
- * w32.c (shutdown_handler): New function to exit cleanly on shutdown.
- (globals_of_w32): Register it as a signal handler.
-
-2006-09-02 Juri Linkov <[email protected]>
-
- * marker.c (Fmarker_position): Doc fix.
-
-2006-09-03 Eli Zaretskii <[email protected]>
-
- * window.c (syms_of_window) <split-height-threshold>:
- <window-min-height, window-min-width>: Doc fix.
-
-2006-09-02 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_file_with_chooser): Change file chooser message
- for writing files. Call gtk_file_chooser_set_current_name to keep
- default filename.
-
- * minibuf.c (Finternal_complete_buffer): Move after DEFUN:s it calls.
-
-2006-09-02 Jindrich Makovicka <[email protected]> (tiny change)
-
- * fns.c (concat) [__GNUC__]: Declare with
- `__attribute__((noinline))'.
-
- * eval.c (apply1, call2) [__GNUC__]: Declare with
- `__attribute__((noinline))'.
-
-2006-09-02 Stuart D. Herring <[email protected]>
-
- * minibuf.c (Finternal_complete_buffer): New function.
- (syms_of_minibuf): Defsubr it.
- (Fread_buffer): Use it, instead of Vbuffer_alist.
-
-2006-09-01 Martin Rudalics <[email protected]>
-
- * buffer.h (struct buffer_text): New field chars_modiff.
- (CHARS_MODIFF, BUF_CHARS_MODIFF): New macros.
- * buffer.c (Fbuffer_chars_modified_tick): New function returning
- value of BUF_CHARS_MODIFF.
- (syms_of_buffer): Defsubr it.
- (Fget_buffer_create): Initialize BUF_CHARS_MODIFF.
- * insdel.c (modify_region): New argument preserve_chars_modiff.
- Set CHARS_MODIFF to MODIFF provided preserve_chars_modiff is zero.
- (insert_1_both, insert_from_string_1, insert_from_buffer_1)
- (adjust_after_replace, adjust_after_replace_noundo)
- (replace_range, replace_range_2, del_range_2): Reset CHARS_MODIFF.
- * lisp.h (modify_region): Add fourth argument in extern.
- * casefiddle.c (casify_region): Call modify_region with fourth
- argument zero to assert that CHARS_MODIFF is updated.
- * editfns.c (Fsubst_char_in_region, Ftranslate_region_internal)
- (Ftranspose_regions): Likewise.
- * textprop.c (Fadd_text_properties, Fset_text_properties)
- (Fremove_text_properties, Fremove_list_of_text_properties):
- Call modify_region with fourth argument 1 to avoid that
- CHARS_MODIFF is updated.
-
-2006-08-31 Richard Stallman <[email protected]>
-
- * editfns.c (Fformat): Don't sign-extend for %o or %x.
-
-2006-08-29 Chong Yidong <[email protected]>
-
- * indent.c (Fvertical_motion): Don't move back if we were
- displaying a Lisp string, either.
-
-2006-08-28 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_window_cursor_type) [!HAVE_WINDOW_SYSTEM]:
- Don't attempt to replace cursor on image glyphs.
-
-2006-08-28 Kenichi Handa <[email protected]>
-
- * coding.c (Fdetect_coding_region, Fdetect_coding_string):
- Fix docstring about ISO-2022 control characters.
-
-2006-08-28 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_window_cursor_type): Replace BOX cursor on images
- with a hollow box cursor if image is larger than 32x32 (or the default
- frame font if that is bigger). Replace any other cursor on images
- with hollow box cursor, as redisplay doesn't support bar and hbar
- cursors on images.
-
-2006-08-27 YAMAMOTO Mitsuharu <[email protected]>
-
- * alloc.c (BLOCK_INPUT_ALLOC, UNBLOCK_INPUT_ALLOC): Undo previous
- change. Move mutex lock/unlock operations inside BLOCK_INPUT.
-
- * dired.c (directory_files_internal_unwind, directory_files_internal)
- (file_name_completion): Add BLOCK_INPUT around opendir/closedir.
-
- * image.c [MAC_OS] (image_load_qt_1): Use ComponentResult instead
- of OSErr.
-
- * keyboard.c (in_sighandler): Remove variable.
- (Fcurrent_idle_time): Add missing `doc:'.
- (input_available_signal, init_keyboard): Undo previous change.
-
- * keyboard.h (in_sighandler): Remove extern.
-
- * mac.c (create_apple_event_from_event_ref, select)
- (Fmac_get_file_creator, Fmac_get_file_type, Fmac_set_file_creator)
- (Fmac_set_file_type, cfstring_create_normalized)
- (mac_get_system_locale, select_and_poll_event, sys_select):
- Use OSStatus instead of OSErr.
-
- * macfns.c [TARGET_API_MAC_CARBON] (mac_update_proxy_icon):
- Don't use FRAME_FILE_NAME. Use (FS)UpdateAlias.
- (Fx_create_frame): Apply 2006-07-03 for xfns.c.
-
- * macselect.c (get_scrap_from_symbol, clear_scrap, put_scrap_string)
- (put_scrap_private_timestamp, scrap_has_target_type, get_scrap_string)
- (get_scrap_private_timestamp, get_scrap_target_type_list)
- (x_own_selection, x_get_foreign_selection)
- (Fx_disown_selection_internal, Fx_selection_owner_p)
- (Fx_selection_exists_p): Use OSStatus instead of OSErr.
-
- * macterm.c (mac_draw_string_common, mac_query_char_extents)
- (x_iconify_frame, XLoadQueryFont, install_window_handler)
- (mac_handle_command_event, init_command_handler, init_menu_bar):
- Use OSStatus instead of OSErr.
- (x_free_frame_resources) [TARGET_API_MAC_CARBON]: Don't use
- FRAME_FILE_NAME.
- (x_query_font): Apply 2006-08-04 change for xterm.c.
- (Qhi_command): Rename from Qhicommand. All uses changed.
-
- * macterm.h (struct mac_output) [TARGET_API_MAC_CARBON]: Remove member
- file_name.
- (FRAME_FILE_NAME): Remove macro.
- (install_window_handler, create_apple_event_from_event_ref):
- Return OSStatus instead of OSErr.
-
-2006-08-26 Kim F. Storm <[email protected]>
-
- * buffer.c (Fset_buffer_multibyte):
- * editfns.c (Fcurrent_time, Fget_internal_run_time):
- * macfns.c (Fxw_color_values):
- * w32fns.c (Fxw_color_values):
- * xfns.c (Fxw_color_values): Simplify; use list3.
-
- * fileio.c (Fmake_directory_internal, Fdelete_directory)
- (Fdelete_file): Simplify; use list1.
- (Frename_file, Fadd_name_to_file, Fmake_symbolic_link):
- Simplify; remove NO_ARG_ARRAY stuff, use list2.
-
-2006-08-25 Richard Stallman <[email protected]>
-
- * buffer.c (Fswitch_to_buffer): Fix previous change.
-
-2006-08-25 Kim F. Storm <[email protected]>
-
- * keyboard.c (Fcurrent_idle_time): Simplify.
-
-2006-08-25 Richard Stallman <[email protected]>
-
- * fns.c (sxhash_string): Rotate properly; don't lose bits.
-
-2006-08-24 Francesc Rocher <[email protected]>
-
- * xdisp.c (overline_margin): New variable.
- (x_produce_glyphs): Use it.
- (syms_of_xdisp): DEFVAR_INT it.
-
- * xterm.c (x_underline_at_descent_line): New variable.
- (syms_of_xterm): DEFVAR_BOOL it.
- (x_draw_glyph_string): Use it.
- Draw underline and overline up to the end of line if the face
- extends to the end of line.
-
- * macterm.c: Likewise.
-
- * w32term.c: Likewise.
-
-2006-08-24 Nick Roberts <[email protected]>
-
- * buffer.c (Fswitch_to_buffer): Move buffer to front of
- buffer-alist if necessary.
-
-2006-08-22 Kim F. Storm <[email protected]>
-
- * xdisp.c (update_tool_bar): Redisplay toolbar also when only
- number of items changes.
-
-2006-08-22 Stefan Monnier <[email protected]>
-
- * buffer.c (Fset_buffer_multibyte): Record proper undo entry.
-
-2006-08-21 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c: Clarify difference between in_sighandler and
- handling_signal.
-
-2006-08-21 Kim F. Storm <[email protected]>
-
- * macterm.c (x_draw_stretch_glyph_string):
- * w32term.c (x_draw_stretch_glyph_string):
- * xterm.c (x_draw_stretch_glyph_string): It is ok to draw a
- stretch glyph in left marginal areas on header and mode lines.
-
-2006-08-21 Kenichi Handa <[email protected]>
-
- * keyboard.c (syms_of_keyboard): Docstring of
- Vunread_post_input_method_events and Vunread_input_method_events
- fixed.
-
-2006-08-20 Chong Yidong <[email protected]>
-
- * keyboard.c (show_help_echo): Preserve mouse movement flag if
- tracking mouse.
-
-2006-08-20 Richard Stallman <[email protected]>
-
- * xfaces.c (load_pixmap): Add quotes in error message.
-
- * keyboard.c (Fcurrent_idle_time): New function.
- (syms_of_keyboard): defsubr it.
-
-2006-08-18 Nick Roberts <[email protected]>
-
- * window.c (Fset_window_fringes): Do nothing on a tty.
- (Fwindow_fringes): Put ? operator after the line break.
-
-2006-08-16 Andreas Schwab <[email protected]>
-
- * print.c (debug_output_compilation_hack): Fix return type.
-
-2006-08-16 Richard Stallman <[email protected]>
-
- * print.c (debug_output_compilation_hack): New function.
-
-2006-08-16 Kenichi Handa <[email protected]>
-
- * fileio.c (choose_write_coding_system): Use LF for end-of-line
- in auto-saving.
-
-2006-08-15 Chong Yidong <[email protected]>
-
- * keyboard.c (read_char): Don't change idle timer state at all if
- end_time is supplied.
-
-2006-08-15 Kenichi Handa <[email protected]>
-
- * coding.c (ONE_MORE_BYTE_CHECK_MULTIBYTE): New arg RET. If SRC
- is exhausted, return with RET.
- (detect_coding_emacs_mule, detect_coding_iso2022)
- (detect_coding_sjis, detect_coding_big5, detect_coding_utf_8)
- (detect_coding_utf_16, detect_coding_ccl): Adjusted for the above
- change.
-
-2006-08-14 Chong Yidong <[email protected]>
-
- * keyboard.c (read_char): Don't reset idle timers if a time limit
- is supplied.
-
-2006-08-14 Kim F. Storm <[email protected]>
-
- * .gdbinit (pitx): Print iterator position.
- Limit stack dump in case iterator is not initialized.
-
-2006-08-12 Eli Zaretskii <[email protected]>
-
- * frame.c (Fmouse_position, Fmouse_pixel_position)
- (Fset_mouse_position, Fset_mouse_pixel_position): Doc fix.
-
-2006-08-11 Jan Dj,Ad(Brv <[email protected]>
-
- * xselect.c (Fx_register_dnd_atom): New function.
- (syms_of_xselect): Defsubr it.
- (x_handle_dnd_message): Check that message_type is in
- dpyinfo->x_dnd_atoms before generating lisp event.
-
- * xterm.h (struct x_display_info): Add x_dnd_atoms* to keep track
- of drag and drop Atoms.
-
- * xterm.c (x_term_init): Initialize dpyinfo->x_dnd_atoms*.
-
-2006-08-10 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c: Define in_sighandler.
- (input_available_signal): Set in_sighandler.
- (init_keyboard): Initialize in_sighandler.
-
- * keyboard.h: Declare in_sighandler.
-
- * alloc.c (UNBLOCK_INPUT_ALLOC, BLOCK_INPUT_ALLOC): Use in_sighandler
- to check if mutex should be locked or not.
-
-2006-08-09 Richard Stallman <[email protected]>
-
- * keyboard.c (keyremap_step): No-op if fkey->parent = nil.
- (read_key_sequence): Always start fkey.start and fkey.end at 0,
- and likewise for keytran.
-
-2006-08-09 Kenichi Handa <[email protected]>
-
- * coding.c (syms_of_coding): Improve the docstring
- of file-coding-system-alist.
-
-2006-08-07 Andreas Schwab <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 1120000.
-
-2006-08-06 Chong Yidong <[email protected]>
-
- * buffer.c (Vchange_major_mode_hook, Qchange_major_mode_hook): New vars.
- (Fkill_all_local_variables): Use it.
- (syms_of_buffer): Defvar it.
-
-2006-08-05 Eli Zaretskii <[email protected]>
-
- * w32.c (w32_valid_pointer_p): New function.
-
- * w32.h: Add prototype for w32_valid_pointer_p.
-
- * alloc.c: Include w32.h.
- (valid_lisp_object_p) [WINDOWSNT]: Call w32_valid_pointer_p to do
- the job.
-
- * keyboard.c (kbd_buffer_get_event): Return Qnil when current time
- is exactly equal to end_time, not only when it is past that.
-
-2006-08-04 Chong Yidong <[email protected]>
-
- * keyboard.c (read_char): Rebalance specpdl after receiving jump.
-
- * process.c: Reapply 2006-08-01 change.
-
-2006-08-04 Eli Zaretskii <[email protected]>
-
- * w32fns.c (w32_query_font): Fix last change: use stricmp.
-
-2006-08-04 Stefan Monnier <[email protected]>
-
- * editfns.c (Fsubst_char_in_region): Redo the setup work after running
- the before-change-functions since they may have altered the buffer.
-
-2006-08-04 Ralf Angeli <[email protected]>
-
- * w32fns.c (w32_createwindow): Handle -geometry command line option
- and the geometry settings in the Registry.
-
-2006-08-04 Kenichi Handa <[email protected]>
-
- * w32fns.c (w32_query_font): Compare names by ignoring case.
-
- * xterm.c (x_query_font): Compare names by ignoring case.
-
-2006-08-03 Jason Rumney <[email protected]>
-
- * w32menu.c (w32_menu_show, w32_dialog_show): Call Fsignal to quit
- when no option selected.
-
-2006-08-03 Chong Yidong <[email protected]>
-
- * process.c: Revert last change.
-
-2006-08-01 Kim F. Storm <[email protected]>
-
- * process.c (wait_reading_process_output_unwind): New function.
- Restores waiting_for_user_input_p to saved value.
- (wait_reading_process_output): Unwind protect waiting_for_user_input_p
- instead of save/restore old value on stack.
-
-2006-07-30 Thien-Thi Nguyen <[email protected]>
-
- * editfns.c: Undo 2006-06-27 change.
-
-2006-07-29 Eli Zaretskii <[email protected]>
-
- * coding.c (Ffind_operation_coding_system): Revert the change from
- 2006-05-29.
-
- * alloc.c [WINDOWSNT]: Include fcntl.h, to fix last change.
-
-2006-07-28 Richard Stallman <[email protected]>
-
- * xfaces.c (lookup_named_face, Fdisplay_supports_face_attributes_p):
- Add conditional aborts for clarity.
-
- * xdisp.c (update_menu_bar): New arg HOOKS_RUN. Callers changed.
- Used to avoid running the hooks over and over for each frame.
- (prepare_menu_bars): Pass value from update_menu_bar
- as HOOKS_RUN of next call.
-
- * keyboard.c (safe_run_hooks_1): Don't crash if Vrun_hooks is nil.
-
-2006-07-28 Kim F. Storm <[email protected]>
-
- * alloc.c (valid_pointer_p): New function (from valid_lisp_object_p).
- (valid_lisp_object_p): Use it to check for valid SUBRP obj.
-
-2006-07-26 Chong Yidong <[email protected]>
-
- * keyboard.c (read_char): New arg END_TIME specifying timeout.
- All callers changed. Turn off echoing if END_TIME is non-NULL.
- (kbd_buffer_get_event): New arg END_TIME.
-
- * lread.c (read_filtered_event): New arg SECONDS to wait until.
- (Fread_char, Fread_event, Fread_char_exclusive): New arg SECONDS.
-
- * lisp.h: Update read-char, read-event, and read_filtered_event
- prototypes.
-
- * keyboard.h: Include systime.h. Update read_char prototype.
-
-2006-07-25 YAMAMOTO Mitsuharu <[email protected]>
-
- * alloc.c (find_string_data_in_pure): New function.
- (make_pure_string): Use it to reuse existing string data if possible.
-
- * puresize.h (BASE_PURESIZE): Decrease to 1102000.
-
-2006-07-22 Stefan Monnier <[email protected]>
-
- * keymap.c (Fdefine_key): If the key binding definition looks like an
- XEmacs-style key sequence, convert it to Emacs's format.
-
-2006-07-22 Ralf Angeli <[email protected]>
-
- * w32fns.c (w32_createwindow): If `left' and/or `top' frame
- parameters are bound to some values, use that instead of
- CW_USEDEFAULT.
-
-2006-07-21 Eli Zaretskii <[email protected]>
-
- * w32.c (convert_time): Use explicit long double constants to
- ensure long double arithmetics is used throughout.
-
-2006-07-20 YAMAMOTO Mitsuharu <[email protected]>
-
- * alloc.c (pure_bytes_used_lisp, pure_bytes_used_non_lisp): New vars.
- (init_alloc_once): Initialize them.
- (pure_alloc): Allocate non-Lisp objects from the end of pure storage
- without alignment.
-
- * puresize.h (BASE_PURESIZE): Decrease to 1141000.
-
-2006-07-18 Francis Litterio <[email protected]>
-
- * w32term.c (x_calc_absolute_position): Fix frame positioning
- with negative X/Y coordinates.
-
-2006-07-18 Dan Nicolaescu <[email protected]>
-
- * xterm.c (x_connection_closed, x_error_quitter): Mark as NO_RETURN.
-
- * textprop.c (text_read_only): Likewise.
-
- * lread.c (end_of_file_error): Likewise.
-
- * lisp.h (circular_list_error, memory_full, buffer_memory_full):
- Likewise.
-
- * eval.c (unwind_to_catch): Likewise.
-
- * buffer.h (buffer_slot_type_mismatch): Likewise.
-
-2006-07-18 Kim F. Storm <[email protected]>
-
- Cleanup Fsignal calls that never returns; now only use it for Qquit.
-
- * eval.c (xsignal): New func. Like Fsignal, but marked no-return.
- (xsignal0, xsignal1, xsignal2, xsignal3): New no-return functions.
- (signal_error): New no-return function (from xfaces.c).
- (Fthrow): Use xsignal2 instead of Fsignal + abort.
- (error): Use xsignal1 instead of Fsignal + abort.
- (FletX, Flet, grow_specpdl): Use signal_error.
- (Feval, Ffuncall, funcall_lambda): Use xsignal1, xsignal2.
-
- * alloc.c (buffer_memory_full, memory_full): Use xsignal. Remove loop.
- (list1): New function.
-
- * lisp.h (list1): Add EXFUN.
- (xsignal, xsignal0, xsignal1, xsignal2, xsignal3, signal_error):
- Add prototypes. Mark them as no-return.
-
- * buffer.c (Fbuffer_local_value, Fbarf_if_buffer_read_only):
- Use xsignal1.
-
- * callint.c (check_mark): Use xsignal0.
-
- * casefiddle.c (casify_object): wrong_type_argument is no-return.
-
- * cmds.c (Fforward_char, Fdelete_char): Use xsignal0.
-
- * coding.c (Fcheck_coding_system): Use xsignal1. Remove loop.
- (Fdefine_coding_system_internal): Use xsignal1.
-
- * data.c (circular_list_error): Use xsignal.
- (wrong_type_argument): Use xsignal2. Don't care about return value.
- (args_out_of_range, args_out_of_range_3): Use xsignal2, xsignal3.
- Remove loop around Fsignal.
- (indirect_variable, Fsymbol_value, set_internal, Fdefault_value)
- (indirect_function, Findirect_function, Fstring_to_number)
- (Fmakunbound, Ffmakunbound, Fsymbol_function, Ffset): Use xsignal1.
- (arith_driver, float_arith_driver, Frem, Fmod, arith_error):
- Use xsignal0.
-
- * doc.c (Fdocumentation): Use xsignal1.
-
- * editfns.c (region_limit, Fget_internal_run_time): Use xsignal0.
-
- * fileio.c (report_file_error): Use xsignal.
- (barf_or_query_if_file_exists, Fcopy_file, Fdelete_file)
- (Finsert_file_contents): Use xsignal2.
- (syms_of_fileio): Use list2, list3.
-
- * floatfns.c (arith_error, range_error, domain_error): Use xsignal2.
- (range_error2, domain_error2): Use xsignal3.
- (rounding_driver, fmod_float): Use xsignal0.
- (float_error): Use xsignal1.
- (matherr): Use xsignal.
-
- * fns.c (Flength): wrong_type_argument is no-return.
- (hashfn_user_defined, Fmake_hash_table): Use signal_error.
- (Fmd5): Use xsignal1.
-
- * frame.c (x_set_line_spacing, x_set_screen_gamma): Use signal_error.
-
- * keyboard.c (recursive_edit_1): Use xsignal1.
-
- * keymap.c (Fmap_keymap): Use xsignal1.
-
- * lread.c (Fload): Use xsignal2, signal_error.
- (end_of_file_error): Use xsignal0, xsignal1.
- (read0): Use xsignal1.
- (invalid_syntax): New error function marked no-return.
- (read_integer, read1, read_list): Use it.
-
- * macselect.c (x_get_local_selection): Use signal_error.
-
- * msdos.c (Fmsdos_set_mouse_buttons): Use xsignal2.
-
- * search.c (compile_pattern_1): Use xsignal1.
- (signal_failure): Remove (was only called once).
- (search_command): Use xsignal1 instead of signal_failure.
-
- * syntax.c (scan_lists): Use xsignal3.
-
- * textprop.c (text_read_only): Use xsignal0, xsignal1.
-
- * unexsol.c (unexec): Use xsignal.
-
- * window.c (window_scroll_pixel_based, window_scroll_line_based):
- Use xsignal0.
-
- * xfaces.c (signal_error): Move to eval.c.
- (resolve_face_name): Use xsignal1.
-
- * xfns.c (x_decode_color): Use signal_error.
-
- * xselect.c (x_get_local_selection, copy_multiple_data)
- (x_get_window_property_as_lisp_data)
- (lisp_data_to_selection_data, CHECK_CUT_BUFFER)
- (Fx_get_cut_buffer_internal): Use signal_error.
-
-2006-07-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (XTread_socket): Undo previous change.
-
-2006-07-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (keycode_to_xkeysym): Remove function. All uses now
- directly lookup keycode_to_xkeysym_table.
- [USE_MAC_TSM] (mac_handle_text_input_event): Don't construct
- ASCII_KEYSTROKE_EVENT for non-zero keycode_to_xkeysym_table entries.
- (XTread_socket): Use character codes to construct keypad key events.
- (mac_initialize_display_info) [MAC_OSX]: Use CGDisplaySamplesPerPixel.
- (x_delete_display): Apply 2006-07-04 change for xterm.c.
-
-2006-07-17 Richard Stallman <[email protected]>
-
- * keyboard.c (Vcommand_error_function): New variable.
- (syms_of_keyboard): Defvar it.
- (cmd_error_internal): Simplify, and handle Vcommand_error_function.
-
- * dispnew.c (init_display): Mention DISPLAY as well as TERM in err msg.
-
-2006-07-17 Kim F. Storm <[email protected]>
-
- * xdisp.c (handle_single_display_spec): Ensure the right value of
- it->position is saved by push_it.
- (pop_it): Restore it->object for GET_FROM_BUFFER and GET_FROM_STRING.
- (reseat_1): Don't setup it->object twice.
- (set_iterator_to_next): No need to set it->object after pop_it.
- (move_it_to): Explicitly check to see if last move reached to_charpos.
-
-2006-07-17 Thien-Thi Nguyen <[email protected]>
-
- * xdisp.c (display_mode_line): Preserve match data.
-
-2006-07-14 Kim F. Storm <[email protected]>
-
- * w32.c (pfn_WSACreateEvent, pfn_WSACloseEvent): New func ptrs.
- (init_winsock): Load them. Use ws2_32.dll.
- (sys_listen): Undo last change. Just set FILE_LISTEN flag.
- (sys_accept): Undo last change. Instead, set child status to
- STATUS_READ_ACKNOWLEDGED and reset char_avail event so next
- sys_select will wakeup the reader thread.
- (_sys_wait_accept): New function used by reader thread to wait for
- an incoming connection on a server socket.
-
- * w32.h (_sys_read_ahead, _sys_wait_accept): Add prototypes.
-
- * w32proc.c (reader_thread): Use _sys_wait_accept to wait on a
- server socket (FILE_LISTEN flag).
-
-2006-07-14 Jan Dj,Ad(Brv <[email protected]>
-
- * sound.c (alsa_init): Call snd_pcm_close after successful snd_pcm_open.
-
-2006-07-14 Kim F. Storm <[email protected]>
-
- * w32.c: Fix high cpu load for server sockets.
- (pfn_WSAEventSelect): New function ptr.
- (init_winsock): Load it.
- (sys_listen): Set FILE_LISTEN flag. Set event mask for socket's
- char_avail event object to FD_ACCEPT.
- (sys_accept): Check FILE_LISTEN flag. Set event mask on new
- socket's char_avail event object to FD_READ|FD_CLOSE.
-
- * w32.h (FILE_LISTEN): New filedesc flag value.
-
-2006-07-13 Kim F. Storm <[email protected]>
-
- * bytecode.c (Fbyte_code): Use CAR, CDR for Bcar, Bcdr.
- Use CAR_SAFE, CDR_SAFE for Bcar_safe, Bcdr_safe.
- Simplify loops and use CAR for Bnth and Belt.
-
- * data.c (Findirect_function): Optimize for no indirection.
-
- * eval.c (Fthrow): Remove loop around Fsignal.
- (Feval, Fapply, Ffuncall): Optimize for no function indirection.
- Use original function name in all signaled errors.
- Simplify Fsignal calls (no return).
- (funcall_lambda): Simplify Fsignal calls (no return).
-
-2006-07-13 Andreas Schwab <[email protected]>
-
- * syntax.c (scan_sexps_forward): Use EMACS_INT for out_bytepos and
- out_charpos.
-
-2006-07-13 Kenichi Handa <[email protected]>
-
- * editfns.c (Fformat): Fix calculation of text property positions
- of format string.
-
-2006-07-12 Kim F. Storm <[email protected]>
-
- * lisp.h (CHECK_TYPE): New macro for generic type checking.
- (CAR_SAFE, CDR_SAFE): New macros.
- (ARRAYP, CHECK_ARRAY): New macros.
- (CHECK_VECTOR_OR_STRING, CHECK_SUBR): New macros.
- (CHECK_WINDOW_CONFIGURATION): New macro.
- (CHECK_LIST_CONS, CHECK_LIST_END): New checks for list traversal.
- (CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST)
- (CHECK_STRING, CHECK_STRING_CAR, CHECK_CONS, CHECK_SYMBOL)
- (CHECK_CHAR_TABLE, CHECK_VECTOR, CHECK_VECTOR_OR_CHAR_TABLE)
- (CHECK_BUFFER, CHECK_WINDOW, CHECK_LIVE_WINDOW, CHECK_PROCESS)
- (CHECK_NUMBER, CHECK_NATNUM, CHECK_MARKER, CHECK_OVERLAY)
- (CHECK_NUMBER_COERCE_MARKER, CHECK_FLOAT, CHECK_NUMBER_OR_FLOAT)
- (CHECK_NUMBER_OR_FLOAT_COERCE_MARKER): Use CHECK_TYPE.
-
- * category.h (CHECK_CATEGORY, CHECK_CATEGORY_SET):
- * frame.h (CHECK_FRAME, CHECK_LIVE_FRAME): Use CHECK_TYPE.
-
- * callint.c (Fcall_interactively):
- * casefiddle.c (casify_object):
- * editfns.c (general_insert_function):
- * fns.c (Flength, Felt, Ffillarray):
- * data.c (Fcar, Fcdr): Remove loop around wrong_type_argument.
-
- * data.c (wrong_type_argument): Remove loop around Fsignal.
- (Farrayp, Fsequencep): Use ARRAYP.
- (Fcar): Use CAR.
- (Fcar_safe): Use CAR_SAFE.
- (Fcdr): Use CDR.
- (Fcdr_safe): Use CDR_SAFE.
- (Fsetcar, Fsetcdr): Use CHECK_CONS.
- (Fsubr_arity, Fsubr_name): Use CHECK_SUBR.
- (Faset): Use CHECK_ARRAY.
-
- * fns.c (Felt): Use CHECK_ARRAY.
- (concat): Use CHECK_NUMBER.
- (Fsubstring, substring_both): Use CHECK_VECTOR_OR_STRING.
- (Fmemq): Use CHECK_LIST.
- (Fassq, Fassoc, Frassq, Frassoc): Use CAR.
- (assq_no_quit): Use CAR_SAFE.
- (Fnthcdr, Fmember, Fdelq, Fdelete, Fnreverse, Fnconc):
- Use CHECK_LIST_CONS.
- (Freverse, Fplist_get, Flax_plist_get): Use CHECK_LIST_END.
-
- * bytecode.c (Fbyte_code): Use CHECK_VECTOR.
-
- * casetab.c (check_case_table):
- * category.c (check_category_table):
- * marker.c (Fcopy_marker):
- * syntax.c (check_syntax_table):
- * xfaces.c (load_pixmap): Use CHECK_TYPE.
-
- * fns.c (Fcopy_sequence, concat):
- * fringe.c (Fdefine_fringe_bitmap):
- * lread.c (check_obarray): Cleanup wrong_type_argument use.
-
- * keyboard.c (access_keymap_keyremap): Use ARRAYP.
-
- * keymap.c (Fdefine_key, Flookup_key):
- * macros.c (Fstart_kbd_macro): Use CHECK_VECTOR_OR_STRING.
-
- * mac.c (Fmac_get_preference): Use CHECK_LIST_END.
-
- * search.c (Fset_match_data): Use CHECK_LIST.
-
- * sunfns.c (sun_item_create): Use CHECK_LIST_CONS.
-
- * window.c (Fwindow_configuration_frame, Fset_window_configuration):
- (compare_window_configurations): Use CHECK_WINDOW_CONFIGURATION.
-
-2006-07-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * Makefile.in (dired.o, editfns.o, fileio.o): Depend on blockinput.h.
-
- * dired.c: Include blockinput.h.
- (Ffile_attributes): Add BLOCK_INPUT around getpwuid/getgrgid.
-
- * editfns.c: Include blockinput.h.
- (Fuser_login_name, Fuser_full_name): Add BLOCK_INPUT around
- getpwuid/getpwnam.
-
- * fileio.c: Include blockinput.h.
- (Fexpand_file_name, search_embedded_absfilename): Add BLOCK_INPUT
- around getpwnam.
- (search_embedded_absfilename): Remove spurious xfree.
-
-2006-07-11 Kim F. Storm <[email protected]>
-
- * dispnew.c (sit_for): Reduce number of args from 5 to 3.
- Now just one TIMEOUT arg that can be a Lisp float or Lisp int.
- Combine args DISPLAY and INITIAL_DISPLAY into one arg DO_DISPLAY.
- Signal error if TIMEOUT is not a number.
- Undo 2006-06-14 change for non-preemptive display if TIMEOUT < 0.
- The rework of sit_for args also fixes several incorrect Qt args
- which should have been 1.
- (Fredisplay): Pass 1 instead of Qt to swallow_events and
- detect_input_pending_run_timers.
-
- * lisp.h (sit_for): Update prototype.
- (Fredisplay): Add EXFUN.
-
- * dispextern.h (sit_for): Remove prototype.
-
- * callint.c (Fcall_interactively):
- * minibuf.c (temp_echo_area_glyphs):
- * keyboard.c (command_loop_1, read_char, Fexecute_extended_command):
- * fileio.c (Fdo_auto_save): Update/simplify sit_for calls.
-
-2006-07-11 Stefan Monnier <[email protected]>
-
- * syntax.c (forw_comment): Also use EMACS_INT for buffer positions.
-
-2006-07-11 Kim F. Storm <[email protected]>
-
- * dispnew.c (Fredisplay): Add FORCE argument to force redisplay when
- input is available. Fix test for redisplay_dont_pause non-nil.
- Specbind redisplay-dont-pause to t if FORCE non-nil.
-
-2006-07-10 Chong Yidong <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment to 1211000.
-
- * dispnew.c (Fredisplay): New function, equivalent to (sit-for 0).
- (Fsit_for): Function deleted.
-
- * keyboard.c (command_loop_1, Fexecute_extended_command):
- Call sit_for instead of Fsit_for.
-
- * minibuf.c (temp_echo_area_glyphs): Likewise.
-
-2006-07-09 Stefan Monnier <[email protected]>
-
- * syntax.c (Fforward_comment): Revert the reversion.
- (back_comment, scan_lists): Also use EMACS_INT for buffer positions.
-
-2006-07-09 John Paul Wallington <[email protected]>
-
- * syntax.c (Fforward_comment): Revert previous change.
-
-2006-07-09 Kim F. Storm <[email protected]>
-
- * window.c (Fforce_window_update): Doc fix.
-
-2006-07-08 Stephen Gildea <[email protected]>
-
- * fileio.c (do_auto_save_make_dir): Make the auto-save-list-file
- directory unreadable for better user privacy.
-
-2006-07-07 Stefan Monnier <[email protected]>
-
- * syntax.c (Fforward_comment): Fix int-32 vs EMACS_INT-64 mixup.
-
- * lread.c (read_filtered_event): Remove `register' qualifier because it
- causes compilation problem with gcc-4.0.2-20051125 on amd64.
- (readevalloop): Remove unused var `bpos'.
- Yet another int/Lisp_Object mixup (YAILOM).
-
-2006-07-07 Eli Zaretskii <[email protected]>
-
- * keyboard.c (Fexecute_extended_command): Mention the argument
- PREFIXARG in the doc string.
-
-2006-07-07 Kim F. Storm <[email protected]>
-
- * fringe.c (Fdefine_fringe_bitmap): Doc fix.
-
-2006-07-05 Chong Yidong <[email protected]>
-
- * insdel.c (prepare_to_modify_buffer): For an indirect buffer, do
- clash detection using the base buffer.
-
- * puresize.h (BASE_PURESIZE): Increment to 1210500.
-
-2006-07-04 Kim F. Storm <[email protected]>
-
- * xterm.c (x_delete_display): Don't free or derefence NULL pointers.
-
-2006-07-04 Kenichi Handa <[email protected]>
-
- * fontset.c (Fset_overriding_fontspec_internal): Check if we need
- to update Voverriding_fontspec_alist.
-
-2006-07-03 Richard Stallman <[email protected]>
-
- * xfns.c (Fx_create_frame): Move unwind_create_frame setup down.
-
- * xfaces.c (Fface_attribute_relative_p): Doc fix.
-
- * textprop.c (Fget_char_property_and_overlay): Doc fix.
-
- * eval.c (Fdefvaralias): Doc fix.
-
-2006-07-03 Kim F. Storm <[email protected]>
-
- * dispnew.c (sit_for): Fix preempt condition.
-
-2006-07-02 Stefan Monnier <[email protected]>
-
- * lread.c (read_filtered_event): Treat select-window just like
- switch-frame.
-
-2006-07-02 Kim F. Storm <[email protected]>
-
- * xdisp.c (display_tool_bar_line): Skip glyphs which are too big
- to ever fit the tool-bar,
- (MAX_FRAME_TOOL_BAR_HEIGHT): New macro.
- (tool_bar_lines_needed): Use unused mode-line row as temp_row.
- (redisplay_tool_bar): Only clear desired matrix if we actually
- change the tool-bar window height. Only try to make the tool-bar
- window bigger if there is actually room for it.
-
-2006-06-30 Ralf Angeli <[email protected]>
-
- * w32term.c (x_make_frame_visible): Use SystemParametersInfo with
- SPI_GETWORKAREA to find the dimensions of the screen work area,
- and adjust vertical position of the frame in order to avoid being
- covered by the task bar.
-
- * w32fns.c (w32_createwindow): Use CW_USEDEFAULT instead of
- f->left_pos and SH_SHOW instead of f->top_pos in the call to
- CreateWindow. Record the actual position in f->left_pos and
- f->top_pos.
-
-2006-06-30 John Paul Wallington <[email protected]>
-
- * w32console.c (syms_of_ntterm) <w32-use-full-screen-buffer>:
- Doc fix - default value has changed.
-
-2006-06-28 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c [!TARGET_API_MAC_CARBON]: Don't include FixMath.h or Scrap.h.
-
- * macfns.c (Fx_create_frame): Apply 2006-06-24 change for xfns.c.
-
- * macgui.h (USE_MAC_TSM) [TARGET_API_MAC_CARBON]: Set default to 1.
-
- * macterm.c (Qeql): Add extern.
- (x_set_mouse_pixel_position) [MAC_OSX]: Use CGWarpMouseCursorPosition.
- (fm_style_face_attributes_alist) [USE_ATSUI]: New variable.
- (syms_of_macterm) [USE_ATSUI]: Initialize and staticpro it.
- Change keys of Vmac_atsu_font_table from strings to numbers.
- (fm_style_to_face_attributes) [USE_ATSUI]: New function.
- (init_font_name_table) [USE_ATSUI]: Use it.
- (saved_ts_script_language_on_focus) [USE_MAC_TSM]: New variable.
- (syms_of_macterm) [USE_MAC_TSM]: Initialize and staticpro it.
- [USE_MAC_TSM] (mac_tsm_resume): Restore script and language codes
- only when saved_ts_script_language_on_focus coincides with
- Vmac_ts_script_language_on_focus.
- [USE_MAC_TSM] (mac_tsm_suspend): Save value of
- Vmac_ts_script_language_on_focus to saved_ts_script_language_on_focus.
- (XTread_socket) [USE_MAC_TSM]: Add Mac OS Classic support.
- [USE_MAC_TSM] (mac_handle_text_input_event, init_tsm): Likewise.
-
-2006-06-27 Chong Yidong <[email protected]>
-
- * editfns.c (Fdelete_field, Ffield_string, Ffield_beginning)
- (Ffield_string_no_properties, Ffield_end): Mention
- args-out-of-range error condition in docstring.
-
-2006-06-27 Kim F. Storm <[email protected]>
-
- * xdisp.c (handle_composition_prop): Set stop_charpos before push_it.
-
-2006-06-25 Kim F. Storm <[email protected]>
-
- * s/gnu-linux.h (SIGNALS_VIA_CHARACTERS): Define for Linux kernel
- version 2.4 and later.
-
-2006-06-24 Chong Yidong <[email protected]>
-
- * xfns.c (Fx_create_frame): Set font parameter directly instead of
- using x_default_parameter, since x_get_args clears the parm alist.
-
-2006-06-24 Eli Zaretskii <[email protected]>
-
- * dired.c (directory_files_internal) [WINDOWSNT]: Find files
- case-insensitively.
-
-2006-06-24 Aidan Kehoe <[email protected]>
-
- * lread.c (read_escape): When an unknown Unicode code point is
- encountered as a string or character escape, signal an error.
-
-2006-06-23 Kim F. Storm <[email protected]>
-
- * .gdbinit (pitx): Dump iterator stack.
-
- * xdisp.c (handle_composition_prop): Push iterator on stack.
- (set_iterator_to_next): Pop iterator at end of composition.
-
-2006-06-23 Martin Rudalics <[email protected]>
-
- * fileio.c (Frename_file) [DOS_NT]: Don't try to move directory to
- itself on DOS_NT platforms, if the old and new names are identical
- but for the letter-case.
-
-2006-06-21 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct it): Add `position' member to iterator stack.
- Rename `pos' member to `current'. Rearrange and add comments.
-
- * xdisp.c (handle_stop): Set it->ignore_overlay_strings_at_pos_p
- if we get any overlays.
- (set_cursor_from_row): Don't clobber `end' if we rescan from
- start_string.
- (push_it, pop_it): Save it->position.
-
-2006-06-19 Richard Stallman <[email protected]>
-
- * window.c (size_window): New arg FIRST_ONLY. All callers changed.
- (adjust_window_trailing_edge): Specially compute FIRST_PARALLEL
- for the case of a top-level window and the following minibuffer.
- Don't exit because of no `next' when there is a parent.
- Use the FIRST_ONLY feature when resizing following windows.
-
- * syntax.c (init_syntax_once): Give most control chars' syntax Spunct.
-
-2006-06-17 Kim F. Storm <[email protected]>
-
- * dispnew.c (update_frame): Check for input pending on entry.
- (update_window, update_frame_1): Break loop if input is detected.
-
-2006-06-16 Francis Litterio <[email protected]>
-
- * xterm.c (x_check_expected_move, handle_one_xevent)
- (x_set_offset, x_check_fullscreen): Extensive changes to make
- frame positioning deterministic under X.
-
- * xterm.h (x_output): Add members left_before_move and
- top_before_move. Removed members expected_left and expected_top.
-
-2006-06-16 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct it): Add union to iterator stack to save
- image, composition, and stretch specific paramters.
-
- * xdisp.c (next_overlay_string): Fix assert.
- (push_it, pop_it): Handle composition and stretch specific values.
- Only handle it->slice in image (for now).
- (back_to_previous_visible_line_start): Continue search if newline is
- part of a compisition. Simplify.
- (reseat_1): Set it->object to buffer.
- (set_iterator_to_next): Set it->object to string or buffer, when
- setting it->method to GET_FROM_STRING or GET_FROM_BUFFER.
- (next_element_from_composition): Set it->object to buffer if not
- from string.
- (set_cursor_from_row): Only save start of string if not already
- done to handle multiple strings in a row.
-
- * .gdbinit (pitx): Show composition parameters.
- (pgx, pg): New commands to print a glyph structure.
- (pgi, pgn): New commands to print specific/next glyph.
- (pgrowx, pgrow): New commands to print all glyphs in a row.
-
-2006-06-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (Fx_display_mm_height, Fx_display_mm_width)
- [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: Use CGDisplayScreenSize.
-
- * macterm.c (do_app_resume, do_app_suspend): Remove functions.
- (mac_tsm_resume, mac_tsm_suspend) [USE_MAC_TSM]: New functions.
- (mac_handle_window_event, XTread_socket) [USE_MAC_TSM]: Use them.
- (Vmac_ts_script_language_on_focus) [USE_MAC_TSM]: New variable.
- (syms_of_macterm) [USE_MAC_TSM]: Defvar it.
- (saved_ts_language, saved_ts_component) [USE_MAC_TSM]: New variables.
- (mac_initialize_display_info) [MAC_OSX]: Use Quartz Display
- Services functions to get size of main display in pixels.
-
-2006-06-14 Chong Yidong <[email protected]>
-
- * xdisp.c (back_to_previous_visible_line_start):
- Reset it->continuation_lines_width.
-
-2006-06-14 Richard Stallman <[email protected]>
-
- * eval.c (Fdefconst): Mark variable as risky.
-
- * callproc.c (Fcall_process): Doc fix.
-
- * window.c (adjust_window_trailing_edge): Don't break out of the loop
- because there's no next window, if there are parallel windows.
- Do break out when WINDOW is nil.
-
-2006-06-14 Kim F. Storm <[email protected]>
-
- * dispextern.h (IT_STACK_SIZE): New macro specifying size of
- iterator stack (instead of hardcoded number). Increase from 2 to
- 4 to make room for propertized overlay strings before and after a
- display string, image or composition.
- (struct it): Add image_id and method members to iterator stack.
-
- * xdisp.c (init_from_display_pos): Don't set it->method and
- overlay_string_index after pop_it. Add asserts.
- (handle_stop): Look for overlay strings around a display string,
- image, or composition. Handle properties on those strings.
- (next_overlay_string): Don't set string, pos or method after pop_it.
- (get_overlay_strings_1): Split from get_overlay_strings; don't
- modify it if no overlay strings are found.
- (get_overlay_strings): Use get_overlay_strings_1. Always set
- it->string and it->method.
- (push_it): Push it->image_id and it->method. Push it->object
- instead of it->string if method is GET_FROM_IMAGE.
- (pop_it): Pop it->image_id and it->method. Ppo it->object
- instead of it->string if method is GET_FROM_IMAGE.
- Reset it->current.string_pos if popped it->string is nil.
- (reseat_1): Remove comment dated 19 May 2003. It expressed doubt
- whether a given change was correct; but the change is correct.
- Clear it->string_from_display_prop_p.
- (set_iterator_to_next): Rely on it->method and it->image_id from
- iterator stack, instead of setting them explicitly after pop_it.
-
- * dispnew.c (sit_for): Undo 2006-06-01 change. Instead, a
- negative time forces redisplay even when input is available.
- (Fsit_for): Doc fix.
-
-2006-06-13 Kim F. Storm <[email protected]>
-
- * dispnew.c: Modify preemptive redisplay to be based on periodic
- checks for input.
- (PERIODIC_PREEMPTION_CHECKING): Define to 1 iff EMACS_HAS_USECS.
- (Vredisplay_preemption_period): New variable.
- (syms_of_display): DEFVAR_LISP and initialize it.
- (preemption_period, preemption_next_check): New variables.
- (update_frame, update_single_window): Initialize them based on
- Vredisplay_preemption_period if !force_p.
- (update_window, update_frame_1): Use them to determine when to
- check for input.
-
-2006-06-03 Aidan Kehoe <[email protected]>
-
- * lread.c (read_escape): Provide a Unicode character escape
- syntax; \u followed by exactly four or \U followed by exactly
- eight hex digits in a comment or string is read as a Unicode
- character with that code point.
-
-2006-06-09 Eli Zaretskii <[email protected]>
-
- * window.c (window_scroll_pixel_based): Signal "Beginning of
- buffer" when scroll-down at the beginning of an empty buffer.
-
-2006-06-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c [USE_MAC_TSM] (mac_handle_text_input_event):
- Exclude 0x7f from ASCII range.
-
-2006-06-05 Jason Rumney <[email protected]>
-
- * w32term.c (w32_set_scroll_bar_thumb, x_scroll_bar_create)
- (w32_set_vertical_scroll_bar, w32_scroll_bar_handle_click)
- (x_scroll_bar_report_motion): Remove workarounds for
- versions of Windows NT < 3.51.
- [!SIF_ALL]: Remove.
- (pfnSetScrollInfo, pfnGetScrollInfo): Remove.
- (w32_initialize): Don't dynamically load Get/SetScrollInfo.
-
-2006-06-04 David Kastrup <[email protected]>
-
- * dispnew.c: Mention `redisplay-dont-pause' in doc string of
- `sit-for'.
-
-2006-06-03 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (x_set_icon_name): Apply 2006-06-02 change for xfns.c.
-
- * macgui.h (USE_MAC_TSM): Set default to 1 on Mac OS X.
-
- * macterm.c (tsm_document_id) [USE_MAC_TSM]: New variable.
- (Qtext_input, Qupdate_active_input_area, Qunicode_for_key_event)
- [USE_MAC_TSM]: Likewise.
- (syms_of_macterm) [USE_MAC_TSM]: Intern and staticpro them.
- (Qbefore_string) [USE_MAC_TSM]: Add extern.
- (do_app_resume, do_app_suspend) [USE_MAC_TSM]: Call
- ActivateTSMDocument/DeactivateTSMDocument.
- (mac_store_event_ref_as_apple_event): Call mac_post_mouse_moved_event.
- (mac_handle_window_event) [USE_MAC_TSM]: Handle
- kEventWindowFocusAcquired/kEventWindowFocusRelinquish.
- (mac_handle_text_input_event) [USE_MAC_TSM]: New function.
- (install_window_handler) [USE_MAC_TSM]: Install it. Register
- kEventWindowFocusAcquired/kEventWindowFocusRelinquish.
- (keycode_to_xkeysym_table): Add entry for f16.
- (XTread_socket) [USE_MAC_TSM]: Set/reset read_socket_inev
- before/after passing keystroke event to toolbox dispatcher.
- (init_tsm) [USE_MAC_TSM]: New function.
- (mac_initialize) [USE_MAC_TSM]: Call it.
- (Vmac_ts_active_input_overlay) [USE_MAC_TSM]: New defvar.
-
- * macterm.h (EVENT_PARAM_TEXT_INPUT_SEQUENCE_NUMBER): New enumerator.
-
-2006-06-02 John Paul Wallington <[email protected]>
-
- * xfns.c (x_set_name_internal): Set icon to `text', derived from
- name, when frame's icon_name isn't a string rather than only when
- it is nil.
-
-2006-06-03 Eli Zaretskii <[email protected]>
-
- * w32fns.c (x_set_icon_name): Don't use arg if it's not a string
- and not nil.
-
-2006-06-02 Chong Yidong <[email protected]>
-
- * xfns.c (x_set_icon_name): No-op if arg is non-nil and not a
- string.
-
-2006-06-02 YAMAMOTO Mitsuharu <[email protected]>
-
- * xdisp.c (next_element_from_composition): Set it->object to
- it->string if composition is coming from string.
- (set_cursor_from_row): Don't return 0 unless row displays a
- continued line.
- (dump_glyph): Dump composite glyph.
-
-2006-06-02 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (menu_nav_ended): Check that menubar_widget is not NULL.
-
-2006-06-01 Richard Stallman <[email protected]>
-
- * window.c (Fsplit_window): Doc fix.
-
-2006-06-01 Micha,Ak(Bl Cadilhac <[email protected]>
-
- * process.c (deleted_pid_list): New variable to store the pids
- of deleted processes. Declare it only if SIGCHLD is defined.
- (init_process): Initialize it.
- (syms_of_process): Staticpro it.
- (Fdelete_process): Add pid of the deleted process to it. Check after
- the addition and before the kill if the process is already stopped,
- in which case it is deleted from the list and not killed.
- (sigchld_handler): Define it only if SIGCHLD is. Search the process
- that signaled Emacs in `deleted_pid_list' before `Vprocess_alist'.
- Original idea by Stefan Monnier.
-
-2006-06-01 Kim F. Storm <[email protected]>
-
- * dispnew.c (sit_for): Perform redisplay even if input is pending
- when redisplay-dont-pause is non-nil.
-
-2006-06-01 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_handle_visibility_change): Set buf.arg to Qnil.
- (XTread_socket): Remove obsolete comment.
-
-2006-06-01 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (syms_of_xmenu): Make accelerate-menu an alias for
- menu-bar-open.
-
-2006-06-01 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (Fmenu_bar_open, syms_of_xmenu): Change menu-bar-start to
- menu-bar-open.
-
- * gtkutil.c (menu_nav_ended): Change x-menu-bar-start to menu-bar-open.
-
-2006-05-31 Juri Linkov <[email protected]>
-
- * minibuf.c (Vhistory_add_new_input): New variable.
- (read_minibuf): Use it.
- (syms_of_minibuf) <history-add-new-input>: New Lisp variable.
- (syms_of_minibuf) <history-delete-duplicates>: Doc fix.
-
-2006-05-31 Kim F. Storm <[email protected]>
-
- * process.c (select_wrapper): Add wrapper around select to work around
- "incomplete backtrace" bug in gdb 5.3, when emacs is stopped inside
- select called from wait_reading_process_output.
-
-2006-05-30 Andreas Schwab <[email protected]>
-
- * xmenu.c (Fmenu_bar_start): Return a value.
-
-2006-05-30 Richard Stallman <[email protected]>
-
- * coding.c (Ffind_operation_coding_system): Doc fix.
-
-2006-05-30 Eli Zaretskii <[email protected]>
-
- * w32term.c (x_draw_hollow_cursor): Fix last change.
-
-2006-05-29 Kim F. Storm <[email protected]>
-
- * w32term.c (x_draw_stretch_glyph_string): Fix last change.
-
-2006-05-29 Eli Zaretskii <[email protected]>
-
- * coding.c (Ffind_operation_coding_system): Doc fix.
-
-2006-05-29 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c [USE_MAC_FONT_PANEL] (Fmac_set_font_panel_visibility):
- Call mac_set_font_info_for_selection if font panel is made visible.
-
- * macterm.c (font_panel_shown_p) [USE_MAC_FONT_PANEL]: New variable.
- (mac_font_panel_visible_p, mac_show_hide_font_panel)
- [USE_MAC_FONT_PANEL]: New functions.
- [USE_MAC_FONT_PANEL] (mac_set_font_info_for_selection):
- Return immediately if font panel is not visible.
-
- * macterm.h (mac_font_panel_visible_p, mac_show_hide_font_panel):
- Add externs.
-
-2006-05-29 Dan Nicolaescu <[email protected]>
-
- * search.c (matcher_overflow): Mark as NO_RETURN.
-
- * xterm.c (x_connection_closed): Likewise.
-
- * sysdep.c (croak): Likewise.
-
- * sound.c (sound_perror, alsa_sound_perror): Likewise.
-
- * lisp.h (die, nsberror): Likewise.
-
-2006-05-29 Jan Dj,Ad(Brv <[email protected]>
-
- * sound.c (alsa_open, alsa_configure, alsa_write):
- Move assignment to err out of if-statement.
-
- * gtkutil.c (menu_nav_ended): New function.
- (create_menus): Connect menu_nav_ended to "selection-done" to fix
- grabs.
-
- * xmenu.c (Fmenu_bar_start): New function for USE_GTK and USE_X_TOOLKIT.
-
-2006-05-28 Dan Nicolaescu <[email protected]>
-
- * charset.h (invalid_character): Mark as NO_RETURN.
-
-2006-05-29 Kenichi Handa <[email protected]>
-
- * coding.c (Ffind_operation_coding_system): Call a function by
- safe_call1 instead of call1.
-
-2006-05-28 Stefan Monnier <[email protected]>
-
- * window.c (struct saved_window): Add `dedicated'.
- (Fset_window_configuration, save_window_save): Save/restore the
- `dedicated' flag.
-
-2006-05-28 Kim F. Storm <[email protected]>
-
- * xdisp.c (set_cursor_from_row): If cursor cannot be set in row,
- don't update w->cursor and return 0. Return 1 on success.
- (try_cursor_movement): Repeat set_cursor_from_row on successive rows
- until it succeeds.
-
- * dispextern.h (set_cursor_from_row): Update prototype.
-
-2006-05-28 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_phys_cursor_geometry): Return computed x and y through
- parameters. Adjust x and width in case cursor in on a partially
- visible stretch glyph on the left edge.
- (erase_phys_cursor): Don't erase into left fringe/margin in case
- previous cursor glyph is a partially visible stretch glyph on left.
-
- * dispextern.h (get_phys_cursor_geometry): Update prototype.
-
- * xterm.c (x_draw_stretch_glyph_string): Fix problems with invisible
- cursor and erasing cursor on partially visible stretch glyph on left.
- (x_draw_hollow_cursor): Compute x via get_phys_cursor_geometry.
-
- * macterm.c: Likewise.
-
- * w32term.c: Likewise.
-
-2006-05-27 YAMAMOTO Mitsuharu <[email protected]>
-
- * macselect.c (mac_handle_apple_event):
- Return errAEEventNotHandled if key binding is not found.
-
-2006-05-26 Eli Zaretskii <[email protected]>
-
- * emacs.c (main) [PROFILING]: Enable also for __MINGW32__.
- [__MINGW32__]: MinGW-specific declaration of `etext'.
-
- * w32heap.c (etext, edata): Remove unused definitions.
-
-2006-05-26 Chong Yidong <[email protected]>
-
- * fileio.c (Fcopy_file): Delete argument MUSTBENEW.
- Incorporate the exclusive file-opening functionality into the behavior
- when OK-IF-ALREADY-EXISTS is nil.
- (Frename_file): Call Fcopy_file without MUSTBENEW argument.
-
-2006-05-26 Jan Dj,Ad(Brv <[email protected]>
-
- * sound.c (alsa_configure): Move get period/buffer_size after
- setting hwparams.
-
-2006-05-26 Kenichi Handa <[email protected]>
-
- * coding.c (Ffind_operation_coding_system): Allow (FILENAME
- . BUFFER) in TARGET.
-
-2006-05-25 Chong Yidong <[email protected]>
-
- * image.c (png_load): Don't call fclose on NULL.
-
-2006-05-25 Luc Teirlinck <[email protected]>
-
- * fns.c (Fyes_or_no_p):
- * callint.c (Fcall_interactively): Fread_from_minibuffer now takes
- only seven args.
-
-2006-05-25 Juri Linkov <[email protected]>
-
- * lisp.h (Fread_from_minibuffer): Decrement number of args.
-
- * minibuf.c (read_minibuf): Remove arg KEEP_ALL. Callers changed.
- (Fread_from_minibuffer): Remove arg KEEP_ALL. Callers changed.
-
- * buffer.c (mode-line-format): Fix docstring.
-
-2006-05-25 Richard Stallman <[email protected]>
-
- * emacs.c (main, Fdump_emacs): Don't test __linux or __linux__.
-
-2006-05-24 Luc Teirlinck <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 1210000.
-
-2006-05-24 Alan Mackenzie <[email protected]>
-
- * lread.c (Vload_history): Enhance doc-string to say that the file
- is the absolute truename of the loaded file.
-
- * lread.c (Vafter_load_alist): doc-string: state that an element
- now has a regexp to match file names, not a file name as such.
-
- * lread.c (readevalloop): Call file-truename on the name for
- load-history, except at preloading time.
-
- * lread.c (Fload): At preloading time, preserve the extension of
- the filename which goes into load-history. New var hist_file_name.
-
- * lread.c (Fload): Do eval-after-load stuff by calling the lisp
- function do-after-load-evaluation.
-
-2006-05-24 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (ae_attr_table): New variable.
- (syms_of_mac): Intern and staticpro its elements.
- (mac_aelist_to_lisp): Also convert Apple event attributes.
- (mac_ae_put_lisp): New function.
- (create_apple_event_from_event_ref) [MAC_OSX]: Use typeUTF8Text.
-
- * macfns.c (Fx_server_version): Use gestaltSystemVersionMajor etc.
-
- * macselect.c (Qemacs_suspension_id): New variable.
- (syms_of_macselect): Intern and staticpro it.
- (struct suspended_ae_info): New struct.
- (deferred_apple_events, defer_apple_events)
- (Fmac_process_deferred_apple_events): Use it.
- (suspended_apple_events): New variable.
- (mac_handle_apple_event_1): New function.
- (mac_handle_apple_event): Use it. Don't process previously
- suspended events.
- (cleanup_suspended_apple_events, get_suspension_id)
- (cleanup_all_suspended_apple_events): New functions.
- (init_apple_event_handler): Call cleanup_all_suspended_apple_events
- at exit.
- (Fmac_cleanup_expired_apple_events, Fmac_ae_set_reply_parameter)
- (Fmac_resume_apple_event): New defuns.
- (syms_of_macselect): Defsubr them.
-
- * macterm.c (fn_keycode_to_keycode_table, XTread_socket) [MAC_OSX]:
- Fix last change. Don't map `fn' modifier if pressed with F1 ... F12.
-
- * macterm.h (TYPE_FILE_NAME): Change from macro to enumerator.
- (KEY_EMACS_SUSPENSION_ID_ATTR): New enumerator.
- (keyReplyRequestedAttr) [MAC_OS_X_VERSION_MAX_ALLOWED < 1030]: Likewise.
- (gestaltSystemVersionMajor, gestaltSystemVersionMinor)
- (gestaltSystemVersionBugFix) [MAC_OS_X_VERSION_MAX_ALLOWED < 1040]:
- Likewise.
- (typeUTF8Text, kEventParamWindowMouseLocation)
- [MAC_OSX && MAC_OS_X_VERSION_MAX_ALLOWED < 1020]: Likewise.
- (x_get_focus_frame, mac_ae_put_lisp): Add externs.
-
-2006-05-23 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (fn_keycode_to_xkeysym_table, convert_fn_keycode): Remove.
- (fn_keycode_to_keycode_table) [MAC_OSX]: New variable.
- (mac_set_unicode_keystroke_event) [TARGET_API_MAC_CARBON]: New function.
- (XTread_socket) [TARGET_API_MAC_CARBON]: Use it.
- (XTread_socket) [MAC_OSX]: Try 'uchr' Unicode keyboard-layout
- resource to backtranslate key with modifiers.
- (XTread_socket): Don't set read_socket_inev around AEProcessAppleEvent.
-
-2006-05-23 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c: Remove declarations already in xterm.h.
-
- * xterm.h: Add extern declarations for x_clear_errors,
- x_fully_uncatch_errors, x_catching_errors and
- x_alloc_lighter_color_for_widget. Remove duplicated declarations.
-
-2006-05-21 Richard Stallman <[email protected]>
-
- * xfaces.c (best_matching_font): Abort for best == NULL
- before we start to use it.
-
- * buffer.c (syms_of_buffer, Fmake_overlay): Doc fixes.
-
-2006-05-20 Kim F. Storm <[email protected]>
-
- * xfaces.c (best_matching_font): Fix crash in 2006-05-17 change.
-
-2006-05-20 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (convert_fn_keycode): Fix last change.
-
-2006-05-19 Eli Zaretskii <[email protected]>
-
- * w32.c (init_environment): Perform the processing of environment
- variables on a copy of default variables and their values, not on
- the original. Simplify code that calls ExpandEnvironmentStrings
- and make buf1[] and buf2[] more visible for easier debugging.
-
-2006-05-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * frame.c (x_set_border_width): Remove #ifndef MAC_OS.
-
- * image.c [MAC_OS] (gif_load): Allocate Lisp string first.
-
- * macfns.c (Fx_focus_frame): Don't check dpyinfo->x_focus_frame.
-
- * macterm.c (XTread_socket) [TARGET_API_MAC_CARBON && MAC_OSX]:
- Forward keyUp events to toolbox_dispatcher.
-
- * window.c (foreach_window): Check WINDOWP (FRAME_ROOT_WINDOW (f)).
-
-2006-05-18 Jan Dj,Ad(Brv <[email protected]>
-
- * config.in: Regenerated (HAVE_ALSA).
-
- * sound.c (alsa_sound_perror, alsa_open, alsa_period_size)
- (alsa_configure, alsa_close, alsa_choose_format, alsa_write)
- (snd_error_quiet, alsa_init): New functions.
- (vox_init): Return 0 if unable to open device.
- (Fplay_sound_internal): Test for alsa first and use vox (oss) as
- a fallback.
- (struct sound_device): Add period_size.
- (wav_play, au_play): Use period_size if set.
-
- * Makefile.in (CFLAGS_SOUND): New flags for ALSA.
- (ALL_CFLAGS): Add CFLAGS_SOUND.
-
-2006-05-18 Kenichi Handa <[email protected]>
-
- * callproc.c (Fcall_process): Reject encoding arguments by
- ascii-incompatible coding systems (e.g. utf-16).
-
- * coding.c (Qascii_incompatible): New variable.
- (syms_of_coding): Setup Qascii_incompatible.
- (setup_coding_system): Be sure to initialize coding->common_flags.
- Check `ascii-incompatible' property of the coding system.
-
- * coding.h (CODING_ASCII_INCOMPATIBLE_MASK): New macro.
-
-2006-05-18 Kim F. Storm <[email protected]>
-
- * xdisp.c (display_tool_bar_line): Restore entire tool-bar
- geometry when backtracking in case last image doesn't fit on line.
-
-2006-05-18 MIYOSHI Masanori <[email protected]> (tiny change)
-
- * xdisp.c (display_tool_bar_line): Don't adjust tool-bar height by
- more than height of one frame default line.
-
-2006-05-17 Richard Stallman <[email protected]>
-
- * xfaces.c (better_font_p): Any font beats no font.
- (best_matching_font): Simplify based on above change.
-
- * buffer.c (Fprevious_overlay_change, Fnext_overlay_change): Doc fixes.
-
-2006-05-16 Kim F. Storm <[email protected]>
-
- * xterm.c (handle_one_xevent): Check that f is not NULL before
- calling x_kill_gs_process.
-
-2006-05-14 Richard Stallman <[email protected]>
-
- * textprop.c (Fnext_single_char_property_change)
- (Fprevious_single_char_property_change): Don't allow returning
- value beyond LIMIT in any cases.
- (Fnext_char_property_change, Fprevious_char_property_change): Doc fix.
-
- * intervals.c (get_local_map): Abort if POSITION outside BEGV, ZV.
-
-2006-05-14 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): Check that f is not NULL before
- calling _XEditResCheckMessages.
-
-2006-05-14 Kim F. Storm <[email protected]>
-
- * xterm.c (handle_one_xevent): Fix crash in 2006-03-24 change.
-
-2006-05-13 Eli Zaretskii <[email protected]>
-
- * frame.c (x_set_border_width): Fix error message to say "frame",
- not "window".
-
- * Makefile.in (SOME_MACHINE_LISP): Add fringe.elc.
-
-2006-05-12 Chong Yidong <[email protected]>
-
- * intervals.c (set_point_both): Fix mixup before before and after
- in variable names.
-
- * editfns.c (Fline_beginning_position): Inhibit point-motion hooks
- while setting point temporarily.
-
-2006-05-11 Richard Stallman <[email protected]>
-
- * lread.c (readevalloop): Abort if START non-nil for non-buffer input.
-
-2006-05-11 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_tool_bar): Handle large tool-bar-border values.
-
-2006-05-11 Kenichi Handa <[email protected]>
-
- * fileio.c (Finsert_file_contents): Fix for the case of IO error
- while handling replace operation.
-
-2006-05-10 Kenichi Handa <[email protected]>
-
- * xfaces.c (realize_default_face) [HAVE_X_WINDOWS]: If the font
- chosen for the default face was different from the frame font,
- adjust the frame font.
-
-2006-05-10 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c (Qduration) [MAC_OS]: Undo previous change.
- (syms_of_image) [MAC_OS]: Likewise.
- [MAC_OS] (gif_load): Emulate Graphic Control Extension block.
-
- * macfns.c (x_to_mac_color): Fix shift amount change.
- (mac_set_font) [USE_MAC_FONT_PANEL]: Use x_get_focus_frame.
- [USE_MAC_FONT_PANEL] (Fmac_set_font_panel_visibility): Doc fix.
-
- * macselect.c (Vmac_service_selection) [MAC_OSX]: Rename from
- Vmac_services_selection. All uses changed.
- (mac_store_service_event): Rename from mac_store_services_event in
- extern and calls.
-
- * macterm.c (Qservice) [MAC_OSX]: Rename from Qservices. All uses
- changed.
- [MAC_OSX] (mac_store_service_event): Rename from
- mac_store_services_event. All callers changed.
- [USE_MAC_FONT_PANEL] (mac_set_font_info_for_selection): Add args
- FACE_ID and C. All callers changed.
- (x_free_frame_resources) [USE_MAC_FONT_PANEL]: Call
- mac_set_font_info_for_selection when focus frame is destroyed.
- (XTread_socket): Revert to FrontNonFloatingWindow/FrontWindow.
-
- * macterm.h (mac_set_font_info_for_selection): Add 2nd and 3rd
- args in extern.
-
-2006-05-09 Chong Yidong <[email protected]>
-
- * keymap.c (describe_map): Avoid generating duplicate entries if
- the shadowed binding has the same definition.
-
-2006-05-09 Kenichi Handa <[email protected]>
-
- * keymap.c (push_key_description): Handle invalid character key.
-
-2006-05-08 Kenichi Handa <[email protected]>
-
- * callproc.c (Fcall_process): Use system_eol_type for encoding
- arguments if eol_type is not yet decided.
-
- * coding.h (system_eol_type): Extern it.
-
- * coding.c (setup_coding_system): For invalid coding-system, set
- coding->eol_type to CODING_EOL_UNDECIDED.
- (encode_coding): Cancel previous change.
- (shrink_encoding_region): Likewise.
- (code_convert_region1): Likewise.
- (code_convert_string1): Likewise.
- (code_convert_string_norecord): Likewise.
-
- * fileio.c (choose_write_coding_system): Use system_eol_type for
- encoding if eol_type is not yet decided.
-
- * process.c (setup_process_coding_systems): Use system_eol_type
- for encoding if eol_type is not yet decided.
- (read_process_output): Likewise.
- (send_process): Likewise.
-
-2006-05-07 Juanma Barranquero <[email protected]>
-
- * minibuf.c (syms_of_minibuf) <history-length>: Fix typo in doc.
-
-2006-05-07 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (Fmac_clear_font_name_table): Move defun to macfns.c.
- (syms_of_mac): Likewise for defsubr.
-
- * macfns.c (mac_set_font): New function.
- (mac_frame_parm_handlers, syms_of_macfns): Replace x_set_font with it.
- (mac_window) [TARGET_API_MAC_CARBON && MAC_OSX]: Specify
- kWindowToolbarButtonAttribute when creating window.
- (Fmac_clear_font_name_table): Move from macfns.c.
- (syms_of_macfns): Likewise for defsubr.
- [USE_MAC_FONT_PANEL] (Fmac_set_font_panel_visibility): New defun.
- (syms_of_macfns) [USE_MAC_FONT_PANEL]: Defsubr it.
-
- * macgui.h (USE_MAC_FONT_PANEL): Define to 1 if USE_ATSUI is set
- and build is done on Mac OS X 10.2 and later.
-
- * macselect.c (mac_do_receive_drag): Remove unused variable `index'.
- (mac_store_services_event): Change return type in extern.
-
- * macterm.c (XLoadQueryFont) [USE_ATSUI]: Set font->mac_fontnum to
- FMFontFamily value.
- [USE_MAC_FONT_PANEL] (mac_set_font_info_for_selection): New function.
- (x_new_focus_frame) [USE_MAC_FONT_PANEL]: Use it.
- (QCfamily, QCweight, QCslant, Qnormal, Qbold, Qitalic): Add extern.
- (QWindow) [MAC_OSX]: Likewise.
- (Qfont) [USE_MAC_FONT_PANEL]: Likewise.
- (Vmac_atsu_font_table) [USE_ATSUI]: New variable.
- (syms_of_macterm) [USE_ATSUI]: Defvar it.
- (Qtoolbar_switch_mode) [MAC_OSX]: New variable.
- (Qpanel_closed, Qselection) [USE_MAC_FONT_PANEL]: Likewise.
- (syms_of_macterm): Intern and staticpro them.
- (init_font_name_table) [USE_ATSUI]: Add data to Vmac_atsu_font_table.
- [TARGET_API_MAC_CARBON] (mac_store_event_ref_as_apple_event):
- New function.
- [USE_CARBON_EVENTS] (mac_handle_command_event): Use it.
- [MAC_OSX] (mac_store_services_event): Likewise.
- [USE_CARBON_EVENTS] (mac_handle_window_event) [MAC_OSX]: Handle
- kEventWindowToolbarSwitchMode event.
- (install_window_handler) [USE_CARBON_EVENTS && MAC_OSX]: Register it.
- [MAC_OSX] (mac_store_services_event): Change return type to OSStatus.
- [USE_MAC_FONT_PANEL] (mac_handle_font_event): New function.
- (install_window_handler) [USE_MAC_FONT_PANEL]: Install it.
- (XTread_socket): Select window on mouse click if x_focus_frame is NULL.
-
- * macterm.h (mac_set_font_info_for_selection): Add extern.
-
-2006-05-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c (Qduration) [MAC_OS]: New variable.
- (syms_of_image) [MAC_OS]: Intern and staticpro it.
- [MAC_OS] (gif_load): Save image extension data in img->data.lisp_val.
- [MAC_OSX] (image_load_quartz2d): Use cfstring_create_with_utf8_cstring
- instead of cfstring_create_with_string.
-
-2006-05-06 Kim F. Storm <[email protected]>
-
- * .gdbinit (xframe): Print frame name.
- (xlist): New command to print a list (max 10 elements).
- (xpr): Print lisp object of any type.
- (pitx): Print it->pixel_width.
-
-2006-05-05 Kenichi Handa <[email protected]>
-
- * xdisp.c (handle_composition_prop): Fix for the case of empty
- composition component.
-
-2006-05-05 YAMAMOTO Mitsuharu <[email protected]>
-
- * keyboard.c (make_lispy_event) [MAC_OS]: Get Apple event info
- from event->arg.
-
- * termhooks.h (enum event_kind) [MAC_OS]: Update comment for
- MAC_APPLE_EVENT.
-
- * macterm.h (mac_make_lispy_event_code): Remove extern.
- (mac_post_mouse_moved_event): Add extern.
- (mac_aelist_to_lisp, mac_aedesc_to_lisp): Change arg 1 to
- `const AEDesc *' in externs.
- (create_apple_event_from_drag_ref) [TARGET_API_MAC_CARBON]: New extern.
-
- * mac.c (mac_aelist_to_lisp, mac_aedesc_to_lisp): Change arg 1 to
- `const AEDesc *'.
- [TARGET_API_MAC_CARBON] (create_apple_event): New function.
- [TARGET_API_MAC_CARBON] (create_apple_event_from_event_ref): Use it.
- Use xrealloc instead of repeated xmalloc/xfree.
- [TARGET_API_MAC_CARBON] (create_apple_event_from_drag_ref):
- New function.
-
- * macmenu.c (restore_menu_items, cleanup_popup_menu): Return a value.
-
- * macselect.c: Update copyright year.
- (mac_store_apple_event): Change return type to void in extern.
- (mac_handle_apple_event): Don't get return value from
- mac_store_apple_event.
- [TARGET_API_MAC_CARBON] (Vmac_dnd_known_types): New variable.
- (syms_of_macselect) [TARGET_API_MAC_CARBON]: Defvar it.
- [TARGET_API_MAC_CARBON] (mac_do_track_drag): Move function from
- macterm.c. Use Vmac_dnd_known_types as acceptable flavors.
- [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Likewise. New
- implementation using create_apple_event_from_drag_ref.
- [TARGET_API_MAC_CARBON] (mac_do_track_dragUPP)
- (mac_do_receive_dragUPP): Move variables from macterm.c.
- (install_drag_handler, remove_drag_handler): New functions.
-
- * macterm.c (XTread_socket) [TARGET_API_MAC_CARBON]: Try window
- path select also for proxy icon click.
- [TARGET_API_MAC_CARBON] (mac_post_mouse_moved_event): New function.
- [USE_TOOLKIT_SCROLL_BARS] (scroll_bar_timer_callback): Use it.
- (xlfdpat_create): Remove unused label `error' and trailing sentences.
- (mac_do_track_drag, mac_do_receive_drag): Move functions to macselect.c.
- (mac_do_track_dragUPP, mac_do_receive_dragUPP): Move variables to
- macselect.c.
- (install_drag_handler, remove_drag_handler): Add extern.
- (mac_store_apple_event): Change return type to void. All uses changed.
- Create Lisp object from Apple event and store it into input event.
- (mac_make_lispy_event_code): Remove function.
- [TARGET_API_MAC_CARBON] (mac_store_drag_event): New function.
- (install_window_handler): Call install_drag_handler.
- (remove_window_handler): Call remove_drag_handler.
-
-2006-05-03 Richard Stallman <[email protected]>
-
- * sound.c (Fplay_sound_internal): Dynamically allocate
- current_sound_device and current_sound.
- (sound_cleanup): Free them.
-
- * minibuf.c (read_minibuf): Don't use read_minibuf_noninteractive
- when inside a keyboard macro.
-
-2006-05-02 Andreas Schwab <[email protected]>
-
- * xmenu.c (restore_menu_items): Return a value.
-
-2006-05-01 Martin Rudalics <[email protected]>
-
- * syntax.c (Fforward_comment): Detect generic comment at beginning of
- buffer when moving backwards.
-
-2006-05-01 YAMAMOTO Mitsuharu <[email protected]>
-
- * dispnew.c (update_window): Don't set changed_p when mode/header
- line is updated.
-
- * xdisp.c (prepare_menu_bars) [MAC_OS]: Call mac_update_title_bar.
- (get_glyph_face_and_encoding, get_char_face_and_encoding):
- Don't distinguish known faces from others.
-
- * mac.c (mac_coerce_file_name_ptr): Try typeFSRef if coercion
- through typeFileURL failed.
-
- * macfns.c (mac_update_title_bar): New function.
- [TARGET_API_MAC_CARBON] (mac_update_proxy_icon): New function.
- (show_hourglass, hide_hourglass) [USE_CG_DRAWING]:
- Call mac_prepare_for_quickdraw.
-
- * macgui.h (USE_ATSUI): Set default to 1 if MAC_OSX is defined.
- (USE_CG_DRAWING): Don't define if compiled on Mac OS X 10.1.
- (enum pcm_status): New enum.
- (XCHARSTRUCTROW_CHAR_VALID_P, XCHARSTRUCTROW_SET_CHAR_VALID)
- (XCharStructRow): Remove. Now validity is represented by
- non-negativeness of sum of ascent and descent.
- (struct MacFontStruct): Change type of member `rows'.
- (struct _XGC) [USE_CG_DRAWING]: Add member `clip_rects'.
-
- * macterm.c (mac_draw_line, mac_draw_line_to_pixmap):
- Adjust endpoints of strictly horizontal/vertical lines.
- (mac_set_clip_rectangles) [USE_CG_DRAWING]: Set clip_rects.
- (pcm_init, pcm_get_status): New functions.
- (x_per_char_metric, XLoadQueryFont): Use them instead of
- XCharStructRow and related macros.
- (x_draw_relief_rect): Don't adjust arguments of mac_draw_line.
- (x_free_frame_resources) [TARGET_API_MAC_CARBON]: Free FRAME_FILE_NAME.
- (XTread_socket) [TARGET_API_MAC_CARBON]: Handle proxy icon drag
- and window path pop-up menu on title bar.
- (mac_use_core_graphics) [USE_CG_DRAWING]: Set default to 1.
-
- * macterm.h (mac_update_title_bar): Add extern.
- (struct mac_output) [TARGET_API_MAC_CARBON]: New member `file_name'.
- (FRAME_FILE_NAME): New macro.
-
- * unexmacosx.c (unexec): Error if trying unexec from dumped executable.
-
-2006-04-30 Richard Stallman <[email protected]>
-
- * keymap.c (Fdefine_key): Improve error message
- when KEY begins with a non-prefix key.
-
-2006-04-30 Martin Rudalics <[email protected]>
-
- * syntax.c (Fforward_comment): Don't forget to break out of the loop
- when we skipped backward over a generic comment.
-
-2006-04-27 Nick Roberts <[email protected]>
-
- * .gdbinit (pp1, pv1): Only print value as expression is now
- printed out by gud-print.
- (pv1): Correct doc string.
-
-2006-04-26 Stefan Monnier <[email protected]>
-
- * keymap.c (store_in_keymap): Change `def' arg to not be `register'.
- Seems to trigger a bug in gcc-amd64 4.0.2 20051125 (Red Hat 4.0.2-8):
- keymap.c:895: error: address of register variable `def' requested.
-
-2006-04-26 Jason Rumney <[email protected]>
-
- * w32term.c (construct_mouse_wheel): Handle negative coordinates.
-
- * w32fns.c (w32_wnd_proc) <WM_LBUTTONDOWN, WM_RBUTTONDOWN>:
- <WM_LBUTTONUP, WM_RBUTTONUP>: Call signal_user_input in the cases
- where we preempt mouse_button_timer.
-
-2006-04-25 Miles Bader <[email protected]>
-
- * editfns.c (Ffield_beginning, find_field): Undo change of 2006-04-23.
-
-2006-04-24 Stefan Monnier <[email protected]>
-
- * process.h: Include headers for pid_t.
-
-2006-04-24 Kim F. Storm <[email protected]>
-
- * xdisp.c (fill_stretch_glyph_string): Set s->nchars = 1 for code which
- does last_glyph=s->first_glyph+s->nchars-1, e.g. if stretch has relief.
- (produce_stretch_glyph): Assume that face box height and width is
- already included in stretch glyph size so caller doesn't have to
- consider the extra space otherwise added (fixes problem in ses.el).
-
- * frame.c (x_set_font): Clear f->n_tool_bar_rows and current frame
- matrices to force recalculation of tool-bar height after font change.
-
- * xdisp.c (tool_bar_lines_needed): New local `temp_row' for clarity.
- Clear it when done, so we don't accidentally draw a second copy of
- the tool-bar after resetting f->n_tool_bar_rows.
- (redisplay_tool_bar): Update tool-bar-lines frame parameter whenever
- we recalculate f->n_tool_bar_rows.
-
-2006-04-23 Lars Hansen <[email protected]>
-
- * editfns.c (find_field): Fix comment.
- (Ffield_beginning): Fix bug when POS is at field beginning.
-
-2006-04-22 Eli Zaretskii <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 1205000.
-
-2006-04-21 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Fix last change. Don't recenter if
- window start is at BEGV.
-
- * dispextern.h (struct image): New member `corners'.
- (TOP_CORNER, LEFT_CORNER, BOT_CORNER, RIGHT_CORNER): New macros.
-
- * image.c (four_corners_best): New arg CORNERS specifies what pixels
- to look at in case image has margin.
- (x_create_bitmap_mask): Pass NULL for CORNERS to four_corners_best.
- (image_background, image_background_transparent)
- (x_build_heuristic_mask): Pass img->corners to four_corners_best.
- (gif_load): Set img->corners according to image's margin spec.
- Use img->corners values directly where applicable.
- Save image extension data in img->data.lisp_val.
- (gif_clear_image): New function to free img->data.lisp_val.
- (gif_type): Use it instead of generic x_clear_image.
- (Fimage_extension_data): New defun.
- (syms_of_image): Defsubr it.
-
-2006-04-21 John Sullivan <[email protected]> (tiny change)
-
- * window.c (Fdisplay_buffer): Doc fix.
-
-2006-04-21 Eli Zaretskii <[email protected]>
-
- * s/ms-w32.h (SYSTEM_PURESIZE_EXTRA): Increase to 25000.
-
-2006-04-21 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c [MAC_OS] (xpm_load_image): Fill in background field
- while we have ximg handy.
-
- * macmenu.c (restore_menu_items, save_menu_items): New functions
- from xmenu.c.
- (set_frame_menubar, digest_single_submenu): Apply 2006-04-18
- changes for xmenu.c.
-
- * macterm.c (x_per_char_metric): Return NULL if glyph width is 0.
- (add_mac_font_name): New function.
- (init_font_name_table): Use it. Adopt the first found font from
- those having the same family name.
-
-2006-04-21 Nick Roberts <[email protected]>
-
- * xdisp.c (note_mouse_highlight): Use build_string.
-
-2006-04-20 Lars Hansen <[email protected]>
-
- * textprop.c (Fremove_list_of_text_properties):
- Ensure modify_region is called only when buffer is modified and that
- signal_after_change is allways called in that case.
-
- * print.c (PRINTFINISH): Call signal_after_change.
-
-2006-04-20 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Fix last change.
-
- * xdisp.c (redisplay_window): If current window start is not at the
- beginning of a line, select a new window start if buffer is modified
- and window start is in the modified region, but the first change is
- before window start.
-
-2006-04-18 Richard Stallman <[email protected]>
-
- * xmenu.c (restore_menu_items, save_menu_items): New fns.
- (set_frame_menubar): Use save_menu_items. Save updated vector in
- the frame before unwinding it. Don't use unuse_menu_items.
- Don't use discard_menu_items.
- (digest_single_submenu): Abort if an item is not in a pane.
- (init_menu_items): Put the error check at the top.
-
- * keymap.c (describe_map): Make "shadowed" warning more verbose.
-
- * window.c (adjust_window_trailing_edge): Correctly distinguish
- series vs parallel cases, even when window has no parent.
-
- * abbrev.c (record_symbol): New function.
- (Finsert_abbrev_table_description): Sort the abbrevs alphabetically.
-
-2006-04-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c (x_create_bitmap_from_data) [MAC_OS]: Don't check return
- value of xmalloc.
-
- * mac.c (mac_coerce_file_name_ptr, mac_coerce_file_name_desc)
- (create_apple_event_from_event_ref, xrm_get_preference_database)
- (cfstring_create_normalized): Don't check return value of xmalloc.
-
- * macselect.c (get_scrap_target_type_list, defer_apple_events)
- (copy_scrap_flavor_data, mac_handle_service_event): Don't check
- return value of xmalloc/xrealloc.
-
- * macterm.c (XCreateGC, x_per_char_metric, xlfdpat_create)
- (init_font_name_table, init_font_name_table, mac_do_list_fonts)
- (XLoadQueryFont, mac_store_apple_event): Don't check return value
- of xmalloc.
-
-2006-04-17 Kim F. Storm <[email protected]>
-
- * window.c (coordinates_in_window): On the vertical border,
- calculate the row number measured from the top of the window, not
- the top of the frame.
- (window_loop): Test w->dedicated with !NILP instead of EQ Qt.
- (window_scroll_pixel_based): Fix off-by-one bug in 2002-12-23 change.
-
-2006-04-16 Eli Zaretskii <[email protected]>
-
- * s/ms-w32.h (SYSTEM_PURESIZE_EXTRA): Reduce to 24000.
-
-2006-04-16 Romain Francoise <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Decrement back to 1200000.
-
-2006-04-16 Andreas Schwab <[email protected]>
-
- * puresize.h (PURESIZE_RATIO): Reduce to 10/6.
-
-2006-04-15 Romain Francoise <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment to 1210000.
-
-2006-04-13 Micha,Ak(Bl Cadilhac <[email protected]>
-
- * print.c (Fprin1_to_string): Mention in the `doc' that the
- behavior is modified by `print-level' and `print-length'.
-
-2006-04-13 Kenichi Handa <[email protected]>
-
- * coding.c (setup_coding_system): If eol-type is not yet decided
- and system_eol_type is not LF, set CODING_REQUIRE_ENCODING_MASK.
- If coding_system is nil, return 0.
- (code_convert_region1): Even if coding_system is nil, don't skip
- conversion if system_eol_type is not LF.
- (code_convert_string1): Likewise.
- (code_convert_string_norecord): Likewise.
-
-2006-04-13 Kenichi Handa <[email protected]>
-
- * coding.c (setup_coding_system): Fix previous change.
- (encode_coding): If eol_type is not yet decided, use system_eol_type.
- (shrink_encoding_region): If eol_type is not yet decided and
- system_eol_type is not LF, don't shrink.
-
-2006-04-13 Nick Roberts <[email protected]>
-
- * xdisp.c (note_mouse_highlight): Add help echo for dragging vertical
- line.
-
-2006-04-12 Richard Stallman <[email protected]>
-
- * keyboard.c (read_key_sequence): Explicitly avoid keybuf[-1].
-
- * process.c (conv_lisp_to_sockaddr): If FAMILY unknown, just return.
- (Fprocess_send_eof): Abort if fail to open null device.
-
-2006-04-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * fns.c [HAVE_MENUS && MAC_OS]: Include macterm.h.
-
- * image.c [MAC_OS] (xpm_load_image): Add parentheses around
- assignment used as truth value. Add explicit braces to avoid
- ambiguous `else'.
- [MAC_OS] (gif_load): Remove unused variable `gcpro1'.
-
- * lisp.h (syms_of_fontset, Fset_fontset_font): Put extern and
- EXFUN in #ifdef HAVE_WINDOW_SYSTEM.
- (syms_of_xfns, syms_of_xsmfns, syms_of_xselect, syms_of_xterm):
- Put externs in #ifdef HAVE_X_WINDOWS.
- (syms_of_macfns, syms_of_macselect, syms_of_macterm)
- (syms_of_macmenu, syms_of_mac) [MAC_OS]: Add externs.
- (init_mac_osx_environment) [MAC_OSX]: Add extern.
-
- * mac.c (init_process): Remove undef.
- (select) [MAC_OSX]: Undefine before including sysselect.h.
- (posix_pathname_to_fsspec, fsspec_to_posix_pathname) [MAC_OSX]:
- Remove functions and prototypes.
- (parse_value): Add parentheses around + inside shift.
- (path_from_vol_dir_name): Make static.
- (get_temp_dir_name): Remove unused variables `cpb' and `dir_name'.
- [!MAC_OSX] (get_path_to_system_folder): Likewise.
- (Fmac_get_file_creator, Fmac_get_file_type): Remove unused
- variable `cCode'.
- (Fmac_coerce_ae_data): Remove unused variables `fref' and `fs'.
- (Fmac_get_preference): Add explicit braces to avoid ambiguous `else'.
-
- * macfns.c (x_to_mac_color): Remove unused variable `tail'.
- (x_set_mouse_color): Remove unused variable `dpy'.
- (Fx_create_frame): Remove unused variable `x_frame_count'.
- (Fx_server_version): Add explicit braces to avoid ambiguous `else'.
- (x_sync): Move from macterm.c.
- (Fx_file_dialog): Remove unused variable `default_filter_index'.
-
- * macmenu.c (min_menu_id): Make element type explicit.
-
- * macselect.c (get_flavor_type_from_symbol): Remove unused
- variable `val'.
- (get_scrap_private_timestamp, x_get_foreign_selection)
- (copy_scrap_flavor_data): Add explicit braces to avoid ambiguous `else'.
- (Fmac_process_deferred_apple_events): Remove unused variables
- `keyword', `reply', `apple_event', `count', and `err'.
-
- * macterm.c: Don't include gnu.h.
- (x_io_error_quitter, x_draw_image_foreground_1): Remove prototypes.
- (x_sync): Move to macfns.c.
- [USE_CG_DRAWING] (mac_define_fringe_bitmap): Remove unused
- variable `mask_bits'.
- (mac_compute_glyph_string_overhangs): Avoid ambiguous `else'.
- (x_draw_image_glyph_string): Remove unused variable `pixmap'.
- (x_mac_to_emacs_modifiers): Remove function.
- (XTset_vertical_scroll_bar, mac_handle_visibility_change)
- (x_make_frame_visible, xlfdpat_create, mac_handle_command_event):
- Add explicit braces to avoid ambiguous `else'.
- (x_make_frame_visible): Remove unused variables `type',
- `original_top', and `original_left'.
- (mac_do_list_fonts, XTread_socket): Add parentheses around && within ||.
- (x_load_font): Remove unused variables `full_name', and `value'.
- (do_get_menus, do_init_managers, do_check_ram_size) [!MAC_OS8]:
- Remove functions.
- (do_zoom_window): Reorganize variables with respect to conditionals.
- (init_command_handler): Remove unused variable `err'.
- [MAC_OSX] (mac_check_bundle): Remove unused variable `child'.
-
- * macterm.h (x_set_mouse_position, x_set_mouse_pixel_position)
- (x_make_frame_invisible, x_iconify_frame, x_free_frame_resources)
- (x_destroy_window, x_wm_set_size_hint, x_delete_display, XFreeGC)
- (do_menu_choice, have_menus_p, x_real_positions)
- (x_set_menu_bar_lines, x_pixel_width, x_pixel_height, x_char_width)
- (x_char_height, x_sync, x_set_tool_bar_lines, x_activate_menubar)
- (free_frame_menubar): Add externs.
-
- * unexmacosx.c: Include config.h before using HAVE_MALLOC_MALLOC_H.
- (malloc, realloc, free): Add undefs.
- (read_load_commands): Remove unused variable `n' and `j'.
- (copy_data_segment): Remove unused variable `r'.
-
- * xdisp.c (get_glyph_string_clip_rects): Add parentheses around &&
- within ||. Add explicit braces to avoid ambiguous `else'.
- (dump_glyph_row): Remove label for `inverse_p' from legend.
-
- * xfaces.c (Finternal_merge_in_global_face, try_font_list):
- Add explicit braces to avoid ambiguous `else'.
-
-2006-04-11 Micha,Ak(Bl Cadilhac <[email protected]>
-
- * dispnew.c (init_display): Don't init X display if the user asked
- for a non-X display.
-
-2006-04-12 Kenichi Handa <[email protected]>
-
- * coding.c (setup_coding_system): Use system_eol_type for default
- coding->eol_type.
-
-2006-04-11 Dan Nicolaescu <[email protected]>
-
- * lisp.h (wrong_type_argument): Mark as NO_RETURN.
-
- * data.c (wrong_type_argument): Try to avoid compiler warnings due
- to the fact the function is now marked as NO_RETURN.
-
-2006-04-10 Eli Zaretskii <[email protected]>
-
- * s/ms-w32.h (pid_t) [_MSC_VER]: New typedef.
-
-2006-04-10 Romain Francoise <[email protected]>
-
- * xrdb.c (gethomedir): Use xstrdup.
-
-2006-04-10 Andreas Schwab <[email protected]>
-
- * xrdb.c (gethomedir): Make sure to always return a pointer that
- can be passed to free.
-
-2006-04-09 Richard Stallman <[email protected]>
-
- * lisp.h (Fkill_emacs): Undo previous change.
-
-2006-04-08 Richard Stallman <[email protected]>
-
- * search.c (boyer_moore): Test ch >= 0400, not >.
-
-2006-04-09 Dan Nicolaescu <[email protected]>
-
- * puresize.h (pure_write_error): Mark as NO_RETURN.
-
- * lisp.h (args_out_of_range, args_out_of_range_3, Fkill_emacs):
- Likewise.
-
-2006-04-08 Eli Zaretskii <[email protected]>
-
- * w32fns.c (w32_wnd_proc) <WM_MOUSEMOVE>: Ignore mouse movements
- if a menu is active on this frame.
-
-2006-04-08 Dan Nicolaescu <[email protected]>
-
- * lisp.h (report_file_error): Mark as NO_RETURN.
-
-2006-04-08 Eli Zaretskii <[email protected]>
-
- * alloc.c [STDC_HEADERS]: Include stddef.h.
-
- * lisp.h (PSEUDOVECSIZE): Fix last change.
-
-2006-04-08 Stefan Monnier <[email protected]>
-
- * process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
- `raw_status_high', and `raw_status_low' with plain integers, and move
- them to the end of the structure.
-
- * alloc.c (allocate_process): Use PSEUDOVECSIZE to initialize the
- pseudovector's size field so only the Lisp_Object fields get GC'd.
-
- * process.c (update_status, make_process, Fdelete_process)
- (Fprocess_status, list_processes_1, start_process_unwind)
- (create_process, Fmake_network_process, server_accept_connection)
- (wait_reading_process_output, send_process, Fprocess_running_child_p)
- (process_send_signal, proc_encode_coding_system, Fprocess_send_eof)
- (sigchld_handler, status_notify): Adjust to new non-Lisp fields for
- `pid' and `raw_status'.
- (Fprocess_id, Fsignal_process): Same, and additionally use floats when
- representing PIDs that are larger than most-positive-fixnum.
-
- * keymap.c (describe_map): Only use XINT if we checked INTEGERP.
-
- * lisp.h (OFFSETOF, PSEUDOVECSIZE): New macros.
-
-2006-04-08 Eli Zaretskii <[email protected]>
-
- * w32fns.c (Fx_show_tip): Add 3 to the 5th arg of SetWindowPos.
-
-2006-04-03 Paul Eggert <[email protected]>
-
- * editfns.c (TM_YEAR_IN_ASCTIME_RANGE): New macro, identical to
- ../lib-src/b2m.c and ../lib-src/editfns.c.
- (Fcurrent_time_string): Use it.
- Document that the year might not consume 4 columns if it's outside
- the range 1000-9999.
- Check for asctime failure.
- Don't assume that the output string length is always exactly 24.
-
-2006-04-03 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (XTread_socket): Initialize variable `f' before its use.
-
-2006-04-03 Kenichi Handa <[email protected]>
-
- * image.c: Include "charset.h" and "coding.h".
- (x_find_image_file): Return an encoded file name.
-
-2006-04-01 Eli Zaretskii <[email protected]>
-
- * configure: Regenerated.
-
-2006-03-31 Kenichi Handa <[email protected]>
-
- * xfns.c (xg_set_icon): Delete superfluous UNGCPRO.
-
-2006-03-30 Dan Nicolaescu <[email protected]>
-
- * xdisp.c (syms_of_xdisp): Fix variable name.
-
-2006-03-30 Kenichi Handa <[email protected]>
-
- * xterm.c (x_term_init): Delete superfluous UNGCPRO.
-
-2006-03-29 Juanma Barranquero <[email protected]>
-
- * keyboard.c (process_tool_bar_item): Reorder dummy args.
-
-2006-03-29 Stefan Monnier <[email protected]>
-
- * keyboard.c (tool_bar_items): Use map_keymap.
- (process_tool_bar_item): Add dummy args to fit the required interface.
-
-2006-03-25 Eli Zaretskii <[email protected]>
-
- * .gdbinit (pr, pp, pp1, pv, pv1): Force print_output_debug_flag
- to zero before calling debug_print or safe_debug_print.
-
- * print.c (print_output_debug_flag): New global variable.
- (Fexternal_debugging_output) [WINDOWSNT]: Don't call
- OutputDebugString if print_output_debug_flag is zero.
-
-2006-03-24 Paul Eggert <[email protected]>
-
- * editfns.c (TM_YEAR_BASE): Move up, so the changes below can use it.
- (Fdecode_time, Fencode_time): Use TM_YEAR_BASE instead of 1900.
- (Fdecode_time): Cast tm_year to EMACS_INT.
- (Fcurrent_time_string): Report an invalid time specification if
- the argument is invalid. Also, check for out-of-range time stamps.
-
-2006-03-24 Kim F. Storm <[email protected]>
-
- * xterm.c (handle_one_xevent):
- * w32term.c (w32_read_socket):
- * macterm.c (XTread_socket): Don't let key-press clear mouse face
- on in toolbar window if mouse-highlight is an integer.
-
- * fns.c (sxhash_list): Include last non-nil CDR in hash.
-
-2006-03-24 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (enum mac_menu_kind): New enum.
- (min_menu_id): New variable.
- (POPUP_SUBMENU_ID, MIN_POPUP_SUBMENU_ID, MIN_MENU_ID)
- (MIN_SUBMENU_ID): Remove defines. All uses are replaced with
- min_menu_id and enumerators in enum mac_menu_kind.
- (fill_menu, dispose_menus, install_menu_quit_handler): New arg KIND.
- All uses changed. Add range check for menu ID.
- (fill_menubar): Add range check for menu ID.
- [HAVE_CANCELMENUTRACKING] (menu_quit_handler): Check error code of
- GetEventParameter.
- (set_frame_menubar, mac_menu_show): Call install_menu_quit_handler
- for each menu kind.
-
-2006-03-22 Kim F. Storm <[email protected]>
-
- * xdisp.c: Undo 2006-03-21 change.
-
- * term.c: Define aliases for append_glyph and produce_stretch_glyph
- when `static' is defined to avoid name clash with those in xdisp.c.
-
- * process.c (Faccept_process_output): Fix to comply with lisp
- reference. Change arg "timeout" to "seconds" and allow both
- integer and float value. Change arg "timeout-msec" to "millisec"
- and interpret" as milliseconds rather than microseconds. Fix doc
- string accordingly.
-
-2006-03-21 Ken Raeburn <[email protected]>
-
- * xdisp.c (store_next_glyph): Rename from append_glyph.
- (generate_stretch_glyph): Rename from produce_stretch_glyph.
- All callers changed accordingly.
-
-2006-03-21 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c: x_session_initialized new variable.
- (x_term_init): Use x_session_initialized to check if
- x_session_initialize should be called.
- (x_initialize): Initialize x_session_initialized.
-
-2006-03-21 Kim F. Storm <[email protected]>
-
- * fringe.c (draw_fringe_bitmap): Don't calculate default overlay arrow
- bitmap here, but ...
- (update_window_fringes): ... here, so we can test if it has changed.
-
-2006-03-20 Andreas Schwab <[email protected]>
-
- * dispnew.c (init_display): Check DISPLAY here.
-
- * emacs.c (main): Don't check here.
-
- * xterm.c (x_display_ok): Don't use DISPLAY env var.
-
-2006-03-20 Stefan Monnier <[email protected]>
-
- * window.c (window_scroll_pixel_based): Yet another int/Lisp_Object
- mixup (YAILOM).
-
-2006-03-20 Eli Zaretskii <[email protected]>
-
- * emacs.c (main): Fix last change.
-
-2006-03-20 Kenichi Handa <[email protected]>
-
- * fileio.c (Fwrite_region): Set visit_file to Qnil before GCPRO it.
-
- * keymap.c (map_keymap): Set tail to Qnil before GCPRO it.
-
- * xfns.c (xg_set_icon): Remove unnecessary GCPRO.
-
- * xterm.c (x_term_init): Remove unnecessary GCPRO.
-
-2006-03-19 Kim F. Storm <[email protected]>
-
- * xdisp.c (set_cursor_from_row): Fix cursor property on overlay string,
- so it doesn't associate overlay string with following glyph by default.
- Allow integer property value to specify explicit number of buffer
- positions associate with overlay string.
-
-2006-03-18 Chong Yidong <[email protected]>
-
- * xterm.c (x_display_ok): Fix minor bug and compilation warnings.
-
-2006-03-18 Nozomu Ando <[email protected]>
-
- * m/pmax.h (BROKEN_NOCOMBRELOC) [__NetBSD__]: Define.
- (LIB_STANDARD, START_FILES) [__NetBSD__]: Don't define.
- (START_FILES, RUN_TIME_REMAP, UNEXEC) [__NetBSD__, __OpenBSD__]:
- Don't redefine.
-
- * m/mips.h: Don't use unexmips on NetBSD.
- (LIBS_MACHINE): Move definition lower, so it doesn't use
- LD_SWITCH_MACHINE, START_FILES, LIB_STANDARD, LIBS_TERMCAP,
- C_SWITCH_MACHINE, and C_DEBUG_SWITCH.
-
- * unexelf.c [BROKEN_NOCOMBRELOC]: Include assert.h.
- (unexec) [BROKEN_NOCOMBRELOC]: Handle platforms whose nocombreloc
- option is broken (e.g., MIPS/NetBSD).
-
-2006-03-18 Craig McDaniel <[email protected]> (tiny change)
-
- * sheap.c (STATIC_HEAP_SIZE): Enlarge STATIC_HEAP_SIZE to 12MB.
- Remove the HAVE_X_WINDOWS conditional.
-
-2006-03-18 Vivek Dasmohapatra <[email protected]> (tiny change)
-
- * emacs.c (main): If user asks for a display that is unavailable,
- simulate -nw.
-
- * xterm.c (x_display_ok): New function.
-
- * xterm.h: Add prototype for x_display_ok.
-
-2006-03-18 Eli Zaretskii <[email protected]>
-
- * w32fns.c (Fw32_select_font): Doc fix.
-
-2006-03-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c [MAC_OS] (XPutPixel, XGetPixel)
- [!WORDS_BIG_ENDIAN && USE_CG_DRAWING]: Don't use specialized
- version when depth is 32.
- (mac_create_cg_image_from_image) [MAC_OS && USE_CG_DRAWING]:
- New function.
- (prepare_image_for_display) [MAC_OS && USE_CG_DRAWING]: Use it.
- (x_clear_image_1) [MAC_OS && USE_CG_DRAWING]: Release CGImage.
-
- * macterm.c (XCreatePixmap) [!WORDS_BIG_ENDIAN && USE_CG_DRAWING]:
- Create GWorld in ARGB pixel format.
- (mac_copy_area, mac_copy_area_with_mask) [USE_CG_DRAWING]:
- Remove functions.
- (x_draw_image_foreground) [USE_CG_DRAWING]: Use mac_draw_cg_image
- instead of mac_copy_area/mac_copy_area_with_mask.
-
-2006-03-15 Kim F. Storm <[email protected]>
-
- * xdisp.c (extend_face_to_end_of_line): Always add space glyph to
- empty row. Fixes memory corruption revealed by 2006-03-02 change.
- (display_tool_bar_line): Skip empty tool-bar line if HEIGHT < 0.
- (tool_bar_lines_needed): Fix tool-bar display in case the tool-bar
- width is exactly the same as the window width. Don't count a final
- empty tool-bar line (pass HEIGHT = -1 to display_tool_bar_line).
-
-2006-03-15 Juanma Barranquero <[email protected]>
-
- * fringe.c (w32_init_fringe, w32_reset_fringes): Revert to being
- conditional on HAVE_NTGUI, not WINDOWS_NT.
-
-2006-03-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * dispextern.h (mac_init_fringe) [MAC_OS]: Add prototype.
-
- * fringe.c (mac_init_fringe) [MAC_OS]: New function.
-
- * macterm.c (mac_initialize) [USE_CG_DRAWING]: Call mac_init_fringe.
- (max_fringe_bmp, fringe_bmp) [USE_CG_DRAWING]: New variables.
- (mac_define_fringe_bitmap, mac_destroy_fringe_bitmap)
- (mac_draw_cg_image) [USE_CG_DRAWING]: New functions.
- (mac_draw_bitmap) [USE_CG_DRAWING]: Remove function.
- (x_draw_fringe_bitmap) [USE_CG_DRAWING]: Use mac_draw_cg_image
- instead of mac_draw_bitmap.
- (x_redisplay_interface) [USE_CG_DRAWING]: Set handlers for
- define_fringe_bitmap and destroy_fringe_bitmap.
-
-2006-03-14 Chong Yidong <[email protected]>
-
- * xterm.c (x_uncatch_errors): Block input for entire function.
-
-2006-03-12 Jason Rumney <[email protected]>
-
- * w32fns.c (Fx_create_frame): Remove call to
- Qface_set_after_frame_default (from xfns.c 2003-05-26).
-
- * w32menu.c (Fx_popup_menu): Call w32_free_menu_strings when
- finished with the menu.
-
- * w32term.c: Sync 2005-10-24 xterm.c changes.
- (last_mouse_glyph_frame): New var.
- (note_mouse_movement): Say mouse moved if current frame differs
- from last_mouse_glyph_frame, and update last_mouse_glyph_frame.
- (w32_mouse_position): Set last_mouse_glyph_frame.
- Remove OLD_REDISPLAY_CODE block.
-
-2006-03-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * macgui.h [USE_ATSUI && MAC_OSX]: Define USE_CG_TEXT_DRAWING to 1.
-
- * macterm.h (struct mac_output) [USE_CG_DRAWING]: New member cg_context.
- (mac_prepare_for_quickdraw) [USE_CG_DRAWING]: Add prototype.
-
- * mac.c (sys_select) [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw.
-
- * macfns.c (x_create_tip_frame): Apply 2006-03-11 change for xfns.c.
-
- * macterm.c (mac_draw_rectangle, x_draw_glyph_string_foreground)
- (x_draw_composite_glyph_string_foreground)
- (x_draw_image_foreground): Undo previous changes.
- (x_draw_hollow_cursor): Likewise. Subtract 1 from the last
- argument of mac_draw_rectangle.
- (CG_SET_FILL_COLOR, CG_SET_STROKE_COLOR): New macros.
- (mac_draw_string_common, mac_draw_image_string_cg): Use them.
- (FRAME_CG_CONTEXT) [USE_CG_DRAWING]: New macro.
- (mac_begin_cg_clip, mac_end_cg_clip, mac_prepare_for_quickdraw)
- [USE_CG_DRAWING]: New functions.
- (mac_draw_line, mac_erase_rectangle, mac_clear_window)
- (mac_fill_rectangle, mac_draw_rectangle, mac_draw_string_common)
- (mac_draw_image_string_cg) [USE_CG_DRAWING]: Add Quartz 2D drawing part.
- (mac_draw_bitmap, mac_invert_rectangle, mac_draw_string_common)
- (mac_copy_area, mac_scroll_area, x_scroll_bar_create)
- (x_scroll_bar_remove, XTset_vertical_scroll_bar, x_set_window_size)
- (XTread_socket) [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw.
-
-2006-03-12 L$,1 q(Brentey K,Aa(Broly <[email protected]>
-
- * xfns.c (x_icon): Disable redundant call to `x_wm_set_window_state'.
-
-2006-03-11 Jason Rumney <[email protected]>
-
- * w32fns.c (signal_user_input): New function.
- (post_character_message): Use it for keyboard input.
- (w32_msg_pump): Use it for mouse input.
-
-2006-03-11 Luc Teirlinck <[email protected]>
-
- * window.c: Rename preserve_y to window_scroll_pixel_based_preserve_y.
- (window_scroll_pixel_based, syms_of_window): Adapt to above change.
-
-2006-03-11 Eli Zaretskii <[email protected]>
-
- * w32fns.c (w32_wnd_proc): Ignore middle and extra button events
- if a menu is already active (the menubar_active flag is on).
-
-2006-03-11 David Ponce <[email protected]>
-
- * xfns.c (x_create_tip_frame): Preserve received parms by copying them.
-
-2006-03-11 Eli Zaretskii <[email protected]>
-
- * w32term.c: Add x_fully_uncatch_errors and x_catching_errors to
- the list of unused display error handling functions.
-
- * eval.c (unwind_to_catch): Call x_fully_uncatch_errors only if
- HAVE_X_WINDOWS.
- (internal_condition_case, internal_condition_case_1)
- (internal_condition_case_2): Call x_catching_errors only if
- HAVE_X_WINDOWS.
-
- * vm-limit.c [HAVE_GETRLIMIT]: Don't define unconditionally.
- Don't include sys/resource.h unless defined.
-
-2006-03-11 Richard Stallman <[email protected]>
-
- * keymap.c (describe_map): Shorten string to indicate shadowed binding.
-
- * vm-limit.c (get_lim_data, lim_data, data_space_start):
- Move from mem-limits.h.
- (enum warnlevel): New data type.
- (check_memory_limits): Rewrite the logic about warnings.
- Use standard `struct rlimit'. Check return values for nonsense.
- (memory_warnings): Always clear lim_data.
-
- * mem-limits.h (get_lim_data, lim_data, data_space_start):
- Move to vm-limit.c.
-
- * xterm.c (x_fully_uncatch_errors, x_catching_errors): New functions.
-
- * eval.c (unwind_to_catch): Call x_fully_uncatch_errors.
- (internal_condition_case_1, internal_condition_case_2):
- Abort if within unclosed x_catch_errors.
-
-2006-03-11 Romain Francoise <[email protected]>
-
- * process.c (Vprocess_adaptive_read_buffering): Doc fix.
-
-2006-03-11 Giorgos Keramidas <[email protected]> (tiny change)
-
- * lisp.h: Remove duplicate prototypes. Make the prototype of
- getloadavg be conditioned on HAVE_GETLOADAVG being undefined.
-
-2006-03-11 Eli Zaretskii <[email protected]>
-
- * xterm.c (x_draw_hollow_cursor): Subtract 1 from the last
- argument of XDrawRectangle.
-
- * xdisp.c (get_phys_cursor_geometry): Don't decrease height by 1.
-
- * macterm.c (mac_draw_rectangle): Don't add 1 to width and height.
- (x_draw_glyph_string_foreground)
- (x_draw_composite_glyph_string_foreground)
- (x_draw_image_foreground): Don't subtract 1 from width and height
- arguments to mac_draw_rectangle.
- (x_draw_hollow_cursor): Add 1 to w->phys_cursor_width.
-
-2006-03-10 Kim F. Storm <[email protected]>
-
- * alloc.c (USE_POSIX_MEMALIGN): Fix last change.
-
-2006-03-09 Stefan Monnier <[email protected]>
-
- * alloc.c (USE_POSIX_MEMALIGN): New macro.
- (ABLOCKS_BASE, lisp_align_malloc, lisp_align_free): Use it.
-
-2006-03-09 Kenichi Handa <[email protected]>
-
- * coding.c (DECODE_EMACS_MULE_COMPOSITION_CHAR): Fix decoding
- ASCII component of a composition.
-
-2006-03-08 Luc Teirlinck <[email protected]>
-
- * window.c: Declare preserve_y as a static global variable.
- (window_scroll_pixel_based): No longer declare preserve_y;
- it is global now.
- (syms_of_window): Set preserve_y to -1.
-
-2006-03-08 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c [MAC_OS] (XPutPixel): Set alpha channel bits if pixmap
- depth is 32.
- [MAC_OS] (XGetPixel): Strip off alpha channel bits if pixmap
- depth is 32.
-
-2006-03-06 Chong Yidong <[email protected]>
-
- * xdisp.c (handle_invisible_prop): Don't update it->position with
- a buffer position if we're in a display string.
-
-2006-03-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.h (MAC_AQUA_VERTICAL_SCROLL_BAR_WIDTH)
- (MAC_AQUA_SMALL_VERTICAL_SCROLL_BAR_WIDTH): New defines.
-
- * macfns.c (x_default_scroll_bar_color_parameter)
- (x_set_scroll_bar_foreground, x_set_scroll_bar_background):
- Remove unnecessary prototypes.
- (x_set_scroll_bar_default_width):
- Use MAC_AQUA_VERTICAL_SCROLL_BAR_WIDTH.
- (mac_set_scroll_bar_width): New function.
- (mac_frame_parm_handlers): Set it as handler for scroll-bar-width.
-
- * macterm.c (get_control_part_bounds): Fix type of return value.
- (x_set_toolkit_scroll_bar_thumb, x_scroll_bar_create)
- (XTset_vertical_scroll_bar) [USE_TOOLKIT_SCROLL_BARS]: Don't show
- scroll bar if it is not tall enough to display scroll bar thumb.
- [USE_CARBON_EVENTS] (mac_convert_event_ref)
- (mac_handle_command_event, mac_handle_window_event)
- (mac_handle_mouse_event): Check error code of GetEventParameter.
- (convert_fn_keycode) [MAC_OSX]: Likewise.
-
-2006-03-05 Andreas Schwab <[email protected]>
-
- * xselect.c (x_catch_errors_unwind): Fix missing return value.
-
-2006-03-02 Kim F. Storm <[email protected]>
-
- * frame.h (struct frame): New member n_tool_bar_rows.
-
- * xdisp.c: Minimize the unpleasent visual impact of the requirement
- that non-toolkit tool-bars must occupy an integral number of screen
- lines, by distributing the rows evenly over the tool-bar screen area.
- (Vtool_bar_border): New variable.
- (syms_of_xdisp): DEFVAR_LISP it.
- (display_tool_bar_line): Add HEIGHT arg for desired row height.
- Make tool-bar row the desired height. Use default face for border
- below tool-bar.
- (tool_bar_lines_needed): Add N_ROWS arg. Use it to return number of
- actual tool-bar rows.
- (redisplay_tool_bar): Calculate f->n_tool_bar_rows initially.
- Adjust the height of the tool-bar rows to fill tool-bar screen area.
- (redisplay_tool_bar): Calculate f->n_tool_bar_rows when tool-bar area
- is resized.
-
-2006-03-01 Luc Teirlinck <[email protected]>
-
- * search.c (Fregexp_quote): Do not precede a literal `]' with two
- backslashes to try to make clear that it has a literal meaning; it
- does not do that. (It could close a character alternative
- containing a backslash.)
-
-2006-02-28 Chong Yidong <[email protected]>
-
- * xselect.c (x_catch_errors_unwind): New function.
- (x_reply_selection_request): Put x_uncatch_errors in an unwind.
- (Fx_get_atom_name): Call x_uncatch_errors earlier.
-
- * window.c (Qscroll_up, Qscroll_down): New syms.
- (window_scroll_pixel_based): Make preserve_y static to avoid
- getting point stuck when scrolling 1 line.
-
-2006-02-26 Chong Yidong <[email protected]>
-
- * xterm.h, xterm.c (x_uncatch_errors): Delete unneccessary argument.
-
- * xterm.c (x_load_font, x_term_init, XTmouse_position)
- (handle_one_xevent, x_connection_closed, x_list_fonts):
- No arg for x_uncatch_errors.
-
- * xselect.c (x_own_selection, x_decline_selection_request)
- (x_reply_selection_request, x_get_foreign_selection)
- (Fx_get_atom_name, Fx_send_client_event): Likewise.
-
- * xfns.c (x_real_positions, x_set_mouse_color, Fx_focus_frame):
- Likewise.
-
-2006-02-26 Luc Teirlinck <[email protected]>
-
- * lread.c: Declare Vload_file_rep_suffixes instead of
- deleted variable default_suffixes.
- (Fget_load_suffixes): New function.
- (Fload): Use Fget_load_suffixes and Vload_file_rep_suffixes.
- No longer use deleted variable default_suffixes. Update docstring.
- (syms_of_lread): defsubr Sget_load_suffixes.
- Expand `load-suffixes' docstring.
- Delete default_suffixes and DEFVAR_LISP the new variable
- `load-file-rep-suffixes'.
-
- * w32.c (check_windows_init_file): Use Fget_load_suffixes instead
- of Vload_suffixes.
-
- * lisp.h: EXFUN Fget_load_suffixes.
- Extern Vload_file_rep_suffixes.
-
- * eval.c (specpdl_ptr): Remove volatile qualifier for consistency
- with lisp.h.
-
-2006-02-26 Stefan Monnier <[email protected]>
-
- * lisp.h (struct specbinding, specpdl_ptr): Remove the volatile
- qualifier which was trying to avoid the bug that was fixed by
- yesterday's changes to xterm.c.
-
-2006-02-25 Chong Yidong <[email protected]>
-
- * xterm.h (x_catch_errors) Return value changed to void.
- (x_uncatch_errors): Delete unused count argument.
-
- * xterm.c (x_catch_errors): Don't use record_unwind_protect, since
- it can be called in a signal handler.
- (x_catch_errors_unwind): Function deleted.
- (x_uncatch_errors): Deallocate last x_error_message_stack struct.
- (x_check_errors): Call x_uncatch_errors before signalling error.
-
- (x_load_font, x_term_init, XTmouse_position, handle_one_xevent)
- (x_connection_closed, x_list_fonts): Use new versions of
- x_catch_errors and x_uncatch_errors.
-
- * xselect.c (x_own_selection, x_decline_selection_request)
- (x_reply_selection_request, x_get_foreign_selection)
- (Fx_get_atom_name, Fx_send_client_event): Likewise.
-
- * xfns.c (x_real_positions, x_set_mouse_color, Fx_focus_frame):
- Likewise.
-
- * eval.c (record_unwind_protect): Add an assertion.
-
-2006-02-25 Stefan Monnier <[email protected]>
-
- * process.c (Fmake_network_process): Init the process's mark.
-
-2006-02-25 Kim F. Storm <[email protected]>
-
- * buffer.c (modify_overlay): Force redisplay if we modify an
- overlay at the end of the buffer.
-
-2006-02-24 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_image_for_pixmap): If x_find_image_file returns
- nil the image file has been removed, in that case use the (cached)
- pixmap.
-
-2006-02-24 Kenichi Handa <[email protected]>
-
- * fileio.c (Finsert_file_contents): When a text is replaced
- partially, be sure to set point before the inserted characters.
-
-2006-02-23 Zhang Wei <[email protected]> (tiny change)
-
- * xfns.c (Fx_file_dialog): Return a decoded file name.
-
-2006-02-23 YAMAMOTO Mitsuharu <[email protected]>
-
- * dispnew.c (update_text_area): Avoid needless redraw of rightmost
- glyph whose face is extended to the text area end.
-
- * macterm.c (x_set_toolkit_scroll_bar_thumb): Don't set control
- values if control is not visible or values are not changed.
-
-2006-02-22 Stefan Monnier <[email protected]>
-
- * window.c (Fwindow_list): Check `window' before doing XWINDOW.
- The default `window' should not be "on a different frame".
-
-2006-02-22 Kim F. Storm <[email protected]>
-
- * indent.c (Fvertical_motion): Only try to move back if we can.
-
-2006-02-22 YAMAMOTO Mitsuharu <[email protected]>
-
- * macgui.h (struct _XGC) [!MAC_OSX || !USE_ATSUI]: New member
- n_clip_rects.
-
- * macmenu.c (digest_single_submenu): Apply 2006-02-19 change for
- xmenu.c.
-
- * macterm.c (GC_CLIP_REGION): Remove macro.
- (mac_begin_clip, mac_end_clip): Take arg GC instead of REGION.
- All uses changed. Don't do clipping if n_clip_rects is zero.
- (mac_set_clip_rectangles): Use xassert instead of abort.
- Set n_clip_rects. Don't make clip_region empty when number of
- clipping rectangles is zero.
- (mac_reset_clip_rectangles): Set n_clip_rects directly instead of
- calling mac_set_clip_rectangles.
- (x_set_toolkit_scroll_bar_thumb): Temporarily hide scroll bar to
- avoid multiple redraws.
-
-2006-02-22 Kim F. Storm <[email protected]>
-
- * fringe.c (draw_fringe_bitmap): Fix overlay-arrow display.
-
-2006-02-21 Kim F. Storm <[email protected]>
-
- * fringe.c (syms_of_fringe) <fringe-bitmaps>: Doc fix.
-
-2006-02-21 Zhang Wei <[email protected]>
-
- * xfns.c (Fx_file_dialog, Motif and GTK): DECODE_FILE before
- returning it.
-
-2006-02-21 Giorgos Keramidas <[email protected]> (tiny change)
-
- * fringe.c (horizontal_bar_bits): Rename from `horisontal_bar_bits'.
- (standard_bitmaps): Use it.
-
-2006-02-21 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_draw_string_common): Remove arg MODE. New arg
- BG_WIDTH. All uses changed. Draw background if BG_WIDTH is not zero.
- (mac_draw_image_string, mac_draw_image_string_16): New arg BG_WIDTH.
- [USE_CG_TEXT_DRAWING] (mac_draw_image_string_cg): Rename from
- mac_draw_string_cg. New arg BG_WIDTH. All uses changed.
- Draw background if BG_WIDTH is not zero. Use float constants as
- divisors instead of double. Use alloca instead of xmalloc/xfree.
- (x_draw_glyph_string_background, x_draw_glyph_string_foreground)
- [!MAC_OS8 || USE_ATSUI]: Background may be drawn using
- mac_draw_image_string* functions.
- (XLoadQueryFont) [MAC_OS8 && USE_ATSUI]: Don't adjust heights of
- some fonts when srcCopy text transfer mode might be used.
- (mac_begin_clip, mac_end_clip): Check if region is empty.
- (mac_set_clip_rectangles): When resetting clip region, make it
- empty instead of disposing of it.
-
-2006-02-20 Kim F. Storm <[email protected]>
-
- * Makefile.in: Add fringe.elc to WINDOW_SUPPORT.
-
- * buffer.h (struct buffer): New members fringe_indicator_alist and
- fringe_cursor_alist.
-
- * buffer.c (init_buffer_once): Set dummy default values for
- fringe-indicator-alist and fringe-cursor-alist. The proper
- default values are set by pre-loading fringe.el.
- (syms_of_buffer): defvar_per_buffer new fringe-indicator-alist and
- fringe-cursor-alist buffer-local variables and defvar_lisp_nopro
- corresponding default- variables.
-
- * fringe.c (enum fringe_bitmap_type): Remove. Change all uses
- to use `int'.
- (NO_FRINGE_BITMAP, UNDEF_FRINGE_BITMAP, MAX_STANDARD_FRINGE_BITMAPS):
- Define explicitly.
- (Qtruncation, Qcontinuation, Qempty_line, Qtop_bottom)
- (Qhollow_small): New variables.
- (syms_of_fringe): Intern and staticpro them.
- (question_mark_bits): Rename from unknown_bits.
- (left_curly_arrow_bits): Rename from continuation_bits.
- (right_curly_arrow_bits): Rename from continued_bits.
- (left_triangle_bits): Rename from ov_bits.
- (right_triangle_bits): Add.
- (filled_rectangle_bits): Rename from filled_box_cursor_bits.
- (hollow_rectangle_bits): Rename from hollow_box_cursor_bits.
- (filled_square_bits): Add.
- (vertical_bar_bits): Rename from bar_cursor_bits.
- (horizontal_bar_bits): Rename from hbar_cursor_bits.
- (empty_line_bits): Rename from zv_bits.
- (standard_bitmaps): Update to use new names.
- (draw_fringe_bitmap_1): Make static.
- (get_logical_cursor_bitmap, get_logical_fringe_bitmap): New functions
- to map from logical cursors and indicators to physical bitmaps.
- (draw_fringe_bitmap): Resolve fringe cursor and overlay-arrow
- bitmaps using symbol names instead of bitmap numbers.
- (update_window_fringes): Use logical indicator symbol names
- instead of bitmap numbers for logical. Add bitmap cache.
- (LEFT_FRINGE, RIGHT_FRINGE): New helper macros.
-
-2006-02-20 Chong Yidong <[email protected]>
-
- * regex.c: Revert 2006-02-19 change.
- (xmalloc, xrealloc): Define these when not linked to Emacs.
- Redefine malloc -> xmalloc, realloc -> xrealloc as in Emacs case.
-
-2006-02-19 Luc Teirlinck <[email protected]>
-
- * regex.c (extend_range_table_work_area): Fix typo.
-
-2006-02-19 Richard M. Stallman <[email protected]>
-
- * xterm.c (x_catch_errors): Use xmalloc.
-
- * regex.c (extend_range_table_work_area): Call xmalloc and xrealloc.
- (regex_compile): Likewise.
- (regcomp): Use xmalloc.
-
- * gtkutil.c (malloc_widget_value): Use xmalloc.
-
- * vm-limit.c [HAVE_GETRLIMIT]: Include sys/resource.h.
- (check_memory_limits) [HAVE_GETRLIMIT]: Use getrlimit.
-
- * xmenu.c (digest_single_submenu): When pane_string is empty,
- do initialize save_wv.
-
-2006-02-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * xdisp.c (update_menu_bar) [MAC_OS]: Don't set
- w->update_mode_line if arg F is not the selected frame.
-
- * macmenu.c (popup_activated_flag, submenu_id)
- (next_menubar_widget_id): Remove variables.
- (initialize_frame_menubar): Remove function.
- (pop_down_menu, mac_menu_show): Simplify save value.
- (dispose_menus): New function.
- (pop_down_menu, fill_menubar): Use it.
- (fill_submenu): Remove function. All uses changed to fill_menu.
- (add_menu_item): Remove args SUBMENU and FORCE_DISABLE. New arg
- POS. Don't call SetMenuItemHierarchicalID here.
- (fill_menu): Add arg SUBMENU_ID. Return submenu_id that is to be
- used next. Call SetMenuItemHierarchicalID here.
- (fill_menubar): Add arg DEEP_P. All uses changed. Clean up menu
- objects if needed. Reuse existing menu bar titles if possible.
- (set_frame_menubar): Don't clean up menu objects here.
-
-2006-02-18 Chong Yidong <[email protected]>
-
- * window.c (window_min_size_1): Ensure room for the scroll bar and
- fringes.
-
-2006-02-17 Romain Francoise <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment to 1200000.
-
-2006-02-17 Stefan Monnier <[email protected]>
-
- * alloc.c (Fmake_symbol): Comment-out left-over assert from before the
- addition of the BLOCK_INPUTs.
-
-2006-02-17 Juanma Barranquero <[email protected]>
-
- * window.c (Fset_window_scroll_bars): Doc fix.
-
-2006-02-17 Kenichi Handa <[email protected]>
-
- * xdisp.c (display_mode_element): Call display_string with correct
- PREC arg (which must be a number of characters, not column width).
-
-2006-02-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * frame.c (x_get_arg): Clear out PARAM in ALIST also on Mac.
-
- * macfns.c (x_set_menu_bar_lines): Menu bar is always shown on Mac.
-
- * macmenu.c (set_frame_menubar): Don't call DrawMenuBar.
-
-2006-02-14 Richard M. Stallman <[email protected]>
-
- * frame.c (x_get_arg): Clear out all occurrences of PARAM in ALIST.
-
- * m/ibms390x.h: New file.
-
-2006-02-14 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_tool_bar_detach_callback): Set show-arrow to the
- value of x-gtk-whole-detached-tool-bar.
- (xg_tool_bar_attach_callback): Set show-arrow to TRUE.
-
- * xfns.c (syms_of_xfns): New variable: x-gtk-whole-detached-tool-bar.
-
-2006-02-14 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_x_to_emacs_modifiers): Make non-static.
-
- * xterm.h: Declare x_x_to_emacs_modifiers.
-
- * gtkutil.c (xg_tool_bar_button_cb): New function.
- (xg_tool_bar_callback): Call x_x_to_emacs_modifiers to
- store modifiers in event.
- (update_frame_tool_bar): Connect button-release-event to
- xg_tool_bar_button_cb.
-
-2006-02-13 Richard M. Stallman <[email protected]>
-
- * .gdbinit (xwindow): Update the code to show the window box.
-
-2006-02-13 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (note_mouse_movement): Check for NULL FRAME_X_OUTPUT (frame).
-
-2006-02-12 Richard M. Stallman <[email protected]>
-
- * cmds.c (internal_self_insert): Handle weird auto-fill-function.
-
-2006-02-11 Eli Zaretskii <[email protected]>
-
- * keyboard.c (Venable_disabled_menus_and_buttons): New variable.
- (syms_of_keyboard): DEVFAR_LISP and initialize it.
- (parse_tool_bar_item, parse_menu_item): If that variable is
- non-nil, don't disable menu items and tool-bar buttons.
-
-2006-02-11 Juanma Barranquero <[email protected]>
-
- * doc.c (Fsubstitute_command_keys): Doc fix.
-
-2006-02-10 Thien-Thi Nguyen <[email protected]>
-
- * data.c (Findirect_function): Rewrite docstring.
- Fix omission bug: Declare new arg NOERROR.
-
-2006-02-10 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (x_set_mouse_color): Don't call rif->define_frame_cursor
- if window_desc is not set yet.
- (Fx_create_frame): Remove variable x_frame_name. Apply 2005-12-07
- and 2006-01-26 changes for xfns.c. Call x_iconify_frame if frame
- parameter `visibility' is `icon'.
- (Fx_create_frame, x_create_tip_frame): Use "fontset-standard"
- instead of "fontset-mac".
- (Fx_focus_frame): New defun.
- (syms_of_macfns): Defsubr it.
-
- * macterm.c (mac_define_frame_cursor): Don't change pointer shape
- for unfocused frame.
- (x_raise_frame): Call BringToFront instead of SelectWindow.
- (x_lower_frame): Use NULL instead of nil.
- (x_make_frame_visible): Don't call SelectWindow.
- (XTread_socket): Increment handling_signal at the start, decrement
- it at the end.
- [USE_CG_TEXT_DRAWING] (init_cg_text_anti_aliasing_threshold): Use
- CFPreferencesGetAppIntegerValue instead of Fmac_get_preference.
-
-2006-02-10 Kim F. Storm <[email protected]>
-
- * data.c (Findirect_function): Add NOERROR arg. All callers changed
- to pass Qnil for NOERROR.
-
- * keymap.c (current_minor_maps_error): Remove.
- (current_minor_maps): Pass Qt for NOERROR to Findirect_function
- instead of using internal_condition_case_1+current_minor_maps_error.
-
-2006-02-09 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): Must note mouse movement even for nil
- frames for GTK, in that case it is the tool bar. This is so that
- highlighted text get reset properly.
-
-2006-02-09 Juanma Barranquero <[email protected]>
-
- * alloc.c (Fmake_bool_vector, Fpurecopy): Doc fixes.
-
-2006-02-08 Jan Dj,Ad(Brv <[email protected]>
-
- * window.c (adjust_window_trailing_edge): Check that shrinking
- does not set a window to size zero or less.
-
-2006-02-08 Miles Bader <[email protected]>
-
- * editfns.c (Fconstrain_to_field): Use Fget_char_property instead
- of Fget_text_property (other field functions work with overlays as
- well as text-properties).
-
-2006-02-07 Kenichi Handa <[email protected]>
-
- * dispextern.h (unibyte_display_via_language_environment): Extern it.
-
- * xterm.h (unibyte_display_via_language_environment):
- * w32term.h (unibyte_display_via_language_environment):
- * macterm.h (unibyte_display_via_language_environment): Delete extern.
-
-2006-02-07 Kenichi Handa <[email protected]>
-
- * term.c (append_glyph): Refer to it->char_to_display instead of it->c.
- (produce_glyphs): Set the character to print in
- it->char_to_display. Handle unibyte-display-via-language-environment.
- (produce_stretch_glyph): Set character to print in it->char_to_display.
-
-2006-02-06 Kenichi Handa <[email protected]>
-
- * lread.c (openp): Initialize encoded_fn before GCPRO it.
-
-2006-02-05 Ken Raeburn <[email protected]>
-
- * editfns.c (Fconstrain_to_field): Fix int/Lisp_Object mixup.
-
- * lisp.h (XPNTR) [!NO_UNION_TYPE && !HAVE_SHM && !DATA_SEG_BITS]:
- Cast bitfield value to EMACS_INT, to suppress gcc warning.
-
- * xrdb.c (malloc, realloc, free) [emacs]: Undefine macros before
- defining.
-
-2006-02-03 Kim F. Storm <[email protected]>
-
- * xdisp.c: Cache last merged escape glyph face.
- (last_escape_glyph_frame, last_escape_glyph_face_id)
- (last_escape_glyph_merged_face_id): New variables.
- (get_next_display_element): Use/update them.
- (redisplay_internal): Reset them before redisplay.
-
- * xdisp.c (set_iterator_to_next): Optimize 2004-12-13 fix.
- Only recheck faces after displaying ellipsis.
-
-2006-02-02 Kenichi Handa <[email protected]>
-
- * coding.c (decode_composition_emacs_mule): Fix handling of
- incorrect format data.
-
-2006-01-31 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): Use new tool bar function
- gtk_toolbar_insert() so we can have tool bars of different sizes.
-
-2006-01-30 Luc Teirlinck <[email protected]>
-
- * data.c (Flistp): Doc fix.
-
-2006-01-30 Juanma Barranquero <[email protected]>
-
- * window.c (Fother_window, Fwindow_vscroll, Fset_window_vscroll):
- Fix typos in docstrings.
-
-2006-01-28 Luc Teirlinck <[email protected]>
-
- * data.c (Fcar, Fcdr): Add links to Elisp manual to the docstrings.
-
-2006-01-27 Chong Yidong <[email protected]>
-
- * alloc.c (make_interval, allocate_string)
- (allocate_string_data, make_float, Fcons, allocate_vectorlike)
- (Fmake_symbol, allocate_misc): Use BLOCK_INPUT when accessing
- global variables.
-
-2006-01-27 Eli Zaretskii <[email protected]>
-
- * dired.c (DIRENTRY_NONEMPTY) [__CYGWIN__]: Don't use d_ino; use
- the MSDOS definition.
-
-2006-01-26 Richard M. Stallman <[email protected]>
-
- * alloc.c (check_pure_size): Make overflow message an "error message".
-
- * keymap.c (Fmap_keymap): Doc fix.
-
- * xfns.c (Fx_create_frame): Put all specified parms into f->param_alist
- unless they were cleared out.
-
- * frame.c (x_get_arg): "Clear out" the parm in ALIST if found there.
-
-2006-01-26 L$,1 q(Brentey K,Aa(Broly <[email protected]>
-
- * editfns.c (Fconstrain_to_field): Fix behaviour on field boundaries.
- (find_field): Set before_field to after_field when pos is at BEGV.
- (Fline_beginning_position, Fline_end_position):
- Clarify confusing doc string.
-
- * cmds.c (Fbeginning_of_line, Fend_of_line): Clarify confusing doc
- string.
-
-2006-01-26 Kenichi Handa <[email protected]>
-
- * callproc.c (Fcall_process): GCPRO error_file. Encode infile,
- current_dir, and error_file. On reporting an error, decode them
- back.
-
-2006-01-24 Stefan Monnier <[email protected]>
-
- * regex.c (IMMEDIATE_QUIT_CHECK): Use it with SYNC_INPUT as well.
- (re_match_2_internal) <on_failure_jump, on_failure_jump_smart>:
- Don't check for quit, since any loop will go through fail or jump.
-
-2006-01-24 Chong Yidong <[email protected]>
-
- * alloc.c (allocate_string_data): Update next_free immediately, to
- reduce risk of memory clobberage.
-
-2006-01-24 L$,1 q(Brentey K,Aa(Broly <[email protected]>
-
- * xdisp.c (handle_invisible_prop): Set it->position to fix cursor
- display when point moves across an ellipsis. If there are
- adjacent invisible texts, don't lose the second one's ellipsis.
- (x_produce_glyphs): Doc fix.
-
-2006-01-23 Stefan Monnier <[email protected]>
-
- * xterm.c (x_catch_errors_unwind): Yet another int/Lisp_Object mixup.
-
-2006-01-23 Kim F. Storm <[email protected]>
-
- * xdisp.c (handle_single_display_spec): Fix handling of space
- property on char from string: set *position rather than
- it->current.pos.
- (produce_stretch_glyph): Reduce width of stretch glyphs so they
- don't get wider than the window (unless truncate-lines is on).
-
-2006-01-22 Stefan Monnier <[email protected]>
-
- * xterm.c: Avoid allocating Lisp data from a signal handler.
- (x_error_message): New var to replace x_error_message_string.
- (x_error_catcher, x_catch_errors, x_catch_errors_unwind)
- (x_check_errors, x_had_errors_p, x_clear_errors, x_error_handler)
- (syms_of_xterm): Use it instead of x_error_message_string.
-
- * alloc.c (lisp_align_free): Add an assertion.
- (make_interval, allocate_string, make_float, Fcons, Fmake_symbol)
- (allocate_misc): If ENABLE_CHECKING is on, check we're not called from
- a signal handler.
-
-2006-01-21 Luc Teirlinck <[email protected]>
-
- * dired.c (syms_of_dired) <completion-ignored-extensions>: Doc fix.
-
-2006-01-21 Romain Francoise <[email protected]>
-
- * xdisp.c (get_window_cursor_type): Fix last change.
- Update copyright year.
-
-2006-01-20 Eli Zaretskii <[email protected]>
-
- * lread.c (Fload): Don't leak the file descriptor returned by
- openp if we are going to signal an error.
-
- * w32.c (sys_close): If FD is outside [0..MAXDESC) limits, pass it
- directly to _close.
- (sys_dup): Protect against new_fd larger than fd_info[] can handle.
- (sys_read): If FD is outside [0..MAXDESC) limits, pass it directly
- to _read.
- (sys_write): If FD is outside [0..MAXDESC) limits, pass it
- directly to _write.
-
- * .gdbinit: Don't dereference Vsystem_type's Lisp_Symbol pointer
- if it is NULL.
-
-2006-01-20 Kenichi Handa <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment to 1190000.
-
-2006-01-19 Chong Yidong <[email protected]>
-
- * xdisp.c (get_window_cursor_type): Use cursor type specified by
- the selected buffer for the echo area too.
-
-2006-01-19 Richard M. Stallman <[email protected]>
-
- * keymap.c (Fmap_keymap): Doc fix.
-
- * s/irix6-5.h (GC_SETJMP_WORKS, GC_MARK_STACK): New definitions.
-
- * keyboard.c (echo_char): Don't omit the space between first two
- echoed chars.
-
- * minibuf.c (read_minibuf): Fix previous change.
-
-2006-01-19 Kenichi Handa <[email protected]>
-
- * xterm.c (handle_one_xevent): Handle keysyms 0x1000000..0x10000FF.
-
-2006-01-17 Richard M. Stallman <[email protected]>
-
- * frame.c (x_frame_get_and_record_arg): Don't record Qunbound
- value in f->param_alist.
-
-2006-01-15 Andreas Schwab <[email protected]>
-
- * search.c (Freplace_match): Use UPPERCASEP instead of !NOCASEP.
-
-2006-01-13 Richard M. Stallman <[email protected]>
-
- * Makefile.in: Define new macro WINDOW_SUPPORT.
- (lisp): Use it.
- (SOME_MACHINE_LISP): Add conditionally loaded files.
-
-2006-01-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c [USE_ATSUI] (atsu_get_text_layout_with_text_ptr)
- [MAC_OS_X_VERSION_MAX_ALLOWED >= 1020]: Specify kATSLineUseQDRendering.
- (XLoadQueryFont) [USE_ATSUI]: Display diacritical marks in
- decomposed form.
-
- * process.c [HAVE_INTTYPES_H]: Include inttypes.h.
- (ifflag_table): Fix typo (IFF_OACTIV -> IFF_OACTIVE).
- (Fnetwork_interface_info): Use HAVE_STRUCT_IFREQ_IFR_NETMASK
- macro. Also try member ifr_addr when getting netmask.
-
-2006-01-10 Stefan Monnier <[email protected]>
-
- * fileio.c (Fexpand_file_name): Remove redundant tests.
- Fix elimination of // so that it doesn't prevent elimination of an
- immediately following /. or /..
-
-2006-01-09 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_toggle_notify_cb): New function.
- (xg_toggle_visibility_cb): Move setting of x_gtk_show_hidden_files to
- xg_toggle_notify_cb.
- (xg_get_file_with_chooser): Add callback to xg_toggle_notify_cb when
- parameter value changes so the toggle button gets updated.
-
-2006-01-06 Nick Roberts <[email protected]>
-
- * .gdbinit: Fix typo.
-
-2006-01-05 Eli Zaretskii <[email protected]>
-
- * .gdbinit: Fix last change.
-
-2006-01-05 Kim F. Storm <[email protected]>
-
- * process.c (Fmake_network_process): Use AF_INET instead of
- AF_UNSPEC when AF_INET6 is not defined.
-
-2006-01-05 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (mac_coerce_file_name_ptr, mac_coerce_file_name_desc):
- Don't check that the other type is known file-related one.
-
- * macfns.c (Fx_server_version): Use gestaltSystemVersionMajor,
- gestaltSystemVersionMinor, and gestaltSystemVersionBugFix on Mac
- OS X 10.4 and later.
-
-2006-01-04 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_image_for_pixmap): If the image is from a file,
- let GTK do all image processing. Importing Emacs own pixmaps to GTK
- looks bad for inactive tool bar items with some Gnome themes.
-
-2006-01-04 Eli Zaretskii <[email protected]>
-
- * .gdbinit: Avoid a warning message when x_error_quitter is not
- compiled in.
-
- * process.c [WINDOWSNT]: Undef AF_INET6 to disable IPv6 support
- for w32.
-
-2006-01-04 Kim F. Storm <[email protected]>
-
- * process.c: Add IPv6 support.
- (Qipv4, Qipv6): New vars.
- (syms_of_process): Intern and staticpro them.
- (Fformat_network_address): Handle 9 or 8 element vector as IPv6 address
- with or without port number. Handle 4 element vector as IPv4 address
- without port number.
- (conv_sockaddr_to_lisp, get_lisp_to_sockaddr_size)
- (conv_lisp_to_sockaddr): Handle IPv6 addresses.
- (Fmake_network_process): Use :family 'ipv4 and 'ipv6 to explicitly
- request that address family only. :family nil or omitted means to
- determine address family from the specified :host and :service.
- (ifflag_table): Add missing OpenBSD IFF_ flags.
- (server_accept_connection): Handle IPv6 addresses.
- (init_process): Add (:family ipv4) and (:family ipv6) sub-features.
-
- * .gdbinit: Undo last change. Instead, look at Vsystem_type to
- determine which breakpoints to set.
-
-2006-01-03 Stefan Monnier <[email protected]>
-
- * keymap.c (describe_map_compare): Yet another int/Lisp_Object mixup.
-
- * window.h (Fwindow_minibuffer_p): Declare (for use in minibuf.c).
-
-2006-01-03 Romain Francoise <[email protected]>
-
- * emacs.c (main): Update copyright year.
-
-2006-01-03 Ken Raeburn <[email protected]>
-
- * callproc.c (delete_temp_file): Bind file-name-handler-alist to
- nil for the call to internal_delete_file.
-
-2006-01-01 Ken Raeburn <[email protected]>
-
- * callproc.c (Fcall_process_region): Bind file-name-handler-alist
- to nil for the call to Fwrite_region.
-
-2005-12-31 Richard M. Stallman <[email protected]>
-
- * minibuf.c (read_minibuf): Clear out all other minibuffer windows.
-
-2005-12-31 Eli Zaretskii <[email protected]>
-
- * emacs.c (gdb_pvec_type): A dummy variable for GDB's sake.
-
-2005-12-30 Luc Teirlinck <[email protected]>
-
- * textprop.c (set_text_properties): Reword description of return value.
- Return Qnil if caller wants to remove all text properties from a
- string and the string already has no intervals.
-
-2005-12-30 Stefan Monnier <[email protected]>
-
- * term.c (visible_cursor): New boolean var.
- (set_terminal_modes, tty_show_cursor): Use "vs" or "ve" depending on
- visible_cursor.
- (syms_of_term): Export the new var as "visible-cursor".
-
-2005-12-30 Eli Zaretskii <[email protected]>
-
- * .gdbinit: Tell users not to worry about GDB warnings that some
- functions do not exist in the binary.
-
-2005-12-30 Andreas Schwab <[email protected]>
-
- * process.c (Fnetwork_interface_info): Correctly terminate the
- loop over ifflag_table.
-
-2005-12-29 Richard M. Stallman <[email protected]>
-
- * lread.c (readevalloop): Test for reading a whole buffer
- before actually reading anything. Handle all cases, including
- START = END = nil and an already-narrowed buffer.
- Convert END to a marker if it is a number.
-
- * keymap.c (describe_map): Put sparse map elements into an array,
- sort them, then output a sequence of identical bindings on one line.
- (struct describe_map_elt): New data type.
- (describe_map_compare): New function.
-
-2005-12-28 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_file_with_chooser): Change message shown
- in file chooser.
-
-2005-12-27 Richard M. Stallman <[email protected]>
-
- * lread.c (readevalloop): Set PT and ZV in the proper buffer,
- not the current one.
-
- * minibuf.c (Fminibuffer_message): Doc fix.
- (read_minibuf): Set current_buffer->enable_multibyte_characters sooner.
-
- * eval.c (do_autoload): Ignore elements of Vautoload_queue
- where car is not symbol.
-
-2005-12-27 Kenichi Handa <[email protected]>
-
- * charset.c (lisp_string_width): Check multibyteness of STRING.
-
-2005-12-27 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_show_hidden_files): New variable.
- (syms_of_xfns): Defvar it.
-
- * gtkutil.c (xg_toggle_visibility_cb): New function.
- (xg_get_file_with_chooser): Add toggle hidden files and a message
- to the new file chooser dialog. Show hidden files if
- x_show_hidden_files is non-zero.
-
-2005-12-26 Richard M. Stallman <[email protected]>
-
- * keyboard.h: Undo previous change.
-
- * Makefile.in (undo.o): Undo previous change.
-
- * undo.c: Undo previous change.
-
-2005-12-26 Luc Teirlinck <[email protected]>
-
- * keyboard.h: extern last_point_position_window.
-
- * undo.c: include keyboard.h.
-
- * Makefile.in (undo.o): Depend on keyboard.h.
-
-2005-12-26 Richard M. Stallman <[email protected]>
-
- * commands.h (last_point_position_window): Declare.
-
- * undo.c: Depend on window.h.
- (record_point): Save old point from the correct window.
-
- * keyboard.c (last_point_position_window): New variable.
- (command_loop_1): Set last_point_position_window.
- (syms_of_keyboard): Init it.
-
- * Makefile.in (undo.o): Depend on window.h.
-
-2005-12-25 Richard M. Stallman <[email protected]>
-
- * eval.c (un_autoload): Expect (0 . OFEATURES) in Vautoload_queue
- to undo a `provide'.
-
- * fns.c (Fprovide): Store (0 . OFEATURES) in Vautoload_queue.
-
-2005-12-25 Giorgos Keramidas <[email protected]>
-
- * m/amdx86-64.h [__FreeBSD__] (START_FILES, LIB_STANDARD):
- define for FreeBSD on this platform.
-
-2005-12-24 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.h (TYPE_FILE_NAME): New define.
- (posix_pathname_to_fsspec, fsspec_to_posix_pathname): Remove externs.
-
- * mac.c (posix_pathname_to_fsspec, fsspec_to_posix_pathname):
- Add prototypes. Make static.
- (mac_aedesc_to_lisp): Initialize err to noErr.
- (mac_coerce_file_name_ptr, mac_coerce_file_name_desc)
- (init_coercion_handler): New functions.
- (Fmac_coerce_ae_data): Use coercion of Apple event data for
- translation from/to file names.
-
- * macterm.c: Don't include sys/param.h.
- (init_coercion_handler): Add extern.
- [MAC_OS8] (main): Call init_coercion_handler.
- (mac_initialize) [MAC_OSX]: Likewise.
- [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Use coercion of
- Apple event data for translation from/to file names.
-
- * macfns.c [TARGET_API_MAC_CARBON] (Fx_file_dialog): Likewise.
-
- * image.c [MAC_OS] (find_image_fsspec): Likewise.
-
-2005-12-23 Martin Rudalics <[email protected]>
-
- * insdel.c (insert, insert_and_inherit, insert_before_markers)
- (insert_before_markers_and_inherit): Make sure FROM is correct
- when `after-change-functions' are called.
-
-2005-12-23 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (Fx_uses_old_gtk_dialog): New function.
-
- * gtkutil.c (xg_uses_old_file_dialog): New function.
- (xg_get_file_name): Use xg_uses_old_file_dialog.
-
- * gtkutil.h: Declare xg_uses_old_file_dialog.
-
-2005-12-22 Richard M. Stallman <[email protected]>
-
- * xmenu.c (xmenu_show): Call inhibit_garbage_collection.
-
-2005-12-22 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (Fmac_coerce_ae_data) [MAC_OSX]: Fix memory leak.
-
- * macgui.h (XCharStruct): Remove member `valid_p'.
- (STORE_XCHARSTRUCT): Don't set member `valid_p'.
- (XCharStructRow): New typedef.
- (XCHARSTRUCTROW_CHAR_VALID_P, XCHARSTRUCTROW_SET_CHAR_VALID):
- New macros.
- (struct MacFontStruct): Add member `bounds'. Remove member
- `per_char'. All uses for QuichDraw Text fonts are changed to
- `bounds.per_char'. ATSUI font bounds are represented as an array
- `bounds.rows' of XCharStructRow's, each of which consists of a
- bitmap of valid entries and an array of char bounds.
-
- * macterm.c (mac_per_char_metric): Add prototype.
- (x_per_char_metric) [USE_CG_TEXT_DRAWING]: Remove prototype.
- (mac_query_char_extents): New function.
- (x_per_char_metric): Use it.
- (XLoadQueryFont): Likewise. Consolidate min/max_bounds calculations.
- [USE_CG_TEXT_DRAWING] (mac_draw_string_cg):
- Use mac_per_char_metric instead of x_per_char_metric.
- (mac_text_extents_16): New function.
- (mac_compute_glyph_string_overhangs): Use it.
- (mac_unload_font): Free member `bounds' in struct MacFontStruct.
-
-2005-12-21 Stefan Monnier <[email protected]>
-
- * minibuf.c (Fdisplay_completion_list): Use XCAR/XCDR.
- (Fminibuffer_completion_help): Remove duplicates before display.
-
-2005-12-21 L$,1 q(Brentey K,Aa(Broly <[email protected]>
-
- * print.c (print_preprocess): Don't lose print_depth levels while
- iterating.
-
-2005-12-21 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (Qmac_apple_event): Add extern.
- (set_frame_menubar, mac_menu_show keymp_panes)
- (single_keymap_panes, list_of_panes, list_of_item)
- (single_menu_item): Add argument types to prototypes.
- (mac_dialog_show) [HAVE_DIALOGS]: Likewise.
- (struct skp): New struct (from xmenu.c).
- (single_keymap_panes, single_menu_item, list_of_panes)
- (list_of_item): Sync with xmenu.c.
- (Fx_popup_menu, Fx_popup_dialog): Likewise. Don't get window from
- POSITION if it is mac-apple-event event.
- (menubar_selection_callback): Don't use menu_command_in_progress.
- (set_frame_menubar): First parse all submenus, then make
- widget_value trees from them. Don't allocate any widget_value
- objects until we are done with the parsing.
- (parse_single_submenu, digest_single_submenu): New functions.
- (single_submenu): Function deleted, replaced by those two.
- (install_menu_quit_handler) [HAVE_CANCELMENUTRACKING]: Don't create
- or dispose of EventHandlerUPP. Install hander to all submenus.
- (mac_menu_show) [!HAVE_MULTILINGUAL_MENU]: Use ENCODE_MENU_STRING
- instead of ENCODE_SYSTEM.
- (free_frame_menubar, fill_submenu, fill_menu): Don't use NULL for
- integer values.
- [HAVE_DIALOGS] (mac_dialog_show): Sync with xdialog_show (in xmenu.c).
- (add_menu_item) [TARGET_API_MAC_CARBON]: Use CFString functions to
- format menu item string. Don't use NULL for integer value.
-
- * macterm.h (struct mac_output): Remove unused member
- menu_command_in_progress.
-
-2005-12-20 Juri Linkov <[email protected]>
-
- * xmenu.c (Fx_popup_menu): Set Vmenu_updating_frame to f if
- position is non-nil, else set it to nil.
-
- * macmenu.c (Fx_popup_menu): Add `else' to set
- Vmenu_updating_frame to nil only if position is nil.
-
- * w32menu.c (Fx_popup_menu): Add `else' to set
- Vmenu_updating_frame to nil only if position is nil.
-
-2005-12-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * keyboard.c (make_lispy_event): Drag-and-drop items are now
- stored in member `args' of struct input_event.
-
- * termhooks.h (struct input_event): Fix comment for DRAG_N_DROP_EVENT.
-
- * xselect.c (x_handle_dnd_message): Drag-and-drop items are now
- stored in member `args' of struct input_event.
-
- * w32term.c (construct_drag_n_drop): Likewise.
-
- * macterm.c (mac_do_receive_drag): Likewise.
- (x_use_underline_position_properties): Undo 2005-07-13 change.
- (syms_of_macterm) <x-use-underline-position-properties>: Likewise.
- (mac_use_core_graphics, mac_wheel_button_is_mouse_2)
- (mac_pass_command_to_system, mac_pass_control_to_system):
- New boolean variables renamed from Lisp_Object ones
- Vmac_use_core_graphics, Vmac_wheel_button_is_mouse_2,
- Vmac_pass_command_to_system, and Vmac_pass_control_to_system.
- All uses changed.
- (syms_of_macterm): DEFVAR_BOOL them. Remove previous DEFVAR_LISPs.
- Make them user options.
- (mac_handle_command_event, mac_store_services_event):
- Call create_apple_event_from_event_ref without 5th argument.
- (backtranslate_modified_keycode): Mask off modifier keys that are
- mapped to some Emacs modifiers before passing it to KeyTranslate.
- (syms_of_macterm): Make variables `mac-emulate-three-button-mouse',
- `mac-wheel-button-is-mouse-2', and `mac-*-modifier' user options.
- Fix docstrings of `mac-*-modifier'.
-
- * mac.c (create_apple_event_from_event_ref): Remove arg `types'.
- (do_applescript): Change argument types to Lisp_Object.
- All uses changed.
-
- * macterm.h (create_apple_event_from_event_ref): Remove 5th
- argument from extern.
-
-2005-12-18 Dan Nicolaescu <[email protected]>
-
- * xfns.c (Fx_backspace_delete_keys_p): In case we cannot determine
- the answer, return `lambda', not nil.
-
-2005-12-17 Eli Zaretskii <[email protected]>
-
- * makefile.w32-in (bootstrap-temacs): Warn that parts of commands
- enclosed in $(ARGQUOTE)s should not be split between two lines, as
- that will break with GNU Make >3.80, when sh.exe is used and
- arg quoting is with '..'.
-
-2005-12-17 Chong Yidong <[email protected]>
-
- * print.c (print_preprocess): Just signal an error if print_depth
- is exceeded.
-
-2005-12-17 Eli Zaretskii <[email protected]>
-
- * .gdbinit: Set a breakpoint on w32_abort.
-
-2005-12-16 Juri Linkov <[email protected]>
-
- * minibuf.c (Fminibuffer_completion_contents): New Lisp function
- created from minibuffer_completion_contents.
- (minibuffer_completion_contents): Remove.
- (do_completion, Fminibuffer_complete_word)
- (Fminibuffer_completion_help): Replace minibuffer_completion_contents
- with Fminibuffer_completion_contents.
- (syms_of_minibuf): Add Sminibuffer_completion_contents.
- (Fdisplay_completion_list): Doc fix.
- (display_completion_list_1): Use `nil' for second arg of
- `Fdisplay_completion_list'.
-
-2005-12-14 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (compute_tip_xy): Handle negative dx and dy.
-
- * w32fns.c (compute_tip_xy): Ditto.
-
- * macfns.c (compute_tip_xy): Ditto.
-
-2005-12-14 Chong Yidong <[email protected]>
-
- * print.c (print_preprocess): Go to a deeper print_depth to avoid
- print_object loop.
-
-2005-12-14 Kyotaro HORIGUCHI <[email protected]> (tiny change)
-
- * coding.c (code_convert_region_unwind): GCPRO arg.
-
-2005-12-12 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (compute_tip_xy): Calculate root_y the same way as root_x,
- i.e. dy is offset from top of frame instead of bottom.
-
- * macfns.c (compute_tip_xy): Ditto.
-
- * w32fns.c (compute_tip_xy): Ditto.
-
- * gtkutil.c (SSDATA): New macro to remove compiler warnings.
- (xg_get_image_for_pixmap, xg_create_frame_widgets)
- (xg_get_file_with_chooser): Use SSDATA instead of SDATA.
-
- * xmenu.c (menubar_selection_callback): Do nothing if the callback
- is for an unselected radio menu item.
-
-2005-12-11 Richard M. Stallman <[email protected]>
-
- * xdisp.c (syms_of_xdisp) <blink-cursor-alist>: Doc fix.
-
- * lisp.h [! NO_UNION_TYPE] (EQ): Use == so args are computed just once.
-
- * keymap.c (Fset_keymap_parent, store_in_keymap): Use CHECK_IMPURE.
- (Flookup_key): Doc fix.
- (syms_of_keymap) <function-key-map>: Doc fix.
-
- * fns.c (Frequire): Treat evaluating from a source file
- like loading the file.
-
- * floatfns.c (Flog): Doc fix.
-
- * fileio.c (Finsert_file_contents): Set Vdeactivate_mark
- when we change the buffer.
-
-2005-12-11 Juri Linkov <[email protected]>
-
- * minibuf.c (display_completion_list_1):
- Call `minibuffer_completion_contents' instead of using `nil' as
- second arg of `Fdisplay_completion_list'.
- (keys_of_minibuf): Unbind SPC in
- Vminibuffer_local_filename_completion_map (see also related
- change on 2005-12-06).
-
-2005-12-11 YAMAMOTO Mitsuharu <[email protected]>
-
- * emacs.c (main) [MAC_OS8]: Undo previous change.
-
- * macselect.c (syms_of_macselect) <mac-apple-event-map>:
- Initialize to nil. Keymap is now created in lisp/term/mac-win.el.
-
-2005-12-10 YAMAMOTO Mitsuharu <[email protected]>
-
- * Makefile.in (macselect.o): Depend on keymap.h.
-
- * emacs.c (main) [MAC_OS8]: Call syms_of_keymap before
- syms_of_macselect.
-
- * image.c (init_image) [MAC_OS]: Don't call EnterMovies.
- [!HAVE_GIF && MAC_OS] (gif_load): Call EnterMovies.
-
- * keyboard.c (Qmac_apple_event) [MAC_OS]: New variable.
- (syms_of_keyboard) [MAC_OS]: Initialize it.
- (make_lispy_event) [MAC_OS]: Build lisp event for MAC_APPLE_EVENT.
-
- * mac.c (Qundecoded_file_name): New variable.
- (syms_of_mac): Initialize it.
- (mac_aelist_to_lisp, mac_aedesc_to_lisp): New functions.
- [TARGET_API_MAC_CARBON] (create_apple_event_from_event_ref): New fun.
- (Fmac_coerce_ae_data): New defun.
- (syms_of_mac): Defsubr it.
-
- * macselect.c: Include keymap.h.
- (mac_ready_for_apple_events): New variable.
- (Vmac_apple_event_map, Qmac_apple_event_class)
- (Qmac_apple_event_id): New variables.
- (syms_of_macselect): Initialize them.
- (Qundefined, mac_store_apple_event): Add externs.
- (struct apple_event_binding): New struct.
- (find_event_binding_fun, find_event_binding)
- (mac_find_apple_event_spec, defer_apple_events)
- (mac_handle_apple_event, init_apple_event_handler)
- (copy_scrap_flavor_data): New functions.
- (Fmac_process_deferred_apple_events): New defun.
- (syms_of_macselect): Defsubr it.
- (mac_store_services_event): Fix extern.
- (mac_handle_service_event): Don't allocate Lisp objects during
- asynchronous input processing. Use mac_store_services_event
- instead of mac_store_application_menu_event.
-
- * macterm.c (Qmac_ready_for_drag_n_drop, Qapplication, Qabout)
- (Qpreferences): Remove variables.
- (syms_of_macterm): Don't initialize them.
- (Qhicommand) [USE_CARBON_EVENTS]: New variable.
- (syms_of_macterm) [USE_CARBON_EVENTS]: Initialize it.
- (init_required_apple_events, do_ae_open_application)
- (do_ae_print_documents, do_ae_open_documents)
- (do_ae_quit_application): Remove functions and prototypes.
- (mac_ready_for_apple_events, Qundefined, init_apple_event_handler)
- (mac_find_apple_event_spec): Add externs.
- (mac_store_application_menu_event): Remove function.
- (mac_store_apple_event, mac_make_lispy_event_code): New functions.
- (mac_handle_command_event): Create Apple event from Carbon event.
- Use mac_store_apple_event instead of mac_store_application_menu_event.
- [MAC_OSX] (mac_store_services_event): Likewise.
- (struct SelectionRange, SelectionRange): Remove struct and typedef.
- [MAC_OS8] (main): Call init_apple_event_handler instead of
- init_required_apple_events.
- (mac_initialize) [MAC_OSX]: Likewise.
- [!USE_CARBON_EVENTS] (mac_wait_next_event):
- Use mac_ready_for_apple_events instead of Qmac_ready_for_drag_n_drop.
-
- * macterm.h (mac_make_lispy_event_code, mac_aedesc_to_lisp):
- Add externs.
- (create_apple_event_from_event_ref) [TARGET_API_MAC_CARBON]: Likewise.
- (Fmac_get_preference): Add EXFUN.
-
- * termhooks.h (enum event_kind) [MAC_OS]: Add new MAC_APPLE_EVENT
- event.
-
-2005-12-09 Richard M. Stallman <[email protected]>
-
- * xfns.c (Fx_create_frame): Reinstate previous change.
-
-2005-12-09 Eli Zaretskii <[email protected]>
-
- * w32fns.c (w32_abort) [__GNUC__]: Add instructions for attaching
- GDB to the abort dialog.
-
-2005-12-09 Kyotaro HORIGUCHI <[email protected]> (tiny change)
-
- * indent.c (Fvertical_motion): Force move if starting on
- stretch glyph.
-
-2005-12-08 Richard M. Stallman <[email protected]>
-
- * lread.c (read_escape) <\s>: Don't treat strings specially.
-
- * xfns.c (Fx_create_frame): Comment out previous change.
-
-2005-12-07 L$,1 q(Brentey K,Aa(Broly <[email protected]>
-
- * xfns.c (Fx_create_frame): Initialize Vdefault_minibuffer_frame,
- when needed.
-
-2005-12-06 Stefan Monnier <[email protected]>
-
- * minibuf.c (keys_of_minibuf): Just unbind SPC in
- Vminibuffer_local_filename_completion_map rather than forcing it
- explicitly to the same binding as the global map.
-
-2005-12-06 Ken Raeburn <[email protected]>
-
- * buffer.c (Fkill_buffer): Avoid dangerous side effects in NILP args.
- * bytecode.c (Fbyte_code): Likewise.
- * fileio.c (internal_delete_file, Fread_file_name_internal): Likewise.
- * minibuf.c (Fminibuffer_complete_and_exit): Likewise.
- * undo.c (truncate_undo_list): Likewise.
-
-2005-12-05 Richard M. Stallman <[email protected]>
-
- * window.c (enlarge_window): Eliminate arg preserve_before.
- Assume it is 0. All callers changed.
- (Fenlarge_window, Fshrink_window): Likewise.
-
-2005-12-02 Eli Zaretskii <[email protected]>
-
- * w32fns.c (compute_tip_xy): Put tip above pointer if it doesn't
- fit below.
-
-2005-12-02 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h: Add prototype for xg_set_icon_from_xpm_data.
-
- * xfns.c (x_real_positions): int ign => unsigned int.
- (xg_set_icon_from_xpm_data): Remove unused variable err.
- (x_set_name_internal, Fx_create_frame, xg_set_icon): Add cast
- to remove compiler warning.
- (compute_tip_xy): Put tip above pointer if it doesn't fit below.
-
-2005-12-02 David Reitter <[email protected]>
-
- * minibuf.c (Fcompleting_read): If Vminibuffer_completing_file_name is
- non-nil, use the new keymaps Vminibuffer_local_filename_completion_map
- and Vminibuffer_local_must_match_filename_map keymaps.
- (keys_of_minibuf): Bind SPC in the new file-name completion keymaps.
-
- * keymap.c (Vminibuffer_local_filename_completion_map)
- (Vminibuffer_local_must_match_filename_map): New variables.
- (syms_of_keymap): DEFVAR_LISP them, initialize them, and set their
- parent to be Vminibuffer_local_completion_map and
- Vminibuffer_local_must_match_map, respectively.
-
- * commands.h (Vminibuffer_local_filename_completion_map)
- (Vminibuffer_local_must_match_filename_map): Declare the new keymaps.
-
-2005-12-01 Stefan Monnier <[email protected]>
-
- * window.c (Fset_window_configuration): Don't accidentally copy the
- window-point of one window to another.
-
-2005-11-30 L$,1 q(Brentey K,Aa(Broly <[email protected]>
-
- * buffer.c (Fpop_to_buffer): Remove superfluous call to record_buffer.
-
-2005-11-30 Kim F. Storm <[email protected]>
-
- * alloc.c: Include fcntl.h. Define O_WRONLY if not defined.
- (valid_lisp_object_p) [!GC_MARK_STACK]: Validate pointer by
- passing it to `emacs_write'.
-
-2005-11-29 Ari Roponen <[email protected]> (tiny change)
-
- * atimer.c (stop_other_atimers): Fix loop to correctly compute `prev'.
-
-2005-11-27 Richard M. Stallman <[email protected]>
-
- * window.c (adjust_window_trailing_edge): New function.
- (Fadjust_window_trailing_edge): New function.
- (syms_of_window): Defsubr it.
- (window_deletion_count): New variable.
- (delete_window): Update window_deletion_count.
-
-2005-11-26 Eli Zaretskii <[email protected]>
-
- * minibuf.c (syms_of_minibuf): Mention the extension of
- `completion-auto-help's meaning by complete.el.
-
-2005-11-26 Henrik Enberg <[email protected]>
-
- * xfaces.c (Finternal_set_lisp_face_attribute_from_resource):
- Handle :inherit property as a lisp expression.
-
-2005-11-24 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (Qcontrol): Rename from Qctrl. All uses changed.
- (syms_of_macterm): Staticpro Qcontrol, Qmeta, Qalt, Qhyper,
- Qsuper, and Qmodifier_value.
- (Vmac_control_modifier, Vmac_option_modifier)
- (Vmac_command_modifier, Vmac_function_modifier)
- (Vmac_emulate_three_button_mouse, Vmac_wheel_button_is_mouse_2)
- (Vmac_pass_command_to_system, Vmac_pass_control_to_system)
- (Vmac_charset_info_alist): Doc fixes.
-
-2005-11-23 YAMAMOTO Mitsuharu <[email protected]>
-
- * emacs.c (main) [MAC_OSX]: Change working directory to home
- directory if `-psn_*' option is specified.
-
- * mac.c (DECODE_UTF_8): Remove macro.
- [TARGET_API_MAC_CARBON] (cfstring_to_lisp_nodecode): New function
- created from cfstring_to_lisp.
- [TARGET_API_MAC_CARBON] (cfstring_to_lisp): Use it.
- (xrm_get_preference_database) [TARGET_API_MAC_CARBON]: Likewise.
-
- * macterm.h (cfstring_to_lisp_nodecode) [TARGET_API_MAC_CARBON]:
- Add prototype.
-
-2005-11-21 Ken Raeburn <[email protected]>
-
- * keymap.c (shadow_lookup): Use make_number to pass a number to
- Fsubstring.
-
-2005-11-21 Juri Linkov <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment to 1180000.
-
-2005-11-20 Chong Yidong <[email protected]>
-
- * xfaces.c (Finternal_set_lisp_face_attribute):
- Use :ignore-defface for new frame defaults when `unspecified' is
- supplied.
- (Finternal_get_lisp_face_attribute): Hide :ignore-defface.
- (merge_face_vectors): Don't do :ignore-defface overwriting here.
- (Finternal_merge_in_global_face): Do it here.
-
-2005-11-20 Juri Linkov <[email protected]>
-
- * charset.c (invalid_character): Use Lisp-readable syntax
- for octal and hex. Reorder decimal, octal and hex values.
-
-2005-11-20 Nick Roberts <[email protected]>
-
- * lisp.h: Use typedef when Lisp_Object is EMACS_INT so that
- this type is recognised when debugging.
-
-2005-11-19 Andreas Schwab <[email protected]>
-
- * .gdbinit (nextcons, xcdr, xfloat): Update for changes in
- Lisp_Cons and Lisp_Float.
-
-2005-11-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c [USE_CG_TEXT_DRAWING] (cg_text_anti_aliasing_threshold):
- New variable.
- [USE_CG_TEXT_DRAWING] (init_cg_text_anti_aliasing_threshold): New fun.
- (init_font_name_table) [USE_ATSUI && USE_CG_TEXT_DRAWING]: Use it.
- [USE_CG_TEXT_DRAWING] (mac_draw_string_cg): Don't do antialiasing if
- font size is smaller than or equal to cg_text_anti_aliasing_threshold.
-
-2005-11-17 Chong Yidong <[email protected]>
-
- * image.c (x_create_bitmap_from_xpm_data): Free attributes on fail.
-
- * xfaces.c (Qignore_defface): New variable.
- (syms_of_xfaces): Provide `:ignore-defface'.
- (IGNORE_DEFFACE_P): New macro.
- (check_lface_attrs, lface_fully_specified_p)
- (Finternal_set_lisp_face_attribute)
- (Fface_attribute_relative_p, Fmerge_face_attribute):
- Handle Qignore_defface as a possible value.
- (merge_face_vectors): The merged face is `unspecified' if the
- mergee specifies `:ignore-defface'.
-
-2005-11-16 Stefan Monnier <[email protected]>
-
- * lread.c (readevalloop): Add missing GCPROs.
-
-2005-11-16 Chong Yidong <[email protected]>
-
- * xfns.c (xg_set_icon_from_xpm_data): New function.
-
- * gnu.h (gnu_xpm_bits): Rename from gnu_bits.
- (gnu_xbm_bits): Rename from gnu_bits (xbm version).
-
- * xterm.c (x_bitmap_icon): Use the xpm if available.
-
- * image.c (x_create_bitmap_from_xpm_data): New function.
- (x_create_bitmap_from_xpm_data): Initialize XpmAttributes.
-
-2005-11-15 Luc Teirlinck <[email protected]>
-
- * Makefile.in (lisp, shortlisp): Add rfn-eshadow.
-
-2005-11-16 Nick Roberts <[email protected]>
-
- * .gdbinit: Make SIGTSTP work like SIGINT normally does.
-
-2005-11-15 Andreas Schwab <[email protected]>
-
- * lisp.h (struct Lisp_Cons): Make cdr a union.
- (XCDR_AS_LVALUE): Adjust.
- (struct Lisp_Float): Make data a union.
- (XFLOAT_DATA): Adjust.
-
- * alloc.c (free_float): Make free list chaining aliasing-safe.
- (make_float): Likewise.
- (free_cons): Likewise.
- (Fcons): Likewise.
- (check_cons_list): Likewise.
- (Fmake_symbol): Likewise.
- (allocate_misc): Likewise.
- (free_misc): Likewise.
- (gc_sweep): Likewise.
-
-2005-11-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (HASHKEY_QUERY_CACHE): New define.
- (xrm_create_database, xrm_q_put_resource): Empty query cache.
- (xrm_get_resource): Use query cache.
-
- * image.c (init_image) [MAC_OS]: Don't call EnterMovies if
- inhibit_window_system is set.
-
-2005-11-13 YAMAMOTO Mitsuharu <[email protected]>
-
- * macgui.h (USE_CG_TEXT_DRAWING): New define.
- (struct MacFontStruct) [USE_CG_TEXT_DRAWING]: New members cg_font
- and cg_glyphs.
-
- * macterm.c [USE_CG_TEXT_DRAWING] (mac_draw_string_cg): New function.
- (x_draw_glyph_string_foreground) [USE_CG_TEXT_DRAWING]: Use it.
- (XLoadQueryFont) [USE_CG_TEXT_DRAWING]: Set members cg_font and
- cg_glyphs in struct MacFontStruct if synthesized bold or italic is
- not used and font substitution never occurs for ASCII and Latin-1
- characters.
- (XLoadQueryFont): Maximum and minimum metrics are now those among
- ASCII characters.
- (XLoadQueryFont) [!MAC_OS8 || USE_ATSUI]: Apply WebKit-style
- height adjustments for Courier, Helvetica, and Times.
-
- * s/darwin.h (LIBS_CARBON) [!HAVE_CARBON]: Remove `-framework Carbon'.
-
-2005-11-11 David Reitter <[email protected]>
-
- * macterm.c (syms_of_macterm): Remove macCtrlKey, macShiftKey,
- macMetaKey, macAltKey. Introduce Qctrl, Qmeta,
- Vmac_control_modifier / mac-control-modifier,
- Vmac_option_modifier / mac-option-modifier,
- Vmac_command_modifier / mac-command-modifier.
- (mac_to_emacs_modifiers): Use the new style modifier
- variables. Return UInt32 (modifiers are longs now.)
- (backtranslate_modified_keycode): New function (refactoring).
- (XTread_socket): Use new modifier variables and refactored function.
- (mac_determine_quit_char_modifiers): Remove macMetaKey (there is
- no dedicated meta key. Not in use anyway.)
- (convert_fn_keycode): Map Fn-keys to their original keycode
- using a table (english keyboard only).
-
-2005-11-11 Kim F. Storm <[email protected]>
-
- * .gdbinit (pitx): Fix output format if n_overlay_strings > 0.
- Add post hook to "backtrace" to always dump lisp call stack to
- increase chance of people sending it to us when reporting bugs.
-
- * doc.c (Fsubstitute_command_keys): Doc fix.
-
- * dispextern.h (struct it): New member ignore_overlay_strings_at_pos_p.
-
- * xdisp.c (handle_stop): Skip overlay string handling if
- ignore_overlay_strings_at_pos_p is set.
- (set_iterator_to_next): At end of display vector, set
- ignore_overlay_strings_at_pos_p if dpvec came from an overlay
- string, so we skip those overlay strings at current pos.
-
-2005-11-10 Lars Hansen <[email protected]>
-
- * fileio.c (file-regular-p): Doc fix.
-
-2005-11-10 Kim F. Storm <[email protected]>
-
- * alloc.c (valid_lisp_object_p): New function to validate that
- an object is really a valid Lisp_Object.
-
- * lisp.h (valid_lisp_object_p): Add prototype.
-
- * print.c (safe_debug_print): New function to be called from gdb
- to print Lisp objects; use valid_lisp_object_p to avoid crashing
- if user tries to print something which is not a Lisp object.
-
- * .gdbinit (pp, pp1): Use safe_debug_print.
- (pv, pv1): New commands to print value of a lisp variable.
-
-2005-11-10 Nick Roberts <[email protected]>
-
- * .gdbinit (pp1): New user-defined function.
-
-2005-11-09 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c [MAC_OSX] (image_load_quartz2d): Fix memory leak.
-
- * mac.c [MAC_OSX] (init_mac_osx_environment): Reinitialize locale
- related variables for dumped executable.
-
- * unexmacosx.c (unexec_write_zero): New function.
- (copy_data_segment): Clear uninitialized local variables in
- statically linked libraries.
-
- * s/darwin.h (C_SWITCH_SYSTEM): Remove -fno-common.
-
-2005-11-09 Juri Linkov <[email protected]>
-
- * keymap.c (shadow_lookup): If Flookup_key returns a number,
- call it again with a sub-key-sequence, and if its return value
- is non-nil (sub-key is bound), return nil.
-
-2005-11-08 Kim F. Storm <[email protected]>
-
- * process.c (Fsignal_process): Recognize signal names with and
- without SIG prefix, e.g. SIGHUP and HUP.
-
- * search.c (search_buffer): No need to initialize base_pat.
-
-2005-11-04 Stefan Monnier <[email protected]>
-
- * window.c (Fget_lru_window, Fget_largest_window, window_loop):
- Don't abuse the `mini' arg. Use the `obj' arg instead.
-
-2005-11-04 Kim F. Storm <[email protected]>
-
- * xdisp.c (show_mouse_face): Clear mouse face to eol.
-
-2005-11-03 Dan Nicolaescu <[email protected]>
-
- * Makefile.in (lisp, shortlisp): Add emacs-lisp/syntax.elc,
- font-lock.elc and jit-lock.elc.
-
-2005-11-03 Richard M. Stallman <[email protected]>
-
- * window.c (Fenlarge_window): Rename SIDE to HORIZONTAL.
- (enlarge_window): Rename WIDTHFLAG to HORIZ_FLAG.
- (CURBEG, CURSIZE): Use HORIZ_FLAG instead of WIDTHFLAG.
-
- * sheap.c (STATIC_HEAP_SIZE): Increment both definitions.
-
- * alloc.c (refill_memory_reserve): Move decl out of conditionals.
-
-2005-11-03 Stefan Monnier <[email protected]>
-
- * window.c (Fdisplay_buffer): Fix last change to not use
- a dedicated window.
-
-2005-11-01 Kim F. Storm <[email protected]>
-
- * fringe.c (update_window_fringes): Undo 2005-10-27 change.
- Instead, rotate the bottom angle bitmap 180 degrees to indicate
- that the bottom row does not end in a newline.
-
-2005-11-01 Andreas Schwab <[email protected]>
-
- * unexelf.c (unexec): Handle .plt section in BSS segment.
-
-2005-11-01 Stefan Monnier <[email protected]>
-
- * lread.c (readevalloop): Yet another int/Lisp_Object mixup (YAILOM).
-
- * window.c (window_loop): For LRU and LARGEST, let the `mini' argument
- determine whether to consider dedicated windows as well.
- (Fget_lru_window, Fget_largest_window): Add `dedicated' argument.
- (Fdisplay_buffer): Do consider dedicated windows in those cases where
- we will split the window rather than reuse it.
- Don't try to use windows on other displays.
-
-2005-10-31 Dan Nicolaescu <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment to 1170000.
-
-2005-10-31 Romain Francoise <[email protected]>
-
- * macfns.c: Update copyright year.
- * m/gould.h: Likewise.
-
-2005-10-30 Kim F. Storm <[email protected]>
-
- * xdisp.c (display_line): Restore it->current_x and call
- extend_face_to_end_of_line when last glyph doesn't fit on line.
- (set_glyph_string_background_width): Remove specific tests here
- to see if face background should extend to end of line. Simplify.
-
-2005-10-30 Richard M. Stallman <[email protected]>
-
- * alloc.c (BYTES_USED): Use uordblks, not arena.
- (bytes_used_when_reconsidered): New variable.
- (emacs_blocked_free): Set that.
-
-2005-10-29 Chong Yidong <[email protected]>
-
- * alloc.c (emacs_blocked_free): Fix typo.
-
-2005-10-29 Richard M. Stallman <[email protected]>
-
- * data.c (Fmake_variable_frame_local): Doc fix.
-
- * xdisp.c (handle_fontified_prop): Do nothing if memory full.
- (format_mode_line_unwind_data): New arg SAVE_PROPTRANS
- controls whether to save and restore mode_line_proptrans_alist.
- Callers changed.
- (unwind_format_mode_line): Work with that feature.
- (redisplay_internal): Don't call prepare_menu_bars if memory full.
- (move_elt_to_front): New function.
- (display_mode_element): Use move_elt_to_front.
- Don't bother munging text props on a null string.
- Delete obsolete elts from mode_line_proptrans_alist.
- (decode_mode_spec): Test Vmemory_full, not spare_memory.
- (Fformat_mode_line): Clear mode_line_proptrans_alist after saving.
-
- * lisp.h (memory_full_cons_threshold): Declare.
- (internal_lisp_condition_case): Declare.
-
- * alloc.c (syms_of_alloc) <memory-full>: Doc fix.
- (Fmemory_full_p): Function deleted.
- (syms_of_alloc): Don't defsubr it.
- (memory_full_cons_threshold): New variable.
- (spare_memory): Now a vector of 7 elts.
- (buffer_memory_full): Don't set Vmemory_full here.
- (xfree): Don't try to refill here.
- (emacs_blocked_free): Record BYTES_USED in local var.
- (memory_full): Now free all the slots in spare_memory.
- (refill_memory_reserve): Allocate each slot in spare_memory.
- (init_alloc_once): Call refill_memory_reserve.
-
- * keyboard.c (command_loop_1): Don't set Vmemory_full here.
-
- * eval.c (internal_lisp_condition_case): New function.
- (Fcondition_case): Use internal_lisp_condition_case.
- (Feval): Test Vmemory_full and memory_full_cons_threshold.
- (Ffuncall): Likewise.
-
- * bytecode.c (Fbyte_code): Use internal_lisp_condition_case.
-
-2005-10-29 Stefan Monnier <[email protected]>
-
- * syntax.c (Fparse_partial_sexp): Fix docstring.
-
-2005-10-28 Romain Francoise <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment to 1130000.
-
-2005-10-28 Richard M. Stallman <[email protected]>
-
- * xfns.c (syms_of_xfns): Provide `x' as feature.
-
- * xdisp.c (decode_mode_spec): Define %e to indicate memory full.
-
- * editfns.c (Fformat): Don't include string padding
- between info[n].start and info[n].end.
-
- * alloc.c (spare_memory): No longer static.
- (xfree) [!SYSTEM_MALLOC]: Call refill_memory_reserve.
-
- * puresize.h (BASE_PURESIZE): Increment to 1120000.
-
-2005-10-27 Chong Yidong <[email protected]>
-
- * data.c (Fmake_variable_frame_local): Add clarification to docstring.
-
- * fringe.c (update_window_fringes): Handle case where buffer ends
- with a newline.
-
-2005-10-27 Kenichi Handa <[email protected]>
-
- * coding.h (DECODE_SYSTEM): Fix argument name; name->str.
-
-2005-10-24 Kenichi Handa <[email protected]>
-
- * charset.h (charset_mule_unicode_0100_24ff)
- (charset_mule_unicode_2500_33ff, charset_mule_unicode_e000_ffff):
- Extern them.
-
- * charset.c (charset_mule_unicode_0100_24ff)
- (charset_mule_unicode_2500_33ff, charset_mule_unicode_e000_ffff):
- New variables.
- (Fsetup_special_charsets): Initialize them.
-
- * xterm.c (handle_one_xevent): Handle keysyms directly mapped to
- supported Unicode characters.
-
-2005-10-25 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_to_x_font): Avoid forcing font widths.
-
-2005-10-25 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c [MAC_OS] (image_load_qt_1): Check image size.
- Use GraphicsImportGetImageDescription instead of
- GraphicsImportGetNaturalBounds.
- [MAC_OSX] (image_load_quartz2d): Check image size.
- [MAC_OS] (xpm_load_image): Likewise.
-
- * macterm.c (last_mouse_glyph_frame): New var.
- (note_mouse_movement): Say mouse moved if current frame differs
- from last_mouse_glyph_frame, and update last_mouse_glyph_frame.
- (XTmouse_position): Set last_mouse_glyph_frame.
- (XTread_socket): Clear last_mouse_glyph_frame on mouse up/down event.
- (mac_draw_string_common) [USE_ATSUI && WORDS_BIG_ENDIAN]: Fix typo.
- Use EndianU16_BtoN.
- (mac_draw_string_common) [MAC_OSX]: Don't use ATSUClearLayoutControls.
- (x_per_char_metric, XLoadQueryFont)
- [MAC_OS_X_VERSION_MAX_ALLOWED < 1020]: Use device origins to get
- glyph bounds.
- (mac_to_x_fontname, mac_do_list_fonts)
- (mac_initialize_display_info): Change screen resolutions to 72dpi.
-
-2005-10-25 Masatake YAMATO <[email protected]>
-
- * minibuf.c (Fdisplay_completion_list): Small doc fix.
-
-2005-10-24 Kim F. Storm <[email protected]>
-
- * xterm.c: Undo 2005-10-23 change.
- (last_mouse_glyph_frame): New var.
- (note_mouse_movement): Say mouse moved if current frame differs
- from last_mouse_glyph_frame, and update last_mouse_glyph_frame.
- (XTmouse_position): Set last_mouse_glyph_frame.
- (handle_one_xevent): Clear last_mouse_glyph_frame [instead of
- last_mouse_glyph] on mouse up/down event.
-
- * editfns.c (Fcompare_buffer_substrings): Fix last change.
-
-2005-10-23 Stefan Monnier <[email protected]>
-
- * editfns.c (Fcompare_buffer_substrings): Handle multibyte chars.
-
-2005-10-23 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (note_mouse_movement): Always call note_mouse_highlight
- so tool tips don't interfere with press on tool bar button.
-
-2005-10-23 Richard M. Stallman <[email protected]>
-
- * casetab.c (Fset_case_table): Doc fix.
-
- * lread.c (build_load_history): Replace STREAM arg with ENTIRE.
- (readevalloop): Compute ENTIRE properly.
- (syms_of_lread) <load-history>: Doc fix.
-
-2005-10-21 Richard M. Stallman <[email protected]>
-
- * lread.c (Fload): Simplify gcpro structure.
- Gcpro FOUND as well as FILE, but not EFOUND.
- Unless preloading, record FOUND instead of FILE in Vload_history.
- Rename repeat local FILE to MSG_FILE.
- (syms_of_lread) <load-history>: Doc fix.
-
-2005-10-21 Kenichi Handa <[email protected]>
-
- * search.c (boyer_moore): Add parens to fix and/or precedence bug.
-
-2005-10-20 Kim F. Storm <[email protected]>
-
- * buffer.c (clone_per_buffer_values): Remove unused var tem.
- (init_buffer): Remove unused vars dotstat, pwdstat.
-
- * ccl.c (check_ccl_update): Remove unused var vp.
-
- * fileio.c (auto_save_error): Call SAFE_FREE.
-
- * fns.c (Fchar_table_range): Remove unused var i.
-
- * minibuf.c (display_completion_list_1): New wrapper function
- for Fdisplay_completion_list.
- (Fminibuffer_completion_help): Use it.
-
- * term.c (encode_terminal_code): Remove unused var src_start.
-
- * window.c (Fwindow_tree): Remove unused var alist.
-
- * xterm.c (x_calc_absolute_position): Remove unused vars win_x, win_y.
-
-2005-10-20 Aubrey Jaffer <[email protected]> (tiny change)
-
- * unexelf.c (unexec): Fix calls to `fatal' with less than 3 arguments.
-
-2005-10-20 Olli Savia <[email protected]> (tiny change)
-
- * syssignal.h [__Lynx__]: Undef SIGPOLL along with SIGIO.
-
-2005-10-20 Andreas Schwab <[email protected]>
-
- * minibuf.c (Fdisplay_completion_list): Doc fix.
-
-2005-10-19 Kim F. Storm <[email protected]>
-
- * image.c (check_image_size): Handle integer Vmax_image_size value
- directly as max pixel value. Use default frame size for null frame.
- (syms_of_image) <max-image-size>: Describe integer value.
-
-2005-10-19 Romain Francoise <[email protected]>
-
- * emacs.c (main): Update copyright year.
-
-2005-10-18 Chong Yidong <[email protected]>
-
- * image.c (Vmax_image_size): New variable.
- (check_image_size): New function.
- (xbm_read_bitmap_data, pbm_load, png_load, jpeg_load, tiff_load)
- (gif_load, gs_load): Use it.
- (lookup_image): Try loading again if previous load failed.
- (xbm_read_bitmap_data): Add a new argument, a pointer to the frame
- to display in, NULL if none.
- (xbm_load_image, xbm_file_p): Pass xbm_read_bitmap_data the new
- argument.
-
-2005-10-18 Richard M. Stallman <[email protected]>
-
- * search.c (Fstring_match): Doc fix.
-
-2005-10-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (note_mouse_movement): Use PtInRect.
- (XTread_socket): Also ignore mouse motion just before a button
- release event. Don't process button release event when mouse is
- not grabbed.
-
-2005-10-16 Masatake YAMATO <[email protected]>
-
- * minibuf.c (Fdisplay_completion_list): Add new optional
- argument COMMON_SUBSTRING. Bind `completion-common-substring'
- to the optional argument during running `completion-setup-hook'.
-
-2005-10-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c [TARGET_API_MAC_CARBON] (get_cfstring_encoding_from_lisp):
- Allow nil as argument.
- [TARGET_API_MAC_CARBON] (Fmac_code_convert_string): Regard nil
- for encoding arguments as UTF-16 in native byte order, no BOM.
-
- * macfns.c (Fx_create_frame): Add debugging code.
- (Fx_show_tip): Set frame pixel width and height.
-
- * macterm.c (MAC_WINDOW_NORMAL_GC): Remove macro.
- (FRAME_NORMAL_GC): New macro.
- (mac_draw_line, mac_clear_area, mac_clear_window)
- (mac_fill_rectangle, mac_draw_string, mac_draw_string_16)
- (mac_draw_image_string, mac_draw_image_string_16): Rename from
- XDrawLine, XClearArea, XClearWindow, XFillRectangle, XDrawString,
- XDrawString16, XDrawImageString, and XDrawImageString16, respectively.
- All uses changed.
- (mac_draw_line, mac_erase_rectangle, mac_clear_area)
- (mac_clear_window, mac_draw_bitmap, mac_draw_rectangle)
- (mac_invert_rectangle, mac_draw_string_common, mac_draw_string)
- (mac_draw_string_16, mac_draw_image_string)
- (mac_draw_image_string_16, mac_copy_area, mac_copy_area_with_mask)
- (mac_scroll_area): Drawing functions now take frame as destination.
- All uses changed.
- (mac_draw_string_common): Get port height with FRAME_PIXEL_HEIGHT.
- (x_draw_fringe_bitmap): Set clipping area in face->gc.
-
- * macterm.h (mac_clear_area): Add extern.
-
-2005-10-14 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (note_mouse_movement, XTread_socket): Apply 2005-10-14
- changes for xterm.c.
-
- * w32term.c (note_mouse_movement, w32_read_socket): Likewise.
-
-2005-10-14 Kenichi Handa <[email protected]>
-
- * search.c (search_buffer): Give up BM search on case-fold-search
- if one of a target character has a case-equivalence of different
- charset even if that target charcter is an ASCII.
-
- * casefiddle.c (casify_object): Fix for the case that case
- conversion change the byte length.
-
-2005-10-14 Kim F. Storm <[email protected]>
-
- * xterm.c (note_mouse_movement): Return 1 if mouse moved; 0 otherwise.
- (handle_one_xevent): Only clear help_echo_string; restore it if
- note_mouse_movement didn't record any mouse movement.
-
- * xdisp.c (pos_visible_p): Convert w->hscroll to pixels before use.
- (remember_mouse_glyph): Clear RECT if mouse is over an image glyph.
-
- * keyboard.c (make_lispy_position): Adjust wx for left margin if
- ON_TEXT.
- (Fposn_at_x_y): Fix calculation of x coordinate.
- (Fposn_at_point): Return nil if point is hscrolled out of view.
-
-2005-10-13 Andreas Schwab <[email protected]>
-
- * sysdep.c (request_sigio, unrequest_sigio): Do nothing in
- non-interactive mode.
-
-2005-10-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * xterm.c, w32term.c, macterm.c (note_mouse_movement): Undo last change.
-
-2005-10-12 Kim F. Storm <[email protected]>
-
- * xterm.c (handle_one_xevent): Clear last_mouse_glyph on mouse up/down.
-
-2005-10-12 Romain Francoise <[email protected]>
-
- * buffer.c (init_buffer): Rename `rc' to `len' for clarity.
-
-2005-10-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * xdisp.c (remember_mouse_glyph): Use MATRIX_BOTTOM_TEXT_ROW to
- get end of text rows. Obtain header-line/mode-line rows directly.
-
- * xterm.c, w32term.c, macterm.c (note_mouse_movement):
- Restore help_echo_string if mouse is moved inside last_mouse_glyph.
-
-2005-10-12 Kim F. Storm <[email protected]>
-
- * xdisp.c (remember_mouse_glyph): New generic version based on
- glyph_rect and remember_mouse_glyph from xterm.c enhanced to
- properly handle all different window areas.
-
- * dispextern.h (remember_mouse_glyph): Add prototype.
-
- * xterm.c (glyph_rect, remember_mouse_glyph): Remove X versions.
- (note_mouse_movement, XTmouse_position): Use generic
- remember_mouse_glyph, add last_mouse_glyph arg.
-
- * w32term.c (note_mouse_movement): Fix last_mouse_glyph check.
- (glyph_rect, remember_mouse_glyph): Remove w32 specific versions.
- (note_mouse_movement, w32_mouse_position): Use generic
- remember_mouse_glyph, add last_mouse_glyph arg.
-
- * macterm.c (note_mouse_movement): Add call to remember_mouse_glyph.
- (glyph_rect, remember_mouse_glyph): Remove mac specific versions.
- (XTmouse_position): Adapt to use generic remember_mouse_glyph
- instead of pixel_to_glyph_coords.
-
- * window.c (coordinates_in_window): Fix x position for ON_RIGHT_MARGIN.
- Fix x position for ON_TEXT when left margin width > 0.
-
-2005-10-11 Kim F. Storm <[email protected]>
-
- * window.c (coordinates_in_window): Fix y position for ON_SCROLL_BAR.
-
- * keyboard.c (make_lispy_position): Fix buffer calculations for
- mouse click or movement in right fringe and the margins.
-
-2005-10-11 Juanma Barranquero <[email protected]>
-
- * image.c (fn_jpeg_stdio_src): Don't define it.
- (init_jpeg_functions): Don't initialize `fn_jpeg_stdio_src'.
- (our_common_init_source): Rename from `our_init_source'.
- (our_common_term_source): Rename from `our_term_source'.
- (our_memory_fill_input_buffer): Rename from
- `our_fill_input_buffer'.
- (our_memory_skip_input_data): Rename from `our_skip_input_data'.
- (jpeg_memory_src): Use the new names.
- (struct jpeg_stdio_mgr): New struct.
- (JPEG_STDIO_BUFFER_SIZE): New constant.
- (our_stdio_fill_input_buffer, our_stdio_skip_input_data)
- (jpeg_file_src): New functions.
- (jpeg_load): Use `jpeg_file_src' instead of `fn_jpeg_stdio_src'.
-
-2005-10-11 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (PER_CHAR_METRIC): Remove unused macro.
- (fm_font_family_alist): New variable.
- (syms_of_macterm): Initialize and staticpro it.
- (decode_mac_font_name): Replace '-' in family name with '_' if it
- occurs just once. Lower family name.
- (parse_x_font_name): Rename from x_font_name_to_mac_font_name.
- All uses changed. Remove argument MF and code conversion for it.
- Add argument SIZE. Rename argument MF_DECODED to FAMILY, and CS
- to CHARSET. Parse font size. Lower family name. Return integer
- value for status of parsing.
- (init_font_name_table) [USE_ATSUI]: Use decode_mac_font_name.
- Don't use Fdowncase because family name is already lowered by
- decode_mac_font_name.
- (init_font_name_table): Always call decode_mac_font_name.
- Add pair of family name and its reference to fm_font_family_alist.
- (mac_clear_font_name_table): Clear fm_font_family_alist.
- (XLoadQueryFont): Move font size parsing part to parse_x_font_name.
- Lookup fm_font_family_alist to get font family reference.
- (XLoadQueryFont) [USE_ATSUI]: Don't use Fdowncase because family
- name is already lowered by parse_x_font_name.
-
-2005-10-11 Kim F. Storm <[email protected]>
-
- * xterm.c (glyph_rect): Return 0 if position is outside text area.
-
- * keyboard.c (make_lispy_position): Fix buffer position calculation for
- mouse click or movement in fringe.
-
-2005-10-10 Jason Rumney <[email protected]>
-
- * xterm.c (remember_mouse_glyph): New function.
- (note_mouse_movement): Use it to remember the current glyph if changed.
- (XTmouse_position): Fix calculation of fake glyph under mouse.
- Move code to calculate glyph under mouse into remember_mouse_glyph.
-
-2005-10-10 Jan Dj,Ad(Brv <[email protected]>
-
- * emacs.c (USAGE3, standard_args): -nb => -nbi.
-
-2005-10-10 Juanma Barranquero <[email protected]>
-
- * frame.c (Fredirect_frame_focus): Fix typos in docstring.
- (next_frame, prev_frame, set_term_frame_name): Make static.
-
- * window.c (Fwindow_tree): Fix spelling.
-
-2005-10-09 Romain Francoise <[email protected]>
-
- * window.c (Fwindow_end): Don't try to redisplay if non-interactive.
-
-2005-10-09 Jan Dj,Ad(Brv <[email protected]>
-
- * emacs.c (standard_args): Remove options -i, -itype, --icon-type.
- Add options -nb, --no-bitmap-icon.
-
- * xfns.c (Fx_create_frame): Make bitmapIcon have default on.
-
-2005-10-08 YAMAMOTO Mitsuharu <[email protected]>
-
- * macgui.h (MAX_CLIP_RECTS): New define.
- (struct _XGC): New member clip_region.
- (struct _XGC) [MAC_OSX && USE_ATSUI]: New members n_clip_rects and
- clip_rects.
-
- * macterm.c (GC_CLIP_REGION): New macro.
- (saved_port_clip_region): New variable.
- (mac_begin_clip, mac_end_clip): New functions.
- (XDrawLine, mac_erase_rectangle, mac_draw_bitmap, XFillRectangle)
- (mac_draw_rectangle, mac_draw_string_common, mac_copy_area)
- (mac_copy_area_with_mask, mac_scroll_area): Use them.
- (mac_set_clip_rectangle, mac_reset_clipping): Remove functions.
- [USE_ATSUI] (atsu_get_text_layout_with_text_ptr)
- [MAC_OS_X_VERSION_MAX_ALLOWED < 1020]: Specify kATSLineFractDisable.
- (mac_draw_string_common) [MAC_OSX && USE_ATSUI]: Clip to clipping
- rectangles stored in gc.
- (XFreeGC): Dispose of clipping region.
- (mac_set_clip_rectangles, mac_reset_clip_rectangles): New functions.
- (x_draw_fringe_bitmap, x_set_glyph_string_clipping)
- (x_draw_relief_rect, x_draw_box_rect, x_draw_stretch_glyph_string)
- (x_draw_glyph_string, x_clip_to_row, x_draw_hollow_cursor)
- (x_draw_bar_cursor): Use them.
- (x_set_glyph_string_clipping): Use get_glyph_string_clip_rects to
- get multiple clipping rectangles.
-
- * macterm.h (mac_term_init): Add types to extern.
- (struct mac_output): Remove members mWP and pending_menu_activation.
- Put members scroll_bar_foreground_pixel and
- scroll_bar_background_pixel in #if 0.
- (FRAME_MAC_WINDOW, FRAME_X_WINDOW): Use window_desc.
-
- * xfaces.c (x_create_gc, x_free_gc) [MAC_OS]: Add BLOCK_INPUT.
- Add debugging code.
-
-2005-10-08 Kim F. Storm <[email protected]>
-
- * window.c (window_tree, Fwindow_tree): Rename fns added 2005-10-04.
-
-2005-10-07 Kim F. Storm <[email protected]>
-
- * dispnew.c (redraw_overlapped_rows, redraw_overlapping_rows)
- [!HAVE_WINDOW_SYSTEM]: Don't declare them...
- (update_window) [!HAVE_WINDOW_SYSTEM]: ...and don't call them.
-
-2005-10-07 YAMAMOTO Mitsuharu <[email protected]>
-
- * dispextern.h (struct glyph_string): Rename member for_overlaps_p
- to for_overlaps. Now occupy 3 bits.
- (OVERLAPS_PRED, OVERLAPS_SUCC, OVERLAPS_BOTH)
- (OVERLAPS_ERASED_CURSOR): New defines.
- (struct redisplay_interface): Add new OVERLAPS arg to member
- fix_overlapping_area.
- (x_fix_overlapping_area): Add new OVERLAPS arg.
- (get_glyph_string_clip_rects): Add extern.
-
- * dispnew.c (redraw_overlapping_rows):
- Call rif->fix_overlapping_area with new OVERLAPS arg as redrawn part.
-
- * xdisp.c: Rename member for_overlaps_p in struct glyph_string to
- for_overlaps.
- (get_glyph_string_clip_rects): New function created from
- get_glyph_string_clip_rect. Set clipping rectangles according to the
- value of for_overlaps. Enable to store multiple clipping rectangles.
- (get_glyph_string_clip_rect): Use get_glyph_string_clip_rects.
- (fill_composite_glyph_string, fill_glyph_string, draw_glyphs):
- Rename argument OVERLAPS_P to OVERLAPS. All uses in macros changed.
- (x_fix_overlapping_area): Add OVERLAPS arg. Pass it to draw_glyphs.
- (draw_phys_cursor_glyph): Set width of erased cursor to use it for
- calculating clipping rectangles later. Call x_fix_overlapping_area
- with new OVERLAPS arg to draw only erased cursor area.
- (expose_overlaps): Call x_fix_overlapping_area with new OVERLAPS arg
- to draw overlaps in both preceding and succeeding rows.
-
- * xterm.c, w32term.c, macterm.c: Rename member for_overlaps_p in
- struct glyph_string to for_overlaps.
-
-2005-10-04 Richard M. Stallman <[email protected]>
-
- * alloc.c (refill_memory_reserve): Conditionalize the body,
- not the function's existence.
-
-2005-10-04 Kim F. Storm <[email protected]>
-
- * window.c (window_split_tree): New function.
- (Fwindow_split_tree): New defun.
- (syms_of_window): Defsubr it.
-
-2005-10-04 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_invert_rectangle): New function.
- (XTflash): Use it.
-
-2005-10-04 Stefan Monnier <[email protected]>
-
- * regex.h (re_char): Don't expose it in the interface.
- (re_set_whitespace_regexp): Adjust the arg's type to not use it.
-
- * regex.c (re_char): Move it back here.
- (re_set_whitespace_regexp): Change the arg's type to not use it.
-
- * keyboard.c (make_lispy_event): If point has moved between down and up
- event, make it a drag, not a click, to mirror what
- mouse-drag-region expects.
-
-2005-10-02 Dan Nicolaescu <[email protected]>
-
- * lisp.h (fatal): Undo previous change.
- * term.c (fatal): Undo previous change.
-
-2005-10-01 Richard M. Stallman <[email protected]>
-
- * xfaces.c (face_color_gray_p): Colors close to black count as gray.
-
-2005-10-01 Kim F. Storm <[email protected]>
-
- * xdisp.c (try_window): Skip scroll-margin check if ZV is visible.
-
-2005-10-01 YAMAMOTO Mitsuharu <[email protected]>
-
- * keyboard.c (init_keyboard) [MAC_OSX]: Don't install SIGINT handler.
-
- * macfns.c (start_hourglass): Apply 2005-05-07 change for xfns.c.
- (x_create_tip_frame) [GLYPH_DEBUG]: Uncomment debugging code.
- (Fx_create_frame, x_create_tip_frame) [USE_ATSUI]:
- Try ATSUI-compatible 12pt Monaco font first.
-
- * macgui.h (struct _XCharStruct): New member valid_p.
- (STORE_XCHARSTRUCT): Set valid_p.
- (struct MacFontStruct) [USE_ATSUI]: New member mac_style.
-
- * macterm.c (mac_draw_string_common, x_per_char_metric)
- (mac_compute_glyph_string_overhangs, init_font_name_table)
- (XLoadQueryFont, mac_unload_font) [USE_ATSUI]: Add ATSUI support.
- (atsu_get_text_layout_with_text_ptr) [USE_ATSUI]: New function.
- (x_draw_glyph_string_background)
- (x_draw_glyph_string_foreground) [MAC_OS8 && USE_ATSUI]: Don't use
- XDrawImageString. Always draw background and foreground separately.
- (x_draw_glyph_string_foreground) [USE_ATSUI]: Don't use 8-bit
- functions for one-byte chars when using ATSUI-compatible fonts.
- (atsu_font_id_hash) [USE_ATSUI]: New variable.
- (syms_of_macterm) [USE_ATSUI]: Initialize and staticpro it.
- (XLoadQueryFont): Set min_byte1, max_byte1, min_char_or_byte2, and
- max_char_or_byte2 more in detail.
- (quit_char_comp, mac_check_for_quit_char) [MAC_OSX]: Remove functions.
-
-2005-09-30 Dan Nicolaescu <[email protected]>
-
- * image.c (slurp_file, xbm_read_bitmap_data): Cast to the correct type.
- * xterm.c (handle_one_xevent, handle_one_xevent): Likewise.
-
- * unexelf.c (fatal): Fix prototype.
-
- * term.c (fatal): Implement using varargs.
-
- * regex.c (re_char): Move typedef ...
- * regex.h (re_char): ... here.
- (re_iswctype, re_wctype, re_set_whitespace_regexp): New prototypes.
-
- * emacs.c (malloc_set_state): Fix return type.
- (endif): Fix type.
-
- * lisp.h (fatal): Add argument types.
-
- * dispextern.h (fatal): Delete prototype.
-
- * systime.h (make_time): Prototype moved from ...
- * editfns.c (make_time): ... here.
-
- * editfns.c: Move systime.h include after lisp.h.
- * dired.c:
- * xsmfns.c:
- * process.c: Likewise.
-
- * alloc.c (old_malloc_hook, old_realloc_hook, old_realloc_hook):
- Add parameter types.
- (__malloc_hook, __realloc_hook, __free_hook): Fix prototypes.
- (emacs_blocked_free): Change definition to match __free_hook.
- (emacs_blocked_malloc): Change definition to match __malloc_hook.
- (emacs_blocked_realloc): Change definition to match __realloc_hook.
-
-2005-09-30 Romain Francoise <[email protected]>
-
- * minibuf.c (Fread_buffer): Follow convention for reading from the
- minibuffer with a default value. Doc fix.
-
-2005-09-29 Juri Linkov <[email protected]>
-
- * editfns.c (Fmessage, Fmessage_box, Fmessage_or_box):
- Rename argument name `string' to `format-string'.
- (Fformat): Doc fix.
-
-2005-09-28 Kim F. Storm <[email protected]>
-
- * image.c (gif_load): Fix size of allocated image buffer
- for images where a sub-image may be larger than the image's
- total height/width specifications.
-
-2005-09-28 YAMAMOTO Mitsuharu <[email protected]>
-
- * macgui.h (struct _XCharStruct): Each member now takes short value.
-
-2005-09-27 Dan Nicolaescu <[email protected]>
-
- * xfaces.c (lookup_derived_face): Add parameter type.
-
- * xdisp.c (cursor_row_fully_visible_p): Add parameter type.
-
- * marker.c (verify_bytepos): Add parameter type.
-
- * process.c (get_operating_system_release): Move prototype ...
-
- * systime.h (get_operating_system_release): ... here.
-
- * xterm.c (handle_one_xevent): Refer to union field to match the
- type required by the function definition.
- (set_vertical_scroll_bar): Move prototype ...
-
- * xterm.h: ... here.
-
- * fns.c (internal_equal, seed_random): Fix prototypes.
- (internal_equal): Add missing parameter.
-
-2005-09-25 Richard M. Stallman <[email protected]>
-
- * keyboard.c (update_menu_bindings): Variable deleted.
- (syms_of_keyboard): Don't defvar it.
- (parse_menu_item): Don't test it.
-
-2005-09-23 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fformat): Explicitly test for end of format string
- and don't use `index'.
-
-2005-09-23 Dan Nicolaescu <[email protected]>
-
- * s/aix4-2.h (BROKEN_GET_CURRENT_DIR_NAME):
- Define BROKEN_GET_CURRENT_DIR_NAME.
-
- * sysdep.c (get_current_dir_name): Also define if
- BROKEN_GET_CURRENT_DIR_NAME.
-
- * m/ibmrs6000.h: Test for USG5, not USG5_4.
-
-2005-09-22 Kim F. Storm <[email protected]>
-
- * xdisp.c (message_dolog): Add warning about GC and Lisp strings.
- (message2): Fix commentary. Ok to use alloca'ed memory.
- Still not ok to use Lisp string data (because of GC).
- (set_message): Add comment why GC cannot happen.
-
-2005-09-22 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (xlfdpat_block_match_1): Fix assertion.
- (init_font_name_table) [TARGET_API_MAC_CARBON]: Don't add style
- variants for a scalable font multiple times.
-
-2005-09-21 YAMAMOTO Mitsuharu <[email protected]>
-
- * process.c (create_process) [RTU || UNIPLUS || DONT_REOPEN_PTY]:
- Setup slave tty options before forking.
-
-2005-09-20 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_set_geometry): Do a gtk_window_move if program
- positions have been set for the frame (as is done for frames in
- special-display-buffer-names).
-
-2005-09-19 Kim F. Storm <[email protected]>
-
- * editfns.c (Fformat): Don't scan past end of format string that
- ends in %. Reported by Johan Bockg,Ae(Brd.
-
-2005-09-18 Andreas Schwab <[email protected]>
-
- * window.h (struct window): Remove height_fixed_p, no longer set.
-
- * window.c (make_window): Don't initialize height_fixed_p.
- (window_fixed_size_p): Don't use it.
-
-2005-09-18 John Paul Wallington <[email protected]>
-
- * data.c (Fdefalias): Signal an error if SYMBOL is not a symbol.
-
-2005-09-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * Makefile.in (SOME_MACHINE_OBJECTS): Undo previous change.
-
- * macfns.c (image_cache_refcount, dpyinfo_refcount) [GLYPH_DEBUG]:
- New variables.
- [TARGET_API_MAC_CARBON] (Fx_file_dialog): Don't allow multiple
- file selection.
-
- * sysdep.c [MAC_OS8]: Don't include stdlib.h. Include sys/param.h.
-
-2005-09-17 Eli Zaretskii <[email protected]>
-
- * Makefile.in (XMENU_OBJ) [!HAVE_CARBON]: Reinstate variable.
- (obj): Use XMENU_OBJ, not a literal xmenu.o.
-
-2005-09-16 Romain Francoise <[email protected]>
-
- * fileio.c (syms_of_fileio) <write-region-inhibit-fsync>: Doc fix.
-
-2005-09-15 Richard M. Stallman <[email protected]>
-
- * xdisp.c (overlay_arrow_at_row): Add HAVE_WINDOW_SYSTEM conditional.
- (display_mode_element): Instead of `lisp_string' and `this',
- record `offset' and increment that.
- `last_offset' replaces `last'.
-
- * Makefile.in (XMENU_OBJ): Variable deleted.
- (obj): Use xmenu.o unconditionally.
- (SOME_MACHINE_OBJECTS): Delete xmenu.o.
-
- * emacs.c (main): Don't conditionalize syms_of_xmenu on HAVE_XMENU.
-
-2005-09-15 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_vertically): Don't try to fetch byte BEGV-1.
- (reseat_at_next_visible_line_start): Likewise (in xassert).
-
-2005-09-14 Romain Francoise <[email protected]>
-
- * fileio.c (write_region_inhibit_fsync): New variable.
- (Fwrite_region): Use it to skip call to fsync.
- (syms_of_fileio): Initialize it.
-
-2005-09-14 Kenichi Handa <[email protected]>
-
- * coding.c (code_convert_region_unwind): Argument format changed.
- (run_pre_post_conversion_on_str): If pre-write-conversion function
- changed the current buffer, delete the new buffer.
- (run_pre_write_conversin_on_c_str): Likewise.
-
- * fileio.c (Fexpand_file_name): Check multibyteness of
- default_directory.
-
-2005-09-13 Kenichi Handa <[email protected]>
-
- * composite.c (compose_chars_in_text): Delete it.
-
- * composite.h (compose_chars_in_text): Delete extern.
-
-2005-09-13 Kim F. Storm <[email protected]>
-
- * print.c (print_error_message): Fix last change.
-
-2005-09-12 Kim F. Storm <[email protected]>
-
- * composite.c (compose_chars_in_text): Fix setup of `pend'.
- Unconditionally reload `ptr' and `pend' after eval.
-
- * xdisp.c (message3): Pass copy of lisp string to message_dolog.
-
- * print.c (print_error_message): Pass copy of caller name to
- message_dolog.
-
- * fileio.c (auto_save_error): Pass copy of lisp string to message2.
-
-2005-09-12 Kenichi Handa <[email protected]>
-
- * xdisp.c (display_mode_element): Be sure to make variables THIS
- and LISP_STRING point into a string data of ELT.
-
-2005-09-12 Kim F. Storm <[email protected]>
-
- * editfns.c (Ftranslate_region_internal): Reload `tt' after
- signal_after_change that may have GC'ed.
- (Fmessage, Fmessage_box, Fmessage_or_box): Doc fix.
-
- * keymap.c (Fdescribe_buffer_bindings): Reload `translate'
- after insert while runs signal_after_change.
-
- * minibuf.c (Fminibuffer_complete_word): Move `completion_string'
- declaration to where it is used.
-
- * w32.c (check_windows_init_file): Fix allocation of error buffer.
-
- * xfns.c (x_encode_text): Declare static. Add FREEP arg.
- (x_set_name_internal): Call x_encode_text with new FREEP arg to
- know if xfree is needed instead of guessing.
-
- * xterm.h (x_encode_text): Remove prototype.
-
-2005-09-11 Chris Prince <[email protected]> (tiny change)
-
- * w32term.c (x_bitmap_icon): Load small icons too.
-
-2005-09-10 Romain Francoise <[email protected]>
-
- * buffer.c (init_buffer): Grow buffer to add directory separator
- and terminal zero. Fix typos.
-
-2005-09-10 Eli Zaretskii <[email protected]>
-
- * buffer.c (init_buffer): Fix error message for failed call to
- get_current_dir_name.
- (get_current_dir_name): Remove prototype.
-
- * xsmfns.c (get_current_dir_name): Remove prototype.
-
- * lisp.h (get_current_dir_name) [!HAVE_GET_CURRENT_DIR_NAME]:
- Add prototype.
-
- * sysdep.c [WINDOWSNT]: Add prototype for getwd.
- Don't #undef NULL after including blockinput.h.
-
- * config.in: Regenerated.
-
-2005-09-10 Giuseppe Scrivano <[email protected]>
-
- Remove the MAXPATHLEN limitations:
-
- * sysdep.c (get_current_dir_name) [!HAVE_GET_CURRENT_DIR_NAME]:
- New function.
-
- * buffer.c (init_buffer): Use it.
-
- * xsmfns.c (smc_save_yourself_CB): Ditto.
-
-2005-09-09 Kim F. Storm <[email protected]>
-
- * doc.c (Fsubstitute_command_keys): Lookup key binding for
- commands that are remapped from some other command.
-
- * xdisp.c (try_window_reusing_current_matrix): Clear mode_line_p
- flag in disabled rows below the window.
-
- * frame.h (struct frame): New member updated_p.
-
- * xdisp.c (redisplay_internal): Mark updated frames in new updated_p
- member. Remove local `updated' array and associated variables.
-
-2005-09-07 Kim F. Storm <[email protected]>
-
- * xdisp.c (handle_display_prop): Respect overlay window property.
-
- * xdisp.c (try_window): Remove superfluous cursor_height calculation.
- Fixes crash reported by YAMAMOTO Mitsuharu.
-
-2005-09-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (struct xlfdpat_block, struct xlfdpat): New structs.
- (xlfdpat_destroy, xlfdpat_create, xlfdpat_exact_p)
- (xlfdpat_block_match_1, xlfdpat_match): New functions.
- (xlfdpat_block_match): New macro.
- (mac_to_x_fontname): Don't use tolower for non-ASCII characters.
- (x_font_name_to_mac_font_name): Set coding.dst_multibyte to 0.
- (add_font_name_table_entry): Increase font_name_table_size more
- rapidly.
- (mac_c_string_match): Remove function.
- (mac_do_list_fonts): Use XLFD pattern match instead of regular
- expression match.
-
- * xfaces.c (xstrlwr): Don't use tolower for non-ASCII characters.
-
-2005-09-03 Richard M. Stallman <[email protected]>
-
- * xdisp.c (redisplay_internal): Make UPDATED as long as needed.
- (move_it_in_display_line_to): Stop after last char on line even
- on a windowing terminal, if that's the specified stop position.
-
- * fns.c (Fsort): Doc fix.
-
- * editfns.c (Fpropertize): Don't insist that properties be symbols.
-
-2005-09-02 Stefan Monnier <[email protected]>
-
- * dired.c (directory_files_internal_unwind, directory_files_internal)
- (file_name_completion): Use a Save_Value object rather than a cons of
- two 16bit ints to store the DIR*.
- (directory_files_internal, file_name_completion): Handle both EINTR and
- EAGAIN consistently after `readdir'.
-
-2005-09-01 Stefan Monnier <[email protected]>
-
- * intervals.c (update_interval): Add position info in error.
-
- * dispnew.c (window_to_frame_hpos, update_window):
- Avoid gcc warning about unused variable `f'.
-
-2005-08-31 Jason Rumney <[email protected]>
-
- * w32menu.c (add_menu_item): If unicode_append_menu returns an
- error, revert to using AppendMenu.
-
-2005-08-31 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c (PIX_MASK_DRAW, PIX_MASK_RETAIN): Remove argument.
- All uses changed.
- [MAC_OS] (XPutPixel, XGetPixel): Add efficient versions for common
- cases.
- (x_create_x_image_and_pixmap) [MAC_OS]: Don't call x_destroy_x_image.
- [MAC_OS] (find_image_fsspec) [!MAC_OSX]: Don't use FSRef.
- Use posix_pathname_to_fsspec.
- [MAC_OS] (xpm_load_image): Fill in background_transparent field
- while we have mask.
-
- * macgui.h [!TARGET_API_MAC_CARBON] (GetPixDepth): New define.
-
- * macterm.h (PIX_MASK_DRAW, PIX_MASK_RETAIN): Move defines to image.c.
-
-2005-08-29 Stefan Monnier <[email protected]>
-
- * syntax.c (update_syntax_table): Properly reproduce the special +1
- setting of e_property at the end of the buffer when bumping into the
- INTERVALS_AT_ONCE limit.
-
-2005-08-27 Eli Zaretskii <[email protected]>
-
- * emacs.c (USAGE1): Fix the description of the -Q option.
-
-2005-08-26 Stefan Monnier <[email protected]>
-
- * xdisp.c (pos_visible_p): Yet another int/Lisp_Object mixup (YAILOM).
-
-2005-08-26 Kim F. Storm <[email protected]>
-
- * xdisp.c (resize_mini_window): Fix 2005-08-20 change.
- Don't move PT to new window start.
-
-2005-08-25 YAMAMOTO Mitsuharu <[email protected]>
-
- * keyboard.c (kbd_buffer_get_event) [MAC_OS]: Make events for
- ICONIFY/DEICONIFY_EVENT.
-
- * macterm.c (mac_copy_area, mac_copy_area_with_mask):
- Restore background color.
- (mac_handle_visibility_change): New function.
- (x_make_frame_invisible, x_iconify_frame)
- (XTread_socket) [!USE_CARBON_EVENTS]: Use it.
- [USE_CARBON_EVENTS] (mac_handle_window_event)
- (install_window_handler): Handle visibility change events.
- (x_make_frame_visible): Don't reposition window if it is iconified
- or asked for visible before. Select and uncollapse window when it
- is made visible.
- (x_make_frame_invisible): Don't reset x_highlight_frame.
- (x_iconify_frame): Likewise. Make invisible frame visible before
- it is iconified.
- (read_socket_inev): Move variable outside #if USE_CARBON_EVENTS.
- (do_window_update): Don't change visibility of invisible frame.
-
-2005-08-22 Juri Linkov <[email protected]>
-
- * term.c (turn_on_face): Check for TS_set_foreground and
- TS_set_background depending on standout_mode. Simplify.
-
-2005-08-21 Kim F. Storm <[email protected]>
-
- * fringe.c (update_window_fringes): Only put TOP and BOTTOM
- bitmaps on fully visible rows.
-
- * fringe.c (update_window_fringes): Replace FORCE_P arg with
- KEEP_CURRENT_P arg; if non-zero, don't update current row fringes,
- and return 0.
-
- * xdisp.c (redisplay_window): Call update_window_fringes with
- KEEP_CURRENT_P non-0 if we are going to refresh fringes later.
-
-2005-08-20 Richard M. Stallman <[email protected]>
-
- * xdisp.c (display_echo_area_1): Get display start pos from w->start.
- (resize_mini_window): Set w->start, and PT, so as to display the tail
- end of the buffer, if it doesn't all fit.
-
-2005-08-18 Kim F. Storm <[email protected]>
-
- * xdisp.c (calc_pixel_width_or_height): Use actual display
- resolution when available instead of Vdisplay_pixels_per_inch.
-
-2005-08-17 Kim F. Storm <[email protected]>
-
- * xdisp.c (pos_visible_p): Adjust X value if window is hscrolled.
-
- * dispnew.c (buffer_posn_from_coords): Check that target row is
- within matrix.
-
-2005-08-16 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_wm_set_icon_pixmap): Move GTK specific code to
- xg_set_frame_icon and call it.
-
- * gtkutil.c (xg_set_frame_icon): New function.
-
- * gtkutil.h (xg_set_frame_icon): Declare it.
-
-2005-08-16 Kim F. Storm <[email protected]>
-
- * dispnew.c (increment_row_positions): Skip non-enabled rows.
-
- * window.c (SAVED_WINDOW_VECTOR_SIZE): Remove dangerous define.
- (Fcurrent_window_configuration): Use VECSIZE macro instead.
-
-2005-08-15 Richard M. Stallman <[email protected]>
-
- * xdisp.c (message3_nolog): Clear echo_message_buffer.
-
-2005-08-15 Kim F. Storm <[email protected]>
-
- * lisp.h (QUIT) [!SYNC_INPUT]: Throw t to Vthrow_on_input.
-
- * process.c (deactivate_process, status_notify, read_process_output)
- (update_status, status_convert, decode_status, allocate_pty)
- (make_process, remove_process, list_processes_1)
- (create_process_1, unwind_request_sigio, read_process_output)
- (send_process, keyboard_bit_set): Declare static.
- (Fdelete_process): Simplify. Pass process to status_notify, so we
- don't try to read output from it.
- (status_notify): New arg deleting_process--don't try to read
- output from that process.
-
- * lisp.h (deactivate_process, status_notify, read_process_output):
- Remove prototypes.
-
-2005-08-14 Richard M. Stallman <[email protected]>
-
- * image.c (syms_of_image): Init Qxbm, Qpbm before calling
- define_image_type.
-
-2005-08-13 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_pixbuf_from_pix_and_mask): New function.
- (xg_get_image_for_pixmap): Move some code to
- xg_get_pixbuf_from_pix_and_mask, and call it.
-
- * gtkutil.h (xg_get_pixbuf_from_pix_and_mask): Declare.
-
- * xterm.c (x_wm_set_icon_pixmap): Call xg_get_pixbuf_from_pix_and_mask
- to get an GTK icon and set it with GTK functions to avoid having GTK
- override an icon set with just X functions.
-
-2005-08-11 Richard M. Stallman <[email protected]>
-
- * image.c (syms_of_image): Init image_types here, and call
- define_image_type.
- (init_image): Not here.
-
-2005-08-09 Richard M. Stallman <[email protected]>
-
- * bytecode.c (BYTE_CODE_QUIT): Throw t to Vthrow_on_input.
-
- * lisp.h (QUIT): Throw t to Vthrow_on_input.
-
-2005-08-09 Thien-Thi Nguyen <[email protected]>
-
- * floatfns.c (Fexpt): Use floats for negative exponent.
-
-2005-08-08 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_modify_menubar_widgets): Remove semicolon that
- should not be there, causing menu display errors with GTK 2.6.9.
-
-2005-08-07 Richard M. Stallman <[email protected]>
-
- * floatfns.c (Fexpt): Undo previous change.
-
- * dispnew.c (Fframe_or_buffer_changed_p): Take an arg
- so it can be used with various state vectors.
-
- * emacs.c (endif): Convert -script into -scriptload.
- (standard_args): Add -scriptload. Allow -basic-display with one dash.
-
- * fns.c (syms_of_fns): Add `emacs' to features.
-
- * term.c (set_terminal_modes): If no TS_termcap_modes string,
- output newlines to scroll the old screen contents off the screen.
-
-2005-08-06 Thien-Thi Nguyen <[email protected]>
-
- * floatfns.c (Fexpt): Use floats for negative exponent.
- Reported by D Goel.
-
-2005-08-02 Richard M. Stallman <[email protected]>
-
- * frame.c (Fframe_char_width): Doc fix.
-
-2005-07-30 Juanma Barranquero <[email protected]>
-
- * xdisp.c (syms_of_xdisp) <redisplay-end-trigger-functions>:
- Defvar it.
-
-2005-07-28 Juanma Barranquero <[email protected]>
-
- * w32fns.c (my_set_window_pos, my_show_window): Don't declare.
- (my_create_window, my_create_tip_window): Make static.
-
- * w32term.c (my_show_window, my_set_window_pos, my_set_focus)
- (my_set_foreground_window, my_destroy_window): Make static.
-
-2005-07-26 Paul Eggert <[email protected]>
-
- Merge gnulib getopt implementation into Emacs.
-
- * s/cygwin.h (C_SWITCH_SYSTEM): Remove, since gettext.h is
- now part of lib-src.
-
-2005-07-26 Stefan Monnier <[email protected]>
-
- * eval.c (Fdefvar): Allow (defvar enable-multibyte-characters).
-
-2005-07-25 Jason Rumney <[email protected]>
-
- * w32menu.c (w32_menu_display_help): Suppress tooltip when
- navigating menus with the keyboard.
-
-2005-07-23 Richard M. Stallman <[email protected]>
-
- * insdel.c (syms_of_insdel): staticpro combine_after_change_buffer.
-
- * bytecode.c (MAYBE_GC): Test gc_cons_threshold and
- gc_relative_threshold, one by one.
-
- * keyboard.c (read_char): Test gc_cons_threshold.
- (syms_of_keyboard): staticpro Qecho_area_clear_hook.
-
- * eval.c (Feval, Ffuncall): Test gc_cons_threshold and
- gc_relative_threshold, one by one.
-
- * alloc.c (gc_cons_threshold): Not static.
- (gc_cons_combined_threshold): Var deleted.
- (gc_relative_threshold): New variable.
- (Fgarbage_collect, init_alloc_once): Compute gc_relative_threshold
- instead of gc_cons_combined_threshold.
-
- * lisp.h (gc_cons_threshold, gc_relative_threshold): Declare.
- (gc_cons_combined_threshold): Declaration deleted.
-
-2005-07-23 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c: Don't include stdlib.h or string.h.
- (Fdo_applescript, Fmac_file_name_to_posix)
- (Fmac_file_name_to_posix): Doc fixes.
- [TARGET_API_MAC_CARBON] (Fmac_get_preference)
- (Fmac_code_convert_string): Likewise.
- [MAC_OSX] (init_mac_osx_environment): Fall back on terminal mode
- if the executable is not contained in a bundle.
-
- * macfns.c: Don't include stdlib.h or string.h. Include atimer.h.
- (gray_width, gray_height): Remove defines.
- (gray_bits, gray_bitmap_width, gray_bitmap_height)
- (gray_bitmap_bits): Remove variables.
- (lispy_function_keys): Remove extern.
- (free_frame_menubar): Add extern.
- (x_window_to_frame): Remove function.
- (unwind_create_tip_frame): Add declaration.
- (x_set_name_internal): New function.
- (x_set_name, x_set_title): Use it.
- (Fx_create_frame, Fx_display_grayscale_p, Fx_display_pixel_width)
- (Fx_display_pixel_height, Fx_display_planes)
- (Fx_display_color_cells, Fx_server_max_request_size)
- (Fx_server_vendor, Fx_server_version, Fx_display_screens)
- (Fx_display_mm_height, Fx_display_mm_width)
- (Fx_display_backing_store, Fx_display_visual_class)
- (Fx_display_save_under, Fx_synchronize, Fx_show_tip): Doc fixes.
-
- * macmenu.c (Fx_popup_menu, Fx_popup_dialog): Doc fixes.
-
- * macselect.c (Fx_own_selection_internal): Follow error conventions.
- (Fx_get_selection_internal, Fx_selection_owner_p)
- (Fx_selection_exists_p): Doc fixes.
- (syms_of_macselect) <selection-converter-alist>: Likewise.
-
-2005-07-21 Juanma Barranquero <[email protected]>
-
- * buffer.c (syms_of_buffer) <cursor-type>: Doc fix.
-
- * ccl.c (Fregister_ccl_program): Fix typos in docstring.
- (Fccl_execute_on_string): Likewise; add usage info.
-
- * composite.c (Fcompose_region_internal)
- (Fcompose_string_internal):
- Improve argument/docstring consistency.
-
- * minibuf.c (Fminibuffer_prompt_end, Feval_minibuffer):
- Fix typos in docstrings.
-
- * textprop.c (Fnext_char_property_change)
- (Fprevious_char_property_change): Doc fixes.
-
- * window.c (Fset_window_margins, Fset_window_fringes):
- Improve argument/docstring consistency.
-
- * xfaces.c (Finternal_lisp_face_p): Doc fix.
-
-2005-07-21 Andreas Schwab <[email protected]>
-
- * eval.c (restore_stack_limits): Return a value.
-
-2005-07-20 Juanma Barranquero <[email protected]>
-
- * eval.c (Fdefvar): Doc fix.
-
-2005-07-20 Kim F. Storm <[email protected]>
-
- * fileio.c (Fdo_auto_save, do_auto_save_unwind):
- Use make_save_value to unwind protect stream.
-
- * lread.c (Fload, load_unwind):
- Use make_save_value to unwind protect stream.
-
-2005-07-19 Juanma Barranquero <[email protected]>
-
- * eval.c (Fprog2, Fcalled_interactively_p),
- (syms_of_eval) <debug-on-quit>: Doc fixes.
- (syms_of_eval) <max-specpdl-size>:
- (Finteractive_p): Fix typos in docstrings.
-
-2005-07-19 Kim F. Storm <[email protected]>
-
- * w32fns.c (Vx_hand_shape): Variable removed.
- (syms_of_w32fns): Intern and staticpro Qw32_charset_default.
-
-2005-07-19 Kenichi Handa <[email protected]>
-
- * fns.c (Fstring_as_multibyte): Escape backslashes in the docstring.
-
-2005-07-18 Stefan Monnier <[email protected]>
-
- * buffer.h (Fgenerate_new_buffer_name): Declare (for use in coding.c).
-
-2005-07-18 Kim F. Storm <[email protected]>
-
- * frame.h (struct frame): New member already_hscrolled_p.
-
- * xdisp.c (redisplay_internal): Only try to hscroll each frame once
- to avoid redisplay looping hscrolling back and forth ad infinitum.
-
-2005-07-18 Juri Linkov <[email protected]>
-
- * buffer.c (scroll-up-aggressively, scroll-down-aggressively):
- * keymap.c (Fminor_mode_key_binding):
- * macterm.c (mac-emulate-three-button-mouse):
- Delete duplicate duplicate words.
-
-2005-07-18 Ken Raeburn <[email protected]>
-
- * minibuf.c (Ftest_completion): Fix odd syntax in test.
-
-2005-07-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (x_set_cursor_color): Use XSetBackground and XSetForeground.
-
- * macgui.h (struct _XGC): New struct.
- (GC): Use it.
- (GCForeground, GCBackground, GCFont): Use X11 mask values.
- (XCreateGC, XParseGeometry): Move externs to macterm.h.
-
- * macterm.c (x_bitmap_icon, x_make_frame_visible): Remove declarations.
- (XSetFont): Add declaration.
- (mac_set_forecolor, mac_set_backcolor, mac_set_colors):
- Remove functions.
- (GC_FORE_COLOR, GC_BACK_COLOR, GC_FONT, MAC_WINDOW_NORMAL_GC):
- New defines.
- (XDrawLine, mac_draw_line_to_pixmap, XClearWindow)
- (mac_draw_bitmap, XCreatePixmapFromBitmapData, XFillRectangle)
- (mac_draw_rectangle, mac_draw_string_common, mac_scroll_area):
- Use them.
- (mac_erase_rectangle): New function.
- (XClearArea, x_draw_fringe_bitmap, x_clear_glyph_string_rect)
- (x_draw_stretch_glyph_string): Use it.
- (XChangeGC, XCreateGC, XGetGCValues, XSetForeground)
- (XSetBackground, XSetFont): Adjust for new GC implementation.
- (x_draw_fringe_bitmap, x_draw_box_rect): Use GC to set colors.
- (XTset_vertical_scroll_bar): Clear area under scroll bar.
-
- * macterm.h (struct mac_display_info): Change types of
- scratch_cursor_gc black_relief.gc, and white_relief.gc to GC.
- (XCreateGC, XParseGeometry): Move externs from macgui.h.
-
- * xfaces.c [MAC_OS] (XCreateGC): Remove extern.
-
-2005-07-16 Richard M. Stallman <[email protected]>
-
- * buffer.c (Fmake_overlay): Doc fix.
-
-2005-07-16 Eli Zaretskii <[email protected]>
-
- * w32proc.c (syms_of_ntproc): staticpro Qhigh, Qlow,
- Vw32_valid_locale_ids, and Vw32_valid_codepages.
-
-2005-07-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c [TARGET_API_MAC_CARBON] (Fmac_code_convert_string):
- Use Fstring_as_unibyte instead of string_make_unibyte.
-
-2005-07-15 Richard M. Stallman <[email protected]>
-
- * xdisp.c (select_frame_for_redisplay): Use find_symbol_value.
-
-2005-07-15 Kim F. Storm <[email protected]>
-
- * xdisp.c: Fix redisplay loop in last change.
- (IT_POS_VALID_AFTER_MOVE_P): New macro.
- (move_it_vertically_backward, move_it_by_lines): Use it.
-
-2005-07-14 Jason Rumney <[email protected]>
-
- * w32.c (init_environment): Default HOME directory to user's
- appdata directory if possible.
-
-2005-07-14 Kim F. Storm <[email protected]>
-
- * .gdbinit (pitx): Fix output format. Print string charpos.
-
- * lread.c (syms_of_lread): Initialize seen_list.
-
- * search.c (syms_of_search): Staticpro searchbuf.whitespace_regexp.
-
- * syntax.c (syms_of_syntax): Staticpro lisp objects in gl_state.
- Staticpro re_match_object.
-
-2005-07-14 YAMAMOTO Mitsuharu <[email protected]>
-
- * macselect.c (get_scrap_target_type_list): Avoid NULL pointer
- dereference.
-
- * macterm.c (mac_window_to_frame): Remove duplicate define.
-
-2005-07-14 Kenichi Handa <[email protected]>
-
- * coding.c (code_convert_region_unwind): ARG is changed to a cons.
- (code_convert_region): Adjust for the above change.
- (set_conversion_work_buffer): If the work buffer is already in
- use, generate a new buffer and return it. Otherwise return Qnil.
- (run_pre_post_conversion_on_str): Adjust for the above change.
- (run_pre_write_conversin_on_c_str): Likewise.
-
-2005-07-13 Kim F. Storm <[email protected]>
-
- * xdisp.c (start_display): Don't reseat to next visible line start
- if current start position is in a string or image.
- (move_it_vertically_backward): Be sure to move out of strings and
- images when moving it2 forward.
- (move_it_by_lines): When moving forward, move to next buffer
- position if we end up in a string or image. When moving backward,
- count rows moved over when moving to start of current row in case
- row starts in middle of a string or image. Also move further
- backward if we end up in a string or image.
- (try_cursor_movement): If overlay string spans multiple lines,
- move backward to set cursor on start of an overlay string.
- (cursor_row_p): Row is ok if cursor is at newline from string, but
- string starts on this line (so we always position cursor at start
- of string).
-
- * indent.c (Fvertical_motion): If start position is on an image,
- don't move back if we move too far (that's almost certain to happen).
-
- * xdisp.c (cursor_row_fully_visible_p): Allow partially visible
- row in minibuffer windows.
- (try_window): Don't check margins in minibuffer windows.
-
-2005-07-13 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c: Don't include stdlib.h or composite.h.
- (x_use_underline_position_properties, last_mouse_press_frame)
- (x_noop_count, Qvendor_specific_keysyms): Remove unused variables.
- (syms_of_macterm, mac_initialize): Don't initialize them.
- (waiting_for_input, initial_argv, initial_argc)
- (Vcommand_line_args, Vx_no_window_manager, errno, window_scroll)
- (set_frame_menubar, path_from_vol_dir_name): Remove externs.
- (extra_keyboard_modifiers): Fix type in extern.
- (x_window_to_frame, x_window_to_scroll_bar): Remove declarations.
- (x_scroll_bar_report_motion): Add argument types to declaration.
- (mac_compute_glyph_string_overhangs): Add declaration.
- (disable_mouse_highlight): Remove unused variable.
- [USE_TOOLKIT_SCROLL_BARS] (construct_scroll_bar_click)
- (x_scroll_bar_handle_press, x_scroll_bar_handle_release)
- (x_scroll_bar_handle_drag): Remove argument `timestamp'.
- All callers changed.
- [USE_TOOLKIT_SCROLL_BARS] (construct_scroll_bar_click): Don't set
- timestamp.
- [USE_CARBON_EVENTS] (mac_handle_mouse_event): Likewise.
- (x_scroll_bar_create, XTset_vertical_scroll_bar): Show scroll bar
- only when its width is less than the height.
- (XTredeem_scroll_bar): Sync with xterm.c.
- (font_name_table, font_name_table_size, font_name_count):
- Make static.
- (drag_and_drop_file_list): Remove variable. Previous use is now
- local to function.
- (do_ae_open_documents): Move DRAG_N_DROP event construction part
- from XTread_socket.
- (XTread_socket): Consolidate setting of event timestamp.
- Move DRAG_N_DROP event construction part to do_ae_open_documents.
- Support extra_keyboard_modifiers.
-
- * xfaces.c (try_font_list) [MAC_OS]: Try font family name
- beginning with that for ASCII.
-
-2005-07-13 Stefan Monnier <[email protected]>
-
- * alloc.c (gc_cons_combined_threshold, Vgc_cons_percentage): New vars.
- (Fgarbage_collect, init_alloc_once): Set gc_cons_combined_threshold.
- (syms_of_alloc): Declare gc-cons-percentage.
-
- * eval.c (Feval, Ffuncall):
- * keyboard.c (read_char):
- * bytecode.c (MAYBE_GC): Use gc_cons_combined_threshold.
-
- * lisp.h (gc_cons_combined_threshold): Declare.
-
-2005-07-12 Kim F. Storm <[email protected]>
-
- * coding.c (Qprocess_argument):
- * coding.h (Qprocess_argument): Remove unused var.
-
- * xselect.c (intern): Remove dup. intern and staticpro for QTIMESTAMP.
-
-2005-07-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c [!TARGET_API_MAC_CARBON]: Include charset.h, coding.h, and
- Endian.h.
- [!MAC_OSX] (fchmod, fchown): New functions.
- (mac_get_code_from_arg): Don't accept Lisp integer as argument.
- Use SBYTES and EndianU32_BtoN.
- (mac_get_object_from_code): Return 4 byte string even if argument
- is 0. Use make_unibyte_string and EndianU32_NtoB.
- (Fmac_get_file_creator, Fmac_get_file_type, Fmac_set_file_creator)
- (Fmac_set_file_type): Fix documents and argument declarations.
- Don't specify kFSCatInfoNodeFlags. Support Mac OS Classic.
-
-2005-07-11 Stefan Monnier <[email protected]>
-
- * window.c (Frecenter): Yet another int/Lisp_Object mixup (YAILOM).
-
-2005-07-11 Jan Dj,Ad(Brv <[email protected]>
-
- * xfaces.c (x_update_menu_appearance): Use fontSet resource for
- Lucid if X_I18N, font otherwise.
-
-2005-07-10 Steven Tamm <[email protected]>
-
- * mac.c (Fmac_get_file_type, Fmac_get_file_creator): Add.
- (Fmac_set_file_type, Fmac_set_file_creator): Add.
- (mac_get_object_from_code, mac_get_code_from_arg): Add.
-
-2005-07-10 Richard M. Stallman <[email protected]>
-
- * lread.c (Qeval_buffer_list, Veval_buffer_list): New vars.
- (syms_of_lread): Set up eval-buffer-list.
- (Feval_buffer, Feval_region): Bind eval-buffer-list.
-
-2005-07-08 Richard M. Stallman <[email protected]>
-
- * eval.c (Fdefvar): Allow defvaring a constant to itself quoted.
-
-2005-07-08 Kim F. Storm <[email protected]>
-
- * keyboard.c (menu_bar_items): Don't GCPRO menu_bar_items_vector here.
- (syms_of_keyboard): Initialize and staticpro menu_bar_items_vector.
-
-2005-07-07 Kim F. Storm <[email protected]>
-
- * window.c (Frecenter): Fix last change (set iarg before use).
-
-2005-07-06 Richard M. Stallman <[email protected]>
-
- * window.c (Frecenter): When arg is inside the scroll margin,
- move it out of the margin.
-
-2005-07-06 Jason Rumney <[email protected]>
-
- * w32console.c (initialize_w32_display): Detect when the console
- dimensions are insane, and default to 80x25 instead.
- (w32_use_full_screen_buffer): Default to nil.
-
-2005-07-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_draw_vertical_window_border): Use foreground of
- VERTICAL_BORDER_FACE_ID for vertical border line.
- (mac_encode_char): Call check_ccl_update in advance.
- (mac_to_x_fontname, x_font_name_to_mac_font_name)
- (init_font_name_table, mac_do_list_fonts, XLoadQueryFont):
- Don't assume that font family length is less than 32.
- (x_compute_min_glyph_bounds): Make static.
- (x_load_font): Never set fonts_changed_p to zero.
-
-2005-07-04 Lute Kamstra <[email protected]>
-
- * Update FSF's address in GPL notices.
-
-2005-07-03 Richard M. Stallman <[email protected]>
-
- * xdisp.c (try_window): Fix previous change in how it handles
- a partially-visible line or one only partly past the margin.
-
- * window.c (window_scroll_pixel_based): Take account
- of this_scroll_margin when finding point when scrolling up.
-
-2005-06-29 Ralf Angeli <[email protected]>
-
- * window.c (window_scroll_pixel_based, window_scroll_line_based):
- Handle `scroll-preserve-screen-position' non-nil, non-t specially.
- (syms_of_window) <scroll-preserve-screen-position>: Doc fix.
-
-2005-07-02 Juri Linkov <[email protected]>
-
- * w32term.c (w32_draw_vertical_window_border): Use foreground of
- VERTICAL_BORDER_FACE_ID for vertical border line.
-
-2005-07-02 Eli Zaretskii <[email protected]>
-
- * fileio.c (Fcopy_file): Rearrange the code that calls fchown and
- fchmod so that chmod doesn't get called on MSDOS before the file
- is closed.
-
-2005-07-01 Jason Rumney <[email protected]>
-
- * w32term.c (cleartype_active): New flag for enabling sub-pixel
- workaround.
- (w32_initialize): Initialize it.
- (w32_native_per_char_metric): Allow a couple of extra pixels when
- Cleartype is active.
-
- * w32term.c (w32_initialize): Move check for screen reader here
- from syms_of_w32term.
-
-2005-06-30 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): bzero compose_status when nbytes
- is not zero.
-
-2005-07-01 Masatake YAMATO <[email protected]>
-
- * emacs.c (main): Passing ADD_NO_RANDOMIZE to `personality'.
-
-2005-06-30 Juri Linkov <[email protected]>
-
- * xdisp.c (x_draw_vertical_border): If left fringe is not present
- decrease x coord of vertical border by 1 pixel to not occupy text
- area of the right window.
-
- * xterm.c (x_draw_vertical_window_border): Use foreground of
- VERTICAL_BORDER_FACE_ID for vertical border line.
-
- * term.c (turn_on_face): In standout mode apply specified
- fg to bg, and specified bg to fg (this makes the logic of
- inversion on terminal consistent with X).
-
-2005-06-29 Juanma Barranquero <[email protected]>
-
- * eval.c (user_variable_p_eh): New function.
- (Fuser_variable_p): Use it. Clarify docstring.
- Return t for aliases of user options, nil for alias loops.
-
-2005-06-27 Richard M. Stallman <[email protected]>
-
- * eval.c (Fdefvar): Improve error message.
-
-2005-06-27 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c [USE_CARBON_EVENTS] (mac_convert_event_ref): Fix last
- change.
-
-2005-06-27 Juanma Barranquero <[email protected]>
-
- * eval.c (Fdefvar): Don't try to set constant symbols.
-
-2005-06-25 Richard M. Stallman <[email protected]>
-
- * macfns.c (Fx_show_tip): Pass new arg to try_window.
-
- * w32fns.c (Fx_show_tip): Pass new arg to try_window.
-
- * xfns.c (Fx_show_tip): Pass new arg to try_window.
-
- * xdisp.c (try_window): New arg CHECK_MARGINS. Calls changed.
- (redisplay_window): Handle try_window reporting point in scroll margin.
-
- * dispextern.h (try_window): Declare new arg.
-
- * fileio.c (Fcopy_file): New arg PRESERVE_UID_GID.
- Use fchmod to copy the file modes.
- (Frename_file): Don't copy UID and GID here;
- instead, specify t for PRESERVE_UID_GID when calling Fcopy_file.
-
- * eval.c (call_debugger): Take full care of extending stack limits
- to make space for the debugger, and restore the change afterward.
- Bind debug-on-error to nil.
- (restore_stack_limits): New subroutine.
- (Fsignal): Extend specpdl bound along with eval depth bound,
- for calling edebug. Don't do either one, for calling debugger.
- (find_handler_clause): Don't bind debug-on-error here.
- Don't unbind anything either.
- Temporarily advance max_specpdl_size for calling
- internal_with_output_to_temp_buffer.
- (grow_specpdl): Don't alter max_specpdl_size before signaling
- an error.
- (syms_of_eval) <max-specpdl-size>: Doc fix.
-
- * lread.c (read1): 0.0e+NaN should make a "positive" NaN.
-
-2005-06-24 Eli Zaretskii <[email protected]>
-
- * fileio.c (Frename_file): Undo last change: no need to ifdef away
- chown on DOS_NT platforms.
-
- * w32.c (sys_chown): New function.
-
- * s/ms-w32.h (chown): New; define to sys_chown.
-
-2005-06-24 Juanma Barranquero <[email protected]>
-
- * xdisp.c (syms_of_xdisp) <nobreak-char-display>: Doc fix.
- (syms_of_xdisp) <void-text-area-pointer>: Doc fix.
-
- * fileio.c (Frename_file)[!DOS_NT]: Don't call chown on MSDOS/Windows.
-
-2005-06-23 Richard M. Stallman <[email protected]>
-
- * xdisp.c (get_next_display_element): Finish reversing the tests of
- Vnobreak_char_display.
-
- * xdisp.c (Vnobreak_char_display): Rename from Vshow_nonbreak_escape.
- All uses changed.
- (Qnobreak_space): Rename from Qno_break_space. All uses changed.
- (syms_of_xdisp): Define nobreak-char-display and nobreak-space.
-
- * fileio.c (Frename_file): Preserve owner and group, if possible,
- when copying.
-
-2005-06-23 Juanma Barranquero <[email protected]>
-
- * abbrev.c (Funexpand_abbrev):
- * category.c (Fmake_category_set):
- * dispnew.c (Fsleep_for, Fsit_for):
- * editfns.c (Fsubst_char_in_region):
- * eval.c (Fdefvar, Fdefconst, Feval, Ffuncall):
- * frame.c (make_frame_without_minibuffer):
- * lread.c (read_vector):
- * macfns.c (check_x_frame):
- * process.c (Fstop_process, Fcontinue_process):
- * search.c (Freplace_match):
- * syntax.c (Fstring_to_syntax):
- * w32fns.c (check_x_frame, check_x_display_info):
- * xfaces.c (x_supports_face_attributes_p):
- * xselect.c (Fx_own_selection_internal): Follow error conventions.
-
- * image.c (fn_png_init_io): Don't define it.
- (init_png_functions) [HAVE_NTGUI]: Don't initialize fn_png_init_io.
- (png_read_from_file): New function, based on png_read_from_memory.
- (png_load): Use it, instead of fn_png_init_io.
-
-2005-06-23 Kim F. Storm <[email protected]>
-
- * search.c (Fmatch_data): Remove evaporate option.
- (Fset_match_data): Do not mention evaporate option in doc string.
- Add commentary explaining evaporate arg (for internal use only).
- (unwind_set_match_data): Add comment on evaporate use.
-
-2005-06-22 Miles Bader <[email protected]>
-
- * xfaces.c (Qvertical_border): Rename from `Qvertical_divider'.
- (realize_basic_faces, syms_of_xfaces): Update references to it.
- * dispextern.h (enum face_id): Rename `VERTICAL_DIVIDER_FACE_ID'
- to `VERTICAL_BORDER_FACE_ID'.
- * dispnew.c (build_frame_matrix_from_leaf_window): Update references.
-
-2005-06-21 Juri Linkov <[email protected]>
-
- * dispextern.h: Add extern Qframe_set_background_mode.
-
- * xfaces.c: Rename obsolete function Qframe_update_face_colors to
- Qframe_set_background_mode.
-
- * frame.c (Fmodify_frame_parameters):
- Call frame-set-background-mode after changing the background color
- on non-window non-dos branch.
-
-2005-06-21 Juanma Barranquero <[email protected]>
-
- * fns.c (Fchar_table_range):
- * process.c (Fmake_network_process): Fix spellings.
-
-2005-06-20 Kim F. Storm <[email protected]>
-
- * fns.c (Fsort): Doc fix.
-
-2005-06-20 Miles Bader <[email protected]>
-
- * xfaces.c (Qvertical_divider): New variable.
- (realize_basic_faces): Realize its face.
- (syms_of_xfaces): Initialize it.
-
- * dispextern.h (enum face_id): Add `VERTICAL_DIVIDER_FACE_ID'.
-
- * dispnew.c (build_frame_matrix_from_leaf_window): Display vertical
- window-separator on ttys using `vertical-divider' face by default.
-
-2005-06-17 Richard M. Stallman <[email protected]>
-
- * xdisp.c (get_next_display_element):
- Reverse test of Vshow_nonbreak_escape.
-
- * term.c (produce_special_glyphs): Use spec_glyph_lookup_face.
- (Ftty_no_underline): New function.
- (syms_of_term): defsubr it.
-
- * keyboard.c (read_char): Call restore_getcjmp after jump occurs.
-
- * dispnew.c (spec_glyph_lookup_face): New function.
- (build_frame_matrix_from_leaf_window): Use it.
-
- * dispextern.h (spec_glyph_lookup_face): Add declaration.
-
- * buffer.c (syms_of_buffer) <cursor-type>: Doc fix.
-
-2005-06-12 Richard M. Stallman <[email protected]>
-
- * keyboard.c (read_char): After catching a longjmp,
- call restore_getcjmp.
-
-2005-06-17 Juanma Barranquero <[email protected]>
-
- * xselect.c (lisp_data_to_selection_data): Fix spelling.
-
-2005-06-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_compute_glyph_string_overhangs): Don't set
- overhangs unless the given glyph type is noncomposite CHAR_GLYPH.
- [USE_CARBON_EVENTS] (mac_convert_event_ref): Convert dead key down
- events.
- (XTread_socket): Don't pass keyboard events with the option
- modifier to the system when Vmac_command_key_is_meta is nil or
- Vmac_option_modifier is non-nil.
- [USE_CARBON_EVENTS] (read_socket_inev): New variable.
- [USE_CARBON_EVENTS] (init_command_handler): Fix argument.
- [USE_CARBON_EVENTS] (mac_handle_mouse_event): New Carbon event
- handler function.
- (install_window_handler) [USE_CARBON_EVENTS]: Install it.
- (XTread_socket) [USE_CARBON_EVENTS]: Move mouse wheel event
- handler part to mac_handle_mouse_event.
-
-2005-06-14 Juanma Barranquero <[email protected]>
-
- * eval.c (Fdefvaralias): Rename arguments SYMBOL and ALIASED to
- NEW-ALIAS and BASE-VARIABLE, respectively.
-
-2005-06-13 Stefan Monnier <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Lisp_Object/int mixup.
- (get_phys_cursor_geometry, format_mode_line_unwind_data)
- (get_line_height_property, x_produce_glyphs): Remove unused vars.
-
- * coding.c (run_pre_post_conversion_on_str): Remove unused var `buf'.
-
-2005-06-13 Eli Zaretskii <[email protected]>
-
- * w32term.c (x_use_underline_position_properties): New variable.
- (x_draw_glyph_string): Remind in a comment to change doc string of
- x-use-underline-position-properties if/when underline positioning
- is implemented.
- (syms_of_w32term): DEFVAR_BOOL x-use-underline-position-properties,
- and initialize it to nil.
-
-2005-06-12 Jason Rumney <[email protected]>
-
- * w32fns.c (NEWOPENFILENAME): New struct.
- (Fx_file_dialog): Use it to trick the system into giving us up to
- date dialogs on systems that are documented to support it.
- Do not set OFN_FILEMUSTEXIST flag if looking for a directory.
-
-2005-06-12 Eli Zaretskii <[email protected]>
-
- * w32fns.c (w32_abort): Use the MB_YESNO dialog instead of
- MB_ABORTRETRYIGNORE. Never return, even if DebugBreak does.
-
-2005-06-11 Eli Zaretskii <[email protected]>
-
- * image.c (x_create_x_image_and_pixmap) [HAVE_NTGUI]: Cast 4th arg
- to CreateDIBSection to avoid a compiler warning.
- (pbm_load): Cast 3rd arg to IMAGE_BACKGROUND to avoid a compiler
- warning.
- (png_load): Cast return values of fn_png_create_read_struct and
- fn_png_create_info_struct, to avoid compiler warnings on W32.
- Cast 3rd arg to IMAGE_BACKGROUND and image_background_transparent
- to avoid compiler warnings.
- (jpeg_load): Cast return value of fn_jpeg_std_error to avoid a
- compiler warning on W32. Cast 3rd arg to IMAGE_BACKGROUND to
- avoid a compiler warning.
- (tiff_load): Cast return values of fn_TIFFOpen and
- fn_TIFFClientOpen to avoid compiler warning on W32. Cast 3rd arg
- to IMAGE_BACKGROUND to avoid a compiler warning.
- (gif_load): Cast return values of fn_DGifOpenFileName and
- fn_DGifOpen to avoid compiler warnings on W32. Cast 3rd arg to
- IMAGE_BACKGROUND to avoid a compiler warning.
- (DrawText) [HAVE_NTGUI || MAC_OS]: If already defined, undef
- before redefining.
-
- * w32bdf.c (create_offscreen_bitmap): Cast `bitsp' to `void **' in
- the call to CreateDIBSection, to avoid a compiler warning.
-
-2005-06-11 Jason Rumney <[email protected]>
-
- * w32fns.c (Fx_file_dialog): Unblock input before falling back to
- minibuffer.
- * macfns.c (Fx_file_dialog): Likewise.
-
-2005-06-10 Eli Zaretskii <[email protected]>
-
- * makefile.w32-in ($(TEMACS)): Depend on addsection.exe.
-
-2005-06-10 Juanma Barranquero <[email protected]>
-
- * process.c (syms_of_process) [ADAPTIVE_READ_BUFFERING]:
- * w32fns.c (syms_of_w32fns): Fix spellings.
-
-2005-06-10 Eli Zaretskii <[email protected]>
-
- * unexw32.c (COPY_CHUNK, COPY_PROC_CHUNK): Add a new argument
- `verbose'; print diagnostic messages only if it is non-zero.
- All callers changed to pass a zero value unless DEBUG_DUMP is defined
- in the environment.
- (copy_executable_and_dump_data): Print section names with %.8s.
-
-2005-06-10 Masatake YAMATO <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Call clear_mouse_face
- when mouse_face is not given.
-
-2005-06-09 Luc Teirlinck <[email protected]>
-
- * window.c (Fselect_window): Adapt call to Fselect_frame.
-
- * lisp.h: Update EXFUN of Fselect_frame.
-
- * keyboard.c (command_loop_1): Adapt call to Fselect_frame.
-
- * frame.c (Fhandle_switch_frame, Fselect_frame): Delete unused arg
- no_enter.
- (Fset_mouse_position, Fset_mouse_pixel_position, Ficonify_frame):
- Adapt to above change.
-
-2005-06-10 Juanma Barranquero <[email protected]>
-
- * fns.c (Fmemq, Fmaphash): Doc fixes.
-
-2005-06-09 Juanma Barranquero <[email protected]>
-
- * xfaces.c (Fdisplay_supports_face_attributes_p):
- Fix typo in docstring.
-
-2005-06-08 Steven Tamm <[email protected]>
-
- * unexmacosx.c (copy_data_segment): Copy __la_sym_ptr2 section
- used by gcc4 on intel mac.
-
-2005-06-09 Kim F. Storm <[email protected]>
-
- * search.c (Fmatch_data): Add optional RESEAT arg. Unchain markers
- in REUSE list if non-nil; free them if equal to evaporate.
- (Fset_match_data): Add optional RESEAT arg. Unchain markers in LIST
- if non-nil; free them if equal to evaporate. Use XCAR/XCDR.
- (restore_search_regs): Rename from restore_match_data. Uses changed.
- (unwind_set_match_data): New function.
- (record_unwind_save_match_data): New function like save-match-data.
-
- * lisp.h (Fmatch_data, Fset_match_data): Fix EXFUN.
- (record_unwind_save_match_data): Add prototype.
- (restore_search_regs): Rename from restore_match_data.
-
- * composite.c (compose_chars_in_text):
- * eval.c (do_autoload):
- * macmenu.c (set_frame_menubar):
- * process.c (read_process_output, exec_sentinel):
- * xmenu.c (set_frame_menubar):
- * xdisp.c (prepare_menu_bars, update_menu_bar, update_tool_bar):
- * w32menu.c (set_frame_menubar):
- Use record_unwind_save_match_data.
-
-2005-06-08 Richard M. Stallman <[email protected]>
-
- * xdisp.c (get_next_display_element): Alter previous change:
- Distinguish Vshow_nonbreak_escape = t or not t.
- For t, use escape_glyph once again, as before previous change.
- Use space or hyphen for display, instead of the non-ASCII char.
- (syms_of_xdisp) <show-nonbreak-escape>: Doc fix.
-
- * process.c (Fstart_process): Don't touch command_channel_p slot.
-
- * process.h (struct process): Delete command_channel_p.
-
-2005-06-07 Masatake YAMATO <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight):
- Check the overlapping of re-rendering area to avoid flickering.
- (note_mouse_highlight): Call clear_mouse_face if PART
- is not ON_MODE_LINE nor ON_HEADER_LINE.
-
-2005-06-07 Kim F. Storm <[email protected]>
-
- * process.c: Improve commentary for adaptive read buffering.
-
-2005-06-06 Stefan Monnier <[email protected]>
-
- * xterm.c (x_create_toolkit_scroll_bar): Use XtNarrowScrollbars
- if available.
-
-2005-06-06 Jan Dj,Ad(Brv <[email protected]>
-
- * macmenu.c (menu_quit_handler, install_menu_quit_handler):
- New functions for popping down menus on C-g.
- (set_frame_menubar, mac_menu_show): Call install_menu_quit_handler.
-
- * macterm.c: Make mac_quit_char_modifiers and mac_quit_char_keycode
- non-static.
-
- * config.in: Add HAVE_CANCELMENUTRACKING.
-
-2005-06-06 Eli Zaretskii <[email protected]>
-
- * w32heap.h (OFFSET_TO_RVA, RVA_TO_OFFSET, RVA_TO_PTR): Remove macros.
-
- * unexw32.c (RVA_TO_PTR): Move here from w32heap.h.
-
- * w32proc.c (RVA_TO_PTR): New macro.
-
- * w32heap.c (RVA_TO_PTR): No need to #undef now.
-
- * makefile.w32-in ($(BLD)/emacs.$(O), $(BLD)/w32select.$(O)):
- Depend on w32heap.h.
-
-2005-06-06 Luc Teirlinck <[email protected]>
-
- * keyboard.c (command_loop_1): Update Vthis_original_command.
-
-2005-06-06 Richard M. Stallman <[email protected]>
-
- * xmenu.c (popup_get_selection): Undo previous change.
-
-2005-06-06 Juri Linkov <[email protected]>
-
- * xdisp.c (Qno_break_space): New variable.
- (syms_of_xdisp): Initialize it.
- (get_next_display_element): Add no-break space and soft hypen
- codes for iso8859-2 and iso8859-5. Don't add `\' for them.
- Use `no-break-space' face for no-break spaces.
-
-2005-06-06 Jan Dj,Ad(Brv <[email protected]>
-
- * window.c (delete_window): Handle the case where a h/vchild has
- a h/vchild.
-
-2005-06-05 Eli Zaretskii <[email protected]>
-
- * w32.c (sys_setsockopt): Change arg 4 to `const void *'. In the
- call to pfn_setsockopt, cast optval to `const char *'.
-
-2005-06-04 Eli Zaretskii <[email protected]>
-
- * w32.c (gettimeofday): Use struct _timeb, not struct timeb.
- (open_unc_volume): Cast return value of map_w32_filename, to avoid
- compiler warnings.
-
- * s/ms-w32.h (fileno): Don't define if already defined.
-
- * emacs.c: Include w32heap.h, to avoid compiler warning about sbrk.
-
- * makefile.w32-in (DOC): Define to point to the generated DOC-X.
-
-2005-06-04 Richard M. Stallman <[email protected]>
-
- * xmenu.c (popup_get_selection): Click not in menu deactivates menu.
-
-2005-06-04 Jan Dj,Ad(Brv <[email protected]>
-
- * macmenu.c (cleanup_popup_menu): New function.
- (Fx_popup_menu): Unwind protect cleanup_popup_menu in case
- mac_menu_show Quit:s.
- (mac_menu_show): Quit on cancel if not popped up on click (i.e.
- a dialog).
-
-2005-06-04 Kim F. Storm <[email protected]>
-
- * coding.c (decode_coding_string): Handle CODING_FINISH_INTERRUPT.
-
- * callproc.c (Fcall_process): Don't use alloca to gradually
- increase size of buf, as it effectively uses twice the necessary
- space on the stack. Instead, pre-allocate buf of full size, and
- gradually increase the read size.
-
- * bytecode.c (BYTE_CODE_QUIT): Check Vthrow_on_input.
-
- * eval.c (unbind_to): Preserve value of Vquit_flag.
-
- * xterm.c (handle_one_xevent): Also ignore mouse motion just
- before a button release event.
-
-2005-06-03 Juanma Barranquero <[email protected]>
-
- * xfaces.c (Finternal_lisp_face_equal_p): Really report
- on faces in a frame, if the argument FRAME is non-nil.
- Improve argument/docstring consistency.
-
-2005-06-02 Kim F. Storm <[email protected]>
-
- * xdisp.c (MODE_LINE_NOPROP_LEN): New macro.
- (x_consider_frame_title, Fformat_mode_line): Save offset into
- mode_line_noprop_buf rather than pointer, in case buffer is relocated.
-
-2005-06-01 Kim F. Storm <[email protected]>
-
- * fns.c (mapcar1): Maybe exit loop if original sequence was modified.
-
-2005-06-01 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_to_x_fontname, mac_do_list_fonts): Set XLFD
- resolution fields for scalable fonts to 0.
-
- * xfaces.c (build_scalable_font_name): Round pixel size to the
- nearest integer.
-
-2005-06-01 Kim F. Storm <[email protected]>
-
- * xdisp.c (display_mode_line): Support nested calls to redisplay
- and format-mode-line. Set mode_line_target to MODE_LINE_DISPLAY.
-
-2005-05-31 Stefan Monnier <[email protected]>
-
- * fileio.c (Finsert_file_contents):
- * xdisp.c (note_mode_line_or_margin_highlight): Lisp_Object/int mixup.
-
-2005-05-31 Kim F. Storm <[email protected]>
-
- * xdisp.c (mode_line_noprop_buf, mode_line_noprop_buf_end)
- (mode_line_noprop_ptr): Rename from frame_title_*.
- (store_mode_line_noprop_char): Rename from store_frame_title_char.
- (store_mode_line_noprop): Rename from store_frame_title.
- (mode_line_target): New enum to specify current output target
- for mode line formatting.
- (display_mode_element): Test it rather than frame_title_ptr and
- mode_line_string_list to determine where output should go.
- (mode_line_proptrans_alist, mode_line_string_alist): Make static.
- (Vmode_line_unwind_vector): New variable.
- (format_mode_line_unwind_data, unwind_format_mode_line):
- New functions for unwind protection in mode line formatting.
- (x_consider_frame_title): Use them and new local var 'title_start'
- to support nested calls to format-mode-line and redisplay.
- Set mode_line_target to MODE_LINE_TITLE.
- (Fformat_mode_line): Use them and new local var 'string_start' to
- support nested calls to format-mode-line and redisplay.
- Set mode_line_target to MODE_LINE_NOPROP or MODE_LINE_STRING.
- Don't trim trailing dashes.
- (decode_mode_spec): Don't make infinite number of trailing dashes
- for MODE_LINE_NOPROP and MODE_LINE_STRING targets.
- (syms_of_xdisp): Initialize and staticpro mode_line_string_face,
- mode_line_string_face_prop, and Vmode_line_unwind_vector.
- (init_xdisp): Initialize mode_line_noprop_ptr to start of _buf.
- Initialize mode_line_target to MODE_LINE_DISPLAY.
-
-2005-05-29 Richard M. Stallman <[email protected]>
-
- * buffer.c (Fbuffer_local_value): Call indirect_variable.
-
-2005-05-28 Masatake YAMATO <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Change the
- pointer to a hand cursor when hoovering over a mouse-face.
-
-2005-05-27 Kenichi Handa <[email protected]>
-
- * xterm.c (x_encode_char): Call check_ccl_update in advance.
-
- * ccl.c: Now an element of Vccl_program_table is a vector of
- length 4, not 3.
- (ccl_get_compiled_code): New arg idx. Caller changed.
- Adjust for the change of Vccl_program_table.
- (setup_ccl_program): Adjust for the change of Vccl_program_table.
- (check_ccl_update): New function.
- (Fregister_ccl_program): Use ASET to set an element of a vector.
- Adjusted for the change of Vccl_program_table.
-
- * ccl.h (struct ccl_program): New member idx.
- (check_ccl_update): Extern it.
-
-2005-05-27 Juanma Barranquero <[email protected]>
-
- * image.c (Vimage_library_alist): Move from image.el.
- (syms_of_image): Defvar it.
- (lookup_image_type): Use it.
-
- * buffer.c (Fbuffer_local_value): Make argument name match its use
- in docstring.
-
-2005-05-26 Juanma Barranquero <[email protected]>
-
- * keyboard.c (Frecursive_edit): Fix typo in docstring.
- (Fposn_at_x_y): Make argument name match its use in docstring.
-
-2005-05-26 Lute Kamstra <[email protected]>
-
- * eval.c (Frun_hooks): Mention run-mode-hooks in docstring.
-
-2005-05-24 Masatake YAMATO <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Use b and e
- as loop sentinels.
-
-2005-05-24 Nick Roberts <[email protected]>
-
- * xmenu.c (Fx_popup_dialog): Add a third boolean argument to
- select frame title ("Question"/"Information").
- (xdialog_show): Use it.
-
- * macmenu.c (Fx_popup_dialog, mac_dialog_show): As for xmenu.c.
-
- * w32menu.c (Fx_popup_dialog, w32_dialog_show): As for xmenu.c.
-
- * fns.c (Fyes_or_no_p, Fy_or_n_p): Call Fx_popup_dialog with
- a third argument (Qnil).
-
- * lisp.h: x-popup-dialog can have three arguments.
-
- * editfns.c (Fmessage_box): Use "Information" for frame title.
-
-2005-05-23 Thien-Thi Nguyen <[email protected]>
-
- * termcap.c [VMS]: Include <starlet.h>.
-
-2005-05-23 Masatake YAMATO <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Add code
- for mouse-face. Change the type of the first argument from `window'
- to `Lisp_Object'.
- (note_mouse_highlight): Call note_mode_line_or_margin_highlight with
- window instead of w.
-
-2005-05-22 Andreas Schwab <[email protected]>
-
- * process.c (send_process): Move misplaced volatile.
-
-2005-05-21 Richard M. Stallman <[email protected]>
-
- * xdisp.c (display_mode_element): If we're processing a list and
- padding is specified, put it after the last element.
-
-2005-05-21 Eli Zaretskii <[email protected]>
-
- * fileio.c (Fexpand_file_name) [DOS_NT]: Don't try to support
- "superroot" on DOS_NT systems.
-
-2005-05-21 David Hunter <[email protected]> (tiny change)
-
- * process.c (send_process): Restore the SIGPIPE handler if we
- catch a SIGPIPE.
-
-2005-05-20 Juanma Barranquero <[email protected]>
-
- * image.c (lookup_image, png_read_from_memory): Remove hacks (and
- misleading comments).
- (DEF_IMGLIB_FN): Use C calling convention for image libraries.
-
-2005-05-20 KOBAYASHI Yasuhiro <[email protected]>
-
- * window.c (Fwindow_inside_edges, Fwindow_inside_pixel_edges):
- Correct the right value.
-
-2005-05-19 Nick Roberts <[email protected]>
-
- * keyboard.c (syms_of_keyboard): Remove Lisp variables
- post-command-idle-hook and post-command-idle-delay.
- (command_loop_1): Don't try to execute post-command-idle-hook.
-
-2005-05-16 Kim F. Storm <[email protected]>
-
- * xdisp.c (handle_display_prop): Handle empty replacement.
- (handle_single_display_spec): Return -1 for empty replacement.
-
- * keyboard.c (adjust_point_for_property): Skip empty overlay string.
-
- * .gdbinit (pitx): Print more info about iterator.
-
-2005-05-16 Andreas Schwab <[email protected]>
-
- * unexmacosx.c (unexec_realloc): Move declarations before statements.
-
-2005-05-14 Richard M. Stallman <[email protected]>
-
- * xdisp.c (message3): Call cancel_echoing.
-
- * alloc.c (Fmemory_full_p): New function.
- (syms_of_alloc): defsubr it.
-
- * process.c (send_process_trap): Unblock SIGPIPE.
- (send_process): Reset SIGPIPE handler before reporting error.
-
-2005-05-14 Nick Roberts <[email protected]>
-
- * emacs.c (syms_of_emacs): Fix doc string for system-type.
-
-2005-05-13 Richard M. Stallman <[email protected]>
-
- * fileio.c (Ffind_file_name_handler): Handle lambda-exp as handler.
- (Finsert_file_contents): If we read 0 bytes from a special file,
- unlock the visited file if we locked it.
- (Fmake_symbolic_link, Frecent_auto_save_p): Doc fixes.
- (Ffile_exists_p, Ffile_symlink_p): Doc fixes.
-
-2005-05-13 YAMAMOTO Mitsuharu <[email protected]>
-
- * emacs.c (main) [MAC_OS8]: Call init_atimer before mac_term_init.
-
- * keyboard.c (readable_events) [USE_TOOLKIT_SCROLL_BARS]:
- Regard toolkit scroll bar thumb drag events as squeezable and prevent
- redisplay from being paused by them.
-
- * mac.c [!MAC_OSX]: Include keyboard.h and syssignal.h.
- [!MAC_OSX] (target_ticks): Remove variable.
- [!MAC_OSX] (check_alarm, pause, index): Remove functions.
- [!MAC_OSX && __MRC__] (sys_strftime): Likewise.
- [!MAC_OSX] (select): If fd 0 is not set in rfds and some input
- event occurs before timeout, behave as if the function were interrupted.
- [!MAC_OSX] (sigblock, sigsetmask, alarm): Simulate SIGALRM
- handling using Time Manager routines.
- [!MAC_OSX] (mac_atimer_task, mac_atimer_qlink, signal_mask):
- New variables.
- [!MAC_OSX] (mac_atimer_handler, set_mac_atimer, remove_mac_atimer)
- (setitimer): New functions.
-
- * macfns.c, macmenu.c: Don't include signal.h.
-
- * macterm.c [USE_TOOLKIT_SCROLL_BARS] (get_control_part_bounds):
- Rename from get_control_part_bound. All callers changed.
- (x_scroll_bar_clear): New function.
- (x_clear_frame): Use it.
- (XTset_vertical_scroll_bar): Don't call Draw1Control.
- (x_scroll_bar_handle_click): Change type of second argument from
- int to ControlPartCode.
- (check_alarm): Remove declaration.
- (XTread_socket) [!TARGET_API_MAC_CARBON]: Don't call it.
- (XTread_socket): Use ControlPartCode instead of SInt16.
-
-2005-05-13 Nozomu Ando <[email protected]>
-
- * unexmacosx.c: Include assert.h.
- (MACOSX_MALLOC_MULT16): New define.
- [MACOSX_MALLOC_MULT16] (ptr_in_unexec_regions): Determine whether
- ptr is in unexec regions by checking it is multiple of 16.
- (unexec_malloc_header_t): New typedef.
- (unexec_malloc, unexec_realloc, unexec_free): Store and use
- allocated size information in unexec_malloc_header.
-
-2005-05-10 Richard M. Stallman <[email protected]>
-
- * xterm.c (noinclude): Add #undef.
-
- * image.c, xfns.c, xmenu.c: Don't include signal.h.
-
-2005-05-09 Juanma Barranquero <[email protected]>
-
- * fileio.c (Fexpand_file_name, Frename_file, Fadd_name_to_file)
- (Fmake_symbolic_link, Faccess_file, Frecent_auto_save_p):
- Doc fixes.
-
- * dired.c (Ffile_name_completion): Make argument name
- match its use in docstring.
-
-2005-05-08 Luc Teirlinck <[email protected]>
-
- * eval.c (Fdefvaralias): Remove any pre-existing
- variable-documentation property of the alias.
-
-2005-05-07 Thien-Thi Nguyen <[email protected]>
-
- * xfns.c (start_hourglass): Do nothing when running on a tty.
-
-2005-05-07 Juanma Barranquero <[email protected]>
-
- * fns.c (Fchar_table_range): Fix typos in docstring.
-
-2005-05-06 Stefan Monnier <[email protected]>
-
- * fns.c (Fchar_table_range): Yet Another Int/Lisp_Object Mixup.
-
-2005-05-06 Eli Zaretskii <[email protected]>
-
- * lread.c (Flocate_file_internal): Doc fix.
-
- * Makefile.in (lisp, shortlisp): Add jka-cmpr-hook.elc.
-
-2005-05-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * macselect.c (x_own_selection): Accept Lisp string as result of
- selection converter function.
- (x_clear_frame_selections): Don't call x-lost-selection-functions
- if Emacs is not owner of the selection.
- (Vmac_services_selection): Put variable and initialization in
- #ifdef MAC_OSX.
- (syms_of_macselect) [MAC_OSX]: Set default value of
- Vmac_services_selection to PRIMARY.
-
- * macterm.c (toolkit_scroll_bar_interaction): Remove unused variable.
- (mac_handle_tool_bar_click): Remove unused function and declaration.
- [USE_TOOLKIT_SCROLL_BARS] (scroll_bar_timer_callback)
- (install_scroll_bar_timer, set_scroll_bar_timer)
- (control_part_code_to_scroll_bar_part, construct_scroll_bar_click)
- (get_control_part_bound, x_scroll_bar_handle_press)
- (x_scroll_bar_handle_release, x_scroll_bar_handle_drag)
- (x_set_toolkit_scroll_bar_thumb): New functions and declarations.
- [USE_TOOLKIT_SCROLL_BARS] (last_scroll_bar_part, scroll_bar_timer)
- (scroll_bar_timer_event_posted_p): New variables.
- [USE_TOOLKIT_SCROLL_BARS] (SCROLL_BAR_FIRST_DELAY)
- (SCROLL_BAR_CONTINUOUS_DELAY): New macros.
- (x_scroll_bar_create): Set control reference with NewControl.
- (x_scroll_bar_create) [USE_TOOLKIT_SCROLL_BARS]:
- Initialize track_top and track_height to nil.
- (x_scroll_bar_set_handle, x_scroll_bar_note_movement):
- Put functions in #ifndef USE_TOOLKIT_SCROLL_BARS.
- (XTset_vertical_scroll_bar): Don't make space between scroll bar
- and associated window.
- (XTset_vertical_scroll_bar) [MAC_OSX]: Get scroll bar area width
- from window config.
- (XTset_vertical_scroll_bar) [USE_TOOLKIT_SCROLL_BARS]:
- Set track_top and track_height to nil when scroll bar size is changed.
- Recalculate them if they are nil.
- (XTread_socket) [MAC_OSX]: Use control kind to determine if the
- clicked control is a scroll bar.
- (XTread_socket) [USE_TOOLKIT_SCROLL_BARS]: Use toolkit scroll bar
- event handler functions. Don't add modifiers to scroll bar click
- events. Call scroll bar release handler when window is deactivated.
- (mac_initialize): Remove unused code for X toolkit.
- (syms_of_macterm) [!USE_TOOLKIT_SCROLL_BARS]:
- Initialize Vx_toolkit_scroll_bars to nil.
-
- * macterm.h (struct scroll_bar) [USE_TOOLKIT_SCROLL_BARS]:
- New members track_top and track_height.
-
- * sysselect.h [DARWIN || MAC_OSX]: Temporarily undefine
- init_process when including sys/select.h.
-
-2005-05-05 Luc Teirlinck <[email protected]>
-
- * eval.c (Fdefvaralias): Doc fix.
-
- * xmenu.c (Fx_popup_menu, Fx_popup_dialog): Doc fixes.
-
-2005-05-05 Kim F. Storm <[email protected]>
-
- * buffer.c (init_buffer_once): Set cursor_in_non_selected_windows
- default value.
- (syms_of_buffer): Add default-cursor-in-non-selected-windows.
- Fix type of cursor-in-non-selected-windows.
-
-2005-05-03 Jan Dj,Ad(Brv <[email protected]>
-
- * mac.c: #undef init_process so not to conflict with system headers.
-
-2005-05-02 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer): Define cursor-in-non-selected-windows.
-
- * buffer.h (struct buffer): Add cursor_in_non_selected_windows slot.
-
- * xdisp.c (Vcursor_in_non_selected_windows)
- (Qcursor_in_non_selected_windows): Vars deleted.
- (syms_of_xdisp): Don't initialize them.
- (get_window_cursor_type): Use cursor_in_non_selected_windows
- buffer slot.
-
-2005-05-02 Kim F. Storm <[email protected]>
-
- * macros.c (executing_kbd_macro_index): Rename from
- executing_macro_index. All uses changed.
- (executing_kbd_macro_iterations): Rename from
- executing_macro_iterations. All uses changed.
- (executing_kbd_macro): Rename from executing_macro.
- All uses changed.
- (syms_of_macros): Rename Lisp var executing-macro-index to
- executing-kbd-macro-index.
-
- * xdisp.c (move_it_in_display_line_to): Fix last change.
-
-2005-05-01 Luc Teirlinck <[email protected]>
-
- * xmenu.c (Fx_popup_menu): Doc fix.
-
- * charset.c (syms_of_charset): Delete defsubr for Schars_in_region.
-
-2005-05-02 Jason Rumney <[email protected]>
-
- * emacs.c (USAGE3, USAGE4): Keep strings below 2048 bytes.
-
-2005-05-02 Nozomu Ando <[email protected]>
-
- * sysselect.h: Fix typo.
-
-2005-05-02 Nick Roberts <[email protected]>
-
- * charset.c (Fchars_in_region): Remove as obsolete.
-
-2005-05-01 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_in_display_line_to): Stop if we move beyond
- TO_CHARPOS. This may happen if last glyphs was an image or stretch
- glyph.
-
-2005-05-01 Luc Teirlinck <[email protected]>
-
- * dispnew.c (sit_for): Vexecuting_macro -> Vexecuting_kbd_macro.
-
-2005-05-01 Richard M. Stallman <[email protected]>
-
- * xmenu.c [not HAVE_X_TOOLKIT] (xmenu_show):
- If user cancels the menu, quit unless FOR_CLICK.
-
- * macros.c (Vexecuting_kbd_macro): Rename from Vexecuting_macro.
- All uses changed.
- (syms_of_macros): Define only executing-kbd-macro, not executing-macro.
- * keyboard.c: Change Vexecuting_macro to Vexecuting_kbd_macro.
- * macros.h (Vexecuting_kbd_macro): Declare instead of Vexecuting_macro.
- * commands.h (Vexecuting_kbd_macro): Likewise.
-
-2005-05-01 Thien-Thi Nguyen <[email protected]>
-
- * sysdep.c (get_frame_size) [VMS]: Use a fresh i/o channel.
-
-2005-04-30 Richard M. Stallman <[email protected]>
-
- * fileio.c (Ffind_file_name_handler): Handle the `operations'
- property of the file name handler.
- (Qoperations): New variable.
- (syms_of_fileio): Initialize and staticpro it.
-
- * xdisp.c (set_message_1): Delete xassert.
-
-2005-04-29 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c: Don't include time.h. Include sysselect.h after systime.h.
-
- * macfns.c (Fx_server_version): Add BLOCK_INPUT around Gestalt.
-
- * macgui.h [HAVE_CARBON && MAC_OSX]: Don't undefine/define mktime
- before/after including Carbon.h if there is a working mktime.
-
-2005-04-28 Kim F. Storm <[email protected]>
-
- * xfaces.c (resolve_face_name): Add arg SIGNAL_P. Calls changed.
- Fix cyclic alias check. If alias loop is detected, signal
- circular-list error if SIGNAL_P, and return Qdefault if !SIGNAL_P.
-
-2005-04-28 Lute Kamstra <[email protected]>
-
- * eval.c (do_autoload): Record only autoloads in the autoload
- property of symbols.
-
-2005-04-28 Nick Roberts <[email protected]>
-
- * emacs.c (USAGE1): Add --basic-display and --quick options.
-
-2005-04-27 Kim F. Storm <[email protected]>
-
- * data.c (syms_of_data) Staticpro Qcyclic_variable_indirection.
-
-2005-04-26 Richard M. Stallman <[email protected]>
-
- * window.c (Fsame_window_p, Fspecial_display_p): Doc fixes.
- (syms_of_window): Doc fixes.
-
- * indent.c (Fvertical_motion): Undo previous change.
-
-2005-04-26 Kenichi Handa <[email protected]>
-
- * fns.c (char_table_range): New function.
- (Fchar_table_range): Signal an error if characters in the range
- have inconsistent values. Don't check the parent.
-
-2005-04-25 Kenichi Handa <[email protected]>
-
- * fontset.c (fontset_set): Fix previous change.
-
-2005-04-24 Richard M. Stallman <[email protected]>
-
- * indent.c (Fvertical_motion): Bind fontification-functions to nil.
-
-2005-04-24 Eli Zaretskii <[email protected]>
-
- * regex.c (re_search_2, re_match_2_internal): Convert second arg
- of RE_TRANSLATE to int, to shut up GCC warnings.
-
- * fileio.c (Fcopy_file): Doc fix.
- [MSDOS]: Fix call to emacs_open: buffer_file_type not defined and
- not needed.
-
-2005-04-24 YAMAMOTO Mitsuharu <[email protected]>
-
- * Makefile.in [HAVE_CARBON] (MAC_OBJ): Add macselect.o.
- (SOME_MACHINE_OBJECTS): Likewise.
- (mac.o): Depend on ccl.h.
- (macselect.o): New target.
-
- * emacs.c (main) [MAC_OS8 || MAC_OSX && HAVE_CARBON]:
- Call syms_of_macselect.
-
- * frame.c (Fdelete_frame) [MAC_OS]: Call x_clear_frame_selections.
-
- * mac.c [!TARGET_API_MAC_CARBON]: Don't include charset.h or coding.h.
- (QCLIPBOARD): Remove variable.
- (syms_of_mac): Don't initialize it.
- (Fmac_paste_function, Fmac_cut_function, Fx_selection_exists_p):
- Remove functions.
- (syms_of_mac): Don't defsubr them.
- [TARGET_API_MAC_CARBON] (Qmime_charset, QNFD, QNFKD, QNFC, QNFKC)
- (QHFS_plus_D, QHFS_plus_C): New variables.
- (syms_of_mac) [TARGET_API_MAC_CARBON]: Initialize them.
- [TARGET_API_MAC_CARBON] (get_cfstring_encoding_from_lisp)
- (cfstring_create_normalized): New functions.
- [TARGET_API_MAC_CARBON] (Fmac_code_convert_string): Likewise.
- (syms_of_mac) [TARGET_API_MAC_CARBON]: Defsubr it.
-
- * macterm.c (handling_window_update, terminate_flag):
- Remove variables.
- (do_window_update, do_ae_quit_application, XTread_socket):
- Don't use them.
- (WNE_SLEEP_AT_SUSPEND, WNE_SLEEP_AT_RESUME): Don't define.
- [USE_CARBON_EVENTS && MAC_OSX] (mac_handle_service_event)
- (init_service_handler): Move to macselect.c. Remove declarations.
- [USE_CARBON_EVENTS && MAC_OSX] (init_service_handler): Add extern.
- (Qapplication, Qabout): New variables.
- (syms_of_mac): Initialize them.
- [USE_CARBON_EVENTS && MAC_OSX] (Qpreferences, Qservices, Qpaste)
- (Qperform): New variables.
- (syms_of_mac) [USE_CARBON_EVENTS && MAC_OSX]: Initialize them.
- (do_get_menus) [TARGET_API_MAC_CARBON]: Don't call AppendResMenu.
- (do_menu_choice): Unhighlight menu bar also when menu_id is 0.
- (mac_store_application_menu_event, init_menu_bar): New functions.
- [USE_CARBON_EVENTS] (mac_handle_command_event)
- (init_command_handler): New functions.
- (mac_handle_window_event): Return noErr on window update event.
- (do_ae_quit_application): Call mac_store_application_menu_event.
- (mac_initialize) [USE_CARBON_EVENTS]: Call init_command_handler
- and init_menu_bar.
-
- * macterm.h (x_clear_frame_selections): Add extern.
-
- * macselect.c: New file for selection processing on Mac OS.
-
-2005-04-23 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fcopy_file): New arg MUSTBENEW.
- (Frename_file): Pass new arg to Fcopy_file.
-
- * window.c (window_size_fixed): Variable deleted.
- (syms_of_window): Initialize window-size-fixed to nil.
- But don't DEFVAR window_size_fixed.
-
-2005-04-23 Andreas Schwab <[email protected]>
-
- * m/macppc.h (LD_SWITCH_MACHINE) [LINUX]: Don't define.
- (START_FILES, LIB_STANDARD) [LINUX && _ARCH_PPC64]: Override to
- use lib64 instead of lib.
- (_LP64) [_ARCH_PPC64]: Define if not defined.
-
-2005-04-23 David Hunter <[email protected]> (tiny change)
-
- * s/ms-w32.h (HAVE_PWD_H): Define.
-
-2005-04-22 Kenichi Handa <[email protected]>
-
- * fns.c (copy_sub_char_table): Explicitly copy the default value
- of the sub-chartable.
-
- * fontset.c (fontset_set): When a sub-chartable is created,
- explicitly sets the defalt value.
-
-2005-04-22 Kim F. Storm <[email protected]>
-
- * fns.c (Fplist_get): Replace by Fsafe_plist_get.
- (Fsafe_plist_get): Rename to Fplist_get.
- (Fsafe_get): Remove, as Fget now uses safe Fplist_get.
- (defsubr): Remove defsubr for Fsafe_plist_get and Fsafe_get.
-
- * lisp.h (Fsafe_plist_get, Fsafe_get): Remove EXFUN.
-
- * xdisp.c (store_mode_line_string, produce_stretch_glyph)
- (note_mode_line_or_margin_highlight, note_mouse_highlight):
- Use Fplist_get instead of Fsafe_plist_get.
-
- * xfaces.c (resolve_face_name): Use Fget instead of Fsafe_get.
-
-2005-04-21 Miles Bader <[email protected]>
-
- * xdisp.c (dump_glyph_row): Don't display overlay_arrow_p field.
-
-2005-04-20 Thien-Thi Nguyen <[email protected]>
-
- * sysdep.c: Remove reference to defunct vms-pwd.h.
- * dired.c: Likewise. Also, for pwd.h, use HAVE_PWD_H, not !VMS.
- * editfns.c, fileio.c, filelock.c, sysdep.c, xrdb.c: Likewise.
-
- * config.in: Regenerate.
-
-2005-04-20 Kenichi Handa <[email protected]>
-
- * lisp.h (CHAR_TABLE_DEFAULT_SLOT_ASCII): New macro.
- (CHAR_TABLE_DEFAULT_SLOT_8_BIT_CONTROL): New macro.
- (CHAR_TABLE_DEFAULT_SLOT_8_BIT_GRAPHIC): New macro.
-
- * alloc.c (make_sub_char_table): Argument changed to initial
- value of the slots.
-
- * data.c (Faref): Handle special slots used as default values of
- ascii, eight-bit-control, eight-bit-control. Don't ignore a
- default value set for a group of characters.
- (Faset): Signal an error if IDXVAL is not a valid character code.
- Make a sub-chartable with correct initial value.
-
- * fns.c (Fset_char_table_range): Don't set slots used as default
- values for ascii, eight-bit-control, eight-bit-graphic.
- Don't call Faref with charset-id.
- (Fset_char_table_default): Document how to treat normal character
- argument. Handle special slots used as default values of ascii,
- eight-bit-control, eight-bit-control. Make a sub chartable if
- necessary.
-
-2005-04-20 Kenichi Handa <[email protected]>
-
- * search.c (boyer_moore): Fix previous change.
-
-2005-04-19 Kim F. Storm <[email protected]>
-
- * xdisp.c (setup_for_ellipsis): Reset saved_face_id to use default
- face unless last visible char and first invisible char have the
- same face. Also use default face if saved_face_id is undefined.
-
-2005-04-19 YAMAMOTO Mitsuharu <[email protected]>
-
- * macgui.h (MacFontStruct): Remove member `fontname'. Add member
- `full_name'.
- [TARGET_API_MAC_CARBON] (MacFontStruct): Use type int for
- mac_scriptcode member.
-
- * macterm.c (Qbig5, Qcn_gb, Qsjis, Qeuc_kr): Remove variables.
- (syms_of_mac): Don't initialize them.
- (Vmac_charset_info_alist): New variable.
- (syms_of_mac): Defvar it.
- (create_text_encoding_info_alist): New function.
- (decode_mac_font_name, mac_to_x_fontname)
- (x_font_name_to_mac_font_name, init_font_name_table): Don't hard
- code the correspondence among XLFD charsets, Mac script codes, and
- Emacs coding systems. Use Vmac_charset_info_alist and result of
- create_text_encoding_info_alist instead.
- (init_font_name_table) [TARGET_API_MAC_CARBON]: Use Font Manager
- routines also on Mac OS Classic.
- (init_font_name_table) [!TARGET_API_MAC_CARBON]:
- Use add_font_name_table_entry.
- (mac_do_list_fonts): Regard 0 in XLFD scaleble fields as
- specified. Derive unspecified scalable fields from specified one.
- (x_list_fonts): Consider Valternate_fontname_alist.
- (kDefaultFontSize): Change value from 9 to 12.
- (XLoadQueryFont): Get decoded font family, font face, and charset
- from x_font_name_to_mac_font_name. Set full name of loaded font.
- (mac_unload_font): Free `full_name' member.
- (x_load_font): Don't try XLoadQueryFont if x_list_fonts returns
- NULL. Copy full_name member of struct MacFontStruct to that of
- struct font_info.
-
-2005-04-19 Kim F. Storm <[email protected]>
-
- * xdisp.c (handle_stop): Set saved_face_id to current face if
- selective_display_ellipsis_p so ellipsis will be shown in same
- face as preceding text.
- (setup_for_ellipsis): Don't set saved_face_id here.
- (next_element_from_display_vector): Default to saved_face_id.
-
- * fns.c (Fsafe_get): New function.
- (syms_of_fns): Defsubr it.
-
- * lisp.h (Fsafe_get): EXFUN it.
-
- * xfaces.c (resolve_face_name): Use Fsafe_get to avoid redisplay
- loops in case of bad face property lists. Limit number of face
- alias lookups to 10 (in case of face alias loops).
-
-2005-04-18 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct glyph_row): New member overlay_arrow_bitmap.
- It replaces the corresponding member from struct window, as a
- window may now show multiple overlay arrows.
- Remove member overlay_arrow_p, superseeded by overlay_arrow_bitmap.
-
- * dispnew.c (row_equal_p, update_window_line, scrolling_window):
- Compare overlay_arrow_bitmap than overlay_arrow_p members.
-
- * fringe.c (draw_fringe_bitmap): Use overlay_arrow_bitmap from row
- rather than from window.
- (update_window_fringes): Compare overlay_arrow_bitmap rather than
- overlay_arrow_p members.
- (Ffringe_bitmaps_at_pos): Return fringe overlay_arrow_bitmap name
- if not default.
-
- * window.h (struct window): Remove member overlay_arrow_bitmap.
-
- * window.c (make_window): Don't initialize overlay_arrow_bitmap.
-
- * xdisp.c (overlay_arrow_string_or_property): Remove PBITMAP arg.
- Calls changed. Don't check for overlay-arrow-bitmap property here.
- (overlay_arrow_at_row): Remove PBITMAP arg. Instead, if left
- fringe is present, return Lisp integer for bitmap (or -1 for default).
- Fix value of overlay-arrow-bitmap property to be a symbol, use
- lookup_fringe_bitmap to parse it.
- (display_line): Change call to overlay_arrow_at_row. Store integer
- return value as overlay bitmap in row rather than window.
- Only show overlay arrow if row displays text, or if no other overlay
- arrow is seen in window (if overlay marker is at point-max).
-
-2005-04-18 Thien-Thi Nguyen <[email protected]>
-
- * xfaces.c (realize_x_face) [!HAVE_WINDOW_SYSTEM]: Return NULL.
-
-2005-04-18 Lute Kamstra <[email protected]>
-
- * lread.c (Vloads_in_progress): Static.
- * fns.c (Vloads_in_progress): Remove extern.
- (load_in_progress): Add extern.
- (Frequire): Use load_in_progress instead of Vloads_in_progress.
-
-2005-04-18 Thien-Thi Nguyen <[email protected]>
-
- * xmenu.c (Fx_popup_menu): Initialize error_name to NULL.
-
-2005-04-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (XTread_socket): Don't beep on keyboard input even if
- no frame is visible.
-
-2005-04-16 Dan Nicolaescu <[email protected]>
-
- * term.c (struct keys): Add support for shifted keys.
-
-2005-04-16 Richard M. Stallman <[email protected]>
-
- * xdisp.c (with_echo_area_buffer): Delete WHICH < 0 case.
- (set_message): Call with_echo_area_buffer with WHICH = 0.
- (set_message_1): Erase the echo area buffer first thing.
- (echo_area_display): Don't clear echo_message_buffer.
-
-2005-04-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * Makefile.in (mac.o): Depend on charset.h and coding.h.
-
- * mac.c: Include charset.h and coding.h.
- [TARGET_API_MAC_CARBON] (Qutf_8): Remove extern.
- [TARGET_API_MAC_CARBON] (cfstring_create_with_string): New function.
- [TARGET_API_MAC_CARBON] (Fmac_get_preference): Use it.
-
- * macfns.c [TARGET_API_MAC_CARBON] (Fx_file_dialog): Likewise.
-
- * image.c [MAC_OSX] (image_load_quartz2d): Likewise.
-
- * macterm.c (x_autoselect_window_p): Remove variable.
- (last_window): New variable.
- (XTreassert_line_highlight, x_change_line_highlight):
- Remove declarations.
- (mac_focus_changed, x_detect_focus_change): New functions and
- declarations.
- (XTextExtents16, front_emacs_window): Remove function.
- (mac_focus_frame): New function.
- (XTmouse_position, do_menu_choice, do_zoom_window, XTread_socket)
- (mac_check_for_quit_char): Use it instead of front_emacs_window.
- (x_scroll_bar_report_motion): Obtain window from control owner.
- (x_make_frame_invisible): Set window manager size hint.
- (do_mouse_moved): Remove function.
- (XTread_socket): Move its contents here. Generate select-window
- event on mouse movement if needed. Use x_detect_focus_change on
- activate/deactivate events. Don't deiconify frame or invalidate
- window rectangle when dnd items are dropped.
- Don't activate/deactivate root control.
- (frame_highlight, frame_unhighlight): Activate/deactivate root
- control here.
- (syms_of_macterm): Delete DEFVAR_BOOL for x_autoselect_window_p.
-
- * macterm.h (cfstring_create_with_string) [TARGET_API_MAC_CARBON]:
- New extern.
-
-2005-04-15 Luc Teirlinck <[email protected]>
-
- * Makefile.in: Define new macro TOOLTIP_SUPPORT.
- (lisp): Use it.
- (SOME_MACHINE_LISP): Add tooltip.
-
-2005-04-14 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c [!TARGET_API_MAC_CARBON]: Include MacLocales.h.
- Don't include TextEncodingConverter.h.
- (mac_system_script_code, Vmac_system_locale): New variables.
- (syms_of_mac): Defvar them.
- (mac_get_system_locale): New function.
-
- * macfns.c (x_set_name, x_set_title) [!TARGET_API_MAC_CARBON]:
- Use ENCODE_SYSTEM to encode title bar string.
- (x_create_tip_frame): Apply 2005-03-18 change for xfns.c.
- (Fx_file_dialog) [TARGET_API_MAC_CARBON && !MAC_OSX]:
- Use CFStringGetSystemEncoding to get system default string encoding.
-
- * macterm.c [!TARGET_API_MAC_CARBON]: Don't include
- TextEncodingConverter.h.
-
-2005-04-13 Steven Tamm <[email protected]>
-
- * macterm.c (syms_of_macterm): Remove redundant definition of
- mac-pass-control-to-system.
-
-2005-04-12 Stefan Monnier <[email protected]>
-
- * window.c (Fset_window_configuration): Be careful when you choose
- among several possible points for the new_current_buffer.
-
-2005-04-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * keyboard.c (poll_for_input) [SYNC_INPUT]: Don't call
- poll_for_input_1. Set interrupt_input_pending to 1 instead.
- (Qlanguage_change) [MAC_OS]: New variable.
- (syms_of_keyboard) [MAC_OS]: Intern and staticpro it.
- (kbd_buffer_get_event) [MAC_OS]: Make event for LANGUAGE_CHANGE_EVENT.
-
- * macterm.c (mac_keyboard_text_encoding)
- (current_mac_keyboard_text_encoding): Remove variables.
- (XTread_socket): Store language-change event if keyboard script change
- is detected. Don't convert input to `mac_keyboard_text_encoding'.
- (syms_of_macterm): Delete DEFVAR_INT for mac-keyboard-text-encoding.
-
- * termhooks.h (enum event_kind) [MAC_OS]: Add LANGUAGE_CHANGE_EVENT.
-
-2005-04-10 Richard M. Stallman <[email protected]>
-
- * emacs.c (standard_args): Rename --bare-bones to --quick.
- Add -D aka --basic-display.
-
- * buffer.c (Fmake_indirect_buffer): Clear out some local variables.
-
-2005-04-09 Richard M. Stallman <[email protected]>
-
- * keymap.c (where_is_internal): Convert a string used as event type
- into "(any string)".
-
- * lread.c (Vloads_in_progress): Not static.
- * fns.c (Vloads_in_progress): Add extern.
- (Frequire): Don't do LOADHIST_ATTACH if Vloads_in_progress is nil.
-
-2005-04-09 Thien-Thi Nguyen <[email protected]>
-
- * dispnew.c (mirror_line_dance): Avoid crash if W2 is null.
-
-2005-04-09 Lute Kamstra <[email protected]>
-
- * print.c (PRINTPREPARE): Check if the marker PRINTCHARFUN is
- within the accessible part of the buffer.
-
-2005-04-09 Kim F. Storm <[email protected]>
-
- * lread.c (readevalloop): Add args START and END as region in
- current buffer to read. Callers changed.
- When specified, narrow to this region only when reading,
- not during eval. Track next point to read from during eval.
- Also restore point to "real" buffer position before eval.
- (Feval_region): Don't save excursion and restriction here, and
- don't narrow to region. Just pass region to readevalloop.
- Note: Point is now preserved even when PRINTFLAG is nil.
-
-2005-04-08 Kim F. Storm <[email protected]>
-
- * xdisp.c (syms_of_xdisp): Init overlay-arrow-string to "=>".
-
-2005-04-06 Kim F. Storm <[email protected]>
-
- * emacs.c (standard_args): Add -Q, --bare-bones, -bare-bones.
-
-2005-04-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (cfdate_to_lisp): Add `const' for variable `epoch_gdate'.
- (Fmac_get_preference): Doc fix.
-
- * macfns.c (Fx_create_frame, x_create_tip_frame):
- Add "fontset-mac" to fallback font/fontsets.
-
-2005-04-04 Kim F. Storm <[email protected]>
-
- * alloc.c (Fgarbage_collect): Call CHECK_CONS_LIST before and after gc.
-
- * eval.c (Ffuncall): Always call CHECK_CONS_LIST on entry.
- Call it again after autoload.
-
-2005-04-02 Jan Dj,Ad(Brv <[email protected]>
-
- * alloc.c (allocate_string_data): Call BLOCK_INPUT before calling
- mallopt.
-
- * ralloc.c (r_alloc_init): Ditto.
-
-2005-04-01 Kenichi Handa <[email protected]>
-
- * lisp.h (Vascii_upcase_table, Vascii_canon_table)
- (Vascii_eqv_table): Extern them.
-
- * casetab.c (set_case_table): If standard is nonzero, setup
- Vascii_upcase_table, Vascii_canon_table, and Vascii_eqv_table.
-
- * search.c (looking_at_1): Use current_buffer->case_canon_table,
- not DOWNCASE_TABLE.
- (string_match_1): Likewise.
- (fast_c_string_match_ignore_case): Use Vascii_canon_table, not
- Vascii_downcase_table.
- (fast_string_match_ignore_case): Likewise.
- (search_buffer): Fix checking of boyer-moore usability.
- (boyer_moore): Calculate translate_prev_byte1/2/3 in advance.
- No need of tranlating characters in PAT. Fix calculation of
- simple_translate.
-
-2005-03-31 Stefan Monnier <[email protected]>
-
- * xterm.c [HAVE_XAW3D]: Include ThreeD.h for XtNbeNiceToColormap.
- (x_create_toolkit_scroll_bar): Test XtNbeNiceToColormap before using it.
- Use XtNtopShadowPixel and XtNbottomShadowPixel.
- (x_set_toolkit_scroll_bar_thumb): Remove ugly old hack that didn't
- really work and that breaks with some versions of Xaw3d.
-
-2005-03-31 Kenichi Handa <[email protected]>
-
- * coding.c (syms_of_coding): Fix previous change.
-
-2005-03-30 Stefan Monnier <[email protected]>
-
- * fileio.c (search_embedded_absfilename): Fix last change.
-
-2005-03-25 Kenichi Handa <[email protected]>
-
- * coding.c (syms_of_coding): Suggest to use set-coding-category in
- the docstring of coding-category-list.
-
-2005-03-31 Kim F. Storm <[email protected]>
-
- * keyboard.c (Qmouse_fixup_help_message): New var.
- (syms_of_keyboard): Intern and staticpro it.
- (show_help_echo): Apply mouse-fixup-help-message to help string.
-
-2005-03-30 Kim F. Storm <[email protected]>
-
- * xdisp.c (display_line): Allow multiple overlay arrows in window.
-
-2005-03-28 Stefan Monnier <[email protected]>
-
- * fileio.c (Fexpand_file_name): Use IS_DEVICE_SEP.
- (file_name_absolute_p): New fun, extracted from Ffile_name_absolute_p.
- (Ffile_name_absolute_p): Use it.
- (search_embedded_absfilename): New fun, extracted from
- Fsubstitute_in_file_name. Use file_name_absolute_p.
- Free the pw data after use.
- (Fsubstitute_in_file_name): Use it.
- After cutting a prefix, re-check file-name-handler.
-
-2005-03-26 Lennart Borgman <[email protected]>
-
- * w32term.h (x_output): Add focus_state.
-
- * w32term.c (x_focus_changed, w32_detect_focus_change): New functions.
- (w32_read_socket) <WM_SETFOCUS>: Call w32_detect_focus_change.
-
-2005-03-25 Stefan Monnier <[email protected]>
-
- * minibuf.c (Fminibuffer_complete_and_exit, Fself_insert_and_exit):
- Use Fexit_minibuffer.
- (Fexit_minibuffer): Mark it as no-return, deactivate the mark.
-
-2005-03-24 Stefan Monnier <[email protected]>
-
- * dired.c (Ffile_attributes): Add a missing gcpro.
-
- * alloc.c (make_number): The arg can be bigger than `int'.
- * lisp.h (make_number): Make prototype more precise.
-
- * process.c, dired.c (Vfile_name_coding_system)
- (Vdefault_file_name_coding_system):
- * callproc.c (Vdoc_file_name, Vfile_name_coding_system)
- (Vdefault_file_name_coding_system): Remove unused declarations.
-
-2005-03-24 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (create_and_show_popup_menu): Just remove menu and return
- if it failed to pop up (Gnome "show pointer on ctrl" option makes
- menus fail to pop up).
-
-2005-03-24 Stefan Monnier <[email protected]>
-
- * xdisp.c (get_next_display_element): Also use `\ ' & `\-' for latin-9.
- Just prepend a backslash without replacing the NBSP by an SPC.
-
-2005-03-22 Kim F. Storm <[email protected]>
-
- * xfaces.c (lookup_derived_face): Add arg SIGNAL_P.
- * dispextern.h (lookup_derived_face): Fix prototype.
- * msdos.c (XMenuActivate): Fix call to lookup_derived_face.
-
- * xdisp.c (handle_single_display_spec): Derive left-fringe and
- right-fringe face from fringe face.
-
- * fringe.c (draw_fringe_bitmap_1, Fset_fringe_bitmap_face):
- Derive face from fringe face.
-
-2005-03-22 Jan Dj,Ad(Brv <[email protected]>
-
- * xrdb.c (x_load_resources): Undo previous change (2005-03-18).
-
-2005-03-22 David Kastrup <[email protected]>
-
- * textprop.c (Fnext_char_property_change)
- (Fprevious_char_property_change): Allow marker as limit.
- (Fnext_single_char_property_change)
- (Fprevious_single_char_property_change): Check that limit is a
- number in strings.
- (Fnext_single_char_property_change): Coerce position to integer.
- (Fprevious_single_char_property_change): Same here.
-
-2005-03-21 Thien-Thi Nguyen <[email protected]>
-
- * s/openbsd.h (LD_SWITCH_SYSTEM_tmp): Define if undefined.
-
-2005-03-19 Stefan Monnier <[email protected]>
-
- * frame.c (Fignore_event): Remove.
- (syms_of_frame): Don't defsubr it.
-
- * keyboard.c (keys_of_keyboard): Just use `ignore' instead of the
- redundant `ignore-event'.
-
-2005-03-19 Eli Zaretskii <[email protected]>
-
- * unexec.c (write_segment, unexec): Move these functions to avoid
- forward references (which cause errors with "gcc -gcoff").
-
-2005-03-18 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_create_tip_frame): Remove setting of Vx_resource_name so
- that it doesn't become "tooltip". The specbind is enough.
-
- * xrdb.c (x_load_resources): Use different char *helv when I18N
- is present.
-
-2005-03-17 Kenichi Handa <[email protected]>
-
- * coding.c (syms_of_coding): Docstring of coding-category-list fixed.
-
-2005-03-17 Stefan Monnier <[email protected]>
-
- * xfaces.c (x_update_menu_appearance) [HAVE_X_I18N]:
- Use xic_create_fontsetname even for non-Motif menus.
- Don't forget to free the fontsetname.
-
- * xfns.c (xic_create_fontsetname): Add a final catch-all font pattern.
-
-2005-03-17 Richard M. Stallman <[email protected]>
-
- * dispnew.c (mirror_line_dance): Set W2 according to FRAME_FROM.
-
- * fileio.c (Fcopy_file, Frename_file, Fadd_name_to_file)
- (Fmake_symbolic_link): Use G to read the new file name.
-
- * callint.c (Finteractive): Document G option.
- (Fcall_interactively): Implement G option.
-
- * buffer.c (buffer_lisp_local_variables): New function,
- broken out from Fbuffer_local_variables.
- (clone_per_buffer_values): Use buffer_lisp_local_variables.
-
-2005-03-17 Stefan Monnier <[email protected]>
-
- * xfns.c (xic_create_fontsetname): Add `motif' argument.
- Always return a freshly allocated string.
- (xic_create_xfontset): Adjust call.
-
- * xfaces.c (x_update_menu_appearance) [USE_MOTIF]:
- Use xic_create_fontsetname to create a fontset so utf-8 locales work.
- (dump_realized_face): Fix warning.
-
- * emacs.c (Fkill_emacs): YAILOM.
-
- * frame.c (Fignore_event): Fix ancient obscure C-u handling bug.
-
-2005-03-17 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (HASHKEY_TERMINAL): Remove.
- (HASHKEY_MAX_NID): New macro.
- (xrm_q_get_resource_1): Rename from xrm_q_get_resource. Add extra
- argument.
- (xrm_q_get_resource): Call xrm_q_get_resource_1 with extra argument.
- (xrm_create_database, xrm_q_put_resource)
- (xrm_merge_string_database, xrm_q_get_resource_1)
- (xrm_q_get_resource): Change resource database representation so
- that it may not use multiple hash tables for a single database.
- [TARGET_API_MAC_CARBON] (xrm_cfproperty_list_to_value): YAILOM.
-
-2005-03-16 Stefan Monnier <[email protected]>
-
- * xmenu.c (ENCODE_MENU_STRING) [HAVE_X_I18N]: Use ENCODE_SYSTEM.
-
- * coding.h (ENCODE_SYSTEM, DECODE_SYSTEM) [!WINDOWSNT]: Use the
- locale-coding-system, as was already done for WINDOWSNT.
-
- * keyboard.c (read_char): Only do the 7-bit-meta -> 27-bit-meta
- translation for chars in the 0-255 range.
-
-2005-03-16 Lute Kamstra <[email protected]>
-
- * floatfns.c (Ffloor): Doc fix.
-
-2005-03-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c: Include macterm.h instead of directly including Carbon.h.
- [TARGET_API_MAC_CARBON] (Qstring, Qnumber, Qboolean, Qdate, Qdata)
- (Qarray, Qdictionary): New variables.
- (syms_of_mac) [TARGET_API_MAC_CARBON]: Initialize them.
- [TARGET_API_MAC_CARBON] (Qutf_8): Add extern.
- [TARGET_API_MAC_CARBON] (DECODE_UTF_8): New macro.
- [TARGET_API_MAC_CARBON] (struct cfdict_context): New struct used
- in callback for CFDictionaryApplyFunction.
- [TARGET_API_MAC_CARBON] (cfdata_to_lisp, cfstring_to_lisp)
- (cfnumber_to_lisp, cfdate_to_lisp, cfboolean_to_lisp)
- (cfobject_desc_to_lisp, cfdictionary_add_to_list)
- (cfdictionary_puthash, cfproperty_list_to_lisp): New functions.
- [TARGET_API_MAC_CARBON] (Fmac_get_preference): New function.
- (syms_of_mac) [TARGET_API_MAC_CARBON]: Defsubr it.
- (P, LOOSE_BINDING, SINGLE_COMPONENT, HASHKEY_TERMINAL): New macro.
- (skip_white_space, parse_comment, parse_include_file)
- (parse_binding, parse_component, parse_resource_name, parse_value)
- (parse_resource_line, xrm_create_database, xrm_q_put_resource)
- (xrm_merge_string_database, xrm_q_get_resource, xrm_get_resource)
- (xrm_cfproperty_list_to_value, xrm_get_preference_database):
- New functions.
-
- * macfns.c (mac_get_rdb_resource): Remove function.
- (x_get_string_resource): Use xrm_get_resource.
-
- * macgui.h (XrmDatabase): Typedef to Lisp_Object.
-
- * macterm.c (x_list_fonts): FONT-LIST-CACHE is now cadr part of
- name_list_element.
- (mac_make_rdb): Create resource database from preferences and
- argument string.
- (mac_term_init): Save resource database to cddr part of
- name_list_element.
-
- * macterm.h (xrm_merge_string_database, xrm_get_resource)
- (xrm_get_preference_database): Add externs.
- [TARGET_API_MAC_CARBON] (cfdata_to_lisp, cfstring_to_lisp)
- (cfnumber_to_lisp, cfdate_to_lisp, cfboolean_to_lisp)
- (cfobject_desc_to_lisp, cfproperty_list_to_lisp): Likewise.
-
- * process.c (init_process): Change `#ifdef DARWIN' to `#if
- defined (DARWIN) || defined (MAC_OSX)'.
-
- * s/darwin.h (DARWIN): Don't define.
-
-2005-03-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (Qhyper, Qsuper, Qmeta, Qalt, Qctrl, Qcontrol, Qshift):
- Remove unused variables.
- (syms_of_macfns): Don't initialize them. Likewise for
- Qface_set_after_frame_default. Defvar and initialize
- Vx_window_horizontal_drag_shape.
- (x_set_mouse_color): Change mouse pointer shape.
- (mac_window) [!MAC_OSX]: Create root control.
- (Fx_create_frame): Remove initializations of mouse pointer shapes.
- (hourglass_started): New function (from xfns.c).
- (start_hourglass, cancel_hourglass): Put function body in #ifdef
- MAC_OSX.
- (show_hourglass) [TARGET_API_MAC_CARBON]: Create progress
- indicator for each non-tooltip frame if needed, and show it.
- (hide_hourglass) [TARGET_API_MAC_CARBON]: Hide progress indicators.
-
- * macgui.h [!TARGET_API_MAC_CARBON]: Include Appearance.h and
- Controls.h. Use ThemeCursor instead of CursHandle.
-
- * macterm.c (activate_scroll_bars, deactivate_scroll_bars):
- Remove functions and declarations.
- (mac_set_colors): Take argument for saving background color.
- All callers changed.
- (XDrawLine, XClearArea, mac_draw_bitmap, XFillRectangle)
- (mac_draw_rectangle, mac_draw_string_common): Save and Restore
- background color.
- (x_update_end, mac_do_track_drag): Don't reset background color.
- (mac_define_frame_cursor) [!TARGET_API_MAC_CARBON]:
- Use SetThemeCursor.
- (x_set_window_size) [TARGET_API_MAC_CARBON]: Move progress
- indicator control to the upper-right corner of the window.
- (arrow_cursor) [!TARGET_API_MAC_CARBON]: Remove variable.
- (do_init_managers) [!TARGET_API_MAC_CARBON]: Don't initialize it.
- (do_window_update): Update controls after updating content area.
- (mac_handle_window_event): Remove unused extern.
- (XTread_socket): Check both control handle and control part code
- to determine whether a scroll bar is clicked. Activate/deactivate
- root control instead of contained scroll bar controls.
- (make_mac_terminal_frame): Use ThemeCursor constants.
-
- * macterm.h (struct mac_output) [TARGET_API_MAC_CARBON]:
- New member hourglass_control.
- (HOURGLASS_WIDTH, HOURGLASS_HEIGHT): New defines.
- (activate_scroll_bars, deactivate_scroll_bars): Remove declarations.
-
-2005-03-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (keycode_to_xkeysym_table): Change mapping so that it
- coincides with that in Apple X11 except `clear', `enter' on
- laptops, and fn + `enter' on laptops.
-
-2005-03-12 Stefan Monnier <[email protected]>
-
- * xmenu.c (ENCODE_MENU_STRING): Explicitly use string_make_unibyte.
- (list_of_panes, list_of_items, Fx_popup_menu): Use XCAR/XCDR.
- (digest_single_submenu, xmenu_show): Use ENCODE_MENU_STRING.
-
- * xfns.c (xic_defaut_fontset): New constant.
- (xic_create_fontsetname): New function.
- Extracted from create_frame_xic. Try to generate a slightly
- better fontset.
- (xic_create_xfontset): Use it.
- (create_frame_xic): Simplify.
-
-2005-03-11 Stefan Monnier <[email protected]>
-
- * fileio.c (Fmake_symbolic_link): Fix last change.
-
-2005-03-11 Richard M. Stallman <[email protected]>
-
- * fileio.c (Frename_file, Fadd_name_to_file)
- (Fmake_symbolic_link): If NEWNAME or LINKNAME is a directory,
- expand the basename of FILE relative to it.
-
-2005-03-11 Kenichi Handa <[email protected]>
-
- * fileio.c (Finsert_file_contents): Call Fcheck_coding_system
- before calling setup_coding_system so that autoloading of a coding
- system work.
-
-2005-03-10 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (hourglass_started): New function.
-
- * dispextern.h: Declare hourglass_started.
-
- * keyboard.c (Fexecute_extended_command): Restart hourglass
- after call to Fcompleting_read if already started.
-
- * gtkutil.c (xg_update_scrollbar_pos): Call x_sync so that the
- GTK main loop is entered in xterm.c, thus doing the redraw.
-
-2005-03-10 Kim F. Storm <[email protected]>
-
- * xdisp.c (pos_visible_p): Fix X value in last line of buffer.
-
-2005-03-08 Kenichi Handa <[email protected]>
-
- * frame.c (x_set_font): Call set_default_ascii_font if an
- available font is found.
-
- * fontset.c (set_default_ascii_font): New function.
- (syms_of_fontset): Don't set FONTSET_ASCII (Vdefault_fontset) here.
-
- * fontset.h (set_default_ascii_font): Extern it.
-
-2005-03-07 Kim F. Storm <[email protected]>
-
- * xdisp.c (CLEAR_IMAGE_CACHE_COUNT): New const.
- (clear_image_cache_count): New var.
- (redisplay_internal): Don't clear face and image caches in the
- middle of redisplay; do it afterwards.
-
- * blockinput.h (TOTALLY_UNBLOCK_INPUT): Avoid dangling else.
-
- * xdisp.c (notice_overwritten_cursor): Check that phys_cursor.vpos
- is valid. If not, clear phys_cursor_on_p and return.
-
-2005-03-07 Andreas Schwab <[email protected]>
-
- * blockinput.h (UNBLOCK_INPUT_TO): Always call UNBLOCK_INPUT.
-
-2005-03-06 Richard M. Stallman <[email protected]>
-
- * keyboard.c (Ftop_level): Let Fthrow deal with UNBLOCK_INPUT.
-
- * eval.c (unwind_to_catch): Use UNBLOCK_INPUT_TO.
- (Feval, Ffuncall): Use CHECK_CONS_LIST.
-
- * lisp.h (CHECK_CONS_LIST): New macro (two definitions).
-
- * blockinput.h (UNBLOCK_INPUT_TO): New macro.
- (TOTALLY_UNBLOCK_INPUT): Handle a pending signal if any.
-
-2005-03-05 Juri Linkov <[email protected]>
-
- * emacs.c (USAGE1): Replace Info node name "command arguments"
- with "emacs invocation".
- (USAGE3): Fix usage of `--color=MODE' which actually doesn't
- allow arguments `--color' and `MODE' to be separated by space.
- Add --no-blinking-cursor, -nbc.
- (standard_args): Add -nbc, --no-blinking-cursor.
-
-2005-03-04 Thien-Thi Nguyen <[email protected]>
-
- * s/vms.h: Define NO_HYPHENS_IN_FILENAMES.
- * s/vms4-4.h, s/vms5-5.h: Undefine NO_HYPHENS_IN_FILENAMES.
- * fileio.c (Fexpand_file_name) [VMS]:
- Use NO_HYPHENS_IN_FILENAMES, not VMS4_4.
- * doc.c (munge_doc_file_name) [VMS]: Likewise.
- (Fsnarf_documentation): Call munge_doc_file_name.
-
-2005-03-04 Thien-Thi Nguyen <[email protected]>
-
- * s/vms.h (FILE_SYSTEM_CASE): New macro.
- * fileio.c (Fexpand_file_name) [VMS]: Don't upcase the name
- "manually"; this is now handled generally via FILE_SYSTEM_CASE.
-
-2005-03-04 YAMAMOTO Mitsuharu <[email protected]>
-
- * emacs.c (main): Change `#ifdef HAVE_CARBON' to `#if
- defined (MAC_OSX) && defined (HAVE_CARBON)'.
-
- * image.c [!MAC_OSX && TARGET_API_MAC_CARBON]: Include QuickTime.h.
-
- * mac.c [!MAC_OSX && HAVE_CARBON]: Include Carbon.h.
- [!MAC_OSX] (select) [TARGET_API_MAC_CARBON]: Use ReceiveNextEvent.
- (posix_pathname_to_fsspec, fsspec_to_posix_pathname): New functions.
- (mac_clear_font_name_table): Move extern to macterm.h.
-
- * macfns.c (install_window_handler): Move extern to macterm.h.
- (Fx_file_dialog): Check STRINGP (default_filename) to see it is
- valid. Don't check !NILP (dir) because it is already checked with
- CHECK_STRING.
- (Fx_file_dialog) [!MAC_OSX]: Use FSSpec instead of FSRef for
- specifying the default location and obtaining the selected filename.
-
- * macgui.h [!MAC_OSX && HAVE_CARBON]: Include Carbon.h.
-
- * macmenu.c [TARGET_API_MAC_CARBON]: Don't include headers that
- are included via Carbon.h.
-
- * macterm.c [TARGET_API_MAC_CARBON && !MAC_OSX]:
- Define USE_CARBON_EVENTS to 1.
- (qd) [__MRC__ && TARGET_API_MAC_CARBON]: Don't declare.
- (x_free_frame_resources): Call remove_window_handler for
- non-tooltip windows.
- [TARGET_API_MAC_CARBON]: Don't include headers that are included
- via Carbon.h.
- [TARGET_API_MAC_CARBON] (mac_do_track_dragUPP)
- (mac_do_receive_dragUPP): New variables.
- (mac_handle_service_event, init_service_handler): Put declarations
- and definitions in #ifdef MAC_OSX.
- (install_window_handler) [TARGET_API_MAC_CARBON]: Create UPPs for
- drag-and-drop handler functions and register them.
- (remove_window_handler): New function.
- (do_ae_open_documents, mac_do_receive_drag) [!MAC_OSX]:
- Use fsspec_to_posix_pathname.
- (main): Change #if !TARGET_API_MAC_CARBON to #ifdef MAC_OS8.
- (XTread_socket) [!MAC_OSX]: Don't pass keyboard events to TSM.
- [MAC_OS8] (make_mac_terminal_frame) [TARGET_API_MAC_CARBON]:
- Set default cursors.
- (mac_initialize) [USE_CARBON_EVENTS && !MAC_OSX]: Don't call
- init_service_handler or init_quit_char_handler.
- (mac_initialize) [!MAC_OSX]: Don't call MakeMeTheFrontProcess.
-
- * macterm.h (install_window_handler, remove_window_handler)
- (posix_pathname_to_fsspec, fsspec_to_posix_pathname)
- (mac_clear_font_name_table): New externs.
-
-2005-03-03 Thien-Thi Nguyen <[email protected]>
-
- * fileio.c (FILE_SYSTEM_CASE): Define macro if not already defined.
- (Ffile_name_directory): Use FILE_SYSTEM_CASE unconditionally.
- (Fexpand_file_name): Likewise.
-
-2005-03-03 Thien-Thi Nguyen <[email protected]>
-
- * emacs.c (Fkill_emacs): Use EXIT_SUCCESS;
- no longer special-case VMS. Add bogus return value.
-
-2005-03-02 Kim F. Storm <[email protected]>
-
- * dispextern.h (XASSERTS): Define to 0 if not already defined.
- (xassert) [!XASSERTS]: Define dummy version.
-
-2005-03-02 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): YABX (yet another bogus xassert).
- Reported by David Kastrup.
-
-2005-03-01 Ehud Karni <[email protected]>
-
- * xdisp.c (get_next_display_element): Fix control and escape
- glyph from display vector.
-
-2005-03-01 Stefan Monnier <[email protected]>
-
- * keyboard.c (Fposn_at_x_y): Check integerness of X and Y.
-
-2005-02-27 Richard M. Stallman <[email protected]>
-
- * xdisp.c (fast_find_position): Rename END to BEG.
- (syms_of_xdisp) <menu-bar-update-hook>: Doc fix.
-
-2005-02-27 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_resize_outer_widget): Remove unneeded call to
- gtk_window_resize and x_wm_set_size_hint.
-
-2005-02-25 Kim F. Storm <[email protected]>
-
- * dispextern.h (OVERLAY_STRING_CHUNK_SIZE): Increase from 3 to 16.
-
- * xdisp.c (init_from_display_pos): Don't read past end of
- it->overlay_strings array.
-
-2005-02-25 Stephan Stahl <[email protected]> (tiny change)
-
- * buffer.c (syms_of_buffer): Fix typo.
-
-2005-02-23 Lute Kamstra <[email protected]>
-
- * buffer.c (Foverlay_buffer): Doc fix.
-
-2005-02-22 Kim F. Storm <[email protected]>
-
- * minibuf.c (Ftry_completion, Fall_completions): Allow both string
- and symbol keys in alists and hash tables.
-
- * xdisp.c (fast_find_position): Fix search for start of overlay.
-
-2005-02-21 Kim F. Storm <[email protected]>
-
- * window.c (window_scroll_pixel_based): When scrolling backwards,
- handle partial visible line at end of window even when we hit PT.
-
-2005-02-21 Stefan Monnier <[email protected]>
-
- * keymap.h: Declare Fcurrent_active_maps, used in doc.c.
-
-2005-02-21 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_vertically_backward): Eliminate two xasserts.
- I think those asserts are bogus if buffer contains invisible text
- or images.
-
-2005-02-21 David Kastrup <[email protected]>
-
- * gtkutil.c (xg_create_frame_widgets): UNBLOCK_INPUT on error.
-
-2005-02-20 Kim F. Storm <[email protected]>
-
- * xdisp.c (pos_visible_p): Be sure to move to the specified
- position. Always get the full ascent / descent of the
- corresponding row, to return reliable rtop and rbot values.
- (back_to_previous_visible_line_start): Fix 2005-01-18 change.
- Must look one character back, as back_to_previous_line_start
- returns position after the newline.
- (move_it_vertically_backward): Fix heuristic for when to move further
- back in case line_height * 2/3 is larger than window height.
- (cursor_row_fully_visible_p): Rename make_cursor_line_fully_visible_p
- as it does not do anything anymore. Add arg current_matrix_p to
- use current matrix rather than desired matrix when set.
- (try_cursor_movement): Don't scroll to make cursor row fully
- visible if cursor didn't move. This avoids unexpected recentering
- in case of blinking cursor or accepting process output.
- Use current matrix to check cursor row visibility.
- (redisplay_window): Fix whether to recenter or move to top in case
- cursor line is taller than window height.
- (find_first_unchanged_at_end_row): Stop search if we reach a row
- which not enabled (instead of abort).
-
-2005-02-18 Kim F. Storm <[email protected]>
-
- * xfaces.c (Finternal_set_lisp_face_attribute): Allow :color property
- to be nil in a :box attribute value list; customize prints that
- as lisp value when no box color is specified.
-
- * .gdbinit (pitx, pit): Pretty print display iterator.
- (prowx, prow): Pretty print glyph row.
- (pcursorx, pcursor): Pretty print a window cursor.
- (pwinx, pwin): Pretty print struct window.
-
-2005-02-18 Stefan Monnier <[email protected]>
-
- * alloc.c (BLOCK_BYTES): Harmless typo.
-
-2005-02-17 Andreas Schwab <[email protected]>
-
- * xfns.c (hack_wm_protocols): Use correct type for last parameter
- of XGetWindowProperty to avoid aliasing issues.
- (Fx_window_property): Likewise.
-
- * xselect.c (Fx_disown_selection_internal): Use union of struct
- input_event and struct selection_input_event to avoid aliasing issues.
-
- * xterm.c (handle_one_xevent): Use union of struct input_event and
- struct selection_input_event to avoid aliasing issues.
- (SET_SAVED_MENU_EVENT): Adapt reference to inev.
-
-2005-02-17 Kim F. Storm <[email protected]>
-
- * dispextern.h (enum it_method): New enum.
- (GET_FROM_*): Its members.
- (struct it): Change member method from function pointer to enum.
-
- * xdisp.c (check_it, init_from_display_pos, handle_stop)
- (setup_for_ellipsis, handle_single_display_spec)
- (handle_composition_prop, next_overlay_string)
- (get_overlay_strings, reseat_1, reseat_to_string)
- (next_element_from_ellipsis, BUFFER_POS_REACHED_P)
- (in_display_vector_p, display_line, get_next_display_element):
- Change it->method from function pointer to enum.
- (get_next_element): New array to map it->method to function.
- (get_next_display_element): Use it.
- (set_iterator_to_next): Use switch instead of if/else chain.
-
-2005-02-15 Benjamin Riefenstahl <[email protected]>
-
- * w32select.c: Summary: Thorough rework to implement Unicode
- clipboard operations and delayed rendering.
-
- Drop last_clipboard_text and related code, keep track of
- ownership via clipboard_owner instead. Drop old #if0 sections.
-
- (DEFAULT_LCID, ANSICP, OEMCP, QUNICODE, QANSICP, QOEMCP)
- (clipboard_owner, modifying_clipboard, cfg_coding_system)
- (cfg_codepage, cfg_lcid, cfg_clipboard_type, current_text)
- (current_coding_system, current_requires_encoding)
- (current_num_nls, current_clipboard_type, current_lcid):
- New static variables.
-
- (convert_to_handle_as_ascii, convert_to_handle_as_coded)
- (render, render_all, run_protected, lisp_error_handler)
- (owner_callback, create_owner, setup_config)
- (enum_locale_callback, cp_from_locale, coding_from_cp):
- New local functions.
-
- (term_w32select, globals_of_w32select): New global functions.
-
- (Fw32_set_clipboard_data): Ignore parameter FRAME, use
- clipboard_owner instead. Use delayed rendering and provide
- all text formats. Provide CF_LOCALE if necessary.
-
- (Fw32_get_clipboard_data): Handle CF_UNICODETEXT and
- CF_LOCALE. Fall back to CF_TEXT, if CF_UNICODETEXT is not
- available. Force DOS line-ends for decoding.
-
- (Fx_selection_exists_p): Handle CF_UNICODETEXT.
-
- (syms_of_w32select): Init and register new variables.
-
- * w32.h: Add prototypes for globals_of_w32select and
- term_w32select. Make the neighboring K&R declarations into
- prototypes, too.
-
- * emacs.c: Include w32.h to get function prototypes.
- (main): Call globals_of_w32select.
-
- * w32.c (term_ntproc): Call term_w32select.
-
- * s/ms-w32.h: Guard MSC-specific #pragmas with an #ifdef.
-
-2005-02-16 Kim F. Storm <[email protected]>
-
- * xdisp.c (BUFFER_POS_REACHED_P): Return true if pos reached and
- at end of display vector.
-
-2005-02-15 Richard M. Stallman <[email protected]>
-
- * xdisp.c (get_next_display_element): Fix escape-glyph criterion
- for mode and header lines.
-
- * lread.c (syms_of_lread) <user-init-file>: Doc fix.
-
- * keymap.h (describe_map_tree): Change decl.
-
- * keyboard.c (command_loop_1): Always use safe_run_hooks
- to run Qdeferred_action_function.
-
- * keymap.c (describe_map_tree): New arg MENTION_SHADOW. Calls changed.
- (describe_map, describe_vector): Likewise. When it's 1,
- don't omit shadowed bindings, instead mark them as shadowed.
-
- * doc.c (Fsubstitute_command_keys): Compute list of shadowing maps
- for describe_map_tree. Pass 1 for MENTION_SHADOW.
-
- * data.c (Fsetq_default): Allow no arg case.
-
-2005-02-14 Kenichi Handa <[email protected]>
-
- * coding.c (encode_coding_string): Always return a unibyte string.
- If NOCOPY is nonzero and there's no need of encoding, make STR
- unibyte directly.
-
- * xselect.c (lisp_data_to_selection_data): If OBJ is a non-ASCII
- multibyte string, signal an error instead of aborting.
-
-2005-02-12 Dan Nicolaescu <[email protected]>
-
- * keyboard.c: If HAVE_FCNTL_H include fcntl.h.
-
-2005-02-12 Kim F. Storm <[email protected]>
-
- * xdisp.c (expose_window): Don't fix overlaps for mode lines.
-
-2005-02-10 Kim F. Storm <[email protected]>
-
- * xdisp.c (try_window_id): Set first_unchanged_at_end_row to NULL
- if it moves outside window or it doesn't display text.
-
-2005-02-09 Kim F. Storm <[email protected]>
-
- * undo.c (Fprimitive_undo): Check that undo function does not
- switch buffer.
-
-2005-02-08 Jan Dj,Ad(Brv <[email protected]>
-
- * xselect.c (selection_data_to_lisp_data): For the special case
- type == XA_ATOM, data contains array of int, not array of Atom.
- (x_property_data_to_lisp, selection_data_to_lisp_data):
- Comment update: data must be array of int for format == 32.
-
-2005-02-08 Stefan Monnier <[email protected]>
-
- * undo.c (Fprimitive_undo): Check veracity of delta,start,end.
-
-2005-02-07 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (Fx_change_window_property): Use long array when format is 32.
- (Fx_window_property): If format is 32 and long is bigger than 32 bits,
- convert long array returned from XGetWindowProperty to an int array.
- (x_set_tool_bar_lines): Check that width and height is greater than
- zero before clearing area.
-
- * xselect.c (x_reply_selection_request): Pass long array to
- XChangeProperty so that 64 bit longs are handeled correctly.
- (x_get_window_property): If format is 32 and long is bigger than 32
- bits convert data from XGetWindowProperty from long array to int array.
- (lisp_data_to_selection_data): When the input is a vector and the
- format is 32, allocate a long array even if long is bigger than 32 bits.
- (x_fill_property_data): Use char, short and long as the man page
- for XChangeProperty specifies. This way the data returned is OK for
- both 32 and 64 bit machines.
- (x_handle_dnd_message): Calculate size correctly even for 64 bit
- machines.
- (Fx_send_client_event): Undo change from 2005-02-05,
- x_fill_property_data now handles that case.
-
- * xfns.c (Fx_backspace_delete_keys_p): Add comment about the
- reason for the approach in the code.
-
-2005-02-07 Kim F. Storm <[email protected]>
-
- * undo.c (Fprimitive_undo): Record max one dummmy apply element.
-
-2005-02-06 Richard M. Stallman <[email protected]>
-
- * eval.c (Frun_hook_with_args)
- (Frun_hook_with_args_until_success)
- (Frun_hook_with_args_until_failure): Doc fixes.
-
-2005-02-05 Andreas Schwab <[email protected]>
-
- * sysdep.c (sys_subshell): Properly terminate execlp argument list.
-
-2005-02-05 Jan Dj,Ad(Brv <[email protected]>
-
- * xselect.c (Fx_send_client_event, x_handle_dnd_message): Handle
- the longs in a XClientMessageEvent correctly when long is 64 bits.
-
-2005-02-05 Eli Zaretskii <[email protected]>
-
- * xfaces.c (face_color_supported_p): Use HAVE_WINDOW_SYSTEM
- instead of HAVE_X_WINDOWS, for non-X windowed sessions.
-
-2005-02-03 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (menubar_selection_callback): Force out GTK buffered
- events so the menu event comes after them. This is to prevent sit-for
- from exiting on buffered events directly after a menu selection,
- lisp code for Help => About Emacs uses sit-for.
-
- * gtkutil.c (create_menus): Connect selection-done event instead of
- the deactivate event to deactivate_cb. This will make the last
- leave event come before the call to deactivate_cb, so the leave
- event does not make sit-for exit after a menu selection.
-
-2005-02-03 Kim F. Storm <[email protected]>
-
- * dispnew.c (build_frame_matrix_from_leaf_window)
- [!GLYPH_DEBUG]: Fix xassert.
-
- * xfaces.c (x_free_gc) [!GLYPH_DEBUG]: Fix xassert.
-
- * xfns.c (unwind_create_frame) [!GLYPH_DEBUG]: Fix xassert.
-
-2005-02-03 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c: Use MAC_OS_X_VERSION_MAX_ALLOWED to conditionalize by
- the compiling OS version.
-
- * macfns.c (x_create_tip_frame): Likewise.
-
- * macterm.c (mac_draw_string_common, x_make_frame_visible): Likewise.
-
-2005-02-03 Richard M. Stallman <[email protected]>
-
- * xterm.c (x_error_quitter): On GCC 3 and up, specify noinline.
-
- * xdisp.c (echo_area_display): Clear echo_message_buffer.
-
- * buffer.c (Fbury_buffer): Doc fix.
-
-2005-02-02 Steven Tamm <[email protected]>
-
- * macfns.c (unwind_create_frame): Fix compile error due to
- xassert being uncondition, but predicate is.
- * dispnew.c (update_window): Fix compile error due to
- xassert being uncondition, but predicate is.
-
-2005-02-02 Miles Bader <[email protected]>
-
- * dispextern.h (xassert): Enable unconditionally.
-
-2005-02-02 Kim F. Storm <[email protected]>
-
- * undo.c (Fprimitive_undo): Fix dummy apply undo entry.
-
-2005-02-02 Kenichi Handa <[email protected]>
-
- * casefiddle.c (casify_object): Enable changing characters of
- different byte length.
- (casify_region): Fix loop condition, args to replace_range_2, and
- update opoint_byte.
-
- * insdel.c (replace_range_2): Fix bugs in adjusting markers and point.
-
-2005-02-01 Kim F. Storm <[email protected]>
-
- * xdisp.c (back_to_previous_visible_line_start): Reset iterator
- stack before calling handle_display_prop.
-
-2005-01-31 Kim F. Storm <[email protected]>
-
- * undo.c (Qapply): New lisp var.
- (syms_of_undo): Intern and staticpro it.
- (Fprimitive_undo): Support formats (apply FUNNAME . ARGS) and
- (apply DELTA BEG END FUNNAME . ARGS) instead of (FUNNAME . ARGS).
-
- * buffer.c (syms_of_buffer) <buffer-undo-list>: Doc fix.
-
-2005-01-30 Jesper Harder <[email protected]>
-
- * macterm.c (syms_of_macterm) <mac-reverse-ctrl-meta>
- <mac-emulate-three-button-mouse>: Fix docstring indentation.
-
-2005-01-29 Luc Teirlinck <[email protected]>
-
- * undo.c (syms_of_undo) <undo-outer-limit>: Doc update.
- Increase value to 3 Meg.
-
-2005-01-29 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (show_hourglass): Use FRAME_X_WINDOW as parent for GTK,
- button events are not received otherwise.
-
-2005-01-29 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer) <buffer-undo-list>: Doc fix.
-
- * undo.c (Fprimitive_undo): Handle (FUNNAME . ARGS) by calling FUNNAME.
-
-2005-01-28 Stefan Monnier <[email protected]>
-
- * keymap.c (access_keymap): YAILOM.
-
-2005-01-27 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_phys_cursor_geometry): New function to calculate
- phys cursor position and size for hollow cursor. Position is
- aligned with get_glyph_string_clip_rect and ensures that a hollow
- cursor is shown, even when the actual glyph is not visible.
-
- * dispextern.h (get_phys_cursor_geometry): Add prototype.
-
- * xterm.c (x_clip_to_row): Ensure y >= 0.
- (x_draw_hollow_cursor): Use get_phys_cursor_geometry.
-
- * w32term.c (x_draw_hollow_cursor): Use get_phys_cursor_geometry.
-
- * macterm.c (x_draw_hollow_cursor): Use get_phys_cursor_geometry.
-
-2005-01-27 Stefan Monnier <[email protected]>
-
- * xterm.c (x_error_quitter): Add a prototype. Make it static again.
-
-2005-01-27 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_glyph_string_clip_rect): Always show a cursor
- glyph, even when row is only partially visible and actual cursor
- position is not visible.
-
-2005-01-24 Richard M. Stallman <[email protected]>
-
- * xterm.c (x_error_quitter): No longer static, and moved after
- x_error_handler.
-
-2005-01-24 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_by_lines): If we move forward after going too
- far back, cancel move if end position is same as start position.
-
-2005-01-24 YAMAMOTO Mitsuharu <[email protected]>
-
- * dispextern.h (struct glyph_string): New members clip_head and
- clip_tail.
-
- * xdisp.c (get_glyph_string_clip_rect): Restrict horizontal clip
- region to the area between clip_head and clip_tail.
- (draw_glyphs): Record the area that need to be actually redrawn to
- the new variables clip_head and clip_tail when there are
- overhangs. Set values of these variables to the corresponding
- members in struct glyph_string. Refine x coordinates for
- notice_overwritten_cursor using clip_head and clip_tail.
-
- * macgui.h (STORE_XCHARSETSTRUCT): New macro.
-
- * macterm.c (mac_compute_glyph_string_overhangs): Implement with
- QDTextBounds.
- (x_draw_glyph_string): Don't fill the background of the successor
- of a glyph with a right overhang if the successor will draw a cursor.
- (XLoadQueryFont): Obtain font metrics using QDTextBounds.
- (x_redisplay_interface): Add entry for compute_glyph_string_overhangs.
-
-2005-01-24 Kim F. Storm <[email protected]>
-
- * window.c (window_scroll_pixel_based): Fix scrolling in the wrong
- direction if window height was smaller than next-screen-context-lines.
- Now always scroll at least one line in the requested direction.
- Ensure that we actually do scroll backwards when requested to do so.
-
- * xdisp.c (redisplay_window): Only try to make cursor line fully
- visible once (to avoid redisplay loop).
-
-2005-01-23 Kim F. Storm <[email protected]>
-
- * window.c (Fpos_visible_in_window_p): Simplify return value for
- partially visible rows.
- (window_scroll_pixel_based): Adapt to that change.
-
- * window.c (window_scroll_pixel_based): Force moving to next line
- if scrolling doesn't move start point, e.g. if looking at tall image.
-
- * xdisp.c (pos_visible_p): Return 0 if non-interactive.
- Clear last_height before calling line_bottom_y to get real height.
- Fix calculation of y.
-
-2005-01-22 Steven Tamm <[email protected]>
-
- * s/darwin.h: Removed PTY_ITERATION from here.
- (DARWIN): Define.
-
- * process.c (init_process): Default process-connection-type to
- nil on darwin 6 or less, t if it is 7 or higher. This way the
- broken pty behavior is still allowed on darwin 6 for interactive
- processes for people that know what they are doing.
-
-2005-01-22 Kim F. Storm <[email protected]>
-
- * window.c (auto_window_vscroll_p): New boolean.
- (syms_of_window): DEFVAR_BOOL it.
- (Fpos_visible_in_window_p): Extend return value to include RTOP
- and RBOT values if FULLY is nil.
- (window_scroll_pixel_based): Adjust vscroll for partially visible
- rows if auto_window_vscroll_p is set.
- (Fset_window_vscroll): Do nothing if vscroll is not modified.
-
- * xdisp.c (pos_visible_p): Replace FULLY arg by RTOP and RBOT args
- to return number of partially invisible pixels at top and bottom
- of the dislay row at POS.
-
- * lisp.h (pos_visible_p): Fix prototype.
-
-2005-01-21 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fcopy_file): Doc fix.
-
-2005-01-21 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_tool_bar_detach_callback): Remove unused variable bw.
- (xg_get_file_name): Move declaration ofx_use_old_gtk_file_dialog to
- start of function for older compilers.
-
-2005-01-20 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fmessage): If arg is "", return "" (as before).
-
- * keymap.c (access_keymap): Protect from bad value of meta_prefix_char.
-
- * .gdbinit (xgetptr, xgetint, xgettype): Copy $arg0 into a temp
- variable.
-
-2005-01-20 Steven Tamm <[email protected]>
-
- * editfns.c (Voperating_system_release): Add.
- (init_editfns): Assign new variable operating-system-release
- based on call to uname if available.
- (get_operating_system_release): Add function to
- allow c-level access to operating system release.
-
- * config.h: Regenerated.
-
- * s/darwin.h (PTY_ITERATION): Don't allow PTYs on darwin 6 or less.
- (MIN_PTY_KERNEL_VERSION): Define minimum kernel version for
- using ptys as '7'.
-
-2005-01-20 Kim F. Storm <[email protected]>
-
- * alloc.c (STRING_MARKED_P, VECTOR_MARKED_P): Return boolean.
-
- * xterm.c (x_draw_glyph_string_box): Fix last_x for full width rows.
- Thanks to Chong Yidong <[email protected]> for debugging this.
-
- * macterm.c (x_draw_glyph_string_box): Likewise.
-
- * w32term.c (x_draw_glyph_string_box): Likewise.
-
- * indent.c (Fvertical_motion): Temporarily disable selective display.
-
-2005-01-19 Kim F. Storm <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Fix :pointer
- image property.
-
- * fns.c (sweep_weak_table): Advance prev pointer when we keep a pair.
-
-2005-01-18 Kim F. Storm <[email protected]>
-
- * xdisp.c (fast_find_position): Backtrack to find first row if
- charpos is inside a display overlay that spans multiple lines.
-
-2005-01-18 Kenichi Handa <[email protected]>
-
- * coding.c (decode_coding_iso2022): Translate invalid codes if
- translation-table is specified.
-
-2005-01-18 Kim F. Storm <[email protected]>
-
- * xdisp.c (back_to_previous_visible_line_start): Undo 2004-12-28
- change. If handle_display_prop indicates newline is replaced by
- image or text, move back to start of relevant overlay or interval
- and continue scan from there. Simplify.
-
-2005-01-17 Kim F. Storm <[email protected]>
-
- * dispnew.c (mode_line_string, marginal_area_string):
- Fix off-by-one error in search for glyph.
-
-2005-01-16 Kim F. Storm <[email protected]>
-
- * macterm.c (syms_of_macterm) <mac-allow-anti-aliasing>: Doc fix.
-
-2005-01-16 Steven Tamm <[email protected]>
-
- * macterm.c (mac_to_x_fontname): Remove spurious argument.
-
-2005-01-16 Andreas Schwab <[email protected]>
-
- * macterm.c (mac_draw_string_common): Fix compilation on OSX 10.1.
-
-2005-01-16 Jan Dj,Ad(Brv <[email protected]>
-
- * fringe.c (Fdefine_fringe_bitmap, init_fringe): When assigning
- fringe_faces, cast result from xmalloc/xrealloc to Lisp_Object *.
-
-2005-01-16 YAMAMOTO Mitsuharu <[email protected]>
-
- * keyboard.c (READABLE_EVENTS_DO_TIMERS_NOW)
- (READABLE_EVENTS_FILTER_EVENTS, READABLE_EVENTS_IGNORE_SQUEEZABLES):
- New flags for readable_events.
- (get_filtered_input_pending, readable_filtered_events): Remove.
- (tracking_off): Call readable_events and get_input_pending with
- flag READABLE_EVENTS_DO_TIMERS_NOW.
- (readable_events): Move code from old readable_filtered_events here,
- but check new READABLE_EVENTS_* in argument flags instead of previous
- two boolean arguments do_timers_now and filter_events.
- If we are doing mouse tracking and the mouse moved, return only if
- READABLE_EVENTS_IGNORE_SQUEEZABLES is not set in flags.
- (swallow_events): Call get_input_pending with flag
- READABLE_EVENTS_DO_TIMERS_NOW.
- (get_input_pending): Move code from old get_filtered_input_pending
- here. Replace boolean arguments do_timers_now, filter_events with
- flags, and pass flags to readable_events. Document new
- READABLE_EVENTS_* flags.
- (detect_input_pending_ignore_squeezables): New function.
- (detect_input_pending_run_timers): Call get_input_pending with flag
- READABLE_EVENTS_DO_TIMERS_NOW.
- (Finput_pending_p): Call get_input_pending with flags
- READABLE_EVENTS_DO_TIMERS_NOW and READABLE_EVENTS_FILTER_EVENTS.
-
- * dispnew.c (update_window, update_frame_1): Replace calls to
- detect_input_pending with detect_input_pending_ignore_squeezables
- so that redisplay is not paused if the event queue contains only
- mouse movements.
-
- * lisp.h: Declare detect_input_pending_ignore_squeezables.
-
-2005-01-15 Steven Tamm <[email protected]>
-
- * macterm.c (Vmac_use_core_graphics): Declare variable for
- mac-allow-anti-aliasing.
- (syms_of_macterm): DEFVAR_LISP and initialize it.
- (mac_draw_string_common): Use core graphics text rendering if
- mac-allow-anti-aliasing is enabled.
-
- * macfns.c (Fx_file_dialog): Save As dialog includes only the
- file name in the text box.
-
-2005-01-15 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (x_set_foreground_color, x_set_background_color):
- Sync with xfns.c.
- (mac_window, x_create_tip_frame): Use XSetWindowBackground.
- * macterm.c (XSetBackground, XSetWindowBackground): New functions.
- * macterm.h (XSetBackground, XSetWindowBackground): Add externs.
-
-2005-01-14 Kim F. Storm <[email protected]>
-
- * keyboard.c (Fposn_at_x_y): Add optional arg WHOLE.
-
-2005-01-13 Richard M. Stallman <[email protected]>
-
- * keymap.c (Fcurrent_active_maps): Ignore Voverriding_local_map
- if Voverriding_terminal_local_map is non-nil.
-
- * keyboard.c (syms_of_keyboard): Doc fix.
-
-2005-01-13 Kim F. Storm <[email protected]>
-
- * xdisp.c (Fformat_mode_line): Fix last change. Remove NO_PROPS arg
- (specify 0 for FACE instead). Reorder arg list. Doc fix.
-
-2005-01-12 Richard M. Stallman <[email protected]>
-
- * xdisp.c (Fformat_mode_line): New arg FACE specifies a default
- face property for characters that don't specify one.
-
- * fns.c (Frequire): Record in load-history unconditionally.
-
-2005-01-10 Kim F. Storm <[email protected]>
-
- * dispextern.h (merge_faces): Rename from merge_into_realized_face.
-
- * xfaces.c (merge_faces): Rename from merge_into_realized_face.
- Callers changed.
- Add support to merge with lisp face id too (if face_name is t).
-
- * xdisp.c (get_next_display_element, next_element_from_display_vector):
- Don't lookup lface_id from display table glyphs here; instead use
- merge_faces to merge the lisp face id into current face.
-
-2005-01-09 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct it): New member dpvec_face_id.
- (merge_into_realized_face): Add prototype.
-
- * xfaces.c (merge_into_realized_face): New function. Used to
- merge escape-glyph face or face from display table into current face.
-
- * xdisp.c (Vshow_nonbreak_escape): New lisp var.
- (syms_of_xdisp): DEFVAR_LISP it.
- (escape_glyph_face): Remove var.
- (redisplay_window): Don't initialize it.
- (setup_for_ellipsis, get_next_display_element):
- Set it->dpvec_face_id to -1.
- (get_next_display_element): Test Vshow_nonbreak_escape.
- Do not setup escape_glyph_face.
- Properly merge escape-glyph face or face from display table with
- current face for escape and control characters.
- Set it->dpvec_face_id to relevant face id instead of adding it to each
- element of display vector.
- (next_element_from_display_vector): If it->dpvec_face_id is set,
- use that instead of lface_id from glyph itself.
-
-2005-01-08 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h (struct x_output): New member, toolbar_detached.
-
- * gtkutil.c (xg_create_frame_widgets): Set initial tool bar height to
- 38.
- (xg_tool_bar_detach_callback): Set toolbar_detached to 1.
- (xg_tool_bar_attach_callback): Set toolbar_detached to 0.
- (xg_create_tool_bar): Initialize toolbar_detached.
- (update_frame_tool_bar): Only set FRAME_TOOLBAR_HEIGHT (f) if
- toolbar_detached is zero.
-
-2005-01-07 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (create_and_show_popup_menu): Pass zero as button to
- gtk_menu_popup if not for_click, so callbacks for the menu are called.
-
- * gtkutil.c (xg_gtk_scroll_destroy, xg_create_scroll_bar)
- (xg_tool_bar_callback, xg_tool_bar_help_callback)
- (update_frame_tool_bar): Cast to EMACS_INT to avoid compiler warning.
-
- * xselect.c (x_get_foreign_selection, x_fill_property_data)
- (Fx_get_atom_name, Fx_send_client_event): Replace XFLOAT with
- XFLOAT_DATA to get extract number from Lisp object.
-
-2005-01-07 Kim F. Storm <[email protected]>
-
- * xdisp.c (set_iterator_to_next): Fix 2004-12-13 change.
- Set stop_charpos to current charpos instead of 0.
-
-2005-01-06 Nick Roberts <[email protected]>
-
- * xdisp.c (Fformat_mode_line): First arg now required.
-
-2005-01-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (XLoadQueryFont): Correctly handle 0 size
- font widths that are returned from some Japanese fonts.
-
-2005-01-06 Kim F. Storm <[email protected]>
-
- * fringe.c (fringe_faces): Change to Lisp_Object pointer.
- (draw_fringe_bitmap_1): Lookup user defined fringe faces here.
- (destroy_fringe_bitmap): Set fringe_faces element to nil.
- (Fdefine_fringe_bitmap, init_fringe): Change allocation of
- fringe_faces array and init elements to nil.
- (Fset_fringe_bitmap_face): Set fringe_faces to face name instead of
- non-persistent face id.
- (mark_fringe_data): New function for GC.
-
- * alloc.c (mark_fringe_data): Declare extern.
- (Fgarbage_collect): Call mark_fringe_data.
-
- * alloc.c (overrun_check_free): Invalidate freed memory if
- XMALLOC_CLEAR_FREE_MEMORY is defined.
-
-2005-01-05 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c: Include sys/param.h.
- [TARGET_API_MAC_CARBON] (mac_nav_event_callback): New declaration
- and function.
- [TARGET_API_MAC_CARBON] (Fx_file_dialog): Use MAXPATHLEN for size
- of filename string. Set event callback function when creating
- dialog boxes. Add code conversions for filenames. Don't dispose
- of apple event descriptor record if failed to create it.
-
- * macterm.c: Include sys/param.h.
- [USE_CARBON_EVENTS] (mac_handle_window_event): Add handler for
- kEventWindowUpdate.
- (install_window_handler) [USE_CARBON_EVENTS]: Register it.
- (do_ae_open_documents) [TARGET_API_MAC_CARBON]: Get FSRef instead
- of FSSpec from apple event descriptor record.
- (do_ae_open_documents) [TARGET_API_MAC_CARBON]: Use MAXPATHLEN for
- size of filename string.
- [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Likewise.
- [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Return error when a
- file dialog is in action.
- [TARGET_API_MAC_CARBON] (mac_do_track_drag): Likewise.
- Reject only when there are no filename items. Set background color
- before (un)highlighting the window below the dragged items.
- (XTread_socket) [USE_CARBON_EVENTS]: Don't call do_window_update.
-
-2005-01-05 Romain Francoise <[email protected]>
-
- * term.c (encode_terminal_code): Fix buffer size computation.
-
-2005-01-04 Richard M. Stallman <[email protected]>
-
- * xdisp.c (Fformat_mode_line): Doc fix.
-
-2005-01-04 Stefan Monnier <[email protected]>
-
- * alloc.c (refill_memory_reserve): Move.
- (emacs_blocked_free, emacs_blocked_malloc, emacs_blocked_realloc)
- (reset_malloc_hooks, uninterrupt_malloc) [SYNC_INPUT]: Don't define.
-
-2005-01-03 Richard M. Stallman <[email protected]>
-
- * window.c (window_scroll_pixel_based): Don't correct preserve_y
- for CURRENT_HEADER_LINE_HEIGHT when moving backwards.
-
-2005-01-03 Jason Rumney <[email protected]>
-
- * w32bdf.c (w32_load_bdf_font): Set fontp->average_width and
- fontp->space_width to FONT_WIDTH so they are valid.
-
- * w32fns.c (w32_load_system_font): Set FONT_WIDTH to maximum, not
- average width. Set fontp->average_width and fontp->space_width to
- their appropriate values.
-
- * w32term.c (x_new_font): Set FRAME_COLUMN_WIDTH to
- fontp->average_width, not FONT_WIDTH. Set FRAME_SPACE_WIDTH to
- fontp->space_width.
-
-2005-01-03 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (x_new_font): Set FRAME_SPACE_WIDTH.
- (x_font_min_bounds, XLoadQueryFont): Use the correct font width
- metrics for max and min bounds.
- (x_load_font): Correctly calculate average font width metrics.
-
-2005-01-02 Richard M. Stallman <[email protected]>
-
- * alloc.c (Fgarbage_collect): Don't truncate_undo_list on dead buffers.
-
-2004-12-31 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): Clear area in expose event for GTK.
-
-2004-12-31 Richard M. Stallman <[email protected]>
-
- * xdisp.c (setup_for_ellipsis, get_next_display_element):
- Set it->ellipsis_p to 1 or 0.
- (display_line): Record whether row ends in mid-ellipsis.
- (set_cursor_from_row): If ends in ellipsis, find start of it.
- (cursor_row_p): If PT's at the end of the ellipsis the row
- ends within, don't display cursor on this row.
-
- * dispextern.h (struct it): New element ellipsis_p.
- (struct glyph_row): New element ends_in_ellipsis_p.
-
- * xdisp.c (BUFFER_POS_REACHED_P): We haven't reached the specified
- position if we're reading from something other than the buffer.
-
- * window.c (window_scroll_pixel_based): Only look at
- Vscroll_preserve_screen_position if the old PT can't be kept.
- (syms_of_window) <scroll-preserve-screen-position>: Doc fix.
-
-2004-12-30 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_line_height_property): New function extracted from
- original calc_line_height_property.
- (calc_line_height_property): Rework. Handle t and (nil . ratio).
- (x_produce_glyphs): Use them to handle line-height and
- line-spacing according to new height spec.
- (Qtotal): Remove.
- (syms_of_xdisp): Remove intern and staticpro for Qtotal.
-
-2004-12-30 Kenichi Handa <[email protected]>
-
- * fileio.c (Finsert_file_contents): Don't use
- current_buffer->buffer_file_coding_system even if REPLACE is
- non-nil. Call Qafter_insert_file_set_coding with the second arg VISIT.
-
- * fontset.h (struct font_info): New members space_width and
- average_width.
-
- * frame.h (struct frame): New member space_width.
- (FRAME_SPACE_WIDTH): New macro.
-
- * xterm.h (struct x_display_info): New member Xatom_AVERAGE_WIDTH.
-
- * xterm.c (x_new_font): Set FRAME_COLUMN_WIDTH to
- fontp->average_width, not FONT_WIDTH. Set FRAME_SPACE_WIDTH to
- fontp->space_width.
- (x_load_font): Calculate fontp->space_width and fontp->average_width.
- (x_term_init): Initialize dpyinfo->Xatom_AVERAGE_WIDTH.
-
- * xdisp.c (x_produce_glyphs): Calculate tab width by
- FRAME_SPACE_WIDTH, not FRAME_COLUMN_WIDTH.
-
-2004-12-29 Sanghyuk Suh <[email protected]>
-
- * macterm.c (SelectionRange): Add Xcode position apple event struct.
- (do_ae_open_documents): Handle Xcode-style file position open events.
-
-2004-12-29 Luc Teirlinck <[email protected]>
-
- * buffer.c (syms_of_buffer) <vertical-scroll-bar>: Correct typo.
-
-2004-12-29 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer) <vertical-scroll-bar>: Doc fix.
-
-2004-12-29 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (install_window_handler): Modify extern to return OSErr
- value.
- (mac_window): Handle return value of install_window_handler.
-
- * macterm.c (reflect_byte): Remove function.
- (mac_create_bitmap_from_bitmap_data): Don't call reflect_byte.
- Lookup table instead.
- (mac_do_font_lists): Simplify calculation of the longest
- nonspecial string.
- (init_mac_drag_n_drop): Remove function and declaration.
- (mac_initialize) [TARGET_API_MAC_CARBON]: Don't call
- init_mac_drag_n_drop.
- (mac_do_track_drag): New function and declaration.
- (install_window_handler): Return OSErr value.
- (install_window_handler) [TARGET_API_MAC_CARBON]:
- Register handlers for tracking/receiving drag-and-drop items.
- (do_ae_open_documents): Generate unibyte strings for filenames.
- (mac_do_receive_drag) [TARGET_API_MAC_CARBON]: Likewise.
- Reject only non-filename items. Set event modifiers, and return value.
-
-2004-12-28 Dan Nicolaescu <[email protected]>
-
- * coding.c (decode_coding): Fix previous change.
-
-2004-12-28 Richard M. Stallman <[email protected]>
-
- * xdisp.c (back_to_previous_visible_line_start):
- Don't call handle_display_prop.
-
-2004-12-28 Dan Nicolaescu <[email protected]>
-
- * coding.c (decode_coding_XXX, decode_composition_emacs_mule)
- (decode_coding_emacs_mule, encode_coding_emacs_mule)
- (decode_coding_iso2022, encode_designation_at_bol)
- (encode_coding_iso2022, decode_coding_sjis_big5, decode_eol)
- (decode_coding): Constify arguments and local vars.
-
-2004-12-27 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (popup_get_selection): Only pop down dialogs
- on C-g and Escape.
- (popup_get_selection): Remove parameter down_on_keypress.
- (create_and_show_popup_menu, create_and_show_dialog):
- Remove parameter down_on_keypress to popup_get_selection.
-
-2004-12-27 YAMAMOTO Mitsuharu <[email protected]>
-
- * dispextern.h: Change HAVE_CARBON to MAC_OS.
- (struct glyph_string): Likewise.
-
- * emacs.c (main) [MAC_OS8]: Call mac_term_init instead of
- mac_initialize.
-
- * fileio.c (Fnext_read_file_uses_dialog_p, Fread_file_name):
- Change TARGET_API_MAC_CARBON to HAVE_CARBON.
-
- * fns.c (vector): Change MAC_OSX to MAC_OS.
-
- * frame.c (x_set_frame_parameters, x_report_frame_params)
- (x_set_fullscreen): Remove #ifndef HAVE_CARBON.
- (x_set_border_width, Vdefault_frame_scroll_bars):
- Change HAVE_CARBON to MAC_OS.
-
- * image.c [MAC_OS]: Include sys/stat.h.
- [MAC_OS && !MAC_OSX]: Include sys/param.h, ImageCompression.h, and
- QuickTimeComponents.h.
-
- * mac.c [!MAC_OSX] (mac_wait_next_event): Add extern.
- [!MAC_OSX] (select): Use mac_wait_next_event.
- [!MAC_OSX] (run_mac_command): Change EXEC_SUFFIXES to Vexec_suffixes.
- [!MAC_OSX] (select, run_mac_command): Change `#ifdef
- TARGET_API_MAC_CARBON' to `#if TARGET_API_MAC_CARBON'.
- (mac_clear_font_name_table): Add extern.
- (Fmac_clear_font_name_table): New defun.
- (syms_of_mac): Defsubr it.
- [MAC_OSX] (SELECT_POLLING_PERIOD_USEC): New define.
- [MAC_OSX] (select_and_poll_event): New function.
- [MAC_OSX] (sys_select): Use it.
- [MAC_OSX && SELECT_USE_CFSOCKET] (socket_callback): New function.
- [MAC_OSX && SELECT_USE_CFSOCKET]
- (SELECT_TIMEOUT_THRESHOLD_RUNLOOP, EVENT_CLASS_SOCK): New defines.
- [MAC_OSX] (sys_select) [SELECT_USE_CFSOCKET]: Use CFSocket and
- RunLoop for simultaneously monitoring two kinds of inputs, window
- events and process outputs, without periodically polling.
-
- * macfns.c (mac_initialized): Remove extern.
- (stricmp): Put in #if 0. All callers changed to use xstricmp in
- xfaces.c.
- (strnicmp): Decrement `n' at the end of each loop, not the beginning.
- (check_mac): Use the term "Mac native windows" instead of "Mac OS".
- (check_x_display_info, x_display_info_for_name): Sync with xfns.c.
- (mac_get_rdb_resource): New function (from w32reg.c).
- (x_get_string_resource): Use it.
- (install_window_handler): Add extern.
- (mac_window): New function.
- (Fx_create_frame): Use it instead of make_mac_frame.
- Set parameter for Qfullscreen. Call x_wm_set_size_hint.
- (Fx_open_connection, Fx_close_connection): New defuns.
- (syms_of_macfns): Defsubr them.
- (x_create_tip_frame) [TARGET_API_MAC_CARBON]:
- Add kWindowNoUpdatesAttribute to the window attribute.
- (x_create_tip_frame) [!TARGET_API_MAC_CARBON]: Use NewCWindow.
- (x_create_tip_frame): Don't call ShowWindow.
- (Fx_show_tip): Call ShowWindow.
- (Fx_file_dialog): Change `#ifdef TARGET_API_MAC_CARBON' to `#if
- TARGET_API_MAC_CARBON'.
- (mac_frame_parm_handlers): Set handlers for Qfullscreen.
- (syms_of_macfns) [MAC_OSX]: Initialize mac_in_use to 0.
-
- * macgui.h [!MAC_OSX]: Don't include Controls.h. Include Windows.h.
- (Window): Typedef to WindowPtr and move outside `#if
- TARGET_API_MAC_CARBON'.
- (XSizeHints): New struct.
-
- * macterm.c (x_update_begin, x_update_end)
- [TARGET_API_MAC_CARBON]: Disable screen updates during update of a
- frame.
- (x_draw_glyph_string_background, x_draw_glyph_string_foreground)
- [MAC_OS8]: Use XDrawImageString/XDrawImageString16.
- (construct_mouse_click): Put in #if 0.
- (x_check_fullscreen, x_check_fullscreen_move): Remove decls.
- (x_scroll_bar_create, x_scroll_bar_handle_click): Change `#ifdef
- TARGET_API_MAC_CARBON' to `#if TARGET_API_MAC_CARBON'.
- (activate_scroll_bars, deactivate_scroll_bars)
- [!TARGET_API_MAC_CARBON]: Use ActivateControl/DeactivateControl.
- (x_make_frame_visible) [TARGET_API_MAC_CARBON]: Reposition window
- if the position is neither user-specified nor program-specified.
- (x_free_frame_resources): Free size_hints.
- (x_wm_set_size_hint): Allocate size_hints if needed. Set size_hints.
- (mac_clear_font_name_table): New function.
- (mac_do_list_fonts): Initialize font_name_table if needed.
- (x_list_fonts): Don't initialize font_name_table. Add BLOCK_INPUT
- around mac_do_list_fonts.
- (mac_unload_font): New function.
- (x_load_font): Add BLOCK_INPUT around XLoadQueryFont.
- (init_mac_drag_n_drop, mac_do_receive_drag): Enclose declarations
- and definitions with #if TARGET_API_MAC_CARBON.
- [USE_CARBON_EVENTS] (mac_handle_window_event): Add decl.
- (install_window_handler): Add decl.
- (do_window_update): Add BeginUpdate/EndUpdate for the tooltip
- window. Use UpdateControls. Get the rectangle that should be
- updated and restrict the target of expose_frame to it.
- (do_grow_window): Set minimum height/width according to size_hints.
- (do_grow_window) [TARGET_API_MAC_CARBON]: Use ResizeWindow.
- (do_zoom_window): Don't use x_set_window_size.
- [USE_CARBON_EVENTS] (mac_handle_window_event): New function.
- (install_window_handler): New function.
- [!USE_CARBON_EVENTS] (mouse_region): New variable.
- [!USE_CARBON_EVENTS] (mac_wait_next_event): New function.
- (XTread_socket) [USE_CARBON_EVENTS]: Move call to
- GetEventDispatcherTarget inside BLOCK_INPUT.
- (XTread_socket) [!USE_CARBON_EVENTS]: Use mac_wait_next_event.
- Update mouse_region when mouse is moved.
- (make_mac_frame): Remove.
- (make_mac_terminal_frame): Put in #ifdef MAC_OS8.
- Initialize mouse pointer shapes. Change values of f->left_pos and
- f->top_pos. Don't use make_mac_frame. Use NewCWindow.
- Don't call ShowWindow.
- (mac_initialize_display_info) [MAC_OSX]: Create mac_id_name from
- Vinvocation_name and Vsystem_name.
- (mac_make_rdb): New function (from w32term.c).
- (mac_term_init): Use it. Add BLOCK_INPUT. Error if display has
- already been opened. Don't pass argument to
- mac_initialize_display_info. Don't set dpyinfo->height/width.
- Add entries to x_display_list and x_display_name_list.
- (x_delete_display): New function.
- (mac_initialize): Don't call mac_initialize_display_info.
- (syms_of_macterm) [!MAC_OSX]: Don't call Fprovide.
-
- * macterm.h (check_mac): Add extern.
- (struct mac_output): New member size_hints.
- (FRAME_SIZE_HINTS): New macro.
- (mac_unload_font): Add extern.
-
- * xdisp.c (expose_window, expose_frame): Remove kludges for Mac.
-
- * xfaces.c (clear_font_table) [MAC_OS]: Call mac_unload_font.
-
-2004-12-27 Richard M. Stallman <[email protected]>
-
- * buffer.c (Fbuffer_disable_undo): Delete (move to simple.el).
- (syms_of_buffer): Don't defsubr it.
-
- * process.c (list_processes_1): Set undo_list instead
- of calling Fbuffer_disable_undo.
-
- * xdisp.c (single_display_spec_string_p): Rename from
- single_display_prop_string_p.
- (single_display_spec_intangible_p): Rename from
- single_display_prop_intangible_p.
- (handle_single_display_spec): Rename from handle_single_display_prop.
- Rewritten to be easier to understand.
-
- Change in load-history format. Functions now get (defun . NAME),
- and variables get just NAME.
-
- * data.c (Fdefalias): Use (defun . FN_NAME) in LOADHIST_ATTACH.
-
- * eval.c (Fdefun, Fdefmacro): Use (defun . FN_NAME) in LOADHIST_ATTACH.
- (Fdefvaralias, Fdefvar, Fdefconst): Use just SYM in LOADHIST_ATTACH.
- (Qdefvar): Var deleted.
- (syms_of_eval): Don't initialze it.
-
- * lread.c (syms_of_lread) <load-history>: Doc fix.
-
-2004-12-27 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (popup_get_selection): Pop down on C-g.
- (set_frame_menubar): Install translations for Lucid/Motif/Lesstif that
- pops down menu on C-g.
- (xdialog_show): If dialog popped down and no button in the dialog was
- pushed, call Fsignal to quit.
- (xmenu_show): In no toolkit version, if menu returns NO_SELECT call
- Fsignal to quit.
-
- * xfns.c (Fx_file_dialog): Motif/Lesstif version: Pop down on C-g.
-
- * gtkutil.c (xg_initialize): Install bindings for C-g so that
- dialogs and menus pop down.
-
-2004-12-27 Kenichi Handa <[email protected]>
-
- * coding.c (code_convert_region): Fix calculation of `ratio'.
-
-2004-12-25 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): Make the value of
- tool-bar-button-margin control margins of images in tool bar.
-
- * alloc.c (check_depth): New variable.
- (overrun_check_malloc, overrun_check_realloc): Only add
- overhead and write check pattern if check_depth is 1 (to handle
- recursive calls). Increase/decrease check_depth in entry/exit.
- (overrun_check_free): Only check for overhead if check_depth is 1.
- Increase/decrease check_depth in entry/exit.
-
-2004-12-23 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c (input_available_signal): Call SIGNAL_THREAD_CHECK
- before touching input_available_clear_time, to avoid accessing it
- from multiple threads.
-
-2004-12-23 Jason Rumney <[email protected]>
-
- * image.c (__WIN32__) [HAVE_NTGUI]: Define for correct behaviour
- of JPEG library.
-
-2004-12-22 Richard M. Stallman <[email protected]>
-
- * emacs.c (main): If batch mode, set Vundo_outer_limit to nil.
-
- * lisp.h (Vundo_outer_limit): Fix decl.
-
- * undo.c (Vundo_outer_limit): Replaces undo_outer_limit.
- Uses changed.
- (syms_of_undo): Initialize appropriately.
- (truncate_undo_list): If it's nil, there's no limit.
-
-2004-12-22 Kenichi Handa <[email protected]>
-
- * xselect.c (Fx_get_cut_buffer_internal): Return a unibyte string.
-
-2004-12-21 Richard M. Stallman <[email protected]>
-
- * eval.c (unwind_to_catch): Clear immediate_quit.
-
- * xdisp.c (get_next_display_element): Display codes 8a0 and 8ad
- specially as `\ ' and `\-'.
-
- * keyboard.c (kbd_buffer_store_event_hold):
- In the code for while-no-input, handle immediate_quit.
-
- * alloc.c (Fgarbage_collect): Update call to truncate_undo_list.
- Call that at the very start.
- (undo_limit, undo_strong_limit, undo_outer_limit): Move to undo.c.
- (syms_of_alloc): Don't define undo-limit,
- undo-strong-limit and undo-outer-limit here.
-
- * undo.c (truncate_undo_list): Return void.
- Take just one argument, the buffer.
- Make it current, and inhibit recursive GC.
- Access and update the undo list directly; return void.
- Refer to the undo...limit variables directly.
- Test undo_outer_limit only after counting the whole current command.
- When it's exceeded, call the function in undo-outer-limit-function.
- (undo_limit, undo_strong_limit, undo_outer_limit): From alloc.c.
- (Vundo_outer_limit_function): New variable.
- (syms_of_undo): Define undo-limit, undo-strong-limit
- and undo-outer-limit here, and undo-outer-limit-function.
- Doc fixes.
-
- * lisp.h (truncate_undo_list): Update decl.
-
-2004-12-21 Piet van Oostrum <[email protected]>
-
- * fileio.c (Fread_file_name): Delete duplicates in
- file-name-history when history_delete_duplicates is true.
-
-2004-12-20 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_do_list_fonts): Fix memory leak.
-
-2004-12-20 Richard M. Stallman <[email protected]>
-
- * regex.c (re_match_2_internal) <symend, wordend>:
- Fix calls to UPDATE_SYNTAX_TABLE_FORWARD.
-
-2004-12-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (endif, x_font_name_to_mac_font_name):
- Use maccentraleurroman instead of maccentraleuropean
- (mac_c_string_match, mac_do_list_fonts): Speed up font search by
- quickly finding a specific font without needing regexps.
-
-2004-12-15 Jan Dj,Ad(Brv <[email protected]>
-
- * syssignal.h: Declare main_thread.
- (SIGNAL_THREAD_CHECK): New macro.
-
- * keyboard.c (input_available_signal): Move thread checking code
- to macro SIGNAL_THREAD_CHECK and call that macro.
- (interrupt_signal): Call SIGNAL_THREAD_CHECK.
-
- * alloc.c (uninterrupt_malloc): Move main_thread to emacs.c.
-
- * emacs.c: Define main_thread.
- (main): Initialize main_thread.
- (handle_USR1_signal, handle_USR2_signal, fatal_error_signal)
- (memory_warning_signal): Call SIGNAL_THREAD_CHECK.
-
- * floatfns.c (float_error): Call SIGNAL_THREAD_CHECK.
-
- * dispnew.c (window_change_signal): Call SIGNAL_THREAD_CHECK.
-
- * sysdep.c (select_alarm): Call SIGNAL_THREAD_CHECK.
-
- * process.c (send_process_trap, sigchld_handler):
- Call SIGNAL_THREAD_CHECK.
-
- * data.c (arith_error): Call SIGNAL_THREAD_CHECK.
-
- * atimer.c (alarm_signal_handler): Call SIGNAL_THREAD_CHECK.
-
- * xterm.c (xg_scroll_callback): Update XG_LAST_SB_DATA before
- returning when xg_ignore_gtk_scrollbar is true.
-
-2004-12-14 Kim F. Storm <[email protected]>
-
- * keyboard.c (read_char): Save and restore echo_string when
- handling input method.
-
-2004-12-13 Richard M. Stallman <[email protected]>
-
- * eval.c (syms_of_eval) <quit-flag>: Doc fix.
-
- * keyboard.c (Vthrow_on_input): New variable.
- (syms_of_keyboard): Defvar and initialize it.
- (kbd_buffer_store_event_hold): Handle Vthrow_on_input.
-
- * lisp.h (QUIT): Check for Vthrow_on_input.
- (Vthrow_on_input): Declare it.
-
-2004-12-13 Kim F. Storm <[email protected]>
-
- * xdisp.c (set_iterator_to_next): Reset stop_charpos after display
- vector.
-
-2004-12-12 Richard M. Stallman <[email protected]>
-
- * indent.c (Fvertical_motion): Call move_it_by_lines even if LINES = 0.
-
- * minibuf.c (Fall_completions): Add var `zero' and use it in loop.
- (Ftry_completion): Really use outer `zero'; eliminate inner one.
-
-2004-12-12 Kenichi Handa <[email protected]>
-
- * term.c (encode_terminal_code): Fix previous change.
-
-2004-12-11 Stefan Monnier <[email protected]>
-
- * keyboard.c (handle_async_input): Remove pthread mutex handling.
- (input_available_signal): Move pthread thingy to !SYNC_INPUT branch.
-
- * syntax.c (Fforward_word): Avoid non-idempotent side-effects
- in macro arguments.
-
- * minibuf.c (Ftry_completion, Fall_completions): Don't use
- XFASTINT blindly.
-
- * emacs.c (main, Fdump_emacs): Don't touch malloc hooks if SYNC_INPUT.
-
-2004-12-11 Jan Dj,Ad(Brv <[email protected]>
-
- * w32term.c (x_calc_absolute_position): Remove calculation of
- difference between inner and outer window. Don't subtract difference
- for left and top calculations.
-
- * xterm.c (x_calc_absolute_position): Don't subtract outer_pixel_diff
- for left and top calculations. Remove call to x_real_positions.
- [Bug report by Drew Adams in November.]
- (x_check_expected_move): Do not set change_gravity to 1 when calling
- x_set_offset.
-
-2004-12-08 Richard M. Stallman <[email protected]>
-
- * xdisp.c (get_next_display_element): Use `escape-glyph' for
- control chars and escaped octal codes.
- (Qescape_glyph): New variable.
- (syms_of_xdisp): Initialize it.
- (escape_glyph_face): New variable.
- (redisplay_window): Initialize it.
-
-2004-12-07 Paul Eggert <[email protected]>
-
- * image.c (our_fill_input_buffer, jpeg_load, CHECK_LIB_AVAILABLE)
- (init_image): Use 1 rather than TRUE. TRUE's not always defined.
-
-2004-12-07 Jan Dj,Ad(Brv <[email protected]>
-
- * emacs.c (Fdump_emacs): Add ! defined (SYSTEM_MALLOC) around
- reset_malloc_hooks.
-
- * keyboard.c (handle_async_input, input_available_signal):
- Add ! defined (SYSTEM_MALLOC) around thread code.
-
- * alloc.c: Add comment about the reason for (UN)BLOCK_INPUT_ALLOC.
-
-2004-12-07 Stefan Monnier <[email protected]>
-
- * eval.c (init_eval_once): Increase max_specpdl_size to 1000.
-
- * config.in: Regenerate.
-
-2004-12-07 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (Fx_popup_menu): Correct documentation about position.
- (xmenu_show): Do not call XTranslateCoordinates. Adjust position
- if not given by a mouse click to correspond with x-popup-menu
- documentation.
-
- * config.in: Regenerate.
-
- * gtkutil.c: Include signal.h and syssignal.h.
- (xg_get_file_name): Block and unblock __SIGRTMIN if defined.
-
- * alloc.c: If HAVE_GTK_AND_PTHREAD, include pthread.h,
- new variables main_thread and alloc_mutex,
- define (UN)BLOCK_INPUT_ALLOC to use alloc_mutex to protect
- emacs_blocked_* calls and only do (UN)BLOCK_INPUT in the main thread.
- If not HAVE_GTK_AND_PTHREAD, (UN)BLOCK_INPUT_ALLOC is the same
- as (UN)BLOCK_INPUT.
- (emacs_blocked_free, emacs_blocked_malloc)
- (emacs_blocked_realloc): Use (UN)BLOCK_INPUT_ALLOC.
- (uninterrupt_malloc): Initialize main_thread and alloc_mutex.
- (reset_malloc_hooks): New function.
-
- * lisp.h: Declare reset_malloc_hooks.
-
- * emacs.c (Fdump_emacs): Call reset_malloc_hooks.
-
- * keyboard.c: Conditionally include pthread.h.
- (handle_async_input, input_available_signalt): If not in the main
- thread, block signal, send signal to main thread and return.
-
- * gtkutil.c (xg_get_file_with_chooser): Handle local files only.
- Set current folder in file chooser if default_filename is a directory.
-
-2004-12-05 Stefan Monnier <[email protected]>
-
- * regex.c (GET_UNSIGNED_NUMBER): Signal an error when reaching the end.
- Remove redundant correctness checks.
- (regex_compile): Fix up error codes for \{..\} expressions.
-
-2004-12-05 Richard M. Stallman <[email protected]>
-
- * regex.c (regex_compile): Fix end-of-pattern case for space.
-
-2004-12-03 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.h (cfstring_create_with_utf8_cstring): Add prototype.
- * mac.c (cfstring_create_with_utf8_cstring): Add to prevent
- crashes with invalid characters.
- * macmenu.c (add_menu_item): Use it.
- * image.c (image_load_quartz2d): Likewise.
- * macfns.c (x_set_name, x_set_title): Likewise.
- (Fx_file_dialog): Likewise. Use constant CFRefs instead of
- creating them each time for labels.
-
-2004-12-02 Richard M. Stallman <[email protected]>
-
- * config.in (RE_TRANSLATE_P): If make_number is not a macro,
- don't use it here.
-
- * eval.c (Fcalled_interactively_p): Don't check INTERACTIVE.
- (interactive_p): Skip Scalled_interactively_p frames
- like Sinteractive_p frames.
- (unwind_to_catch): Clear handling_signal.
-
- * data.c (Fmake_variable_buffer_local): Doc fix.
- (Fmake_local_variable): Doc fix.
-
- * insdel.c (insert_from_string_before_markers)
- (insert_from_string): Don't modify buffer on empty insertion.
-
- * window.c (Fget_lru_window, Fget_largest_window): Doc fixes.
-
-2004-12-01 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (add_menu_item): Fallback on MacRoman if encoding
- menu text as UTF8 fails.
-
-2004-12-01 Kim F. Storm <[email protected]>
-
- * alloc.c: Add commentary for last change.
- (XMALLOC_PUT_SIZE, XMALLOC_GET_SIZE): New macros to handle
- sizeof(size_t) != 4.
- (overrun_check_malloc, overrun_check_realloc, overrun_check_free):
- Use them. Also clear header and trailer of freed memory.
- (GC_STRING_OVERRUN_COOKIE_SIZE): Rename from GC_STRING_EXTRA.
- (string_overrun_cookie): Rename from string_overrun_pattern.
- (GC_STRING_EXTRA): Define from GC_STRING_OVERRUN_COOKIE_SIZE.
-
-2004-12-01 Andreas Schwab <[email protected]>
-
- * lisp.h: Declare string_to_multibyte.
-
-2004-12-01 Kenichi Handa <[email protected]>
-
- * w32console.c (w32con_write_glyphs): Decide coding here.
- Adjusted for the change of encode_terminal_code.
-
- * term.c (encode_terminal_code): Don't make it "static".
-
-2004-11-30 Kenichi Handa <[email protected]>
-
- * term.c (encode_terminal_buf, encode_terminal_bufsize): New variables.
- (encode_terminal_code): Argument changed. Encode all
- characters at once, and return a pointer to the result of encoding.
- (write_glyphs): Decide coding here. Adjusted for the above change.
- (insert_glyphs): Likewise.
- (term_init): Initialize encode_terminal_bufsize to 0.
-
- * coding.c (Vcode_conversion_workbuf_name): New variable.
- (syms_of_coding): Initialize and staticpro it.
- (set_conversion_work_buffer): New function.
- (run_pre_post_conversion_on_str): Use it.
- (run_pre_write_conversin_on_c_str): New function.
-
- * coding.h (run_pre_write_conversin_on_c_str): Extern it.
-
-2004-11-30 YAMAMOTO Mitsuharu <[email protected]>
-
- * keyboard.c: Don't undef SIGIO
- * s/darwin.h (NO_SOCK_SIGIO): Define NO_SOCK_SIGIO on carbon
- * Makefile.in (mac.o): Depend on blockinput.h and atimer.h.
- (macfns.o): Don't depend on ccl.h.
- * macfns.c (mac_frame_parm_handlers): Set handlers for
- Qleft_fringe and Qright_fringe.
- * macterm.c (mac_fill_rectangle_to_pixmap)
- (mac_draw_rectangle_to_pixmap, mac_copy_area_to_pixmap)
- (mac_copy_area_with_mask_to_pixmap, x_draw_image_foreground_1):
- Put in #if 0.
- (mac_scroll_area) [TARGET_API_MAC_CARBON]: Use ScrollWindowRect.
- (x_flush) [TARGET_API_MAC_CARBON]: Don't traverse frames.
- (XFlush) [TARGET_API_MAC_CARBON]: Define to an empty replacement.
- (x_draw_glyph_string_background, x_draw_glyph_string_foreground)
- [!MAC_OS8]: Added ifdef'd out code for os8. Don't use
- XDrawImageString. Always draw background and foreground separately.
- (x_draw_image_foreground): Use clipping instead of computing the
- intersection rectangle.
- (x_draw_image_glyph_string): Don't draw an image with mask to a
- pixmap.
- (x_redisplay_interface): Set flush_display_optional member to 0.
- (XTread_socket): Correctly reset the TEConverter
- object.
-
-2004-11-30 Kim F. Storm <[email protected]>
-
- * lisp.h: New defines to enable buffer overrun checking.
- (GC_CHECK_STRING_OVERRUN, GC_CHECK_STRING_FREE_LIST)
- (XMALLOC_OVERRUN_CHECK, GC_CHECK_CONS_LIST): Add.
-
- * alloc.c: Add more checks for buffer overruns.
- (XMALLOC_OVERRUN_CHECK_SIZE, xmalloc_overrun_check_header)
- xmalloc_overrun_check_trailer, overrun_check_malloc)
- overrun_check_realloc, overrun_check_free): Add.
- (GC_STRING_EXTRA, string_overrun_pattern): Add.
- (check_sblock, allocate_string_data, compact_small_strings):
- Set and check string_overrun_pattern if GC_CHECK_STRING_OVERRUN.
- (check_cons_list): Condition on GC_CHECK_CONS_LIST.
- (check_string_free_list): Add.
- (allocate_string, sweep_strings): Call check_string_free_list.
-
- * emacs.c (malloc_initialize_hook): Don't free malloc_state_ptr if
- XMALLOC_OVERRUN_CHECK to avoid crash during load.
-
-2004-11-29 Kim F. Storm <[email protected]>
-
- * fns.c (concat): Use SAFE_ALLOCA.
-
-2004-11-29 Stefan Monnier <[email protected]>
-
- * sysdep.c (emacs_write): Don't use QUIT.
-
-2004-11-29 Kenichi Handa <[email protected]>
-
- * buffer.c (init_buffer): Set current_buffer->directory to a
- multibyte string made by string_to_multibyte.
-
- * emacs.c (init_cmdargs): Set unibyte strings in Vcommand_line_args.
-
-2004-11-27 Andreas Schwab <[email protected]>
-
- * alloc.c (mark_stack): Call GC_MARK_SECONDARY_STACK if defined.
-
- * s/gnu-linux.h: Enable no-op gcpros on ia64.
- (GC_MARK_SECONDARY_STACK) [__ia64__]: Define.
-
- * filelock.c (lock_file_1): Call get_boot_time early.
- Increase buffer size.
-
-2004-11-27 Eli Zaretskii <[email protected]>
-
- * lisp.h (DECL_ALIGN): Define non-trivially only if NO_DECL_ALIGN
- is not defined.
-
-2004-11-27 Kim F. Storm <[email protected]>
-
- * search.c (syms_of_search) <search-spaces-regexp>: Move 'doc:'
- marker out of doc string.
-
-2004-11-26 Stefan Monnier <[email protected]>
-
- * s/darwin.h (POSIX_SIGNALS): Undo the removal of 2002-08-25,
- which was not mentioned in the log.
-
-2004-11-26 Kim F. Storm <[email protected]>
-
- * fringe.c (update_window_fringes): Prefer truncation bitmaps over
- angle bitmaps at top/bottom line.
-
- * xdisp.c: Undo recent changes for restoring saved_face_id. Instead,
- set it when it->method is set to next_element_from_display_vector.
- (setup_for_ellipsis): Add LEN argument. Callers changed.
- Set it->saved_face_id.
- (get_next_display_element): Use loop instead of recursion.
- Set it->saved_face_id. Combine duplicate code for ctr chars.
- (next_element_from_display_vector): Do not set it->saved_face_id.
- (next_element_from_ellipsis): Use setup_for_ellipsis.
-
-2004-11-26 Eli Zaretskii <[email protected]>
-
- * eval.c (Fdefvar): Declare pdl from last change as `volatile' to
- prevent compiler warnings.
-
-2004-11-25 Stefan Monnier <[email protected]>
-
- * keyboard.c (command_loop_1): Print a message describing the key
- the user just pressed when this key has no binding.
-
- * sysdep.c (sys_signal): Don't use SA_RESTART if SYNC_INPUT is set.
- (emacs_open, emacs_read, emacs_write): Check QUIT when interrupted.
-
- * lread.c (readchar): Check QUIT when `getc' is interrupted.
-
-2004-11-24 Richard M. Stallman <[email protected]>
-
- * coding.c (run_pre_post_conversion_on_str): Bind Qinhibit_read_only.
-
- * buffer.c (syms_of_buffer) <indicate-buffer-boundaries>: Doc fix.
-
-2004-11-24 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_in_display_line_to, display_line):
- Restore saved_face_id also when truncate-lines or hscrolled.
-
-2004-11-23 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_file_name): Rename use-old-gtk-file-dialog to
- x-use-old-gtk-file-dialog.
-
- * xfns.c: Define x_use_old_gtk_file_dialog.
- (syms_of_xfns): Rename use-old-gtk-file-dialog to x-... Move it
- outside ifdef USE_GTK.
-
-2004-11-23 Stefan Monnier <[email protected]>
-
- * coding.h (ENCODE_FILE, DECODE_FILE, ENCODE_SYSTEM, DECODE_SYSTEM):
- Don't use XFASTINT blindly.
-
- * config.in (RE_TRANSLATE_P): Don't use XFASTINT blindly.
-
- * indent.c (skip_invisible): Avoid non-idempotent side-effects
- in macro arguments.
-
- * keymap.c (Flookup_key): Check INTEGERP before XINT.
-
- * lread.c (oblookup): Don't use XFASTINT blindly.
-
- * window.c (Fset_window_scroll_bars): Don't use XINT if it isn't int.
- (decode_next_window_args, window_loop): Don't use XFASTINT blindly.
-
-2004-11-23 Kim F. Storm <[email protected]>
-
- * dispextern.h (MATRIX_ROW_ENDS_IN_MIDDLE_OF_CHAR_P)
- (MATRIX_ROW_STARTS_IN_MIDDLE_OF_CHAR_P): Not if dpvec_index is zero.
-
- * xfaces.c (lookup_named_face): Add signal_p arg. Return -1 if
- signal_p is zero and face name is unknown.
- (Fx_list_fonts): Don't signal error in lookup_named_face.
- (Fface_font): Signal error in lookup_named_face.
- (ascii_face_of_lisp_face): Likewise.
-
- * dispextern.h (lookup_named_face): Fix prototype.
-
- * xdisp.c (handle_single_display_prop): Don't signal error in
- lookup_named_face for unknown fringe face name.
- (highlight_trailing_whitespace): Don't signal error in
- lookup_named_face if trailing-whitespace face unknown.
- (calc_line_height_property): Don't signal error in
- lookup_named_face if specified face name is unknown.
-
- * fringe.c (update_window_fringes): Show top row indicator if
- window has header-line. Don't show arrow at bob and eob
- if the boundary indicators are not used.
- (Fset_fringe_bitmap_face): Signal error in lookup_named_face.
-
- * window.c (set_window_buffer): Clear display_error_modiff.
-
-2004-11-22 Kim F. Storm <[email protected]>
-
- * fringe.c (update_window_fringes): Provide sensible fall-back
- value for non-nil indicate-buffer-boundaries setting.
-
-2004-11-22 Markus Rost <[email protected]>
-
- * minibuf.c (Fminibuffer_complete_and_exit): Fix previous change.
-
-2004-11-22 Stefan Monnier <[email protected]>
-
- * eval.c (Fdefvar): Warn when var is let-bound but globally void.
-
-2004-11-21 Kim F. Storm <[email protected]>
-
- * xdisp.c (erase_phys_cursor): Clear hollow cursor inside TEXT_AREA.
-
- * xterm.c (x_clip_to_row): Add area arg. Callers changed.
- (x_draw_hollow_cursor, x_draw_bar_cursor): Clip to TEXT_AREA.
-
- * w32term.c (w32_clip_to_row): Add area arg. Callers changed.
- (x_draw_hollow_cursor, x_draw_bar_cursor): Clip to TEXT_AREA.
-
- * macterm.c (x_clip_to_row): Add area arg. Callers changed.
- (x_draw_hollow_cursor, x_draw_bar_cursor): Clip to TEXT_AREA.
-
- * xdisp.c (move_it_in_display_line_to, display_line):
- Restore saved_face_id if overflow-newline-into-fringe is enabled and
- line is continued before or in middle of element from display vector.
-
- * indent.c (Fvertical_motion): Fix last change. Use another
- method to detect if iterator moved too far ahead after reseat.
-
- * xdisp.c (IT_EXPAND_MATRIX_WIDTH): New macro. Do not
- expand matrix width for overflow in zero-width area.
- (append_glyph, append_composite_glyph, produce_image_glyph)
- (append_stretch_glyph): Use it to avoid loop in redisplay.
- (note_mode_line_or_margin_highlight): Don't let help-echo from
- string override help-echo from image map.
-
-2004-11-20 Luc Teirlinck <[email protected]>
-
- * fns.c (Fyes_or_no_p): Call Fread_from_minibuffer with extra argument.
- * callint.c (Fcall_interactively): Ditto.
-
-2004-11-20 Stefan Monnier <[email protected]>
-
- * minibuf.c (Fminibuffer_complete_and_exit):
- Fixup the case of the completed value, for case-indep completion.
-
-2004-11-20 Richard M. Stallman <[email protected]>
-
- * lisp.h (Fread_from_minibuffer): Add arg in decl.
-
- * minibuf.c (read_minibuf): New arg KEEP_ALL. Callers changed.
- (Fread_from_minibuffer): New arg KEEP_ALL. Callers changed.
-
- * search.c (Vsearch_spaces_regexp):
- Rename from Vsearch_whitespace_regexp. All uses changed.
-
-2004-11-20 Thien-Thi Nguyen <[email protected]>
-
- * eval.c (init_eval_once): Increase `max_specpdl_size' to 650.
-
-2004-11-19 Richard M. Stallman <[email protected]>
-
- * search.c (Vsearch_whitespace_regexp): New variable.
- (syms_of_search): Defvar it.
- (compile_pattern_1): Call re_set_whitespace_regexp with it.
- (search_buffer): No regexp is trivial if Vsearch_whitespace_regexp
- is non-nil.
- (struct regexp_cache): New element whitespace_regexp.
- (syms_of_search): Initialize whitespace_regexp elements.
- (compile_pattern): Compare whitespace_regexp elements.
- (compile_pattern_1): Set whitespace_regexp elements.
-
- * regex.c (regex_compile): Substitute whitespace_regexp
- for spaces, if it is nonzero.
- (whitespace_regexp): New variable.
- (re_set_whitespace_regexp): New function.
-
-2004-11-19 Kim F. Storm <[email protected]>
-
- * indent.c (Fvertical_motion): Fix last change.
-
-2004-11-18 Kim F. Storm <[email protected]>
-
- * indent.c (Fvertical_motion): Undo 2004-11-16 change.
- Instead, move back again if reseating moves too far ahead.
-
-2004-11-17 Luc Teirlinck <[email protected]>
-
- * xdisp.c (message3): Call clear_message.
-
-2004-11-17 Kim F. Storm <[email protected]>
-
- * xdisp.c (erase_phys_cursor): Adjust cursor row visible height.
-
-2004-11-16 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_file_name): Typo in HAVE_GTK_FILE_SELECTION_NEW.
-
- * xmenu.c (x_menu_in_use): Remove.
- (x_menu_set_in_use): Also set popup_activated_flag.
-
- * xfns.c (Fx_file_dialog): Call popup_activated instead of
- x_menu_in_use. Call x_menu_set_in_use in Motif version also.
-
- * xterm.h (x_menu_in_use): Remove.
-
-2004-11-16 Richard M. Stallman <[email protected]>
-
- * keymap.c (Fmap_keymap): New arg SORT-FIRST.
- Use map-keymap-internal to implement that.
-
- * indent.c (Fvertical_motion): In batch mode, use vmotion directly.
-
-2004-11-16 Stefan Monnier <[email protected]>
-
- * xdisp.c (get_glyph_string_clip_rect, init_glyph_string): Check it's
- a window before using XWINDOW.
-
- * window.c (make_window, Fselect_window, make_dummy_parent)
- (save_window_save):
- * frame.c (make_frame):
- * fns.c (concat): Avoid side-effects inside XSETFASTINT's arguments.
-
- * lisp.h (NILP): Use EQ rather than XFASTINT.
-
-2004-11-16 Kim F. Storm <[email protected]>
-
- * fringe.c (Fdefine_fringe_bitmap): Always set 'h'. Simplify.
-
- * indent.c (Fvertical_motion): Fix last change. Only reseat when
- moving backwards.
-
-2004-11-16 Luc Teirlinck <[email protected]>
-
- * dispextern.h: Extern reseat_at_previous_visible_line_start.
-
-2004-11-16 Kenichi Handa <[email protected]>
-
- * xdisp.c (display_mode_element): Fix previous change (calculate
- end position of substring to display correctly).
-
-2004-11-16 Kim F. Storm <[email protected]>
-
- * keyboard.c (Fposn_at_point): Remove extra */ after doc string.
- Reported by Andrew M. Scott.
-
-2004-11-15 Kim F. Storm <[email protected]>
-
- * fns.c (Fsafe_plist_get): New defun.
- (syms_of_fns): Defsubr it.
-
- * lisp.h (Fsafe_plist_get): Add EXFUN.
-
- * xdisp.c (store_mode_line_string, produce_stretch_glyph):
- Use Fsafe_plist_get.
- (note_mode_line_or_margin_highlight, note_mouse_highlight):
- Fix image map element parsing. Use Fsafe_plist_get.
-
-2004-11-15 Richard M. Stallman <[email protected]>
-
- * xdisp.c (get_next_display_element): Fix previous change.
-
-2004-11-14 Jan Dj,Ad(Brv <[email protected]>
-
- * window.c (shrink_windows): Handle special case of one window left
- when trying to shrink the final reminder. Grow windows if
- total_removed is less than total_shrink.
-
- * xmenu.c (pop_down_menu): Remove global variable current_menu,
- extract pointer from arg with XSAVE_VALUE.
- (create_and_show_popup_menu, create_and_show_dialog, xmenu_show):
- Construct arg to record_unwind_protect with make_save_value.
-
-2004-11-13 Richard M. Stallman <[email protected]>
-
- * xdisp.c (reseat_at_previous_visible_line_start): No longer static.
- (get_next_display_element): Fix previous change to apply only to \n.
-
- * indent.c (Fvertical_motion): Scan to PT from start of line to
- make iterator consistent.
-
- * minibuf.c (syms_of_minibuf) <completion-ignore-case>: Doc fix.
-
-2004-11-14 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (pop_down_file_dialog): Add BLOCK_INPUT.
-
- * xfns.c (Fx_file_dialog): Call x_menu_in_use and x_menu_set_in_use.
- Record unwind with clean_up_file_dialog.
-
- * xterm.h (x_menu_in_use, x_menu_set_in_use, x_menu_wait_for_event):
- Declare.
-
- * xmenu.c (x_menu_in_use, x_menu_set_in_use): New functions.
-
-2004-11-13 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_file_sel_ok, xg_file_sel_cancel)
- (xg_file_sel_destroy): Remove.
- (xg_file_response_cb, pop_down_file_dialog)
- (xg_get_file_name_from_chooser, xg_get_file_name_from_selector):
- New functions.
- (xg_get_file_with_chooser, xg_get_file_with_selection):
- Take new arg func, set it to xg_get_file_name_from_chooser/selector.
- Move common code to xg_get_file_name. Return widget created.
- (xg_get_file_name): Set name, transient for, modal and destroy
- with parent here. Connect response signal to xg_file_response_cb,
- connect delete-event to gtk_true. Record pop_down_file_dialog
- for unwind. Do event loop and call x_menu_wait_for_event in loop.
- (xg_create_widget): Make dialogs modal.
-
- * xmenu.c (unuse_menu_items, pop_down_menu): Arg is of type
- Lisp_Object.
- (popup_get_selection): Move unwind protect ...
- (create_and_show_popup_menu, create_and_show_dialog): ... to here.
- Move destroy of widget to pop_down_menu.
- (popup_widget_loop): Move unwind protect ...
- (create_and_show_popup_menu, create_and_show_dialog): ... to here.
- Move destroy of widget to pop_down_menu.
- (pop_down_menu): BLOCK_INPUT and destroy widget/window.
- (xmenu_show): Record unwind pop_down_menu. Move XMenuDestroy,
- x_mouse_leave and grabbed = 0 to pop_down_menu.
-
-2004-11-13 Kim F. Storm <[email protected]>
-
- * xdisp.c (make_cursor_line_fully_visible_p): New variable.
- (syms_of_xdisp): DEFVAR_BOOL it.
- (make_cursor_line_fully_visible, try_cursor_movement)
- (try_window_id): Use it.
-
-2004-11-12 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct glyph_row): New member extra_line_spacing.
- (struct it): New member max_extra_line_spacing.
- (MR_PARTIALLY_VISIBLE, MR_PARTIALLY_VISIBLE_AT_TOP)
- (MR_PARTIALLY_VISIBLE_AT_BOTTOM): New helper macros.
- (MATRIX_ROW_PARTIALLY_VISIBLE_P): Fix to return false if invisible
- part of last line is only extra line spacing (so the text on the
- line is fully visible). Use helper macros.
- Add W arg (to use them). All callers changed.
- (MATRIX_ROW_PARTIALLY_VISIBLE_AT_TOP_P)
- (MATRIX_ROW_PARTIALLY_VISIBLE_AT_BOTTOM_P): Use helper macros.
-
- * window.c (window_scroll_pixel_based, Frecenter):
- Use move_it_vertically_backward directly.
- (Frecenter): Fix calculation of new start pos for negative arg.
- Before, the new start pos was sometimes chosen too far back, so
- the last line became only partially visible, and thus would be
- either only semi-visible or automatically scrolled to the middle
- of the window by redisplay.
-
- * xdisp.c (init_iterator): Clear it.max_extra_line_spacing.
- (move_it_vertically_backward): Don't recure to move further back.
- (move_it_vertically): Remove superfluous condition.
- (move_it_by_lines): Clear last_height when moved 0 lines.
- (resize_mini_window): Use it.max_extra_line_spacing.
- (display_tool_bar_line): Clear row->extra_line_spacing.
- (try_scrolling): Use move_it_vertically_backward directly.
- (redisplay_window): Likewise.
- (compute_line_metrics): Set row->extra_line_spacing.
- (display_line, display_string): Likewise.
- (x_produce_glyphs): Update it->max_extra_line_spacing.
-
- * xmenu.c (pop_down_menu): Return nil.
-
-2004-11-12 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (x_menu_wait_for_event): New function.
- (popup_get_selection, popup_widget_loop): Call x_menu_wait_for_event
- to handle timers.
- (popup_widget_loop): Add argument do_timers.
- (create_and_show_popup_menu, create_and_show_dialog): Pass 1 for
- do_timers to popup_widget_loop.
- (xmenu_show): Call XMenuActivateSetWaitFunction so that
- x_menu_wait_for_event is called by XMenuActivate.
- (create_and_show_popup_menu): Pass 1 for do_timers to
- popup_get_selection.
- (pop_down_menu): New function.
- (popup_get_selection, popup_widget_loop): Unwind protect to
- pop_down_menu.
- (popup_widget_loop): Add argument widget.
- (create_and_show_popup_menu, create_and_show_dialog): Pass new
- argument widget to popup_widget_loop.
-
-2004-11-10 Stefan Monnier <[email protected]>
-
- * keymap.c (Fkeymap_prompt): Accept symbol keymaps.
-
-2004-11-09 Kim F. Storm <[email protected]>
-
- * xselect.c: Include <sys/types.h> and <unistd.h> (for getpid).
- Fix various comments referring to XEvents instead of input events.
- (x_queue_event): Fix format strings.
- (x_stop_queuing_selection_requests): Likewise.
-
- * xdisp.c (produce_image_glyph): Remove unused variable 'face_ascent'.
- (pint2hrstr): Add extra braces to silence compiler.
-
- * print.c (print_object): Fix format string.
-
- * lread.c (read1): Fix next_char matching.
-
- * lisp.h (Fdelete): Add EXFUN.
- (replace_range_2): Add prototype.
-
- * keyboard.c (read_avail_input): Remove unused variable 'discard'.
-
- * intervals.h (NULL_INTERVAL_P): Add separate version when
- ENABLE_CHECKING is not defined to silence compiler.
- (compare_string_intervals): Add prototype.
-
- * fringe.c (destroy_fringe_bitmap): Fix return type.
- (Ffringe_bitmaps_at_pos): Remove unused var 'old_buffer'.
-
- * emacs.c (Fdump_emacs): Fix format string.
-
- * doc.c: Include <ctype.h>.
- (Fsubstitute_command_keys): Remove unused variable 'firstkey'.
-
- * data.c (store_symval_forwarding): Remove unused variables.
-
- * callint.c (Fcall_interactively): Remove unused variable 'funcar'.
-
-2004-11-09 Jan Dj,Ad(Brv <[email protected]>
-
- * Makefile.in (stamp-oldxmenu): If HAVE_GTK, don't add dependencies
- to ${OLDXMENU}.
-
-2004-11-09 Kim F. Storm <[email protected]>
-
- * process.c (Fmake_network_process): Remove kludge for interrupted
- connects on BSD. If connect is interrupted, just close socket and
- start over rather than sleeping and retry with same socket.
-
-2004-11-09 Jan Dj,Ad(Brv <[email protected]>
-
- * .cvsignore: Add buildobj.lst.
-
- * doc.c: New variable Vbuild_files.
- (Fsnarf_documentation): If Vbuild_files is nil, populate it with
- file names from buildobj.lst. Only attach docstrings from files
- that are in Vbuild_files.
- (syms_of_doc): Defvar Vbuild_files.
-
- * Makefile.in (SOME_MACHINE_OBJECTS): Add fringe.o, image.o
- and w32*.o.
- (temacs${EXEEXT}): Generate buildobj.lst when temacs is linked.
- (mostlyclean): Rm buildobj.lst.
-
- * makefile.w32-in ($(TEMACS)): Generate buildobj.lst when temacs
- is linked.
-
-2004-11-09 Kim F. Storm <[email protected]>
-
- * fringe.c (update_window_fringes): Update fringe bitmaps if
- cur and row ends_at_zv_p differs. If bitmaps of a row is updated,
- also update previous row to get rid of misc. artifacts.
-
-2004-11-08 Kim F. Storm <[email protected]>
-
- * xdisp.c (fast_find_position): Fix start pos if header line present.
- (note_mouse_highlight): Clear mouse face if we move out of text area.
-
-2004-11-08 Eli Zaretskii <[email protected]>
-
- * editfns.c: Move #include "systime.h" before <sys/resource.h>.
- Don't include <sys/time.h> explicitly.
- Include <stdio.h> unconditionally, not just on MacOS.
-
-2004-11-08 Kenichi Handa <[email protected]>
-
- * fontset.c (fontset_pattern_regexp): Cancel my previous change;
- don't pay attention to '\' before '*'.
- (fontset_pattern_regexp): Change the meaning of the second arg.
- (Fnew_fontset): Call fs_query_fontset, not Fquery_fontset.
- (check_fontset_name): Try NAME as literal at first, and if it
- failes, try NAME as pattern.
-
-2004-11-07 Jan Dj,Ad(Brv <[email protected]>
-
- * emacs.c (Fdump_emacs): Only output warning on GNU/Linux.
-
-2004-11-07 Andreas Schwab <[email protected]>
-
- * lisp.h (Fmsdos_downcase_filename): Declare.
- * dired.c (Fmsdos_downcase_filename): Don't declare here.
- * fileio.c: Likewise.
-
-2004-11-07 Jan Dj,Ad(Brv <[email protected]>
-
- * dosfns.c (Fdos_memget, Fdos_memput): Use integer variable offs in
- comparisons with integers instead of Lisp_Object address.
- (Fmsdos_set_keyboard): Declare argument allkeys.
-
- * msdos.c (IT_set_frame_parameters): Use EQ, not ==, for Lisp_Object:s.
-
- * dired.c (Fmsdos_downcase_filename): Declare extern on MSDOS to avoid
- int/Lisp_Object mixup.
-
- * fileio.c: Ditto.
-
-2004-11-06 Steven Tamm <[email protected]>
-
- * editfns.c: Need to include sys/time.h before resource.h on darwin.
-
-2004-11-06 Richard M. Stallman <[email protected]>
-
- * callint.c (Fcall_interactively): Avoid reusing EVENT for other data.
-
- * xfaces.c (merge_named_face): GCPRO the face_name in the
- named_merge_point struct that we make.
- (merge_face_heights): Eliminate GCPRO arg. All callers changed.
-
- * keyboard.c (command_loop_1): Change Vtransient_mark_mode
- before deciding whether to inactivate mark.
-
-2004-11-06 Lars Brinkhoff <[email protected]>
-
- * config.in: Regenerate (add HAVE_GETRUSAGE).
- * editfns.c (Fget_internal_run_time): New function.
- (syms_of_data): Defsubr it.
- * fns.c (sxhash): As far as possible, merge calculation of
- hash code for symbols and strings.
-
-2004-11-06 Eli Zaretskii <[email protected]>
-
- * frame.c (syms_of_frame): Fix the example in the doc string.
-
-2004-11-06 Jan Dj,Ad(Brv <[email protected]>
-
- * eval.c (Feval): Remove check for INPUT_BLOCKED_P.
-
- * xmenu.c (popup_get_selection, create_and_show_popup_menu)
- (create_and_show_dialog): Revert change from 2004-10-31.
-
-2004-11-05 Luc Teirlinck <[email protected]>
-
- * macros.c (syms_of_macros) <defining-kbd-macro>: Doc fix.
-
-2004-11-05 Kim F. Storm <[email protected]>
-
- * print.c (print_object): Print Lisp_Misc_Save_Value objects.
-
- * fileio.c (Ffile_modes): Doc fix.
- (auto_save_1): Check for Ffile_modes nil value.
-
-2004-11-05 Kim F. Storm <[email protected]>
-
- * xselect.c (struct selection_event_queue, selection_queue)
- (x_queue_selection_requests, x_queue_event)
- (x_start_queuing_selection_requests)
- (x_stop_queuing_selection_requests): Add new queue for selection
- input events to replace previous XEvent queue in xterm.c.
- (queue_selection_requests_unwind): Adapt to new queue.
- (x_reply_selection_request): Adapt to new queue.
- Unexpect wait_object in case of x errors (memory leak).
- (x_handle_selection_request, x_handle_selection_clear): Make static.
- (x_handle_selection_event): New function. May queue selection events.
- (wait_for_property_change_unwind): Use save_value instead of cons.
- Clear property_change_reply_object.
- (wait_for_property_change): Abort if already waiting.
- Use save_value instead of cons for unwind data.
- (x_handle_property_notify): Skip events already arrived, but don't
- free them, as "arrived" field is checked by wait_for_property_change,
- and it will be freed by unwind or explicit unexpect_property_change.
- (x_get_foreign_selection): Add to new queue.
- (receive_incremental_selection): Don't unexpect wait_object when done
- as it has already been freed by previous wait_for_property_change.
-
- * xterm.h (x_start_queuing_selection_requests)
- (x_stop_queuing_selection_requests, x_handle_selection_request)
- (x_handle_selection_clear): Remove prototypes.
- (x_handle_selection_event): Add prototype.
-
- * xterm.c (handle_one_xevent): Don't queue X selection events
- here, it may be too late if we start queuing after we have already
- stored some selection events into the kbd buffer.
- (struct selection_event_queue, queue, x_queue_selection_requests)
- (x_queue_event, x_unqueue_events, x_start_queuing_selection_requests)
- (x_stop_queuing_selection_requests): Remove/move to xselect.c.
- (x_catch_errors_unwind): Block input around final XSync.
-
- * keyboard.h (kbd_buffer_unget_event): Add prototype.
-
- * keyboard.c (kbd_buffer_store_event_hold): Remove obsolete code.
- (kbd_buffer_unget_event): New function.
- (kbd_buffer_get_event, swallow_events): Combine SELECTION events
- and use x_handle_selection_event.
- (mark_kboards): Don't mark x and y of SELECTION_CLEAR_EVENT.
-
-2004-11-05 Jan Dj,Ad(Brv <[email protected]>
-
- * xselect.c (TRACE3): New debug macro.
- (x_reply_selection_request): Use it.
- (receive_incremental_selection): In call to TRACE0, the name of
- a symbol is in xname.
-
-2004-11-05 Kim F. Storm <[email protected]>
-
- * fontset.c (fontset_pattern_regexp): Use unsigned char.
-
-2004-11-04 Jan Dj,Ad(Brv <[email protected]>
-
- * fileio.c (Fnext_read_file_uses_dialog_p): New function.
-
- * gtkutil.h (use_old_gtk_file_dialog): Declare.
-
- * gtkutil.c: Make use_old_gtk_file_dialog non-static.
- (xg_initialize): Move DEFVAR_BOOL for use_old_gtk_file_dialog ...
- * xfns.c (syms_of_xfns): ... to here.
-
- * gtkutil.c (xg_get_file_with_chooser): Expand DEFAULT_FILENAME if
- it doesn't start with /.
-
-2004-11-04 Kenichi Handa <[email protected]>
-
- * fontset.c (fontset_pattern_regexp): If '*' is preceded by '\',
- treat it as a literal character.
-
-2004-11-03 Kim F. Storm <[email protected]>
-
- * .gdbinit (ppt): New function.
-
-2004-11-02 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_window_to_scroll_bar): Only call
- xg_get_scroll_id_for_window if toolkit scroll bars are used.
-
- * gtkutil.c (xg_get_file_with_chooser): Use GTK_STOCK_OK instead
- of save.
-
-2004-11-02 Andreas Schwab <[email protected]>
-
- * window.c (Fscroll_right): Fix last change.
-
-2004-11-02 Kim F. Storm <[email protected]>
-
- * Makefile.in (callproc.o): Depend on blockinput.h, atimer.h, systime.h.
-
-2004-11-02 YAMAMOTO Mitsuharu <[email protected]>
-
- * callproc.c (Fcall_process): Block input around vfork.
-
-2004-11-02 Kim F. Storm <[email protected]>
-
- * eval.c (Fcalled_interactively_p): Rename from Fcall_interactive_p.
- (syms_of_eval): Defsubr it.
-
-2004-11-02 Richard M. Stallman <[email protected]>
-
- * insdel.c (replace_range_2): New function.
-
- * casefiddle.c (casify_region): Handle changes in byte-length
- using replace_range_2.
-
- * emacs.c (USAGE3): Delete --horizontal-scroll-bars, -hb.
-
- * xdisp.c (back_to_previous_visible_line_start):
- Subtract 1 from pos when checking previous newline for invisibility.
-
- * window.c (window_scroll_pixel_based): Update preserve_y
- for header line if any.
- (Fscroll_left, Fscroll_right): Don't call interactive_p;
- use a new second argument instead.
-
- * eval.c (Fcall_interactive_p): New function.
- (interactive_p): Don't test INTERACTIVE here.
- (Finteractive_p): Doc fix.
-
- * eval.c (Feval): Abort if INPUT_BLOCKED_P.
-
-2004-11-02 KOBAYASHI Yasuhiro <[email protected]>
-
- * w32fns.c (w32_font_match): Use fast_string_match_ignore_case for
- comparing font names.
-
-2004-11-02 Jan Dj,Ad(Brv <[email protected]>
-
- * fileio.c (Fread_file_name): Pass Qt as fifth parameter to
- Fx_file_dialog if only directories should be read.
-
- * lisp.h: Fx_file_dialog takes 5 parameters.
-
- * xfns.c (Fx_file_dialog): Both Motif and GTK version:
- Add parameter only_dir_p.
- In Motif version, don't put DEFAULT_FILENAME in filter part of the
- dialog, just text field part. Do not add DEFAULT_FILENAME
- to list of files if it isn't there.
- In GTK version, pass only_dir_p parameter to xg_get_file_name.
-
- * macfns.c (Fx_file_dialog): Add parameter only_dir_p.
- Check only_dir_p instead of comparing prompt to "Dired". When using
- a save dialog, add option kNavDontConfirmReplacement, change title
- to "Enter name", change text for save button to "Ok".
-
- * w32fns.c (Fx_file_dialog): Add parameter only_dir_p.
- Check only_dir_p instead of comparing prompt to "Dired".
-
- * gtkutil.c (xg_get_file_with_chooser, xg_get_file_with_selection):
- New functions, only defined ifdef HAVE_GTK_FILE_CHOOSER_DIALOG_NEW
- and HAVE_GTK_FILE_SELECTION_NEW respectively.
- (xg_get_file_name): Add parameter only_dir_p.
- Call xg_get_file_with_chooser or xg_get_file_with_selection
- depending on HAVE_GTK_FILE* and the value of use_old_gtk_file_dialog.
- (xg_initialize): New DEFVAR_BOOL use_old_gtk_file_dialog.
-
- * gtkutil.h (xg_get_file_name): Add parameter only_dir_p.
-
- * config.in: Rebuild (added HAVE_GTK_FILE_*).
-
-2004-11-01 Kim F. Storm <[email protected]>
-
- * process.c (connect_wait_mask, num_pending_connects):
- Only declare and use them if NON_BLOCKING_CONNECT is defined.
- (init_process): Initialize them if NON_BLOCKING_CONNECT defined.
- (IF_NON_BLOCKING_CONNECT): New helper macro.
- (wait_reading_process_output): Only declare and use local vars
- Connecting and check_connect when NON_BLOCKING_CONNECT is defined.
-
-2004-11-01 Andy Petrusenco <[email protected]> (tiny change)
-
- * w32term.c (x_scroll_run): Delete region objects after use.
-
-2004-10-31 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c: Add prototypes for forward function declarations.
- (popup_get_selection): Remove parameter do_timers, remove call to
- timer_check.
- (create_and_show_popup_menu, create_and_show_dialog):
- Remove parameter do_timers from call to popup_get_selection.
-
- * xdisp.c (update_tool_bar): Pass a copy of f->tool_bar_items to
- tool_bar_items and assign the result to f->tool_bar_items if
- not equal. Move BLOCK/UNBLOCK_INPUT from around call to
- tool_bar_items to assignment of result.
-
- * atimer.c (alarm_signal_handler): Do not call set_alarm if
- pending_atimers is non-zero.
-
-2004-10-31 Kim F. Storm <[email protected]>
-
- * dispnew.c (margin_glyphs_to_reserve): Don't use ncols_scale_factor.
-
-2004-10-28 Will <[email protected]>
-
- * macterm.c: Allow user to assign key modifiers to the Mac Option
- key via a 'mac-option-modifier' variable.
-
-2004-10-28 Stefan Monnier <[email protected]>
-
- * xselect.c (Vx_lost_selection_functions, Vx_sent_selection_functions):
- Rename from Vx_lost_selection_hooks and Vx_sent_selection_hooks.
- (x_handle_selection_request, x_handle_selection_clear)
- (x_clear_frame_selections, syms_of_xselect): Adjust accordingly.
-
-2004-10-28 Richard M. Stallman <[email protected]>
-
- * w32fns.c (Fx_server_vendor, Fx_server_version): Doc fixes.
-
- * xfns.c (Fx_server_vendor, Fx_server_version): Doc fixes.
-
-2004-10-27 Stefan Monnier <[email protected]>
-
- * syntax.c (scan_sexps_forward): Give precedence to a 2-char
- comment-starter over a 1-char one.
-
-2004-10-27 Richard M. Stallman <[email protected]>
-
- * xdisp.c (get_next_display_element): In mode lines,
- treat newline and tab like other control characters.
-
- * editfns.c (Fmessage): Doc fix.
-
- * indent.c (vmotion): When moving up, check the newline before.
- Make prevline an int, not a Lisp_Object.
-
-2004-10-27 Kim F. Storm <[email protected]>
-
- * editfns.c (Fformat): Allocate discarded table with SAFE_ALLOCA.
- Only allocate info and discarded tables once.
-
- * lisp.h (USE_SAFE_ALLOCA): Add and init sa_must_free integer.
- (SAFE_ALLOCA, SAFE_ALLOCA_LISP): Increment it when malloc is used.
- (SAFE_FREE): Test it to determine if we need to unwind to free.
- Remove size arg. All users changed.
- (SAFE_FREE_LISP): Remove. All users changed to use SAFE_FREE.
-
-2004-10-26 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c: Put empty line between comment and function body.
- (xg_destroy_widgets): Rename from remove_from_container.
- Just destroy all widgets in list. Argument wcont removed.
- (xg_update_menubar, xg_update_submenu): Call xg_destroy_widgets
- instead of remove_from_container.
- (xg_display_close, xg_create_tool_bar, update_frame_tool_bar)
- (free_frame_tool_bar): Add comment.
-
- * xfns.c (xic_create_xfontset): Check that FRAME_XIC_BASE_FONTNAME
- is not NULL before strcmp.
-
-2004-10-26 Kim F. Storm <[email protected]>
-
- * callint.c (Fcall_interactively): Add 'U' code to get the
- up-event discarded by a previous 'k' or 'K' argument.
-
-2004-10-26 David Kastrup <[email protected]>
-
- * buffer.c (syms_of_buffer): Fix a few typos.
-
-2004-10-26 Jan Dj,Ad(Brv <[email protected]>
-
- * xsmfns.c: Put empty line between comment and function body.
- Use two spaces before comment end.
-
-2004-10-25 Kenichi Handa <[email protected]>
-
- * fontset.c (fontset_pattern_regexp): Optimize for the case that
- PATTERN is full XLFD.
-
-2004-10-24 Kenichi Handa <[email protected]>
-
- * regex.h (enum reg_errcode_t): New value REG_ERANGEX.
-
- * regex.c (re_error_msgid): Add an entry for REG_ERANGEX.
- (regex_compile): Return REG_ERANGEX if appropriate.
-
-2004-10-22 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (xic_create_xfontset): Initialize missing_list to NULL.
-
-2004-10-21 K,Aa(Broly L$,1 q(Brentey <[email protected]>
-
- * xterm.h (x_output): New member `xic_base_fontname'.
- (FRAME_XIC_BASE_FONTNAME): New macro.
- (xic_free_xfontset): Declare.
-
- * xfns.c (xic_create_xfontset): Share fontsets between frames
- based on base_fontname.
- (xic_free_xfontset): New function.
- (free_frame_xic): Use it.
- (xic_set_xfontset): Ditto.
-
- * xterm.c (xim_destroy_callback): Ditto.
-
-2004-10-20 B. Anyos <[email protected]> (tiny change)
-
- * w32term.c (x_draw_glyph_string): Use overline_color for overlines.
-
-2004-10-20 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h (XSync): If USE_GTK, define XSync as process_all and then
- XSync.
-
- * emacs.c (my_heap_start, heap_bss_diff, MAX_HEAP_BSS_DIFF):
- New variables and constant.
- (main): Calculate heap_bss_diff. If we are dumping and the
- heap_bss_diff is greater than MAX_HEAP_BSS_DIFF, set PER_LINUX32
- and exec ourself again.
- (Fdump_emacs): If heap_bss_diff is greater than MAX_HEAP_BSS_DIFF
- print a warning.
-
- * lastfile.c: Make my_endbss and my_endbss_static available on all
- platforms.
-
- * Makefile.in (RUN_TEMACS): Remove @SETARCH@.
- * config.in (HAVE_PERSONALITY_LINUX32): Regenerate.
-
-2004-10-19 Luc Teirlinck <[email protected]>
-
- * data.c (Flocal_variable_if_set_p): Doc fix.
-
-2004-10-19 Jason Rumney <[email protected]>
-
- * w32.c (init_environment): Set emacs_dir correctly when running
- emacs from the build directory.
-
-2004-10-19 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fdelete_and_extract_region):
- If region is empty, return null string.
-
-2004-10-19 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.h (xg_update_scrollbar_pos): Remove arguments real_left
- and canon_width.
- (xg_frame_cleared): Remove.
-
- * gtkutil.c (xg_frame_cleared, xg_fixed_handle_expose)
- (xg_find_top_left_in_fixed): Remove.
- (xg_create_scroll_bar): Put an event box widget between
- the scroll bar widget and the edit widget.
- (xg_show_scroll_bar): Show the parent widget (the event box).
- (xg_remove_scroll_bar): Destroy parent (the event box) also.
- (xg_update_scrollbar_pos): Remove arguments real_left and canon_width.
- Move the parent (the event box) widget inside the fixed widget.
- Move window clear to xterm.c.
-
- * gtkutil.h (xg_frame_cleared): Remove.
-
- * xterm.c (x_clear_frame): Remove call to xg_frame_cleared
- (x_scroll_bar_create, XTset_vertical_scroll_bar):
- Remove arguments left and width to xg_update_scrollbar_pos.
- (XTset_vertical_scroll_bar): Do x_clear_area for USE_GTK also.
-
-2004-10-19 Kenichi Handa <[email protected]>
-
- * xdisp.c (display_mode_element): Fix display of wide chars.
-
-2004-10-18 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_update_scrollbar_pos): Change XClearWindow to
- gdk_window_clear and move gdk_window_process_all_updates after
- clear so events are sent to the X server in correct order.
-
-2004-10-18 Kenichi Handa <[email protected]>
-
- * fontset.c (fs_load_font): Use fast_string_match_ignore_case for
- comparing font names.
- (fs_query_fontset): Use fast_string_match for comparing fontset names.
- (list_fontsets): Likewise.
-
- * search.c (fast_string_match_ignore_case): New function.
-
- * lisp.h (fast_string_match_ignore_case): Extern it.
-
-2004-10-17 Kim F. Storm <[email protected]>
-
- * xdisp.c (overlay_arrow_at_row): Return overlay string rather
- than bitmap if there is not left fringe.
- (get_overlay_arrow_glyph_row): Also used on windows system.
- (display_line): Display overlay string if no left fringe.
-
-2004-10-16 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_font_match): Encode font name being matched.
-
-2004-10-16 Richard M. Stallman <[email protected]>
-
- * window.c (Fspecial_display_p): Doc fix.
-
-2004-10-15 Stefan Monnier <[email protected]>
-
- * doc.c (Fsubstitute_command_keys): Fix remap-handling.
- Don't ignore menus, because where-is-internal already does it for us.
-
-2004-10-15 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Only update fringes and vertical
- border on window frames.
-
-2004-10-14 Andreas Schwab <[email protected]>
-
- * m/ia64.h (DATA_SEG_BITS): Don't define.
-
-2004-10-14 Kim F. Storm <[email protected]>
-
- * xterm.h: Include Xutil.h after keysym.h to work around bug
- in some X versions.
-
-2004-10-13 Stefan Monnier <[email protected]>
-
- * fns.c (map_char_table): Add missing gcpros.
-
-2004-10-13 Stefan Monnier <[email protected]>
-
- * keymap.c (get_keymap): An autoload form is not a keymap.
-
- * textprop.c (syms_of_textprop): Make `syntax-table' nonsticky.
-
-2004-10-13 Kim F. Storm <[email protected]>
-
- * callproc.c (Fcall_process): Simplify handling of display arg.
- Resume `display_on_the_fly' once a coding system is determined.
-
- * xdisp.c (redisplay_preserve_echo_area): Fix last change.
-
-2004-10-12 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_preserve_echo_area): Flush display in case
- caller, such as call-process, is not going to poll for input.
- (calc_line_height_property): Handle case where it->object is nil.
-
- * xterm.c (x_redisplay_interface): Fix flush_display_optional.
-
-2004-10-12 Kenichi Handa <[email protected]>
-
- * xdisp.c (get_next_display_element):
- If unibyte_display_via_language_environment is zero, display 8-bit
- chars in octal in unibyte buffer.
-
-2004-10-12 Kim F. Storm <[email protected]>
-
- * doc.c (Fsubstitute_command_keys): Ignore remappings unless there
- are no ordinary bindings.
-
-2004-10-11 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (syms_of_xfns): Defsubr x-file-dialog for GTK also.
-
-2004-10-10 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (x_raise_frame): Add BLOCK_INPUT around SelectWindow.
- (x_lower_frame): Add BLOCK_INPUT around SendBehind.
- (make_mac_frame): Add BLOCK_INPUT around the making of a
- terminal frame.
- (mac_initialize): Add BLOCK_INPUT around carbon initialization.
- * macgui.h (mktime): Use emacs_mktime.
- * macfns.c (Fx_file_dialog): Add BLOCK_INPUT around more code.
- Make a cancel file-open dialog be like C-g.
- * mac.c (mktime): Use emacs_mktime.
- (Fdo_applescript): Add BLOCK_INPUT around do_applescript.
- (Fmac_paste_function): Add better error handling for carbon cut/paste.
-
-2004-10-10 Kim F. Storm <[email protected]>
-
- * keyboard.c (timer_resume_idle): New function to resume idle
- timer without resetting timers on the idle list.
- (read_char): Use timer_resume_idle. Remove local var last_idle_start.
- (timer_start_idle, timer_stop_idle): Declare static.
- (read_key_sequence): Use timer_resume_idle instead of timer_start_idle.
-
- * keyboard.h (timer_start_idle, timer_stop_idle): Remove prototypes.
-
-2004-10-08 Steven Tamm <[email protected]>
-
- * config.in (HAVE_MALLOC_MALLOC_H): Regenerate.
- * macterm.c (mac_check_for_quit_char): Remove warning for using
- NULL where 0 should be used.
- * unexmacosx.c: Use malloc/malloc.h on Tiger instead of
- objc/malloc.h
- * mac.c: Include time.h for Tiger compatibility.
-
-2004-10-07 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Fix flicker on vertical line between
- windows. Update vertical line after drawing window fringes, but
- only if actually drawing any bitmaps--or there is no fringe.
-
- * xterm.c (x_update_window_end): Likewise.
- * macterm.c (x_update_window_end): Likewise.
- * w32term.c (x_update_window_end): Likewise.
-
- * fringe.c (draw_window_fringes): Return value now indicates if
- any fringe bitmaps were redrawn (or there are no fringes).
-
- * dispextern.h (draw_window_fringes): Update prototype.
-
-2004-10-06 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (mac_get_window_bounds): Add extern.
- (x_real_positions): Use mac_get_window_bounds.
-
- * macmenu.c (update_submenu_strings): Apply 2004-09-07 change for
- xmenu.c (YAILOM).
-
- * macterm.c [!MAC_OSX]: Include Windows.h.
- (front_emacs_window): Rename from mac_front_window. All uses
- changed. Return the frontmost non-tooltip emacs window.
- (mac_get_window_bounds): New function.
- (x_calc_absolute_position): Use the difference of width and height
- between the inner and outer window.
- (x_set_offset): Specify window position by the coordinae of the
- outer window. Adjust the position if the title bar is completely
- outside the screen.
- (app_is_suspended, app_sleep_time): Remove unused variables.
- (do_app_resume, do_app_suspend): Remove their contents because
- window-activate/deactivate events will do the job.
- (do_zoom_window): Remove unused variables. Make compliant to the
- standard way of zooming. Set f->left_pos and f->top_pos.
- (XTread_socket): Don't use argument `expected'. Don't use
- FrontWindow to determine the clicked window. Exclude unprocessed
- mouseUp cases in the early stage. Add parentheses to fix operator
- precedence.
- (XTread_socket) [TARGET_API_MAC_CARBON]: Don't specify drag area.
-
-2004-10-05 Jan Dj,Ad(Brv <[email protected]>
-
- * config.in: Regenerate.
-
- * Makefile.in (RUN_TEMACS): Check HAVE_RANDOM_HEAPSTART instead of
- HAVE_EXECSHIELD.
-
-2004-10-05 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_find_modifier_meanings): Ignore any Super or Hyper for
- a row if Alt or Meta has been found for that row. Also stop scanning
- for Keysyms for that row.
-
-2004-10-04 Kim F. Storm <[email protected]>
-
- * fringe.c (Ffringe_bitmaps_at_pos): Change return value from cons
- to list. Include overlay arrow bitmap in return value.
-
- * xterm.c (XTset_vertical_scroll_bar): Improve handling of scroll
- bars with fractional column width. If scroll bar separates two
- windows, move it towards the window it belongs to. Only update
- the padding area below the scroll bar widget when necessary,
- i.e. when scroll bar widget is created, moved, or resized.
-
- * xdisp.c (define_frame_cursor1): Do not change frame cursor
- while tracking/dragging mouse.
- (x_draw_vertical_border): Do not draw line if frame has scroll bars.
-
- * window.c (coordinates_in_window): Relax check for cursor
- on vertial border between mode lines.
- (Fset_window_fringes): Do not allow negative widths.
- (Fset_window_scroll_bars): Likewise.
-
- * .gdbinit (pp): Shorthand for p ARG + pr.
- (ff): New command: flush frame updates (X only).
-
-2004-10-03 Michael Albinus <[email protected]>
-
- * fileio.c (auto_save_1) Call Ffile_modes for remote files.
-
-2004-09-30 Kenichi Handa <[email protected]>
-
- * process.c (send_process): Free composition data.
-
- * fileio.c (Finsert_file_contents): Free composition data.
-
- * coding.c (code_convert_region): Don't skip ASCIIs if there are
- compositions to encode.
- (encode_coding_string): Likewise. Free composition data.
-
-2004-09-30 Florian Weimer <[email protected]>
-
- * coding.c (code_convert_region): Free composition data.
-
-2004-09-29 Kim F. Storm <[email protected]>
-
- * fringe.c: Remove limit on number of bitmaps.
- (fringe_bitmaps, fringe_faces): Change to pointers.
- (max_fringe_bitmaps): New var.
- (Fdefine_fringe_bitmap): Expand fringe_bitmaps and fringe_faces.
- (init_fringe): Allocate fringe_bitmaps and fringe_faces.
-
- * dispextern.h (FRINGE_ID_BITS): Increase to 16 bits (64K bitmaps).
- (struct glyph_row): Reorder fringe_bitmap related fields.
- (struct it): Likewise.
-
- * w32term.c (fringe_bmp): Change to pointer.
- (max_fringe_bmp): New var.
- (w32_define_fringe_bitmap): Expand fringe_bmp.
- (w32_draw_fringe_bitmap): Check max_fringe_bmp.
- (w32_destroy_fringe_bitmap): Likewise.
-
-2004-09-29 Kim F. Storm <[email protected]>
-
- * fringe.c: Simplify last change.
- (lookup_fringe_bitmap): New function.
- (valid_fringe_bitmap_p, resolve_fringe_bitmap): Remove.
- (Fdestroy_fringe_bitmap): Use lookup_fringe_bitmap.
- Keep standard bitmaps in Vfringe_bitmaps.
- (Fdefine_fringe_bitmap): Use lookup_fringe_bitmap.
- (Fset_fringe_bitmap_face): Likewise.
-
- * dispextern.h (lookup_fringe_bitmap): Add prototype.
- (valid_fringe_bitmap_p): Remove prototype.
-
- * xdisp.c (handle_single_display_prop): Use lookup_fringe_bitmap.
-
-2004-09-29 Kim F. Storm <[email protected]>
-
- * fringe.c (destroy_fringe_bitmap, init_fringe_bitmap)
- (w32_init_fringe, w32_reset_fringes): Fix bootstrap (NULL rif).
-
- * dispextern.h (valid_fringe_bitmap_p): Fix prototype.
-
- * fringe.c (Vfringe_bitmaps): New variable.
- (syms_of_fringe): DEFVAR_LISP it.
- (valid_fringe_bitmap_p): Rename from valid_fringe_bitmap_id_p.
- Change arg to Lisp_Object and fail if not an integer.
- (get_fringe_bitmap_name, resolve_fringe_bitmap)
- (destroy_fringe_bitmap): New functions.
- (Fdestroy_fringe_bitmap): Change arg to bitmap symbol.
- Use destroy_fringe_bitmap. Remove symbol from Vfringe_bitmaps and
- clear its fringe property.
- (init_fringe_bitmap): Use destroy_fringe_bitmap instead of
- Fdestroy_fringe_bitmap.
- (Fdefine_fringe_bitmap): Add BITMAP arg specifying new or existing
- bitmap symbol; remove WHICH arg. Add symbol to Vfringe_bitmaps
- and set fringe property. Signal error if no free slots.
- (Fset_fringe_bitmap_face): Change arg to bitmap symbol.
- (Ffringe_bitmaps_at_pos): Return bitmap symbols instead of numbers.
-
- * xdisp.c (handle_single_display_prop): Fringe bitmaps are now
- symbols with a fringe property.
-
-2004-09-27 Kim F. Storm <[email protected]>
-
- * buffer.c (syms_of_buffer) <indicate-buffer-boundaries>:
- Doc fix. Format may now be a symbol or alist, not a cons.
-
- * fringe.c (update_window_fringes): Handle new formats of
- indicate-buffer-boundaries (symbol or alist). No longer
- allow a simple cons.
- (Ffringe_bitmaps_at_pos): Use nil value for no bitmap.
-
-2004-09-25 Jan Dj,Ad(Brv <[email protected]>
-
- * config.in: Rebuild.
-
-2004-09-24 Jan Dj,Ad(Brv <[email protected]>
-
- * config.in: Rebuild.
-
- * Makefile.in: Run setarch i386 ./temacs if exec-shield is present.
-
-2004-09-18 Stefan Monnier <[email protected]>
-
- * xterm.c (x_term_init): Work around a bug in some X servers.
-
-2004-09-18 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer) <default-major-mode>: Doc fix.
-
- * xdisp.c (try_window_reusing_current_matrix):
- Handle the case where we reach the old displayed text,
- out of sync with the old line boundary.
-
-2004-09-14 Stefan Monnier <[email protected]>
-
- * fileio.c (Finsert_file_contents): Fix case of replacement in a
- narrowed buffer.
-
-2004-09-14 Kim F. Storm <[email protected]>
-
- * puresize.h (PURESIZE_RATIO): Define based on BITS_PER_EMACS_INT.
-
- * xfaces.c (Qface_no_inherit): New var.
- (syms_of_xfaces): Intern and staticpro it.
- (Finternal_make_lisp_face, Finternal_set_lisp_face_attribute)
- (Finternal_copy_lisp_face, update_face_from_frame_parameter):
- Don't increment face_change_count when face has non-nil
- face-no-inherit property.
-
-2004-09-13 Stefan Monnier <[email protected]>
-
- * bytecode.c (BYTE_CODE_QUIT): Add missing AFTER_POTENTIAL_GC.
- (Fbyte_code): Remove dead code after `wrong_type_argument'.
-
- * alloc.c (Fgarbage_collect): Mark keyboards, gtk data, and specpdl
- before doing the mark_stack_check_gcpros since they're not on the stack.
-
-2004-09-12 Kim F. Storm <[email protected]>
-
- * editfns.c (Fformat): Handle format strings with multiple text
- properties. Reverse text property list from the format string,
- so the positions are in increasing order.
-
-2004-09-10 Jan Dj,Ad(Brv <[email protected]>
-
- * xselect.c (x_reply_selection_request): XSync and UNBLOCK before
- x_uncatch_errors so that possible protocol errors are delivered.
-
-2004-09-10 Eli Zaretskii <[email protected]>
-
- * Makefile.in (msdos.o): Depend on buffer.h, commands.h, and
- blockinput.h.
- (dosfns.o): Depend on blockinput.h, window.h, dispextern.h,
- charset.h, and coding.h
- (w16select.o): Depend on buffer.h, charset.h, coding.h, and composite.h.
- (term.o): Depend on window.h and keymap.h.
- (abbrev.o): Depend on syntax.h.
- (callint.o): Depend on keymap.h.
- (casefiddle.o): Depend on charset.h and keymap.h.
- (category.o): Depend on keymap.h.
- (coding.o): Depend on dispextern.h.
- (cmds.o): Depend on keyboard.h and keymap.h.
- (dispnew.o): Depend on indent.h and intervals.h.
- (doc.o): Depend on keymap.h.
- (editfns.o): Depend on frame.h.
- (emacs.o): Depend on dispextern.h.
- (fileio.o): Don't depend on ccl.h.
- (filelock.o): Depend on charset.h and coding.h.
- (frame.o): Depend on w32term.h and macterm.h.
- (insdel.o): Depend on region-cache.h.
- (keyboard.o): Depend on keymap.h, w32term.h, and macterm.h.
- (minibuf.o): Depend on $(INTERVALS_SRC) and keymap.h.
- (search.o): Depend on $(INTERVALS_SRC).
- (syntax.o): Depend on keymap.h, regex.h, and $(INTERVALS_SRC).
- (window.o): Depend on keymap.h, blockinput.h, $(INTERVALS_SRC),
- xterm.h, w32term.h, and macterm.h.
- (xdisp.o): Depend on keyboard.h, $(INTERVALS_SRC), xterm.h,
- w32term.h, and macterm.h.
- (xfaces.o): Depend on keyboard.h, $(INTERVALS_SRC),
- region-cache.h, xterm.h, w32term.h, and macterm.h.
- (bytecode.o): Depend on dispextern.h, frame.h, and xterm.h.
- (data.o): Depend on frame.h.
- (fns.o): Depend on keymap.h, xterm.h, and blockinput.h.
- (print.o): Depend on termchar.h and $(INTERVALS_SRC).
- (lread.o): Depend on $(INTERVALS_SRC), termhooks.h, and coding.h.
- (intervals.o): Depend on keymap.h.
-
- * msdos.c (msdos_set_cursor_shape, IT_display_cursor):
- Add debugging print-out to termscript.
-
-2004-09-09 Richard M. Stallman <[email protected]>
-
- * xdisp.c (decode_mode_spec): Use current buffer for most purposes.
-
-2004-09-08 Richard M. Stallman <[email protected]>
-
- * window.c (Fset_window_buffer): Doc fix.
-
- * xdisp.c (Fformat_mode_line): New arg BUFFER says which buffer to use.
-
-2004-09-08 Dan Nicolaescu <[email protected]>
-
- * minibuf.c (history_delete_duplicates): New variable.
- (read_minibuf): Use it.
- (syms_of_minibuf): Create the corresponding lisp variable.
-
-2004-09-08 Kim F. Storm <[email protected]>
-
- * xdisp.c (set_cursor_from_row): Also look at 'cursor' property in
- overlay just before point.
-
-2004-09-07 Luc Teirlinck <[email protected]>
-
- * buffer.h (struct buffer): Add auto_save_file_format field.
- * buffer.c (reset_buffer, init_buffer_once):
- Handle auto_save_file_format field.
- (syms_of_buffer): Add DEFVAR_PER_BUFFER for
- `buffer-auto-save-file-format'.
- * fileio.c: Delete declaration for removed Vauto_save_file_format.
- (build_annotations): Adapt to replacement of
- `auto-save-file-format' with the new buffer-local variable
- `buffer-auto-save-file-format'.
- (syms_of_fileio): Delete DEFVAR_LISP for auto-save-file-format.
-
-2004-09-07 Jason Rumney <[email protected]>
-
- * w32term.h (AppendMenuW_Proc): Move declaration from w32menu.c.
-
- * w32fns.c (w32_wnd_proc) <WM_MEASUREITEM, WM_DRAWITEM>:
- Handle Unicode menu titles.
-
-2004-09-07 Kim F. Storm <[email protected]>
-
- * xdisp.c (set_cursor_from_row): Fix last change. Only use 'cursor'
- property from text property or overlay strings at point.
-
-2004-09-07 Stefan Monnier <[email protected]>
-
- * xmenu.c (update_submenu_strings): YAILOM.
- (set_frame_menubar): Make sure last_i is initialized.
-
-2004-09-03 Jason Rumney <[email protected]>
-
- * w32menu.c (_widget_value): Add lname and lkey.
- (digest_single_submenu): Set lname and lkey in widget_value
- instead of name and key.
- (update_submenu_strings): New function.
- (set_frame_menubar): Remove call to inhibit_garbage_collection,
- call update_submenu_strings.
-
- * w32menu.c (globals_of_w32menu): Check for Unicode API.
- (digest_single_submenu, w32_menu_show): Encode menu strings as
- UTF-8 if Unicode API is available.
- (utf8to16): New function.
- (add_menu_item): Use it when calling Unicode API.
-
-2004-09-03 Kim F. Storm <[email protected]>
-
- * xdisp.c (set_cursor_from_row): Look for non-nil `cursor' property
- in overlay or text-property strings; set cursor on corresponding
- glyph rather than at end of the string.
-
-2004-09-02 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c (x_real_positions): Save the current window port and
- set a new one before obtaining the global coordinate.
- Use FRAME_MAC_WINDOW.
- (x_set_name, x_set_title): Encode title to UTF8.
- Use SetWindowTitleWithCFString.
- (Fx_server_version): Get correct OS version.
-
- * macmenu.c (add_menu_item): Remove unused variable `i'.
- Don't let separator items destroy refence constants of other menu items.
-
- * macterm.c (x_update_end): Move SetPortWindowPort to inside
- BLOCK_INPUT.
- (x_set_offset): Use FRAME_MAC_WINDOW.
-
- * xdisp.c (note_mouse_highlight): Set the mouse pointer shape to
- nontext_cursor if it is on a scroll bar.
-
- * s/darwin.h (LIBS_CARBON): New define to specify libraries for
- Carbon support.
- (LD_SWITCH_SYSTEM_TEMACS): Don't link with unused libstdc++.
- Use LIBS_CARBON.
-
-2004-09-02 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_set_name_internal): New function. Check if we shall call
- xfree before ENCODE_UTF_8.
- (x_set_name, x_set_title): Call x_set_name_internal.
-
-2004-08-31 NAKAMURA Toshikazu <[email protected]> (tiny change)
-
- * w32fns.c (w32_load_font): If a BDF font is already loaded, do not
- reload it.
-
-2004-08-30 Jan Dj,Ad(Brv <[email protected]>
-
- * macmenu.c (_widget_value): Add lname and lkey.
- (single_submenu): Set lname and lkey in widget_value
- instead of name and key.
- (update_submenu_strings): New function.
- (set_frame_menubar): Remove call to inhibit_garbage_collection,
- call update_submenu_strings.
-
- * xmenu.c (digest_single_submenu): Set lname and lkey in widget_value
- instead of name and key.
- (update_submenu_strings): New function.
- (set_frame_menubar): Remove call to inhibit_garbage_collection,
- call update_submenu_strings.
-
- * gtkutil.h (_widget_value): Added lname and lkey.
-
-2004-08-30 Steven Tamm <[email protected]>
-
- * macmenu.c (mac_menu_show): Remove shadowing of menu variable
- by using different names for inner loop variables.
-
-2004-08-27 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (set_frame_menubar): Reintroduce inhibit_garbage_collection
- from 2002-07-15T00:01:[email protected] so that strings from ENCODE_UTF_8 isn't GC:ed before used.
-
- * gtkutil.c (xg_create_frame_widgets): Compensate for tool bar when
- tool bar items is 0.
-
-2004-08-26 YAMAMOTO Mitsuharu <[email protected]>
-
- * macmenu.c (ENCODE_MENU_STRING): Added to handle multibyte
- strings in menu items.
- (single_submenu): Use ENCODE_MENU_STRING
- (mac_menu_show): Use ENCODE_MENU_STRING. Reset grabbed because
- button release isn't passed to event loop
- (add_menu_item): Use SetMenuItemWithCFString.
-
-2004-08-26 Steven Tamm <[email protected]>
-
- * fileio.c (Fread_file_name): Call x_file_dialog on carbon on
- tool-bar/menu click.
- * macfns.c (Fx_file_dialog): Implement using NavServices.
-
-2004-08-24 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_catch_errors_unwind): Do not XSync if display has closed.
-
- * xfns.c (x_window_to_frame, x_any_window_to_frame)
- (x_non_menubar_window_to_frame, x_menubar_window_to_frame)
- (x_top_window_to_frame): Return 0 if wdesc is None.
-
-2004-08-22 Richard M. Stallman <[email protected]>
-
- * process.c (process_send_signal) [SIGNALS_VIA_CHARACTERS,
- HAVE_TERMIOS]: If there's no char for this signal, drop through
- and use system calls.
-
- * bytecode.c (Fbyte_code) <unwind-protect>: Cannot GC.
-
-2004-08-20 Kim F. Storm <[email protected]>
-
- * process.c (wait_reading_process_output): Rename from
- wait_reading_process_input. All uses changed.
- (wait_reading_process_output_1): Rename from
- wait_reading_process_input_1. All uses changed.
-
- * dispnew.c (Fsleep_for): Remove obsolete code.
-
-2004-08-20 Kenichi Handa <[email protected]>
-
- * syntax.c (skip_chars): Fix for unibyte case.
-
-2004-08-19 Stefan Monnier <[email protected]>
-
- * syntax.c (char_quoted): Mixup byte/char pos.
- (back_comment): Fixup globals in all cases.
-
-2004-08-19 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_set_name, x_set_title): Encode title to UTF8 before
- passing it to gtk_window_set_title.
-
-2004-08-19 Kim F. Storm <[email protected]>
-
- * process.c (wait_reading_process_input): Clean up.
- Add wait_for_cell, wait_proc, and just_wait_proc args
- to avoid overloading `read_kbd' and `do_display' args.
- Change read_kbd arg to int. All callers changed.
-
- * process.c (process_send_signal): Use CDISABLE.
-
- * sysdep.c (child_setup_tty, init_sys_modes): Use CDISABLE.
-
-2004-08-18 Kim F. Storm <[email protected]>
-
- * process.c (Faccept_process_output): Add arg JUST-THIS-ONE;
- forward to wait_reading_process_input via DO_DISPLAY arg.
- (wait_reading_process_input): If DO_DISPLAY < 0 for a process
- object, only process output from that process; also inhibit
- running timers if DO_DISPLAY==-2.
-
-2004-08-17 Kim F. Storm <[email protected]>
-
- * process.c (process_send_signal): Fix last change--use
- _POSIX_VDISABLE instead of CVDISABLE when available.
-
-2004-08-16 Richard M. Stallman <[email protected]>
-
- * sysdep.c (child_setup_tty) [SIGNALS_VIA_CHARACTERS]:
- Set VQUIT and VINTR chars to the standard ones if they are unset.
- [AIX]: Don't do that here. And don't force VINTR to standard
- when SIGNALS_VIA_CHARACTERS.
-
- * process.c (process_send_signal)
- [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
- Do nothing if the character is CVDISABLE.
-
- * xfaces.c (merge_face_ref): Specifying `unspecified' is a no-op.
-
- * intervals.c (move_if_not_intangible):
- Force POSITION to be between BEGV and ZV.
-
-2004-08-14 John Paul Wallington <[email protected]>
-
- * buffer.c (Frestore_buffer_modified_p): Doc fix.
-
- * fileio.c (Fread_file_name): Doc fix.
-
- * minibuf.c (syms_of_minibuf) <completion-ignore-case>: Doc fix.
-
-2004-08-09 Luc Teirlinck <[email protected]>
-
- * keymap.c (Fmake_keymap, Fmap_keymap, Fwhere_is_internal): Doc fixes.
-
-2004-08-08 Luc Teirlinck <[email protected]>
-
- * keyboard.c: Declare Qdisabled_command_function instead of
- Qdisabled_command_hook.
- (Fcommand_execute): Use Qdisabled_command_function instead of
- Qdisabled_command_hook.
- (syms_of_keyboard): Ditto.
-
-2004-08-07 Luc Teirlinck <[email protected]>
-
- * keymap.c (Flocal_key_binding, Fglobal_key_binding)
- (syms_of_keymap) <key-translation-map>: Doc fixes.
-
-2004-08-07 Stefan Monnier <[email protected]>
-
- * window.c (window_list_1): YAILOM.
-
- * fileio.c (make_temp_name): Handle multibyte prefixes.
-
-2004-08-06 Luc Teirlinck <[email protected]>
-
- * keyboard.c (syms_of_keyboard) <overriding-terminal-local-map>:
- Doc fix.
-
-2004-08-03 Kenichi Handa <[email protected]>
-
- * coding.c (decode_coding_string): Adjust coding->consumed, and
- etc. with shrinked_bytes.
-
-2004-08-03 Kim F. Storm <[email protected]>
-
- * indent.c (compute_motion): Fix check for full width window
- in non-window case. Do not count left truncation glyph on
- window systems.
-
-2004-08-02 Luc Teirlinck <[email protected]>
-
- * data.c (Finteractive_form): Doc fix.
-
-2004-08-02 Kim F. Storm <[email protected]>
-
- * indent.c (compute_motion): Use actual window width if WIDTH is -1,
- properly accounting for continuation glyph on non-window systems.
- (Fcompute_motion): Use actual window width if WIDTH is nil, and
- actual window width/height if TOPOS is nil, properly accounting for
- continuation glyphs on non-window systems, and optional header lines.
- (vmotion): Let compute_motion calculate actual window width.
-
- * window.c (window_scroll_line_based): Let compute_motion
- calculate actual window width.
-
-2004-08-02 Kim F. Storm <[email protected]>
-
- * process.c (read_process_output): Use whole read buffer.
- Don't trigger adaptive read buffering on errors.
-
-2004-07-31 Luc Teirlinck <[email protected]>
-
- * keymap.c (Fset_keymap_parent, Fdefine_prefix_command): Doc fixes.
-
- * keyboard.c (syms_of_keyboard) <disable-point-adjustment>: Doc fix.
-
- * callint.c (Fcall_interactively): Doc fix.
-
-2004-07-30 Richard M. Stallman <[email protected]>
-
- * abbrev.c (Fexpand_abbrev): Undo previous change.
-
-2004-07-30 Kim F. Storm <[email protected]>
-
- * editfns.c (Fformat): Allocate extra (dummy) element in info.
-
-2004-07-28 Luc Teirlinck <[email protected]>
-
- * eval.c (Fdefvar, Fdefconst): Doc fixes.
-
-2004-07-27 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_in_display_line_to): Check BUFFER_POS_REACHED_P after
- we have ensured that the glyph fits on the current line (or returned
- MOVE_LINE_CONTINUED otherwise).
-
-2004-07-26 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_in_display_line_to): If overflow-newline-into-fringe
- is enabled, return MOVE_LINE_CONTINUED rather than MOVE_POS_MATCH_OR_ZV
- if target position is at end of display line but char is not a newline.
-
-2004-07-25 Richard M. Stallman <[email protected]>
-
- * window.c (coordinates_in_window): Return ON_SCROLL_BAR
- instead of ON_VERTICAL_BORDER, when on scroll bar.
- (Fcoordinates_in_window_p): Handle ON_SCROLL_BAR--return nil.
-
- * dispextern.h (enum window_part): Add ON_SCROLL_BAR.
-
- * window.c (Fcoordinates_in_window_p):
- Take account of FRAME_INTERNAL_BORDER_WIDTH.
-
- * alloc.c (check_cons_list): New function (contents commented out).
-
-2004-07-24 Luc Teirlinck <[email protected]>
-
- * xfaces.c (Fcolor_supported_p): Doc fix.
-
- * frame.c (Fselect_frame, Fset_frame_selected_window)
- (Fframe_visible_p, Fraise_frame): Doc fixes.
-
-2004-07-24 Richard M. Stallman <[email protected]>
-
- * keyboard.h (not_single_kboard_state): Declare.
-
- * fileio.c (Fwrite_region): Doc fix.
-
- * window.c (Fwindow_at): Take account of FRAME_INTERNAL_BORDER_WIDTH.
-
- * abbrev.c (Fexpand_abbrev): Run Qpre_abbrev_expand_hook
- only when a real abbrev is present.
-
- * xfns.c (x_icon_verify): New function.
- (Fx_create_frame): Use it.
-
-2004-07-22 Barry Fishman <[email protected]> (tiny change)
-
- * s/gnu-linux.h: Use GC_MARK_STACK if __amd64__ is defined.
-
-2004-07-21 Kim F. Storm <[email protected]>
-
- * window.h (struct glyph_matrix): New members nrows_scale_factor
- and ncols_scale_factor.
-
- * window.c (make_window): Initialize nrows_scale_factor and
- ncols_scale_factor members.
-
- * dispnew.c (margin_glyphs_to_reserve): Apply ncols_scale_factor.
- (allocate_matrices_for_frame_redisplay): Fix left/right margin mix-up.
- (required_matrix_height): Apply nrows_scale_factor.
- (required_matrix_width): Apply ncols_scale_factor.
-
- * xdisp.c (display_line): Increment nrows_scale_factor and set
- fonts_changed_p if past last allocated row.
- (append_glyph, append_composite_glyph, produce_image_glyph)
- (append_stretch_glyph): Increment ncols_scale_factor and set
- fonts_changed_p if current area is full.
-
-2004-07-21 Jan Dj,Ad(Brv <[email protected]>
-
- * widget.c (EmacsFrameDestroy): Don't abort if normal_gc is 0.
-
-2004-07-19 Luc Teirlinck <[email protected]>
-
- * window.c (Fpos_visible_in_window_p, Fset_window_hscroll)
- (Fwindow_inside_pixel_edges, Fwindow_end, Fset_window_point)
- (Fset_window_start, Fscroll_up, Fscroll_down)
- (Fother_window_for_scrolling, Fscroll_other_window)
- (Fsave_window_excursion, Fset_window_vscroll)
- (syms_of_window) <window-size-fixed>: Doc fixes.
-
-2004-07-19 KOBAYASHI Yasuhiro <[email protected]>
-
- * w32fns.c (Fx_file_dialog): Use ENCODE_FILE instead of
- ENCODE_SYSTEM for filenames.
-
-2004-07-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (sys_select): Block input around call to
- ReceiveNextEvent to prevent breakage. Correctly handle
- blocking on event queue only by calling ReceiveNextEvent
- instead of select (since GUI events aren't on an fd).
- (sys_read): Remove function
- * sysdep.c: Remove redefine of read to sys_read if HAVE_CARBON.
-
-2004-07-18 YAMAMOTO Mitsuharu <[email protected]>
-
- * mac.c (sys_select): Redo sys_select to use alarm-based
- polling instead of 1 sec timeouts (like solaris).
-
- * macterm.c (x_make_frame_visible): Comment in polling on
- frame creation.
-
- * keyboard.c: Undef SIGIO on Carbon.
-
- * atimer.c (alarm_signal_handler): Call alarm handlers after
- scheduling.
-
- * eval.c (Feval): Remove quit_char test.
-
- * process.c (wait_reading_process_input): Remove clearing
- stdin for select call on process input.
-
-2004-07-18 Luc Teirlinck <[email protected]>
-
- * xdisp.c (syms_of_xdisp) <window-scroll-functions>: Correct
- capitalization error in docstring.
-
-2004-07-17 Juanma Barranquero <[email protected]>
-
- * keyboard.c (not_single_kboard_state): Do nothing unless
- MULTI_KBOARD is defined.
-
-2004-07-17 Richard M. Stallman <[email protected]>
-
- * window.c (coordinates_in_window): Inside the window but outside
- its box to the L or R, return ON_VERTICAL_BORDER.
- (window_list_1): Rotate the list to start with WINDOW.
-
- * print.c (print_preprocess): Test for print_depth at limit
- before entering in being_printed.
-
- * keyboard.c (not_single_kboard_state): New function.
- (stuff_buffered_input): Now no-op only if no SIGTSTP.
-
- * frame.c (Fdelete_frame): If we're in single_bboard_state on
- this kboard, and we delete its last frame, go to any_kboard_state.
-
- * buffer.c (syms_of_buffer) <transient-mark-mode>: Doc fix.
-
-2004-07-15 KOBAYASHI Yasuhiro <[email protected]>
-
- * w32fns.c (Fx_file_dialog): Encode strings in system coding
- system before passing them to OS functions for display.
-
-2004-07-15 David Kastrup <[email protected]>
-
- * search.c (syms_of_search): Staticpro `saved_last_thing_searched'.
- Apparently fixes an abort condition.
-
-2004-07-14 Luc Teirlinck <[email protected]>
-
- * fileio.c (Fvisited_file_modtime): Return a list of two integers,
- instead of a cons.
-
-2004-07-14 K,Aa(Broly L$,1 q(Brentey <[email protected]>
-
- * keyboard.c (echo_dash): Do nothing if there already is a dash
- at the end of the echo string.
-
-2004-07-12 Kim F. Storm <[email protected]>
-
- * alloc.c (mark_object): Only look at Lisp_Misc_Save_Value
- if GC_MARK_STACK.
-
-2004-07-10 Luc Teirlinck <[email protected]>
-
- * buffer.c (Fswitch_to_buffer, Fpop_to_buffer): Doc fixes.
-
- * window.c (Fwindow_buffer, Fother_window, Fget_lru_window)
- (Fget_largest_window, Fget_buffer_window, Fdelete_windows_on)
- (Freplace_buffer_in_windows, Fset_window_buffer)
- (Fselect-window, Fdisplay-buffer, Fsplit_window): Doc fixes.
- (syms_of_window): Expand docstring of `display-buffer-function'.
-
-2004-07-09 Luc Teirlinck <[email protected]>
-
- * editfns.c (Ffloat_time, Fformat_time_string, Fdecode_time)
- (Fcurrent_time_string, Fcurrent_time_zone): Mention in docstrings
- that time values of the type (HIGH . LOW) are considered obsolete.
-
-2004-07-06 Luc Teirlinck <[email protected]>
-
- * keyboard.c (syms_of_keyboard): Fix `keyboard-translate-table'
- docstring.
-
- * fns.c (Fclear_string): Declare `len' before call to CHECK_STRING.
-
-2004-07-06 John Paul Wallington <[email protected]>
-
- * eval.c (Fdefmacro): Signal an error if NAME is not a symbol.
-
- * fns.c (Fclear_string): Signal an error if STRING is not a string.
-
-2004-07-05 Jan Dj,Ad(Brv <[email protected]>
-
- * macterm.c (mac_initialize_display_info): Use CGGetActiveDisplayList
- instead of CGMainDisplayID (only in OSX 10.2 and later).
-
-2004-07-04 John Paul Wallington <[email protected]>
-
- * fileio.c (read_file_name_completion_ignore_case): New variable.
- (syms_of_fileio): Declare and initialise it.
- (Fread_file_name): Bind `completion-ignore-case' to respect it.
-
-2004-07-03 Eli Zaretskii <[email protected]>
-
- * msdos.c (dos_rawgetc): Use make_number to produce Lisp objects
- for event.x and event.y.
-
-2004-07-01 Kenichi Handa <[email protected]>
-
- * w32select.c (Fw32_set_clipboard_data): Update `nbytes' correctly
- after getting a new string by pre-write-conversion.
-
-2004-06-30 Stefan Monnier <[email protected]>
-
- * xterm.c (x_detect_focus_change): Remove unused var `nr_events'.
- (x_calc_absolute_position): Remove unused var `child'.
-
- * xfaces.c (x_supports_face_attributes_p)
- (Fdisplay_supports_face_attributes_p): YAILOM.
- (tty_supports_face_attributes_p): Remove unused var `i'.
-
- * syntax.c (skip_chars): Remove unused labels fwd_unibyte_ok and
- back_unibyte_ok.
-
- * search.c (match_limit, Fmatch_data, Fset_match_data): YAILOM.
-
- * fontset.c (Fset_fontset_font): Remove unused vars `family' and
- `registry'.
-
- * Makefile.in (${etc}DOC): Fix file name of make-docfile.
-
-2004-06-30 Andreas Schwab <[email protected]>
-
- * image.c (CHECK_LIB_AVAILABLE): Add third parameter LIBRARIES.
- (Finit_image_library): Pass LIBRARIES through to
- CHECK_LIB_AVAILABLE. Declare parameters. Doc fix.
- (lookup_image_type): Pass Qnil as second argument to
- Finit_image_library.
-
- * lisp.h (Finit_image_library): Declare.
-
-2004-06-29 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (do_window_activate, do_window_deactivate): Remove.
- (XTread_socket): Send mouse button events to the toolbox
- dispatcher even when the mouse is grabbed. Don't process window
- activate events for non-Emacs windows. Replace function calls to
- do_window_activate and do_window_deactivate with their contents.
- Reset mouse grabbing status when a window is deactivated.
-
-2004-06-29 Steven Tamm <[email protected]>
-
- * macterm.c (mac_get_emulated_btn)
- (mac_event_to_emacs_modifiers): Fix emulated mouse button
- support to correctly mask out modifiers.
-
-2004-06-29 David Kastrup <[email protected]>
-
- * search.c (Fset_match_data): Allow buffer before end of list
- which can happen if set-match-data is using a pre-consed list.
-
-2004-06-28 Steven Tamm <[email protected]>
-
- * macterm.c (XTread_socket): Correctly set the frame position
- after the window is moved.
-
-2004-06-28 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_image_for_pixmap): Call g_object_unref on
- gpix and gmask just before return to avoid memory leak.
- (xg_get_image_for_pixmap): Add workaround for monochrome displays
- so insensitive and activated icons look ok.
-
-2004-06-27 Jason Rumney <[email protected]>
-
- * w32fns.c (file_dialog_callback): Disable edit control if set
- to directories only on CDN_INITDONE message.
- (Fx_file_dialog): Default to directories only when prompt starts
- with "Dired".
-
-2004-06-25 Kim F. Storm <[email protected]>
-
- * alloc.c (allocate_misc): Update total_free_markers.
- (free_misc): New function.
- (safe_alloca_unwind, free_marker): Use it.
-
- * lisp.h (free_misc): Add prototype.
-
- * fns.c (Fmapconcat, Fmapcar): Remove superfluous GCPROs.
-
-2004-06-24 Richard M. Stallman <[email protected]>
-
- * emacs.c (Vsignal_USR1_hook, Vsignal_USR2_hook): Definitions deleted.
- (syms_of_emacs): Lisp variables deleted.
-
-2004-06-23 David Kastrup <[email protected]>
-
- * search.c (Freplace_match): Adjust the match-data more thoroughly
- when replacing strings in the buffer.
- (Fmatch_data): When INTEGERS is non-nil and the last match was in
- a buffer, add the buffer as last element to the match data.
- (Fset_match_data): If an additional element of the match-data is a
- buffer, restore it to last_thing_searched.
- (save_search_regs): Save last_thing_searched as part of the match data.
- (restore_match_data): Restore it again.
-
-2004-06-23 Luc Teirlinck <[email protected]>
-
- * keymap.c (Ftext_char_description): Doc fix.
- * doc.c (Fsnarf_documentation): Doc fix.
-
-2004-06-22 Kim F. Storm <[email protected]>
-
- * fns.c (Fmapcar, Fmapconcat): GCPRO the args array.
-
- * lisp.h (struct Lisp_Save_Value): New member dogc.
- (SAFE_ALLOCA_LISP): Change second arg to number of elements.
- Set dogc member in Lisp_Save_Value object so it will be GC'ed.
- (SAFE_FREE_LISP): New macro.
-
- * alloc.c (safe_alloca_unwind): Clear dogc and pointer members.
- (make_save_value): Init new dogc member.
- (mark_object): Mark Lisp_Save_Value pointer array if dogc is set.
-
- * fns.c (Fmapconcat, Fmapcar): Use new SAFE_ALLOCA_LISP and
- SAFE_FREE_LISP macros.
-
-2004-06-22 Kim F. Storm <[email protected]>
-
- * lisp.h (SAFE_ALLOCA_LISP): New macro to allocate Lisp_Objects.
- Temporarily inhibits GC if memory is xmalloc'ed, as the Lisp_Objects
- in that memory area are unknown to GC. Add comments.
-
- * fns.c (Fmapconcat, Fmapcar): Use SAFE_ALLOCA_LISP.
-
-2004-06-21 Kim F. Storm <[email protected]>
-
- * lisp.h (MAX_ALLOCA): Define here.
- (safe_alloca_unwind): Add prototype.
- (USE_SAFE_ALLOCA, SAFE_ALLOCA, SAFE_FREE): New macros.
-
- * alloc.c (safe_alloca_unwind): New function.
-
- * casefiddle.c (casify_object): Use SAFE_ALLOCA.
-
- * charset.c (Fstring): Use SAFE_ALLOCA.
-
- * coding.c (MAX_ALLOCA): Remove define.
-
- * data.c (MAX_ALLOCA): Remove define.
- (Faset): Use SAFE_ALLOCA.
-
- * editfns.c (Fformat, Ftranspose_regions): Use SAFE_ALLOCA.
-
- * fns.c (string_make_multibyte, string_to_multibyte)
- (string_make_unibyte, Fmapconcat, Fmapcar): Use SAFE_ALLOCA.
- (MAX_ALLOCA): Remove define.
- (Fbase64_encode_region, Fbase64_encode_string)
- (Fbase64_decode_region, Fbase64_decode_string): Use SAFE_ALLOCA.
- (Fbase64_encode_region, Fbase64_encode_string): Fix potential
- memory leak if encoding fails.
-
- * xdisp.c (add_to_log): Use SAFE_ALLOCA.
-
-2004-06-21 Eli Zaretskii <[email protected]>
-
- * print.c (Fwith_output_to_temp_buffer): Doc fix.
-
-2004-06-20 Richard M. Stallman <[email protected]>
-
- * xfaces.c (Finternal_copy_lisp_face): Small cleanup; doc fix.
-
- * search.c (match_limit): Cleaner err msg when no match data available.
-
- * window.c (syms_of_window): Doc fix.
-
- * keyboard.c (command_loop_1): Handle values `only' and `identity'
- for Vtransient_mark_mode.
-
- * buffer.c (syms_of_buffer): Doc fix.
-
-2004-06-21 David Kastrup <[email protected]>
-
- * minibuf.c (Ftry_completion, Fall_completions): Do lazy binding
- and unbinding of `case-fold-search' according to
- `completion-ignore-case' around calls of string-match and
- predicates, respectively. Should give satisfactory performance
- in all relevant cases.
-
-2004-06-17 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_draw_image_foreground_1): Subtract slice.x/y from
- clip_x/y_origin.
-
- * fns.c (string_to_multibyte): Use xmalloc/xfree instead of alloca.
-
- * macfns.c (Fx_display_color_cells): Do not limit return value to 256.
-
- * macterm.c (mac_initialize_display_info): Initialize n_planes correctly
- on Mac OSX.
-
-2004-06-16 Luc Teirlinck <[email protected]>
-
- * buffer.c (syms_of_buffer): Clarify `fill-column' docstring.
-
-2004-06-16 Kim F. Storm <[email protected]>
-
- * dispextern.h (Vimage_types): Remove extern.
-
-2004-06-16 Miles Bader <[email protected]>
-
- * image.c (lookup_image_type): Initialize image type if necessary.
-
-2004-06-15 Kim F. Storm <[email protected]>
-
- * xdisp.c (try_cursor_movement): Exclude header line from scroll
- margin at top of window.
- (try_window_reusing_current_matrix): Calculate proper cursor position
- after scrolling up with non-zero scroll margin, as the old cursor
- position corresponds to value of PT before executing this command.
- (try_window_id): Consider scroll margin at bottom of window too;
- otherwise we fail to scroll when hl-line-mode is enabled.
-
- * syntax.c (skip_chars): Only recognize [:class:] when it has the
- proper format and class is a lower-case word.
-
-2004-06-14 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_get_image_for_pixmap): New function.
- (xg_get_gdk_pixmap_and_mask): Remove.
- (update_frame_tool_bar): Call xg_get_image_for_pixmap instead of
- xg_get_gdk_pixmap_and_mask.
-
- * xterm.h (struct x_display_info): Typo in comment fixed.
-
-2004-06-14 Juanma Barranquero <[email protected]>
-
- * dispextern.h (Vimage_types): Make it conditional on
- HAVE_WINDOW_SYSTEM.
-
- * image.c (Vimage_types): Move from xdisp.c.
- (Vimage_type_cache): New variable.
- (define_image_type): New argument indicating whether an image
- library was loaded; cache loaded status and return t on success,
- nil otherwise.
- (CACHE_IMAGE_TYPE, ADD_IMAGE_TYPE): New macros.
- (w32_delayed_load): New function to load an image library from a
- list of possible filenames.
- (init_xpm_functions, init_png_functions, init_jpeg_functions)
- (init_tiff_functions, init_gif_functions): Use `w32_delayed_load'.
- (CHECK_LIB_AVAILABLE): Call `define_image_library' with new argument.
- (Finit_image_library): New function, extracted from `init_image'.
- Try to initialize an image library on demand and cache whether we
- were successful or not.
- (syms_of_image): Initialize `Vimage_types' and
- `Vimage_type_cache'. Add recognized image types to Vimage_types.
- Export `init-image-library'.
- (init_image): Remove initialization of all image types, except xbm
- and pbm.
-
- * xdisp.c (Vimage_types): Delete (moved to image.c).
-
-2004-06-14 Andreas Schwab <[email protected]>
-
- * minibuf.c (Ftry_completion, Fall_completions, Ftest_completion):
- Avoid calling specbind when completion-regexp-list is empty.
-
-2004-06-13 Richard M. Stallman <[email protected]>
-
- * regex.h (CHAR_CLASS_MAX_LENGTH, re_wctype_t, re_wchar_t)
- (re_wctype, re_iswctype, re_wctype_to_bit):
- Non-function definitions moved here from regex.c.
-
- * regex.c (re_wctype, re_iswctype): Function defs longer static.
- (CHAR_CLASS_MAX_LENGTH, re_wctype_t, re_wchar_t)
- (re_wctype, re_iswctype, re_wctype_to_bit):
- Non-function definitions moved to regex.h.
-
- * window.c (Fselect_window): Doc fix.
-
- * syntax.c: Include regex.h.
- (skip_chars): New arg HANDLE_ISO_CLASSES. Callers changed.
- If requested, make a list of classes, then check the scanned
- chars for membership in them.
- (in_classes): New function.
- Doc fix.
-
- * keyboard.c (cmd_error): Don't call any_kboard_state
- if inside a recursive edit level.
-
-2004-06-13 K,Aa(Broly L$,1 q(Brentey <[email protected]>
-
- * keyboard.c (command_loop): Call any_kboard_state before
- command_loop_2 when at top level.
-
-2004-06-13 Andreas Schwab <[email protected]>
-
- * print.c (print_object): Always use %ld for printing EMACS_INT.
-
- * keyboard.c (cancel_hourglass_unwind): Return a value.
- (modify_event_symbol): Always use %ld for printing EMACS_INT.
- (Fexecute_extended_command): Likewise.
-
- * syntax.h (SYNTAX_ENTRY_FOLLOW_PARENT): Rename local variable to
- avoid clashes.
- (SYNTAX): Likewise.
- (SYNTAX_WITH_FLAGS): Likewise.
- (SYNTAX_MATCH): Likewise.
-
- * syntax.c (char_quoted): Avoid warning about undefined operation.
- (find_defun_start): Likewise.
- (scan_lists): Likewise.
- (INC_FROM): Likewise.
- (scan_sexps_forward): Likewise.
-
- * image.c: Include <ctype.h>.
-
- * xfaces.c (face_attr_equal_p): Declare parameters.
-
-2004-06-13 Kenichi Handa <[email protected]>
-
- * ccl.c (CCL_READ_CHAR): If hit EOF, set REG to -1.
-
-2004-06-12 Matthew Mundell <[email protected]>
-
- * eval.c (Fdefun): Signal an error if NAME is not a symbol.
-
-2004-06-12 Kenichi Handa <[email protected]>
-
- * ccl.c (CCL_CALL_FOR_MAP_INSTRUCTION): Save eof_ic in
- ccl_prog_stack_struct and update it.
- (CCL_INVALID_CMD): If CCL_DEBUG is defined, call ccl_debug_hook.
- (CCL_READ_CHAR): Get instruction counter from eof_ic, not from
- ccl->eof_ic on EOF.
- (ccl_debug_hook): New function.
- (struct ccl_prog_stack): New member eof_ic.
- (ccl_driver): Handle EOF in subrountine call correctly.
-
-2004-06-11 Kenichi Handa <[email protected]>
-
- * coding.c (encode_coding_string): Check CODING_FINISH_INTERRUPT.
-
-2004-06-11 Kim F. Storm <[email protected]>
-
- * emacs.c (shut_down_emacs): Inhibit redisplay during shutdown.
-
-2004-06-11 Juanma Barranquero <[email protected]>
-
- * keyboard.c (Fposn_at_point): Doc fix.
-
-2004-06-11 David Kastrup <[email protected]>
-
- * search.c (match_limit): Don't flag an error if match-data
- exceeding the allocated search_regs.num_regs gets requested, just
- return Qnil.
-
-2004-06-08 Miles Bader <[email protected]>
-
- * xfaces.c (push_named_merge_point): Return 0 when a cycle is detected.
-
-2004-06-07 Juanma Barranquero <[email protected]>
-
- * editfns.c (Fuser_login_name, Ffloat_time, Fencode_time)
- (Fcurrent_time_string, Fcurrent_time_zone)
- (Finsert_buffer_substring, Ftranspose_regions): Doc fixes.
-
-2004-06-07 Miles Bader <[email protected]>
-
- * xfaces.c (struct named_merge_point): New type.
- (push_named_merge_point): New function.
- (merge_named_face): New function.
- (merge_face_ref, face_at_buffer_position, face_at_string_position):
- Use `merge_named_face'.
- (merge_face_inheritance): Function removed.
- (merge_face_ref): Rename from `merge_face_vector_with_property'.
- Add new `err_msgs' and `named_merge_points' args. Return error
- status. Only print error messages if ERR_MSGS is true. Don't try to
- do :inherit attribute validation.
- (merge_face_heights): Handle `unspecified' in both directions.
- (merge_face_vectors): Rename `cycle_check' arg to `named_merge_points'.
- Call `merge_face_ref' instead of `merge_face_inheritance'.
- (Fdisplay_supports_face_attributes_p, Fface_attributes_as_vector)
- (compute_char_face, face_at_buffer_position)
- (face_at_string_position): Call `merge_face_ref' instead of
- `merge_face_vector_with_property'.
-
-2004-06-07 Kenichi Handa <[email protected]>
-
- * coding.c (find_safe_codings): Check NILP (safe_codings) only at
- the necessary places.
-
-2004-06-07 Kim F. Storm <[email protected]>
-
- * process.c (Fdelete_process): Undo 2004-05-28 change.
- Instead, call status_notify also for network process.
- (status_message): Use process instead of status as arg.
- Give messages "deleted" or "connection broken by remote peer" for
- an exited network process.
- (status_notify): Change call to status_message.
- (read_process_output): Increase readmax to 4096. Do not increase
- buffer size for datagram channels (default is now large enough).
-
-2004-06-06 Steven Tamm <[email protected]>
-
- * macfns.c (x_create_tip_frame): Fix Mac OS X 10.1 compilation
- problem due to newly defined variable.
-
-2004-06-06 Miles Bader <[email protected]>
-
- * xfaces.c (Fdisplay_supports_face_attributes_p): Give up
- immediately if non-interactive or not initialized.
-
-2004-06-05 Richard M. Stallman <[email protected]>
-
- * minibuf.c (Fcompleting_read): Doc fix.
-
-2004-06-05 Andreas Schwab <[email protected]>
-
- * macfns.c (x_create_tip_frame): Fix declaration after statement.
-
-2004-06-05 Juanma Barranquero <[email protected]>
-
- * keymap.c (Fdescribe_vector): Fix docstring.
- (Fkey_description, Fglobal_key_binding): Fix typo in docstring.
-
-2004-06-05 Miles Bader <[email protected]>
-
- * xfaces.c (tty_supports_face_attributes_p): Make sure the specified
- attributes have different values than the default face.
-
-2004-06-04 Eli Zaretskii <[email protected]>
-
- * xfaces.c (x_supports_face_attributes_p): Make this function
- conditional on HAVE_WINDOW_SYSTEM.
- (Fdisplay_supports_face_attributes_p) [HAVE_WINDOW_SYSTEM]:
- Don't call x_supports_face_attributes_p if it was not compiled in.
-
-2004-06-04 Miles Bader <[email protected]>
-
- * xfaces.c (tty_supports_face_attributes_p): New function, mostly
- from Ftty_supports_face_attributes_p.
- (x_supports_face_attributes_p): New function.
- (Ftty_supports_face_attributes_p): Function deleted.
- (Fdisplay_supports_face_attributes_p): New function.
- (syms_of_xfaces): Initialize Sdisplay_supports_face_attributes_p.
- (face_attr_equal_p): New function.
- (lface_equal_p): Use it.
-
-2004-06-03 Juanma Barranquero <[email protected]>
-
- * w32fns.c (Fx_display_grayscale_p, Fw32_send_sys_command)
- (Vw32_color_map): Fix typo in docstring.
- (Fx_create_frame, Fw32_find_bdf_fonts, Fx_show_tip)
- (Fw32_unregister_hot_key, Fw32_reconstruct_hot_key):
- Make argument names match their use in docstring.
-
-2004-06-02 Juanma Barranquero <[email protected]>
-
- Work around bugs/problems with MinGW builds of graphics libraries
- called from MSVC builds of Emacs.
-
- * image.c (lookup_image): Make pointer to img static.
- (png_read_from_memory): Disable "global" optimization.
-
-2004-06-01 Stefan Monnier <[email protected]>
-
- * eval.c (Fcondition_case): Fix usage. Simplify.
-
- * mem-limits.h (EXCEEDS_LISP_PTR) [USE_LSB_TAG]: Never true.
-
-2004-05-29 YAMAMOTO Mitsuharu <[email protected]>
-
- * macfns.c: Don't include ccl.h.
- [MAC_OSX]: Don't include QuickTime/QuickTime.h.
- [!MAC_OSX]: Don't include alloca.h, Windows.h, Gestalt.h, or
- TextUtils.h.
- (Fx_create_frame): Sync with xfns.c. Initialize cursor descriptors.
- (Fx_display_mm_height, Fx_display_mm_width): Calculate length from
- display height/width.
- (compute_tip_xy, Vx_max_tooltip_size): Declare.
- (unwind_create_tip_frame, compute_tip_xy): New functions.
- (x_create_tip_frame, Fx_show_tip, Fx_hide_tip): Sync with xfns.c.
- (syms_of_macfns): Initialize Qcancel_timer, Vx_max_tooltip_size,
- and last_show_tip_args.
-
- * macgui.h [!MAC_OSX]: Include Gestalt.h.
- (Cursor, No_Cursor): New defines.
- [!TARGET_API_MAC_CARBON] (SetPortWindowPort): New compatibility macro.
- [!TARGET_API_MAC_CARBON] (arrow_cursor): Declare.
-
- * macmenu.c (mac_menu_show, mac_dialog): Use SetPortWindowPort.
-
- * macterm.c: Don't include Gestalt.h.
- (enum mouse_tracking_type, mouse_tracking_in_progress): Remove.
- (XDrawLine, XClearArea, XClearWindow, mac_draw_bitmap)
- (mac_set_clip_rectangle, mac_reset_clipping, XCreatePixmap)
- (XFillRectangle, mac_draw_rectangle, mac_draw_string_common)
- (mac_copy_area, mac_copy_area_with_mask, x_update_end)
- (construct_mouse_click, XTmouse_position)
- (x_scroll_bar_report_motion, x_calc_absolute_position)
- (do_mouse_moved, do_zoom_window, mac_do_receive_drag)
- (XTread_socket, make_mac_frame): Use SetPortWindowPort.
- (note_mouse_movement): Clear the mouse face and reset the pointer
- shape when the pointer goes outside the frame without grabbing.
- (mac_front_window): New function.
- (mac_window_to_frame): New macro.
- (XTmouse_position, x_scroll_bar_report_motion, do_window_update)
- (do_window_activate, do_window_deactivate, do_app_resume)
- (do_app_suspend, do_mouse_moved, do_menu_choice, do_grow_window)
- (do_zoom_window, mac_do_receive_drag, XTread_socket)
- (mac_check_for_quit_char): Use mac_front_window and/or
- mac_window_to_frame.
- (x_scroll_bar_handle_click): Set `(PORTION . WHOLE)' part in a
- scroll-bar click event.
- (mac_define_frame_cursor): Change the pointer shape.
- (x_free_frame_resources): Reset tip_window to NULL when it is
- disposed of.
- [!TARGET_API_MAC_CARBON] (arrow_cursor): New variable.
- [!TARGET_API_MAC_CARBON] (do_init_managers): Initialize arrow_cursor.
- (do_window_update): Don't do anything if the updated window is the
- tooltip window.
- (do_mouse_moved): Handle mouse movement events here (previously in
- XTread_socket). Clear the mouse face if
- dpyinfo->mouse_face_hidden is set.
- (do_os_event, do_events): Remove (now in XTread_socket).
- (XTread_socket): Immediately return if interrupt_input_blocked.
- Loop until all the events in the queue are processed.
- Rearrange codes for mouse grabbing. Add tooltip support. Include the
- contents of do_os_event and do_events. Remove mouse movement
- handling (now in do_mouse_moved). Add the case where
- Vmouse_highlight has an integer value.
- (NewMacWindow): Remove.
- (make_mac_frame): Do what NewMacWindow previously did. Don't do
- excess initializations.
- (make_mac_terminal_frame): Previous initializations in
- make_mac_frame are moved here.
- (mac_initialize_display_info):
- Initialize dpyinfo->mouse_face_overlay and dpyinfo->mouse_face_hidden.
-
- * xdisp.c [MAC_OS] (No_Cursor): Remove variable.
- (define_frame_cursor1): Don't treat HAVE_CARBON as a special case.
-
-2004-05-29 Richard M. Stallman <[email protected]>
-
- * lisp.h (truncate_undo_list): Update decl.
-
- * alloc.c (undo_outer_limit): New variable.
- (syms_of_alloc): Defvar it.
- (Fgarbage_collect): Pass undo_outer_limit to truncate_undo_list.
-
- * undo.c (truncate_undo_list): New arg LIMITSIZE.
-
- * alloc.c (lisp_align_malloc): Check for base == 0
- regardless of HAVE_POSIX_MEMALIGN.
- Clean up HAVE_POSIX_MEMALIGN handling of `err'.
-
-2004-05-28 Stefan Monnier <[email protected]>
-
- * alloc.c: Undo Kim's recent changes and fix the same bug differently.
- (marker_blocks_pending_free): Remove.
- (Fgarbage_collect): Sweep after cleaning up undo-lists.
- Mark the undo lists after claning them up.
- Don't free block in marker_blocks_pending_free.
- (mark_buffer): Don't mark undo_list.
- (gc_sweep): Sweep hash-tables and strings first.
- Do free marker blocks that are empty.
-
-2004-05-28 Jim Blandy <[email protected]>
-
- * regex.c (print_partial_compiled_pattern): Add missing 'break'
- after 'case wordend'. For symbeg and symend, print to stderr,
- like the other cases.
-
-2004-05-28 Noah Friedman <[email protected]>
-
- * process.c (Fdelete_process): Do not call remove_process.
-
-2004-05-28 Stefan Monnier <[email protected]>
-
- * alloc.c (struct backtrace): Remove.
- (Fgarbage_collect): Use the new mark_backtrace.
-
- * eval.c (mark_backtrace): New function.
-
- * minibuf.c (run_exit_minibuf_hook): New function.
- (read_minibuf_unwind): Don't run exit-minibuffer-hook any more.
- (read_minibuf): Use separate unwind handler to run exit-minibuf-hook.
-
-2004-05-27 Kim F. Storm <[email protected]>
-
- * xdisp.c (back_to_previous_visible_line_start): Skip backwards
- over display properties, e.g. images, that replace buffer text.
-
-2004-05-25 Kim F. Storm <[email protected]>
-
- * alloc.c (marker_blocks_pending_free): New var.
- (gc_sweep): Store free marker blocks on that list.
- (Fgarbage_collect): Free them after undo-list cleanup.
-
- * process.c (wait_reading_process_input): Check connect_wait_mask
- before actually accepting connection in case it has already been
- accepted due to recursion.
-
-2004-05-23 K,Aa(Broly L$,1 q(Brentey <[email protected]>
-
- * coding.c (Fset_safe_terminal_coding_system_internal):
- Set suppress_error in safe_terminal_coding, not terminal_coding.
-
-2004-05-22 Richard M. Stallman <[email protected]>
-
- * alloc.c (Fmake_string): Doc fix.
-
- * buffer.c (clone_per_buffer_values): Copy the alist of local vars,
- and the alist pairs too.
-
- * casefiddle.c (casify_object): Return OBJ unchanged if not real char.
-
- * emacs.c (main): Update copyright year.
-
- * fileio.c (Fread_file_name): Expand DIR if not absolute.
-
- * insdel.c (del_range_2, replace_range): Don't write an anchor
- if the gap is empty.
-
- * xdisp.c (try_scrolling): If scroll-up-aggressively or
- scroll-down-aggressively is small but positive, put point
- near the screen edge.
-
-2004-05-22 Juanma Barranquero <[email protected]>
-
- * keymap.c (Fdefine_key): Doc fix.
-
-2004-05-22 Kim F. Storm <[email protected]>
-
- * alloc.c (struct backtrace): Add debug_on_exit member.
- (Fgarbage_collect): Clear out buffer undo_list markers after gc_sweep.
- Identify those markers as Lisp_Misc_Free objects. Clear car and cdr of
- the removed cons cells.
- (mark_object): Undo previous change - disallow Lisp_Misc_Free objects.
- (gc_sweep): Clear cons_blocks before sweeping strings, so we don't have
- any cons cells pointing to unallocated stings.
- Do not lisp_free any marker blocks, as there may still be pointers
- to them from buffer undo lists at this stage of GC.
-
- * keyboard.c (struct backtrace): Add debug_on_exit member.
- (Fcommand_execute): Clear it.
-
-2004-05-20 Luc Teirlinck <[email protected]>
-
- * intervals.c (lookup_char_property): Do not prematurely return nil.
-
-2004-05-19 Jim Blandy <[email protected]>
-
- Add support for new '\_<' and '\_>' regexp operators, matching the
- beginning and end of symbols.
-
- * regex.c (enum syntaxcode): Add Ssymbol.
- (init_syntax_once): Set the syntax for '_' to Ssymbol, not Sword.
- (re_opcode_t): New opcodes `symbeg' and `symend'.
- (print_partial_compiled_pattern): Print the new opcodes properly.
- (regex_compile): Parse the new operators.
- (analyse_first): Skip sym(beg|end) (they match only the empty string).
- (mutually_exclusive_p): `symend' is mutually exclusive with \s_ and
- \sw; `symbeg' is mutually exclusive with \S_ and \Sw.
- (re_match_2_internal): Match symbeg and symend.
-
- * search.c (trivial_regexp_p): \_ is no longer a trivial regexp.
-
-2004-05-19 Kim F. Storm <[email protected]>
-
- * .gdbinit (xsymbol): Fix last change.
-
-2004-05-18 Stefan Monnier <[email protected]>
-
- * .gdbinit (xprintstr): New fun.
- (xstring, xprintsym): Use it.
-
- * w32proc.c (create_child): Use INTMASK.
-
- * alloc.c (Fgarbage_collect): Do all the marking before flushing
- unmarked elements of the undo list.
-
-2004-05-18 David Ponce <[email protected]>
-
- * print.c (print): Reset print_depth before to call print_object.
-
-2004-05-18 Jason Rumney <[email protected]>
-
- * w32console.c: Prefix RIF functions with w32con_ to avoid
- namespace clash with functions in term.c and w32term.c.
-
- * w32menu.c (add_menu_item, w32_menu_display_help)
- [USE_LISP_UNION_TYPE]: Cast from Lisp_Object using i member.
-
- * w32term.h (display_x_get_resource, vga_stdcolor_name): Add prototype.
-
-2004-05-18 Eli Zaretskii <[email protected]>
-
- * lisp.h (DECL_ALIGN): Remove restriction on MS-DOS systems.
-
- * msdos.c (syms_of_msdos): Initialize dos-unsupported-char-glyph
- with make_number.
- (IT_write_glyphs): Extract glyph from dos-unsupported-char-glyph
- with XINT.
-
-2004-05-18 Kim F. Storm <[email protected]>
-
- * blockinput.h (INPUT_BLOCKED_P): New macros.
-
- * keyboard.c (Frecursive_edit): Return immediately if input blocked.
- (Ftop_level): Unblock input if blocked.
-
- * buffer.h (GET_OVERLAYS_AT): New macro.
- * msdos.c (IT_note_mouse_highlight): Use it.
- * textprop.c (get_char_property_and_overlay): Use it.
- * xdisp.c (next_overlay_change, note_mouse_highlight): Use it.
- * xfaces.c (face_at_buffer_position): Use it.
-
- * print.c (print_object): Increase buf size.
-
-2004-05-17 Jason Rumney <[email protected]>
-
- * w32fns.c (Fw32_register_hot_key, Fw32_unregister_hot_key)
- (Fw32_toggle_lock_key) [USE_LISP_UNION_TYPE]: Cast from
- Lisp_Object using i member.
- (w32_quit_key): Rename from Vw32_quit_key, and make an int.
- (syms_of_w32fns, globals_of_w32fns): Use Lisp_Object and int
- consistently.
-
- * w32proc.c (create_child): Use make_number instead of masking pid.
-
- * w32fns.c (w32_color_map_lookup): Return a Lisp_Object.
- (x_to_w32_charset, w32_to_x_charset, w32_to_all_x_charsets):
- Use EQ to compare Lisp_Objects.
- (w32_parse_hot_key): Use int for lisp_modifiers consistently.
-
- * w32term.c (w32_num_mouse_buttons): Rename from
- Vw32_num_mouse_buttons and make it an int.
-
- * w32.c (init_environment): Use it.
-
- * w32fns.c (w32_wnd_proc): Likewise.
-
- * w32proc.c (w32_pipe_read_delay): Rename from
- Vw32_pipe_read_delay and make it an int.
-
- * w32.c (_sys_read_ahead): Use it.
-
- * lisp.h (egetenv) [USE_CRT_DLL]: Remove condition.
-
- * w32proc.c (create_child) [USE_LSB_TAG]: Don't try to mask pid.
-
- * w32inevt.c (w32_console_mouse_position, do_mouse_event)
- (key_event): Don't mix Lisp_Object and int.
-
- * w32heap.c (init_heap) [USE_LSB_TAG]: Don't check heap location.
-
- * keyboard.c (kbd_buffer_get_event): Don't use event->code and
- modifiers in language change event.
-
-2004-05-17 Kim F. Storm <[email protected]>
-
- * alloc.c (mark_object): Ignore Lisp_Misc_Free objects.
- Such objects may be freed markers which still exist on an undo list.
-
-2004-05-16 Juanma Barranquero <[email protected]>
-
- * data.c (Fset_default): Make argument names match their use in
- docstring.
-
-2004-05-15 Andreas Schwab <[email protected]>
-
- * emacs.c (gdb_array_mark_flag): Define.
- * .gdbinit: Mask off gdb_array_mark_flag from vector sizes.
-
-2004-05-15 Eli Zaretskii <[email protected]>
-
- * lisp.h (DECL_ALIGN) [MSDOS]: Don't define DECL_ALIGN to use
- __attribute__((__aligned__)), so that USE_LSB_TAG would not become
- defined for the MS-DOS build.
-
-2004-05-14 Stefan Monnier <[email protected]>
-
- * w32fns.c (Fw32_define_rgb_color): Avoid XSET.
-
-2004-05-14 Kenichi Handa <[email protected]>
-
- * ccl.c (Fccl_execute_on_string): Fix setting elements of STATUS.
-
-2004-05-14 YAMAMOTO Mitsuharu <[email protected]>
-
- * lisp.h (Vx_resource_name, Vx_resource_class): Move from xfns.c
- section to frame.c section.
- (Fxw_display_color_p, Fx_file_dialog): Declare if
- HAVE_WINDOW_SYSTEM defined.
-
- * macfns.c (Fx_create_frame): Fix int/Lisp_Object mixup.
-
- * macmenu.c (set_frame_menubar): Use NILP to test a lisp value.
-
- * macterm.c (mac_get_emulated_btn, mac_event_to_emacs_modifiers)
- (mac_get_mouse_btn): Use NILP and EQ to test/compare lisp values.
- (XTread_socket): Fix int/Lisp_Object mixup.
- (mac_check_for_quit_char): Fix pointer/Lisp_Object mixup.
-
- * macterm.h (struct frame, struct face, struct image)
- (display_x_get_resource, Fx_display_color_p)
- (Fx_display_grayscale_p, Fx_display_planes, x_free_gcs):
- Add prototypes.
-
-2004-05-14 Kim F. Storm <[email protected]>
-
- * process.c (wait_reading_process_input): Make reentrant.
- Make Available and Connecting non-static. Save and restore value
- of waiting_for_user_input_p.
-
-2004-05-13 Kim F. Storm <[email protected]>
-
- * keyboard.c (mark_kboards): Don't mark x and y members
- that are overloaded in selection request events.
-
-2004-05-13 Stefan Monnier <[email protected]>
-
- * lisp.h (USE_LSB_TAG): Make it the default when it is known to work.
-
-2004-05-13 Glenn Morris <[email protected]>
-
- * window.c (Fdisplay_buffer, Fsplit_window)
- (split-height-threshold): Doc fix.
-
-2004-05-13 Juanma Barranquero <[email protected]>
-
- * xfaces.c (Ftty_supports_face_attributes_p)
- (Finternal_copy_lisp_face): Fix typo in docstring.
- (Finternal_get_lisp_face_attribute): Fix docstring.
-
-2004-05-12 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (syms_of_xfns): Provide x-toolkit also for GTK.
-
-2004-05-11 Steven Tamm <[email protected]>
-
- * macfns.c (Fx_create_frame): Default to using tool-bar by
- setting tool-bar-lines to 1 in default-frame-alist.
-
-2004-05-11 YAMAMOTO Mitsuharu <[email protected]>
-
- * image.c (xpm_scan, xpm_make_color_table_v, xpm_put_color_table_v)
- (xpm_get_color_table_v, xpm_make_color_table_h)
- (xpm_put_color_table_h, xpm_get_color_table_h)
- (xpm_str_to_color_key, xpm_load_image, xpm_load)
- (syms_of_image): Support XPM on Carbon Emacs. Does not
- depend on libXpm, but only supports XPM version 3 without extensions.
-
-2004-05-11 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (x_flush, XTframe_up_to_date): Use FRAME_MAC_P
- instead of FRAME_X_P.
-
-2004-05-11 Kim F. Storm <[email protected]>
-
- * process.c (read_process_output): Grow decoding_buf when needed;
- this could cause a crash in allocate_string and compact_small_strings.
-
-2004-04-29 Jim Blandy <[email protected]>
-
- * regex.c (mutually_exclusive_p): In 'case wordbeg', compare op2
- against proper opcode.
-
-2004-05-10 Juanma Barranquero <[email protected]>
-
- * process.c (Fstart_process): Fix docstring.
-
- * charset.c (Fget_unused_iso_final_char): Fix typos in docstring.
- (Fchar_bytes, Fchar_width, Fstring_width, Fchar_direction)
- (Fsplit_char, Fchar_charset): Make argument names match their use
- in docstring.
-
-2004-05-10 Richard M. Stallman <[email protected]>
-
- * print.c (print_preprocess): Use being_printed, loop_count and
- halftail to detect overdeep nesting and cyclic cdr chains.
-
-2004-05-10 Andreas Schwab <[email protected]>
-
- * lisp.h (Fmake_symbolic_link): Declare.
-
- * fileio.c (Frename_file): Remove extra argument in call to
- Fmake_symbolic_link.
-
-2004-05-10 Kim F. Storm <[email protected]>
-
- * xdisp.c (calc_line_height_property): Use string position when
- object is a string.
-
-2004-05-10 Kenichi Handa <[email protected]>
-
- * print.c (temp_output_buffer_setup): Bind inhibit-read-only and
- inhibit-modification-hooks to t temporarily before calling
- Ferase_buffer.
-
- * xfns.c (x_create_tip_frame): Bind inhibit-read-only and
- inhibit-modification-hooks to t temporarily before calling
- Ferase_buffer.
-
- * w32fns.c (x_create_tip_frame): Bind inhibit-read-only and
- inhibit-modification-hooks to t temporarily before calling
- Ferase_buffer.
-
- * fns.c (count_combining): Delete it.
- (concat): Don't check combining bytes.
-
-2004-05-09 Jason Rumney <[email protected]>
-
- * w32fns.c (Vw32_ansi_code_page): New Lisp variable.
- (globals_of_w32fns): Set it.
-
-2004-05-09 Piet van Oostrum <[email protected]>
-
- * data.c (Fquo): Simplify.
-
-2004-05-08 Peter Whaite <[email protected]> (tiny change)
-
- * data.c (Fquo): If any argument is float, do the computation in
- floating point.
-
-2004-05-08 Juanma Barranquero <[email protected]>
-
- * process.c (Fwaiting_for_user_input_p, Fmake_network_process)
- (Fset_process_query_on_exit_flag, Vprocess_adaptive_read_buffering):
- Fix spelling of Emacs on docstring.
- (Fset_process_coding_system, Fprocess_coding_system)
- (Fset_process_filter_multibyte, Fprocess_filter_multibyte_p):
- Make argument names match their use in docstring.
- (Fprocess_id, Fprocess_query_on_exit_flag, Finterrupt_process):
- Fix docstring.
-
- * editfns.c (Finsert_buffer_substring): Make argument names match their
- use in docstring.
-
- * syntax.c (Fmodify_syntax_entry): Fix docstring.
-
-2004-05-07 Steven Tamm <[email protected]>
-
- * macterm.c (mac_check_for_quit_char): Adding BLOCK_INPUT
- around call to ReceiveEvent to avoid certain crashes.
-
-2004-05-07 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (mac_draw_line_to_pixmap, XCreatePixmapFromBitmapData)
- (mac_fill_rectangle_to_pixmap, mac_draw_rectangle_to_pixmap)
- (mac_copy_area_to_pixmap, mac_copy_area_with_mask_to_pixmap):
- Save/restore the current graphics port and device handle when
- drawing into an offscreen graphics world.
-
- * image.c [MAC_OS] (XPutPixel, XGetPixel, image_load_qt_1)
- (gif_load): Likewise.
-
-2004-05-07 Juanma Barranquero <[email protected]>
-
- * window.c (Fset_window_buffer): Fix docstring.
-
-2004-05-06 Thien-Thi Nguyen <[email protected]>
-
- * emacs.c (main) [VMS]: Fix var ref.
-
-2004-05-06 Romain Francoise <[email protected]>
-
- * data.c (Fsetq_default): Fix docstring.
-
-2004-05-06 Jason Rumney <[email protected]>
-
- * image.c (Display) [HAVE_NTGUI]: Redefine while loading xpm.h
- to avoid name clash.
-
-2004-05-04 Jan Dj,Ad(Brv <[email protected]>
-
- * fileio.c (barf_or_query_if_file_exists): Use lstat.
- (Frename_file): Handle renaming of symlinks across file systems.
- (Frename_file): Put symlink handling inside #ifdef S_IFLNK.
-
-2004-05-04 Kim F. Storm <[email protected]>
-
- * xdisp.c (Qtotal): New var.
- (syms_of_xdisp): Intern and staticpro it.
- (calc_line_height_property): New arg total. Set it if
- line-spacing property has format (total . VALUE).
- (x_produce_glyphs): Ignore line-spacing if line-height is 0.
- Handle total line-spacing property.
-
-2004-05-03 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_update_scrollbar_pos): Call XClearWindow to clear
- "under" scroll bar when size/position changes.
-
-2004-05-03 Jason Rumney <[email protected]>
-
- * makefile.nt: Remove.
-
-2004-05-02 Eli Zaretskii <[email protected]>
-
- * syntax.h (SET_RAW_SYNTAX_ENTRY, SYNTAX_ENTRY_INT):
- Avoid compiler warnings.
-
- * Makefile.in (region-cache.o): Depend on config.h.
-
-2004-05-02 Romain Francoise <[email protected]>
-
- * indent.c (compute_motion): Save vpos in prev_vpos when dealing
- with continuation lines, too.
-
-2004-05-02 Thien-Thi Nguyen <[email protected]>
-
- * syssignal.h (init_signals): Move decl outside `#ifdef POSIX_SIGNALS'.
-
-2004-05-01 Stefan Monnier <[email protected]>
-
- * xdisp.c (calc_line_height_property): YAILOM (yet another
- int/Lisp_Object mixup).
-
-2004-05-01 Eli Zaretskii <[email protected]>
-
- * msdos.c (top-level): Add "#pragma pack(0)" after <dir.h>, to
- undo bad effect of pack(4) in some versions of system headers.
-
-2004-05-01 Jason Rumney <[email protected]>
-
- * w32term.c (x_draw_hollow_cursor): Sync with xterm.c.
-
-2004-04-30 Kim F. Storm <[email protected]>
-
- * buffer.c (syms_of_buffer) <line-spacing>: Allow float value.
- (syms_of_buffer) <cursor-type>: Doc fix.
-
- * dispextern.h (struct it): Remove member use_default_face.
- Add members override_ascent, override_descent, override_boff.
-
- * xdisp.c (init_iterator): Handle line-spacing float value.
- Initialize override_ascent member.
- (append_space_for_newline): Reset override_ascent.
- Remove use_default_face.
- (calc_line_height_property): New function to calculate value of
- line-height and line-spacing properties. Look at overlays, too.
- Set override_ascent, override_descent, override_boff members when
- using another face than the current face. Float values are now
- relative to the frame default font, by default; accept a cons
- of ratio and face name to specify value relative to a specific face.
- (x_produce_glyphs): Use calc_line_height_property.
- Use override_ascent etc. when set to handle different face heights.
- A negative line-spacing property value is interpreted as a total
- line height, rather than inter-line spacing.
- (note_mouse_highlight): Allocate room for 40 overlays initially.
-
-2004-04-29 Stefan Monnier <[email protected]>
-
- * data.c (Fsubr_name): New fun.
- (syms_of_data): Defsubr it.
-
-2004-04-29 Kim F. Storm <[email protected]>
-
- * xdisp.c (null_glyph_slice): New var.
- (append_glyph, append_composite_glyph, append_stretch_glyph):
- Use it to initialize glyph slice.
-
-2004-04-27 Stefan Monnier <[email protected]>
-
- * xdisp.c (x_produce_glyphs): Fix the proverbial int/Lisp_Object mixup.
- (on_hot_spot_p): Make sure we always return a value.
- (Flookup_image_map): Remove unused var ix and iy.
- (note_mode_line_or_margin_highlight): Remove unused var `image'.
-
-2004-04-27 Eli Zaretskii <[email protected]>
-
- * msdos.c (init_environment): If one of the TMP... environment
- variables is set to a drive letter without a trailing slash,
- append a slash.
-
-2004-04-27 Matthew Mundell <[email protected]>
-
- * editfns.c (lisp_time_argument): Provide externally.
-
- * fileio.c (Fset_file_times): New function.
- (syms_of_fileio): Intern and staticpro it.
-
-2004-04-27 Kim F. Storm <[email protected]>
-
- * xdisp.c (x_produce_glyphs): Fix last change; handle newline in
- header line strings.
-
- * dispextern.h (struct it): New member use_default_face.
-
- * xdisp.c (Qline_height): New variable.
- (syms_of_xdisp): Intern and staticpro it.
- (append_space_for_newline): Partially undo 2004-04-25 change;
- add default_face_p arg, and restore callers.
- Clear it->use_default_face after use.
- (x_produce_glyphs): Set default font for ascii char if
- it->use_default_font is set. Change line-spacing property to set
- just extra line spacing. Handle new line-height property.
-
-2004-04-26 Andreas Schwab <[email protected]>
-
- * print.c (print_object): Print non-ascii characters in bool
- vector representation as octal escapes.
-
- * lisp.h (BOOL_VECTOR_BITS_PER_CHAR): Define.
- * print.c (print_object): Use it instead of BITS_PER_CHAR for
- bool vectors.
- * lread.c (read1): Likewise.
- * alloc.c (Fmake_bool_vector): Likewise.
- * data.c (Faref, Faset): Likewise.
- * fns.c (Fcopy_sequence, concat, internal_equal, Ffillarray)
- (mapcar1): Likewise.
-
-2004-04-26 Steven Tamm <[email protected]>
-
- * lread.c (init_lread): Fix typo in HAVE_CARBON test logic.
-
-2004-04-26 Miles Bader <[email protected]>
-
- * lisp.h (CYCLE_CHECK): Macro moved from xfaces.c.
-
-2004-04-26 Juanma Barranquero <[email protected]>
-
- * buffer.c (Fpop_to_buffer): Fix docstring.
-
-2004-04-26 Steven Tamm <[email protected]>
-
- * lread.c (init_lread): Don't display missing lisp directory
- warnings with Carbon Emacs because self-contained bundled Emacs
- may be built without correct installation path.
-
-2004-04-25 Kim F. Storm <[email protected]>
-
- * macterm.c (x_draw_hollow_cursor): Fix height of box for narrow lines.
-
- * xterm.c (x_draw_hollow_cursor): Fix height of box for narrow lines.
-
- * xdisp.c (append_space_for_newline): Rename from append_space.
- Remove DEFAULT_FACE_P arg; always use current face. Callers changed.
- (x_produce_glyphs): Handle line-spacing property on newline char.
- If value is t, adjust ascent and descent to fit current row height.
- If value is an integer or float, set extra_line_spacing to integer
- value, or to float value x current line height.
-
-2004-04-23 Kenichi Handa <[email protected]>
-
- * fontset.c (Finternal_char_font): If POSITION is nil, return
- font for displaying CH with the default face.
-
-2004-04-23 Juanma Barranquero <[email protected]>
-
- * makefile.w32-in: Add "-*- makefile -*-" mode tag.
-
-2004-04-21 Stefan Monnier <[email protected]>
-
- * lisp.h (XINT) [EXPLICIT_SIGN_EXTEND && !NO_UNION_TYPE]:
- Don't make assumptions about the relative place of i and val.
- (EQ) [!NO_UNION_TYPE]: Don't forget to check the type match as well.
-
-2004-04-21 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct glyph_slice): New struct.
- (struct glyph): New member slice.
- (GLYPH_SLICE_EQUAL_P): New macro.
- (GLYPH_EQUAL_P): Use it.
- (struct glyph_string): New member slice.
- (struct it_slice): New struct.
- (struct it): New member slice, add member to stack too.
- New member constrain_row_ascent_descent_p.
- (image_ascent): Add prototype.
-
- * dispnew.c (buffer_posn_from_coords): Return full image width
- and height even for image slices (posn is relative to full image).
- (marginal_area_string): Adjust x0,y0 for image slice.
-
- * image.c (image_ascent): Add slice arg; calculate ascent for
- image slice (or full image).
-
- * keyboard.c (Fposn_at_x_y, Fposn_at_point): New defuns.
- (syms_of_keyboard): Defsubr them.
-
- * lisp.h (pos_visible_p): Fix prototype.
-
- * macterm.c (x_draw_relief_rect): Add top_p and bot_p args.
- (x_draw_glyph_string_box): Fix call to x_draw_relief_rect.
- (x_draw_image_foreground, x_draw_image_relief)
- (x_draw_image_foreground_1, x_draw_image_glyph_string):
- Draw sliced images.
-
- * w32term.c (w32_draw_relief_rect): Add top_p and bot_p args.
- (x_draw_glyph_string_box): Fix call to x_draw_relief_rect.
- (x_draw_image_foreground, x_draw_image_relief)
- (w32_draw_image_foreground_1, x_draw_image_glyph_string):
- Draw sliced images.
-
- * w32term.h (image_ascent): Remove prototype.
-
- * window.c (Fpos_visible_in_window_p): Return pixel position if
- PARTIALLY arg is non-nil. Simplify. Doc fix.
- (Fwindow_vscroll, Fset_window_vscroll): Add optional PIXEL_P arg
- to return/set vscroll in pixels.
-
- * window.h (Fwindow_vscroll, Fset_window_vscroll): Fix EXFUN.
-
- * xdisp.c (Qslice): New variable.
- (syms_of_xdisp): Intern and staticpro it.
- (pos_visible_p): Return pixel position in new x and y args.
- (init_iterator): Reset it->slice info.
- (handle_display_prop): Parse (slice ...) property.
- (push_it, pop_it): Save/restore slice info.
- (make_cursor_line_fully_visible): Fix 2004-04-14 change. Do not
- force repositioning of tall row if window is vscrolled, as that
- would reset vscroll.
- (append_space): Set it->constrain_row_ascent_descent_p to avoid
- increasing row height if row is non-empty.
- (fill_image_glyph_string): Copy slice info.
- (take_vertical_position_into_account): Simplify.
- (produce_image_glyph): Handle iterator slice info, setup glyph
- slice info. Do not force minimum line height.
- (x_produce_glyphs): If it->constrain_row_ascent_descent_p is set,
- do not increase height (ascent/descent) of non-empty row when
- adding normal character glyph; instead reduce glyph ascent/descent
- appropriately; if row is higher than current glyph, adjust glyph
- descent/ascent to reposition glyph within the existing row.
- Likewise, when char is newline, only set ascent/descent if row is
- currently empty.
- (note_mouse_highlight): Handle hotspots with sliced image.
-
- * xterm.c (x_draw_relief_rect): Add top_p and bot_p args.
- (x_draw_glyph_string_box): Fix call to x_draw_relief_rect.
- (x_draw_image_foreground, x_draw_image_relief)
- (x_draw_image_foreground_1, x_draw_image_glyph_string):
- Draw sliced images.
-
- * xterm.h (image_ascent): Remove prototype.
-
-2004-04-20 Stefan Monnier <[email protected]>
-
- * keymap.c (Fkey_description): Fix the usual int/Lisp_Object mixup.
-
-2004-04-20 John Paul Wallington <[email protected]>
-
- * fns.c (Fassoc, Feql): Fix indentation.
-
- * fontset.c (regularize_fontname): Rename from regulalize_fontname.
-
-2004-04-19 John Paul Wallington <[email protected]>
-
- * fns.c (Feql): New function.
- (syms_of_fns): Defsubr it.
-
-2004-04-18 Jason Rumney <[email protected]>
-
- * w32select.c (Fw32_set_clipboard_data): Get sequence number
- after closing the clipboard.
-
-2004-04-16 Luc Teirlinck <[email protected]>
-
- * buffer.c (Fbuffer_base_buffer): Doc fix.
-
-2004-04-17 Kim F. Storm <[email protected]>
-
- * keymap.c (Fkey_description): Add optional PREFIX arg.
- Combine prefix with KEYS to make up the full key sequence to describe.
- Correlate meta_prefix_char and following (simple) key to describe
- as meta modifier. All callers changed.
- (describe_map): Rename arg `keys' to `prefix'. Remove local
- `elt_prefix' var. Use Fkey_description with prefix instead of
- elt_prefix combined with Fsingle_key_description.
- (describe_vector): Declare static. Replace arg `elt_prefix' with
- `prefix'. Add KEYMAP_P arg. Add local var `elt_prefix'; use it
- if !KEYMAP_P. Use Fkey_description with prefix instead of
- Fsingle_key_description.
-
- * keymap.h (Fkey_description): Fix prototype.
- (describe_vector): Remove prototype.
-
- * xdisp.c (update_overlay_arrows): Fix handling of up_to_date < 0.
-
- * image.c (PNG_BG_COLOR_SHIFT): Remove.
- (png_load): Fix calculation of transparent background color on X
- and W32 platforms.
-
-2004-04-16 Juanma Barranquero <[email protected]>
-
- * xdisp.c (try_scrolling): Make sure `scroll-conservatively' is
- not too large before computing how much to scroll.
-
-2004-04-15 Stefan Monnier <[email protected]>
-
- * dired.c (Ffile_attributes): Don't pass extra nil arg to file-handler.
-
-2004-04-14 Luc Teirlinck <[email protected]>
-
- * fileio.c (Fverify_visited_file_modtime, Fvisited_file_modtime):
- Add hyperlink to Elisp manual to the docstring.
-
-2004-04-14 Stefan Monnier <[email protected]>
-
- * callint.c (fix_command): Use XDCR.
-
-2004-04-14 Nick Roberts <[email protected]>
-
- * window.c (Fget_lru_window): Doc fix.
-
-2004-04-14 Kim F. Storm <[email protected]>
-
- * editfns.c (Fformat): Fix allocation size of precision array.
-
- * dispnew.c (update_window): Only set changed_p if
- scrolling_window actually did scroll.
- (scrolling_window): Only return 1 if we actually did scroll.
-
- * xdisp.c (get_glyph_string_clip_rect): Fix reduction of cursor
- height to glyph height when cursor row is not fully visible.
- (make_cursor_line_fully_visible): Add FORCE_P arg to return
- failure in case row is higher than window. Callers changed.
- (try_scrolling): Fix loop in scrolling if last_line_misfit (from Gerd).
- Try to scroll partially visible, higher-than-window cursor row.
- (redisplay_window): Always try to scroll partially visible,
- higher-than-window cursor row - both initially and again with
- centering_position = 0.
- Clear desired matrix before retrying with centering_position = 0.
-
-2004-04-13 Stefan Monnier <[email protected]>
-
- * syntax.c (scan_lists): Simplify backward string scan.
- Fix off-by-one boundary check for string and comment fences.
-
-2004-04-13 Joe Buehler <[email protected]>
-
- * sheap.c, unexcw.c: New files.
-
-2004-04-12 Luc Teirlinck <[email protected]>
-
- * buffer.c (Fmake_indirect_buffer): Throw an error if the intended
- base buffer has been killed. Correct the error message if the
- base buffer does not exist.
-
-2004-04-12 Joe Buehler <[email protected]>
-
- * s/cygwin.h: Changes for Cygwin unexec() support, changes in
- Cygwin itself. Add support for Xaw3d scrollbars.
-
- * puresize.h: Set up PURE_P() for Cygwin unexec() support.
-
- * lastfile.c: Define my_endbss[] for Cygwin unexec() support.
-
- * gmalloc.c (__default_morecore): Use bss_sbrk(), not __sbrk(),
- before Cygwin unexec.
-
- * Makefile.in: Link changes for Cygwin unexec() support.
-
-2004-04-12 Andreas Schwab <[email protected]>
-
- * buffer.c (Fmake_indirect_buffer): Check that NAME is a string.
-
-2004-04-11 Luc Teirlinck <[email protected]>
-
- * buffer.c (Fgenerate_new_buffer_name): Return NAME argument if
- IGNORE argument equals NAME. Doc fix.
-
-2004-04-11 Masatake YAMATO <[email protected]>
-
- * buffer.c (fix_start_end_in_overlays): Make overlays
- empty if they are backwards.
-
-2004-04-09 Stefan Monnier <[email protected]>
-
- * xfaces.c (face_color_supported_p): Fix compilation without X11.
-
-2004-04-07 Stefan Monnier <[email protected]>
-
- * doc.c (Fsnarf_documentation): Ignore new file name entries.
-
-2004-04-06 Kim F. Storm <[email protected]>
-
- * msdos.c (clear_mouse_face): Only clear mouse highlight if not hidden.
- (dos_rawgetc): Set mouse_face_hidden after clearing highlight.
-
- * w32term.c (w32_read_socket): Set mouse_face_hidden after
- clearing highlight.
-
- * xdisp.c (clear_mouse_face): Only clear mouse highlight if not hidden.
-
- * xterm.c (handle_one_xevent): Set mouse_face_hidden after
- clearing highlight.
-
- * indent.c (vmotion): Do not reserve one column for continuation
- marks on window frames.
-
-2004-04-04 Eli Zaretskii <[email protected]>
-
- * charset.h (SINGLE_BYTE_CHAR_P): Fix macro to avoid warnings
- from GCC.
-
-2004-04-03 Stefan Monnier <[email protected]>
-
- * .gdbinit-union: Remove.
-
- * .gdbinit: Make it work for USE_LSB_TAG and !NO_LISP_UNION.
- (xgetptr, xgetint, xgettype): New funs. Use them everywhere.
- ($nonvalbits): Remove.
- ($valmask): Set it by calling xreload to avoid redundancy.
-
- * emacs.c (gdb_use_union, gdb_use_lsb): New vars.
- (gdb_emacs_intbits): Remove.
-
-2004-03-31 Jan Dj,Ad(Brv <[email protected]>
-
- * data.c (Fbyteorder): Make test work even if unsigned is not 4 bytes.
-
-2004-03-30 Kenichi Handa <[email protected]>
-
- * editfns.c (Fformat): Fix initialization of the array info.
-
-2004-03-30 Kim F. Storm <[email protected]>
-
- * xterm.c (x_mouse_click_focus_ignore_position): New var.
- (syms_of_xterm): DEFVAR_BOOL it.
- (ignore_next_mouse_click_timeout): New var.
- (handle_one_xevent): Clear it on KeyPress, set it on EnterNotify.
- Use it to filter mouse clicks following focus event.
-
-2004-03-29 David Ponce <[email protected]>
-
- * callint.c (Fcall_interactively): Fix last change.
-
-2004-03-28 Stefan Monnier <[email protected]>
-
- * eval.c (Fcommandp): Simplify.
-
- * data.c (Finteractive_form): Rename from Fsubr_interactive_form.
- Extend to handle all kinds of functions.
-
- * lisp.h (Finteractive_form): Declare.
-
- * callint.c (Fcall_interactively): Use it.
-
-2004-03-26 Kim F. Storm <[email protected]>
-
- * xdisp.c (syms_of_xdisp): Include `void-variable' in list_of_error
- to catch errors in calc_pixel_width_or_height during redisplay.
-
-2004-03-26 Masatake YAMATO <[email protected]>
-
- * buffer.c (fix_start_end_in_overlays): Rename fix_overlays_in_range.
-
- * lisp.h (fix_start_end_in_overlays): Likewise.
-
- * insdel.c (adjust_markers_for_insert): Call fix_start_end_in_overlays.
-
- * editfns.c (Ftranspose_regions): Likewise.
-
-2004-03-20 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): Do not pass key press events to GTK.
-
-2004-03-19 Richard M. Stallman <[email protected]>
-
- * s/sol2-6.h: Delete previous change.
-
-2004-03-19 Kim F. Storm <[email protected]>
-
- * xdisp.c (move_it_in_display_line_to): Fix MOVE_TO_POS case when
- to_charpos corresponds to newline in right fringe. Use local
- BUFFER_POS_REACHED_P macro.
-
-2004-03-19 Jan Dj,Ad(Brv <[email protected]>
-
- * xdisp.c (calc_pixel_width_or_height): Add ifdef HAVE_WINDOW_SYSTEM
- to compile on non-window system.
-
-2004-03-19 Kim F. Storm <[email protected]>
-
- * dispextern.h (calc_pixel_width_or_height): Add prototype.
-
- * image.c (Qcenter): Move to xdisp.c.
-
- * xdisp.c (Qcenter): Declare here.
- (syms_of_xdisp): Intern and staticpro it.
- (handle_single_display_prop): Allow space display property on all
- platforms.
- (display_mode_line): Set mode_line_p before displaying line.
- (calc_pixel_width_or_height): Declare extern. Add separate :align-to
- handling. Remove complex cases for fringes and scroll-bars.
- Add left, right, and center alignment positions. Add text (area)
- width/height. Return width or height for image specs.
- (produce_stretch_glyph): Improve handling of :align-to. Is now
- relative to left of text area by default, but other base offsets
- can be specified -- also for text lines.
-
- * term.c (produce_glyphs): Handle IT_STRETCH.
- (produce_stretch_glyph): New function to handle space width and
- align-to display properties on non-window systems.
-
-2004-03-17 Stefan Monnier <[email protected]>
-
- * fileio.c (Fread_file_name): Set completion-ignore-case for
- case-insensitive systems.
-
-2004-03-14 Masatake YAMATO <[email protected]>
-
- * xdisp.c (note_mode_line_or_margin_highlight): Accept HEADER_LINE
- when keymap and cursor are setup.
-
-2004-03-14 Steven Tamm <[email protected]>
-
- * Makefile.in (XMENU_OBJ) [HAVE_CARBON]: Do not include xmenu.o.
-
-2004-03-14 Kim F. Storm <[email protected]>
-
- * dispextern.h (x_find_image_file): Add prototype.
-
- * image.c (x_find_image_file): Make extern.
-
- * xfns.c (x_find_image_file): Remove prototype.
-
-2004-03-13 Eli Zaretskii <[email protected]>
-
- * Makefile.in (XMENU_OBJ): Include xmenu.o if HAVE_MENUS is defined.
-
- * emacs.c (main): Call syms_of_xmenu only if HAVE_MENUS is defined.
-
-2004-03-12 Richard M. Stallman <[email protected]>
-
- * fns.c (internal_equal): New arg PROPS controls comparing
- text properties. All callers changed.
- (Fequal_including_properties): New function.
- (syms_of_fns): defsubr it.
-
-2004-03-12 Kim F. Storm <[email protected]>
-
- Fix image support on MAC. From YAMAMOTO Mitsuharu.
-
- * dispextern.h (XImagePtr, XImagePtr_or_DC): Add typedefs.
- (image_background, image_background_transparent): Fix prototypes.
-
- * image.c (XImagePtr, XImagePtr_or_DC): Move typedefs to dispextern.h.
-
- * macfns.c (x_list_fonts, x_get_font_info, x_load_font)
- (x_query_font, x_find_ccl_program, x_set_window_size)
- (x_make_frame_visible, mac_initialize, XCreatePixmap)
- (XCreatePixmapFromBitmapData, XFreePixmap, XSetForeground)
- (mac_draw_line_to_pixmap): Move prototypes to macterm.h.
-
- * macterm.h (x_list_fonts, x_get_font_info, x_load_font)
- (x_query_font, x_find_ccl_program, x_set_window_size)
- (x_make_frame_visible, mac_initialize, XCreatePixmap)
- (XCreatePixmapFromBitmapData, XFreePixmap, XSetForeground)
- (mac_draw_line_to_pixmap): Add prototypes.
-
-2004-03-12 YAMAMOTO Mitsuharu <[email protected]>
-
- * macterm.c (XTread_socket): Fix mouse click on tool bar.
-
-2004-03-11 Kim F. Storm <[email protected]>
-
- * dispextern.h: Move image related prototypes from xfns.c section
- to image.c. Condition them by HAVE_WINDOW_SYSTEM rather than
- HAVE_X_WINDOWS.
-
- * Makefile.in (XOBJ): Consolidate into one list. Add image.o.
- Move gtkutil.o to new GTK_OBJ list.
- (XMENU_OBJ) [HAVE_MENUS]: Move declaration to proper place.
- (GTK_OBJ) [USE_GTK]: New declaration.
- (obj): Add $(GTK_OBJ) to list.
-
-2004-03-11 Steven Tamm <[email protected]>
-
- * image.c [MAC_OSX]: Include sys/stat.h.
-
- * macfns.c (syms_of_macfns): Remove definitions of things now
- defined in image.c.
-
-2004-03-11 Kim F. Storm <[email protected]>
-
- The following changes consolidates the identical/similar image
- support code previously found in xfns.c, w32fns.c, and macfns.c
- into a new file image.c.
-
- * makefile.w32-in (OBJ1): Add image.o.
- ($(BLD)/image.$(O)): Add dependencies.
-
- * Makefile.in (XOBJ, MAC_OBJ): Add image.o.
- (image.o): Add dependencies.
-
- * image.c: New file with consolidated image support code.
- (COLOR_TABLE_SUPPORT): New define to control whether
- color table support is available (X only).
- (Bitmap_Record): Common name for x_bitmap_record,
- w32_bitmap_record, and mac_bitmap_record.
- (XImagePtr): Common name for pointer to XImage or equivalent.
- (XImagePtr_or_DC): New type to simplify code sharing; equivalent
- to XImagePtr on X+MAC, and to HDC on W32.
- (GET_PIXEL): Wrapper for XGetPixel or equivalent.
- (NO_PIXMAP): Common name for "None" or equivalent.
- (PNG_BG_COLOR_SHIFT): Bits to shift PNG background colors.
- (RGB_PIXEL_COLOR): Common type for an integer "pixel color" value.
- (PIX_MASK_RETAIN, PIX_MASK_DRAW): Portability macros (from macfns.c).
- (FRAME_X_VISUAL, x_defined_color, DefaultDepthOfScreen):
- Define with suitable equivalents on W32 and MAC for code sharing.
- (XDrawLine): Define on MAC for code sharing.
- (Destroy_Image, Free_Pixmap): Wrappers for code sharing.
- (IF_LIB_AVAILABLE): Macro to simplify code sharing.
- (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
- (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
- (x_reference_bitmap, x_create_bitmap_from_data)
- (x_create_bitmap_from_file, x_destroy_bitmap)
- (x_destroy_all_bitmaps, x_create_bitmap_mask)
- (XGetImage, XPutPixel, XGetPixel, XDestroyImage)
- (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
- (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
- (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
- (define_image_type, lookup_image_type, valid_image_p)
- (image_error, enum image_value_type, struct image_keyword)
- (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
- (make_image, free_image, prepare_image_for_display, image_ascent)
- (four_corners_best, image_background, image_background_transparent)
- (x_clear_image_1, x_clear_image, x_alloc_image_color)
- (make_image_cache, free_image_cache, clear_image_cache)
- (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
- (forall_images_in_image_cache, x_create_x_image_and_pixmap)
- (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
- (find_image_fsspec, image_load_qt_1, image_load_quicktime)
- (init_image_func_pointer, image_load_quartz2d)
- (struct ct_color, init_color_table, free_color_table)
- (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
- (cross_disabled_images, x_to_xcolors, x_from_xcolors)
- (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
- (x_disable_image, x_build_heuristic_mask)
- (XBM support, XPM support, PBM support, PNG support, JPEG support)
- (TIFF support, GIF support, Ghostscript support): Consolidate image
- code from xfns.c, w32fns.c, and macfns.c.
- (syms_of_image): Consolidate image related symbol setup here.
- (init_image): Consolidate image related initializations here.
-
- * emacs.c (main) [HAVE_WINDOW_SYSTEM]: Add calls to syms_of_image
- and init_image. Remove call to init_xfns.
-
- * macterm.h (struct mac_bitmap_record): Add file member.
- Not currently used, but simplifies code sharing.
-
- * macfns.c (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
- (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
- (x_reference_bitmap, x_create_bitmap_from_data)
- (x_create_bitmap_from_file, x_destroy_bitmap)
- (x_destroy_all_bitmaps, x_create_bitmap_mask)
- (XGetImage, XPutPixel, XGetPixel, XDestroyImage)
- (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
- (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
- (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
- (define_image_type, lookup_image_type, valid_image_p)
- (image_error, enum image_value_type, struct image_keyword)
- (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
- (make_image, free_image, prepare_image_for_display, image_ascent)
- (four_corners_best, image_background, image_background_transparent)
- (x_clear_image_1, x_clear_image, x_alloc_image_color)
- (make_image_cache, free_image_cache, clear_image_cache)
- (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
- (forall_images_in_image_cache, x_create_x_image_and_pixmap)
- (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
- (find_image_fsspec, image_load_qt_1, image_load_quicktime)
- (init_image_func_pointer, image_load_quartz2d)
- (struct ct_color, init_color_table, free_color_table)
- (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
- (cross_disabled_images, x_to_xcolors, x_from_xcolors)
- (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
- (x_disable_image, x_build_heuristic_mask)
- (XBM support, XPM support, PBM support, PNG support, JPEG support)
- (TIFF support, GIF support, Ghostscript support): Merge with image
- code from xfns.c and macfns.c into image.c.
- (syms_of_xfns): Move image related symbols to image.c.
- (init_external_image_libraries, init_xfns): Remove; initialization
- moved to init_image in image.c.
-
- * w32fns.c (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
- (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
- (x_reference_bitmap, x_create_bitmap_from_data)
- (x_create_bitmap_from_file, x_destroy_bitmap)
- (x_destroy_all_bitmaps, x_create_bitmap_mask)
- (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
- (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
- (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
- (define_image_type, lookup_image_type, valid_image_p)
- (image_error, enum image_value_type, struct image_keyword)
- (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
- (make_image, free_image, prepare_image_for_display, image_ascent)
- (four_corners_best, image_background, image_background_transparent)
- (x_clear_image_1, x_clear_image, x_alloc_image_color)
- (make_image_cache, free_image_cache, clear_image_cache)
- (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
- (forall_images_in_image_cache, x_create_x_image_and_pixmap)
- (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
- (struct ct_color, init_color_table, free_color_table)
- (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
- (cross_disabled_images, x_to_xcolors, x_from_xcolors)
- (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
- (x_disable_image, x_build_heuristic_mask)
- (XBM support, XPM support, PBM support, PNG support, JPEG support)
- (TIFF support, GIF support, Ghostscript support): Merge with image
- code from xfns.c and macfns.c into image.c.
- (syms_of_xfns): Move image related symbols to image.c.
- (init_external_image_libraries, init_xfns): Remove; initialization
- moved to init_image in image.c.
-
- * xfns.c (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
- (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
- (x_reference_bitmap, x_create_bitmap_from_data)
- (x_create_bitmap_from_file, x_destroy_bitmap)
- (x_destroy_all_bitmaps, x_create_bitmap_mask)
- (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
- (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
- (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
- (define_image_type, lookup_image_type, valid_image_p)
- (image_error, enum image_value_type, struct image_keyword)
- (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
- (make_image, free_image, prepare_image_for_display, image_ascent)
- (four_corners_best, image_background, image_background_transparent)
- (x_clear_image_1, x_clear_image, x_alloc_image_color)
- (make_image_cache, free_image_cache, clear_image_cache)
- (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
- (forall_images_in_image_cache, x_create_x_image_and_pixmap)
- (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
- (struct ct_color, init_color_table, free_color_table)
- (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
- (cross_disabled_images, x_to_xcolors, x_from_xcolors)
- (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
- (x_disable_image, x_build_heuristic_mask)
- (XBM support, XPM support, PBM support, PNG support, JPEG support)
- (TIFF support, GIF support, Ghostscript support): Merge with
- w32fns.c and macfns.c image code into image.c.
- (syms_of_xfns): Move image related symbols to image.c.
- (init_xfns): Remove; initialization moved to init_image in image.c.
-
- * lisp.h (syms_of_image, init_image): Add protoypes.
- (init_xfns): Remove prototype.
-
- * dispextern.h (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
- (x_reference_bitmap, x_create_bitmap_from_data)
- (x_create_bitmap_from_file, x_destroy_bitmap)
- (x_create_bitmap_mask): Move prototypes from dispextern.h.
- (gamma_correct) [MAC_OS]: Add prototype.
-
- * xterm.h (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
- (x_reference_bitmap, x_create_bitmap_from_data)
- (x_create_bitmap_from_file, x_destroy_bitmap)
- (x_create_bitmap_mask): Move prototypes to dispextern.h.
-
-2004-03-09 Kenichi Handa <handa@etlken2>
-
- * coding.c (decode_coding_emacs_mule): Handle insufficent source
- correctly.
-
-2004-03-04 Richard M. Stallman <[email protected]>
-
- * s/sol2-6.h (LD_SWITCH_SYSTEM_TEMACS): New definition.
-
- * window.c (Fdisplay_buffer): Doc fix.
-
- * buffer.c (Fpop_to_buffer): Doc fix.
-
-2004-03-03 Kim F. Storm <[email protected]>
-
- * xdisp.c (display_line): Fix call to get_overlay_arrow_glyph_row.
-
-2004-03-02 Stefan Monnier <[email protected]>
-
- * editfns.c (Ftranslate_region): Lisp_Object/int mixup.
-
-2004-03-02 Richard M. Stallman <[email protected]>
-
- * indent.c (compute_motion): Save vpos in prev_vpos, like hpos etc.
-
-2004-03-02 Kenichi Handa <[email protected]>
-
- * doc.c (Fsubstitute_command_keys): Fix counding bytes.
-
-2004-03-02 Kim F. Storm <[email protected]>
-
- * window.h (struct window): New member overlay_arrow_bitmap.
-
- * window.c (make_window): Initialize overlay_arrow_bitmap.
-
- * xdisp.c (Voverlay_arrow_variable_list): New variable to properly
- implement and integrate multiple overlay arrows with redisplay.
- (syms_of_xdisp): DEFVAR_LISP and initialize it.
- (last_arrow_position, last_arrow_string): Replace by properties.
- (Qlast_arrow_position, Qlast_arrow_string)
- (Qoverlay_arrow_string, Qoverlay_arrow_bitmap): New variables.
- (syms_of_xdisp): Intern and staticpro them.
- (overlay_arrow_string_or_property, update_overlay_arrows)
- (overlay_arrow_in_current_buffer_p, overlay_arrows_changed_p)
- (overlay_arrow_at_row): New functions for multiple overlay arrows.
- (redisplay_internal): Use them instead of directly accessing
- Voverlay_arrow_position etc. for multiple overlay arrows.
- (mark_window_display_accurate): Use update_overlay_arrows.
- (try_cursor_movement): Use overlay_arrow_in_current_buffer_p.
- (try_window_id): Use overlay_arrows_changed_p.
- (get_overlay_arrow_glyph_row): Add overlay_arrow_string arg.
- (display_line): Use overlay_arrow_at_row to check multiple
- overlay arrows, and get relevant overlay-arrow-string and
- overlay-arrow-bitmap. Set w->overlay_arrow_bitmap accordingly.
- (produce_image_glyph): Set pixel_width = 0 for fringe bitmap.
- (syms_of_xdisp): Remove last_arrow_position and last_arrow_string.
-
- * fringe.c (draw_fringe_bitmap): Use w->overlay_arrow_bitmap if set.
- (update_window_fringes): Remove unused code.
-
-2004-03-01 Jason Rumney <[email protected]>
-
- * w32term.c (w32_read_socket): Fix last change to ButtonPress handling.
-
-2004-03-01 Juanma Barranquero <[email protected]>
-
- * fringe.c (Fdefine_fringe_bitmap): Fix typo in docstring.
-
- * makefile.w32-in ($(BLD)/fringe.$(O)): Add dependencies.
-
-2004-03-01 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (Fx_display_color_cells): Use number of planes to calculate
- how many colors can be displayed.
-
-2004-03-01 Kenichi Handa <[email protected]>
-
- * editfns.c (Ftranslate_region): Handle multibyte chars in TABLE
- correctly.
-
-2004-02-28 Kim F. Storm <[email protected]>
-
- * dispnew.c (update_window): Update header line also if there are
- no other changes in window (move code after set_cursor label).
-
- * lisp.h (mark_window_display_accurate): Remove prototype.
-
- * window.c (window_loop, Fforce_window_update): Force mode line
- updates by setting prevent_redisplay_optimizations_p and
- update_mode_lines.
-
-2004-02-28 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_window): Fix indentation.
-
- * xterm.c (x_calc_absolute_position): Call x_real_positions
- to get WM window sizes and use those to calculate position.
- (x_set_offset): Remove code commented out.
-
-2004-02-28 Miles Bader <[email protected]>
-
- * keyboard.c (adjust_point_for_property): #ifdef-out dodgy xassert.
-
-2004-02-28 Kim F. Storm <[email protected]>
-
- * keyboard.c (kbd_buffer_store_event_hold): New function to store
- an event into kbd fifo, but with special handling of quit event;
- a quit event is saved for later, and further events are discarded
- until the saved quit event has been processed.
- (kbd_buffer_store_event): Use kbd_buffer_store_event_hold.
- (gen_help_event): Store help event in kbd fifo.
- (NREAD_INPUT_EVENTS): Remove.
- (read_avail_input): Adapt to new read_socket_hook interface.
- Remove allocation and initialization of local input_event buffer,
- as read_socket_hook stores events directly in fifo. Allocate and
- initialize local hold_quit event to handle postponed quit event
- (and store it if set by kbd_buffer_store_event_hold).
-
- * keyboard.h (kbd_buffer_store_event_hold): Add prototype.
- (gen_help_event): Fix prototype.
-
- * macterm.c (XTread_socket): Remove bufp_r and
- numcharsp args. Add hold_quit arg.
- Rework to use just one, local, inev input_event. Store inev
- directly in fifo using kbd_buffer_store_event_hold.
-
- * sysdep.c (BUFFER_SIZE_FACTOR): Remove.
- (read_input_waiting): Adapt to new read_socket_hook interface.
- Remove allocation and initialization of local input_event buffer,
- as read_socket_hook stores events directly in fifo. Allocate and
- initialize local hold_quit event to handle postponed quit event
- (and store it if set by kbd_buffer_store_event_hold).
-
- * term.c (read_socket_hook): Fix arg list.
-
- * termhooks.h (read_socket_hook): Fix prototype.
-
- * w32inevt.c (w32_console_read_socket): Remove bufp_r and
- numcharsp args. Add hold_quit arg.
- Rework to use just one, local, inev input_event. Store inev
- directly in fifo using kbd_buffer_store_event_hold.
-
- * w32inevt.h (w32_console_mouse_position): Fix prototype.
-
- * w32term.c (w32_read_socket): Remove bufp_r and numcharsp args.
- Add hold_quit arg. Rework to use just one, local, inev
- input_event. Store inev directly in fifo using
- kbd_buffer_store_event_hold. Update count in one place.
- Postpone call to gen_help_event until inev is stored; use new
- local do_help for this.
- Remove local emacs_event in handing of ButtonPress event; just use
- inev instead (so no reason to copy it later).
-
- * xsmfns.c (x_session_check_input): Remove numchars arg.
-
- * xterm.c (x_focus_changed, x_detect_focus_change):
- Remove numchars arg. Always store event into bufp arg.
- Return nothing. Callers changed accordingly.
- (glyph_rect): Simplify.
- (STORE_KEYSYM_FOR_DEBUG): New macro.
- (SET_SAVED_MENU_EVENT): Use inev instead of bufp, etc.
- (current_bufp, current_numcharsp) [USE_GTK]: Remove.
- (current_hold_quit) [USE_GTK]: Add.
- (event_handler_gdk): Adapt to new handle_one_xevent.
- (handle_one_xevent): Remove bufp_r and numcharsp args.
- Add hold_quit arg. Rework to use just one, local, inev
- input_event. Store inev directly in fifo using
- kbd_buffer_store_event_hold. Update count in one place.
- Postpone call to gen_help_event until inev is stored; use new
- local do_help for this.
- Simplify handling of keysyms (consolidate common code). Fix bug
- where count was updated with nchars instead of nbytes.
- Remove local emacs_event in handing of ButtonPress event; just use
- inev instead (so no reason to copy it later).
- Remove `out' label. Rename label `ret' to `done'; add various
- `goto done' to clarify code flow in deeply nested blocks.
- (x_dispatch_event): Simplify as handle_one_xevent now calls
- kbd_buffer_store_event itself.
- (XTread_socket): Remove bufp_r and numcharsp args. Add hold_quit
- arg. Call handle_one_xevent with new arglist. Store event from
- x_session_check_input in fifo.
- [USE_GTK]: Setup current_hold_quit.
- Decrement handling_signal before unblocking input.
- (x_initialize) [USE_GTK]: Initialize current_count.
-
- * xterm.h (x_session_check_input): Fix prototype.
-
-2004-02-26 YAMAMOTO Mitsuharu <[email protected]>
-
- * s/darwin.h (LD_SWITCH_SYSTEM_TEMACS): Add `-framework QuickTime'.
-
- * dispextern.h [MAC_OSX]: Do not include Carbon/Carbon.h (now in
- macgui.h).
-
- * emacs.c (main) [HAVE_CARBON]: Call init_xfns.
-
- * macgui.h [MAC_OSX]: Include Carbon/Carbon.h.
- (mktime, DEBUG, Z, free, malloc, realloc, max, min)
- (init_process) [MAC_OSX]: Avoid conflicts with Carbon/Carbon.h.
- [!MAC_OSX]: Include QDOffscreen.h and Controls.h.
- (INFINITY) [MAC_OSX]: Avoid conflict with definition in math.h.
- (Bitmap): Remove typedef.
- (Pixmap): Change int to GWorldPtr.
-
- * macmenu.c [MAC_OSX]: Don't include Carbon/Carbon.h (now in macgui.h).
-
- * macterm.h [MAC_OSX]: Don't include Carbon/Carbon.h (now in macgui.h).
- (RED16_FROM_ULONG, GREEN16_FROM_ULONG, BLUE16_FROM_ULONG):
- New #define to extract 16-bit depth color components from unsigned
- long representation.
- (PIX_MASK_DRAW, PIX_MASK_RETAIN): New #define to represent pixel
- colors used for masks.
- (struct mac_display_info): Add color_p. Remove n_cbits.
-
- * macfns.c: Include sys/types.h and sys/stat.h.
- [MAC_OSX]: Do not include Carbon/Carbon.h (now in macgui.h).
- Include QuickTime/QuickTime.h.
- (XCreatePixmap, XCreatePixmapFromBitmapData, XFreePixmap)
- (XSetForeground, mac_draw_line_to_pixmap): Add externs for
- functions defined in macterm.c.
- (XImagePtr): New typedef. Corresponds to XImage * in xfns.c.
- (ZPixmap): New #define for compatibility with xfns.c.
- (XGetImage, XPutPixel, XGetPixel, XDestroyImage)
- (x_create_x_image_and_pixmap, x_destroy_x_image, x_put_x_image)
- (find_image_fsspec, image_load_qt_1, image_load_quicktime):
- New functions.
- (four_corners_best, x_create_x_image_and_pixmap)
- (x_destroy_x_image, unwind_create_frame, x_disable_image)
- (x_edge_detection, init_color_table, colors_in_color_table)
- (lookup_rgb_color, lookup_pixel_color, postprocess_image)
- (x_put_x_image, slurp_file, xbm_scan, xbm_load, xbm_load_image)
- (xbm_image_p, xbm_read_bitmap_data, xbm_file_p, x_to_xcolors)
- (x_from_xcolors, x_detect_edges): New declarations (from xfns.c).
- (mac_color_map_lookup, x_to_mac_color): Fix Lisp_Object/unsigned
- long mixup.
- (mac_defined_color, x_to_x_colors): Use RED16_FROM_ULONG etc.
- (x_decode_color): Don't use n_cbits (in struct mac_display_info).
- (x_set_foreground_color, x_set_cursor_color): Sync with w32fns.c.
- (x_set_cursor_type, Fxw_color_values, valid_image_p)
- (image_value_type, parse_image_spec, image_ascent, x_clear_image)
- (x_alloc_image_color, clear_image_cache, lookup_image)
- (x_find_image_file, xbm_read_bitmap_file_data)
- (enum xbm_keyword_index, xbm_format, xbm_image_p, xbm_scan)
- (xbm_read_bitmap_data, xbm_load, pbm_image_p, pbm_scan_number)
- (enum pbm_keyword_index, pbm_format, enum png_keyword_index)
- (png_format, png_image_p, enum jpeg_keyword_index, jpeg_format)
- (jpeg_image_p, enum tiff_keyword_index, tiff_format, tiff_image_p)
- (enum gif_keyword_index, gif_format, gif_image_p): Sync with xfns.c.
- (x_make_gc): Sync with xfns.c. Enclose unused `border_tile' with
- #if 0.
- (x_free_gcs): Sync with xfns.c. Enclose unused `border_tile' with
- #if 0. Free white_relief.gc and black_relief.gc.
- (unwind_create_frame, x_emboss, x_laplace, x_edge_detection):
- New functions (from xfns.c).
- (Fx_create_frame): Record unwind_create_frame.
- (Fxw_display_color_p): Use dpyinfo->color_p.
- (Fx_display_grayscale_p, Fx_display_planes): Don't use
- dpyinfo->n_cbits.
- (Fx_display_color_cells): Use dpyinfo->n_planes;
- (QCmatrix, QCcolor_adjustment, QCmask, Qemboss, Qedge_detection)
- (Qheuristic, cross_disabled_images, emboss_matrix)
- (laplace_matrix): New variables (from xfns.c).
- (Fimage_size, Fimage_mask_p, four_corners_best, image_background)
- (x_clear_image_1, postprocess_image, slurp_file, xbm_load_image)
- (xbm_file_p, x_to_xcolors, x_from_xcolors, x_detect_edges)
- (image_background_transparent): New function (from xfns.c).
- Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
- (image_load_quicktime): Add declaration.
- [MAC_OSX] (image_load_quartz2d): Likewise.
- [MAC_OSX] (CGImageCreateWithPNGDataProviderProcType): New typedef.
- [MAC_OSX] (MyCGImageCreateWithPNGDataProvider): New variable.
- [MAC_OSX] (init_image_func_pointer, image_load_quartz2d): New funs.
- (xbm_load_image_from_file, x_laplace_read_row)
- (x_laplace_write_row, pbm_read_file): Remove functions.
- [HAVE_XPM] (enum xpm_keyword_index, xpm_format, xpm_image_p)
- (xpm_load): Sync with xfns.c (although XPM is not supported yet).
- (colors_in_color_table): Sync with xfns.c (although not used).
- (lookup_rgb_color): Don't lookup color table. Just do gamma
- correction.
- (COLOR_INTENSITY): New #define (from xfns.c).
- (x_disable_image): New function (from xfns.c).
- Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
- (x_build_heuristic_mask): Sync with xfns.c.
- Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
- (HAVE_PBM): Remove #ifdef.
- (pbm_load): Sync with xfns.c. Set img->width and img->height
- before IMAGE_BACKGROUND.
- (png_image_p, png_load): Don't enclose declarations with #if HAVE_PNG.
- (Qpng, enum png_keyword_index, png_format, png_type, png_image_p):
- Don't enclose with #if HAVE_PNG.
- [!HAVE_PNG] (png_load) [MAC_OSX]: Use image_load_quartz2d if a
- symbol _CGImageCreateWithPNGDataProvider is defined.
- Otherwise use image_load_quicktime.
- [!HAVE_PNG] (png_load) [!MAC_OSX]: Use image_load_quicktime.
- [HAVE_PNG] (png_load): Sync with xfns.c.
- Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
- (jpeg_image_p, jpeg_load): Don't enclose declarations with #if
- HAVE_JPEG.
- (Qjpeg, enum jpeg_keyword_index, jpeg_format, jpeg_type)
- (jpeg_image_p): Don't enclose with #if HAVE_JPEG.
- [!HAVE_JPEG] (jpeg_load) [MAC_OSX]: Use image_load_quartz2d.
- [!HAVE_JPEG] (jpeg_load) [!MAC_OSX]: Use image_load_quicktime.
- [HAVE_JPEG] (jpeg_load): Sync with xfns.c.
- (tiff_image_p, tiff_load): Don't enclose declarations with #if
- HAVE_TIFF.
- (Qtiff, enum tiff_keyword_index, tiff_format, tiff_type)
- (tiff_image_p): Don't enclose with #if HAVE_TIFF.
- [!HAVE_TIFF] (tiff_load): Use image_load_quicktime.
- [HAVE_TIFF] (tiff_error_handler, tiff_warning_handler):
- New functions (from xfns.c).
- [HAVE_TIFF] (tiff_load): Sync with xfns.c.
- (gif_image_p, gif_load): Don't enclose declarations with #if HAVE_GIF.
- (Qgif, enum gif_keyword_index, gif_format, gif_type, gif_image_p):
- Don't enclose with #if HAVE_GIF.
- [!HAVE_GIF] (gif_load): Use Quicktime Movie Toolbox if it is
- animated gif. Otherwise use image_load_quicktime.
- [HAVE_GIF] (gif_lib.h): Temporarily define DrawText as
- gif_DrawText to avoid conflict with QuickdrawText.h.
- [HAVE_GIF] (gif_load): Sync with xfns.c.
- (enum gs_keyword_index, gs_format, gs_image_p, gs_load)
- [HAVE_GHOSTSCRIPT] (x_kill_gs_process): Sync with xfns.c (although
- Ghostscript is not supported yet).
- (syms_of_macfns): Initialize Qemboss, Qedge_detection, Qheuristic,
- QCmatrix, QCcolor_adjustment, and QCmask. Add DEFVAR_BOOL
- cross_disabled_images (from xfns.c). Remove #if 0 for supported
- image types. Remove #if HAVE_JPEG, HAVE_TIFF, HAVE_GIF, and
- HAVE_PNG. Add defsubr for Simage_size and Simage_mask_p.
- (init_xfns): Remove #if HAVE_JPEG, HAVE_TIFF, HAVE_GIF, and
- HAVE_PNG. Call EnterMovies to support animated gifs.
- Call init_image_func_pointer to bind a symbol
- _CGImageCreateWithPNGDataProvider if it is defined.
-
- * macterm.c [MAC_OSX]: Don't include Carbon/Carbon.h (now in macgui.h).
- (x_draw_bar_cursor): Sync declaration with xterm.c.
- (XFreePixmap, mac_draw_rectangle_to_pixmap, mac_copy_area)
- (mac_copy_area_to_pixmap): Implementation with GWorld (offscreen
- graphics).
- (mac_set_forecolor, mac_set_backcolor): Use RED16_FROM_ULONG etc.
- (mac_draw_line_to_pixmap, XCreatePixmap)
- (XCreatePixmapFromBitmapData, mac_fill_rectangle_to_pixmap)
- (mac_copy_area_with_mask, mac_copy_area_with_mask_to_pixmap):
- New functions.
- (mac_draw_bitmap) [TARGET_API_MAC_CARBON]:
- Use GetPortBitMapForCopyBits instead of the cast to Bitmap *.
- Cast bits to char *.
- (reflect_byte): New function (from w32fns.c).
- (mac_create_bitmap_from_bitmap_data): Use it and don't stuff bits
- due to byte alignment.
- (mac_scroll_area) [TARGET_API_MAC_CARBON]:
- Use GetPortBitMapForCopyBits instead of the cast to Bitmap *.
- (XSetForeground): Remove static (now used in macfns.c).
- (HIGHLIGHT_COLOR_DARK_BOOST_LIMIT): New #define (from w32term.c).
- (mac_alloc_lighter_color, x_destroy_window): Sync with w32term.c.
- (x_setup_relief_color, x_setup_relief_colors, x_draw_box_rect)
- (x_draw_glyph_string_box, x_draw_image_foreground)
- (x_draw_image_foreground_1, x_draw_image_glyph_string)
- (x_draw_stretch_glyph_string, x_draw_glyph_string)
- (x_draw_hollow_cursor, x_draw_bar_cursor, mac_draw_window_cursor):
- Sync with xterm.c.
- (x_draw_relief_rect): Sync with xterm.c. Make 1 pixel shorter
- than the xterm.c version when a strictly horizontal or vertical
- line is drawn.
- (XTset_terminal_window): Add static.
- (x_make_frame_visible): Add UNBLOCK_INPUT.
- (x_free_frame_resources): New funcion (from xterm.c).
- (XTread_socket): Call handle_tool_bar_click if mouse up/down event
- occurs in tool bar area.
- (mac_initialize_display_info): Remove dpyinfo->n_cbits.
- Set dpyinfo->color_p. Determine dpyinfo->n_planes using HasDepth.
- Initialize image cache.
- (stricmp, wildstrieq, mac_font_pattern_match, mac_font_match):
- Enclose unused functions with #if 0.
- (Qbig5, Qcn_gb, Qsjis, Qeuc_kr): New variables.
- (decode_mac_font_name): New function to apply code conversions
- from a mac font name to an XLFD font name according to its script code.
- (x_font_name_to_mac_font_name): Apply code conversion from an XLFD
- font name to a mac font name according to REGISTRY and ENCODING fields.
- (init_font_name_table) [TARGET_API_MAC_CARBON]: Don't use a font
- whose name starts with `.'.
- (init_font_name_table): Use decode_mac_font_name. Add both
- jisx0208.1983-sjis and jisx0201.1976-0 entries if the script code
- of a font is smJapanese.
- (mac_do_list_fonts): New function to list fonts that match a given
- pattern.
- (x_list_fonts, XLoadQueryFont): Use it.
- (XLoadQueryFont): Set rbearing field for each variable width
- character to avoid needless redraw.
- (syms_of_macterm): Initialize Qbig5, Qcn_gb, Qsjis, and Qeuc_kr.
-
-2004-02-26 Kim F. Storm <[email protected]>
-
- * keyboard.c (NREAD_INPUT_EVENTS): Temporarily increase to 512
- as read_socket_hook handler on X aborts if buffer is too small
- and W32 handler doesn't always check buffer limit.
-
- * xdisp.c (handle_single_display_prop): Handle left-fringe and
- right-fringe similar to a display margin image. Specifically,
- the characters having the fringe prop are no longer shown, and
- we use IT_IMAGE/next_element_from_image with image_id = -1 to
- do this. Set fringe bitmap face_id in it->face_id.
- (produce_image_glyph): Handle image_id < 0 as "no image" case, but
- still realize it->face (i.e. the fringe bitmap face).
-
-2004-02-25 Miles Bader <[email protected]>
-
- * xdisp.c (check_it): Check string/string_pos consistency.
- (init_iterator): Initialize string-related fields properly.
-
-2004-02-11 Miles Bader <[email protected]>
-
- * xdisp.c (produce_image_glyph): Force negative descents to zero.
-
-2004-02-10 Miles Bader <[email protected]>
-
- * xfns.c (lookup_image): Remove xassert(!interrupt_input_blocked);
- BLOCK_INPUT can be nested, so it doesn't make much sense.
-
-2004-02-24 Michael Mauger <[email protected]>
-
- * w32fns.c (slurp_file, xbm_scan, xbm_load_image)
- (xbm_read_bitmap_data): Use unsigned char for image data.
-
-2004-02-23 Luc Teirlinck <[email protected]>
-
- * abbrev.c (Finsert_abbrev_table_description): Doc fix.
-
-2004-02-22 Jason Rumney <[email protected]>
-
- * w32term.c (w32_draw_fringe_bitmap): Draw overlaid bitmaps
- correctly over other bitmaps.
-
-2004-02-21 Eli Zaretskii <[email protected]>
-
- * emacs.c (USAGE1): Split into two halves.
- (USAGE2): Second half of the old USAGE1.
- (USAGE3): Rename from USAGE2.
- (USAGE4): Rename from USAGE3.
-
-2004-02-21 Juri Linkov <[email protected]>
-
- * emacs.c (USAGE1): Add --no-desktop. Move --display from USAGE2.
- Fix --multibyte. Move --help, --version to USAGE2. Add alias
- --file. Fix -f, -l. Sort options. Untabify.
- (USAGE2): Add -hb. Fix --name, --title. Sort options. Untabify.
-
-2004-02-19 Luc Teirlinck <[email protected]>
-
- * category.c (Fdefine_category, Fcategory_docstring)
- (Fget_unused_category, Fset_category_table)
- (Fcategory_set_mnemonics): Doc fixes.
-
-2004-02-20 Kim F. Storm <[email protected]>
-
- * keyboard.c: Undo 2004-02-16 and 2004-02-17 changes.
- The following changes are relative to the 2004-01-21 revision.
- (NREAD_INPUT_EVENTS): Define as max number of input events to read
- in one call to read_socket_hook. Value is 8.
- (read_avail_input): Separate and rework handling of read_socket_hook
- and non-read_socket_hook cases. Use smaller input_event buffer
- in read_socket_hook case, and repeat if full buffer is read.
- Use new local variable 'discard' to skip input after C-g.
- In non-read_socket_hook case, just use a single input_event, and
- call kbd_buffer_store_event on the fly for each character.
-
-2004-02-19 Stefan Monnier <[email protected]>
-
- * lisp.h (union Lisp_Object): Give a more precise type for `type'.
- Remove unused `gu' alternative.
-
-2004-02-19 Andreas Schwab <[email protected]>
-
- * fringe.c (Fdefine_fringe_bitmap): Use && instead of & to avoid
- warning.
-
-2004-02-18 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_window_cursor_type, display_and_set_cursor):
- Fix last change.
-
-2004-02-17 Kim F. Storm <[email protected]>
-
- * xdisp.c (fast_find_position): Fix return value of new version;
- it was inverted compared to the 21.1 version.
- (get_window_cursor_type): Don't look at glyph if NULL.
- (display_and_set_cursor): Set glyph to NULL if cursor in fringe.
-
- * keyboard.c: Rework previous change; it didn't consider that the
- buf array was allocated on the stack.
- (prev_read): Remove variable.
- (read_avail_input_buf): New static event buffer array.
- (in_read_avail_input): New static variable to handle re-entrancy.
- (read_avail_input): Change buf to pinter to read_avail_input_buf.
- Use in_read_avail_input to handle re-entrance; when re-entered,
- fully initialize and use tmp_buf array instead of read_avail_input_buf.
- Do not initialize read_avail_input_buf in full here; instead assume it
- is always cleared on entry. To ensure that, we clear (just) the
- entries that were used before we return.
- (init_keyboard): Initialize read_avail_input_buf here.
-
-2004-02-16 Jesper Harder <[email protected]>
-
- * cmds.c (Fend_of_line): Doc fix.
-
-2004-02-16 Dmitry Antipov <[email protected]> (tiny change)
-
- * keyboard.c (prev_read): New static variable.
- (read_avail_input): Use it to zero out only those slots in buf[]
- that were used last time we were called.
-
-2004-02-16 Eli Zaretskii <[email protected]>
-
- * Makefile.in (obj): Move fringe.o from here...
- (XOBJ, MAC_OBJ): ...to here.
-
-2004-02-16 Stephen Eglen <[email protected]>
-
- * fringe.c (init_fringe_bitmap): Define j in MAC_OS code.
-
-2004-02-15 Stefan Monnier <[email protected]>
-
- * data.c (Fbyteorder):
- * fringe.c (Fdefine_fringe_bitmap):
- * xdisp.c (handle_single_display_prop):
- * xselect.c (x_handle_dnd_message): Lisp_Object/int mixup.
-
-2004-02-16 Jason Rumney <[email protected]>
-
- * w32term.c (w32_draw_fringe_bitmap): Handle overlay fringe bitmaps.
-
-2004-02-15 Steven Tamm <[email protected]>
-
- * macterm.c (Vmac_emulate_three_button_mouse): New variable for
- controlling emulation of a three button mouse with option and
- command keys.
- (Qreverse, mac_get_enumlated_btn): Handle the emulation.
- (mac_event_to_emacs_modifiers, XTread_socket): Ditto.
-
-2004-02-15 Kim F. Storm <[email protected]>
-
- * buffer.c (syms_of_buffer): Doc fix for indicate-buffer-boundaries.
-
- * fringe.c (init_fringe_bitmap) [MAC_OS, WORDS_BIG_ENDIAN]:
- Perform byte-swapping.
-
-2004-02-14 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct draw_fringe_bitmap_params): Change member
- bits from char to short to facilitate wider bitmaps.
- (struct redisplay_interface): Fix prototype of define_fringe_bitmap
- member.
-
- * fringe.c (struct fringe_bitmap): Change member bits from char to
- short to facilitate 16 bits wide bitmaps. Modify all standard
- bitmaps accordingly.
- (BYTES_PER_BITMAP_ROW, STANDARD_BITMAP_HEIGHT): New macros.
- (FRBITS): Use STANDARD_BITMAP_HEIGHT instead of just sizeof.
- (draw_fringe_bitmap): Ditto.
- (init_fringe_bitmap) [MAC_OS]: Don't bitswap.
- (init_fringe_bitmap) [HAVE_X_WINDOWS]: Enhance bitswapping to
- handle up to 16 bits wide bitmaps.
- (Fdefine_fringe_bitmap): Doc fix. Handle wider bitmaps.
- (Ffringe_bitmaps_at_pos): Add missing arg declarations.
-
- * macterm.c (mac_draw_bitmap): Handle 16 bits wide bitmaps directly.
- (x_draw_fringe_bitmap): Use enhanced mac_draw_bitmap, so we no longer
- need to call mac_create_bitmap_from_bitmap_data and mac_free_bitmap.
-
- * w32term.c (w32_define_fringe_bitmap): Bitmaps are now 16 bits wide,
- so it is no longer necessary to expand them here.
-
- * xterm.c (x_draw_fringe_bitmap): Handle wider bitmaps (max 16 bits).
-
-2004-02-12 Kim F. Storm <[email protected]>
-
- * window.c (Fwindow_fringes): Doc fix.
-
-2004-02-10 Jan Dj,Ad(Brv <[email protected]>
-
- * xselect.c (x_get_foreign_selection): Add new optional parameter
- time_stamp.
- (Fx_get_selection_internal): Ditto, pass time_stamp to
- x_get_foreign_selection.
-
- * data.c (Fbyteorder): New function.
-
-2004-02-09 Jan Dj,Ad(Brv <[email protected]>
-
- * atimer.c: Move include stdio.h to same place as in other files.
-
- * region-cache.c: Ditto.
-
- * sysdep.c: Ditto.
-
- * xfaces.c: Ditto.
-
-2004-02-09 Sam Steingold <[email protected]>
-
- * w32term.c (w32_draw_fringe_bitmap): Fix a typo in the last patch.
-
-2004-02-09 Kim F. Storm <[email protected]>
-
- * fringe.c: New file. Move original fringe related declarations
- and code from dispextern.h and xdisp.c here.
- Rework code to support user defined fringe bitmaps, redefining
- standard bitmaps, ability to overlay user defined bitmap with
- overlay arrow bitmap, and add faces to bitmaps.
- (Voverflow_newline_into_fringe): Declare here.
- (enum fringe_bitmap_align): New enum.
- (..._bits): All bitmaps are now defined without bitswapping; that
- is now done in init_fringe_once (if necessary).
- (standard_bitmaps): New array with specifications for the
- standard fringe bitmaps.
- (fringe_faces): New array.
- (valid_fringe_bitmap_id_p): New function.
- (draw_fringe_bitmap_1): Rename from draw_fringe_bitmap.
- (draw_fringe_bitmap): New function which draws fringe bitmap,
- possibly overlaying bitmap with cursor in right fringe or the
- overlay arrow in the left fringe.
- (update_window_fringes): Do not handle overlay arrow here.
- Compare and copy fringe bitmap faces.
- (init_fringe_bitmap): New function.
- (Fdefine_fringe_bitmap, Fdestroy_fringe_bitmap): New DEFUNs to
- define and destroy user defined fringe bitmaps.
- (Fset_fringe_bitmap_face): New DEFUN to set face for a fringe bitmap.
- (Ffringe_bitmaps_at_pos): New DEFUN to read current fringe bitmaps.
- (syms_of_fringe): New function. Defsubr new DEFUNs.
- DEFVAR_LISP Voverflow_newline_into_fringe.
- (init_fringe_once, init_fringe): New functions.
- (w32_init_fringe, w32_reset_fringes) [WINDOWS_NT]: New functions.
-
- * Makefile.in (obj): Add fringe.o.
- (fringe.o): New dependencies.
-
- * dispextern.h (FRINGE_ID_BITS): New definition for number of
- bits allocated to hold a fringe number. Increase number of bits
- from 4 to 8 to allow user defined fringe bitmaps.
- (struct glyph_row, struct it): New members left_user_fringe_bitmap,
- left_user_fringe_face_id, right_user_fringe_bitmap,
- right_user_fringe_face_id.
- (enum fringe_bitmap_type, struct fringe_bitmap, fringe_bitmaps):
- Move to new file fringe.c.
- (MAX_FRINGE_BITMAPS): Define here.
- (struct draw_fringe_bitmap_params): New members bits, cursor_p,
- and overlay_p. Change member which to int.
- (struct redisplay_interface): New members define_fringe_bitmap
- and destroy_fringe_bitmap.
- (valid_fringe_bitmap_id_p): Add prototype.
- (w32_init_fringe, w32_reset_fringes) [WINDOWS_NT]: Add prototypes.
-
- * dispnew.c (row_equal_p): Compare fringe bitmap faces and overlay
- arrows.
- (update_frame): Do flush_display if force_flush_display_p to
- ensure display (specifically fringes) are updated in a timely
- manner when resizing the frame by dragging the mouse.
- (update_window_line): Update row if overlay arrow changed.
- (scrolling_window): Redraw fringe bitmaps if fringe bitmap faces
- or overlay arrow changed.
-
- * emacs.c (main) [HAVE_WINDOW_SYSTEM]: Call init_fringe_once,
- syms_of_fringe, and init_fringe.
-
- * frame.h (struct frame): New member force_flush_display_p.
-
- * lisp.h (syms_of_fringe, init_fringe, init_fringe_once):
- Add prototypes.
-
- * macterm.c (mac_draw_bitmap): Add overlay_p arg.
- (x_draw_fringe_bitmap): Handle overlayed fringe bitmaps;
- thanks to YAMAMOTO Mitsuharu for advice on how to do this.
- Use cursor color for displaying cursor in fringe.
- (x_redisplay_interface): Add null handlers for
- define_fringe_bitmap and destroy_fringe_bitmap functions.
-
- * w32term.c (w32_draw_fringe_bitmap): Copy unadapted code from
- xterm.c to handle overlayed fringe bitmaps and to use cursor color
- for displaying cursor in fringe.
- (w32_define_fringe_bitmap, w32_destroy_fringe_bitmap): New W32
- specific functions to define and destroy fringe bitmaps in fringe_bmp.
- (w32_redisplay_interface): Add them to redisplay_interface.
- (w32_term_init): Call w32_init_fringe instead of explicitly
- defining fringe bitmaps in fringe_bmp array.
- (x_delete_display): Call w32_reset_fringes instead of explicitly
- destroying fringe bitmaps in fringe_bmp array.
-
- * xdisp.c (Voverflow_newline_into_fringe, syms_of_xdisp)
- (left_bits, right_bits, up_arrow_bits, down_arrow_bits)
- (continued_bits, continuation_bits, ov_bits, first_line_bits)
- (last_line_bits, filled_box_cursor_bits, hollow_box_cursor_bits)
- (bar_cursor_bits, hbar_cursor_bits, zv_bits, hollow_square_bits)
- (fringe_bitmaps, draw_fringe_bitmap, draw_row_fringe_bitmaps)
- (draw_window_fringes, compute_fringe_widths, update_window_fringes):
- Move fringe handling vars and code to new file fringe.c.
- (handle_display_prop): Handle left-fringe and right-fringe
- display properties; store user fringe bitmaps in iterator.
- (move_it_in_display_line_to): Handle cursor in fringe at eob.
- (clear_garbaged_frames): Set force_flush_display_p if resized.
- (redisplay_window): Redraw fringe bitmaps if not just_this_one_p.
- (display_line): Handle cursor in fringe at eob.
- (display_line): Set row user fringe bitmaps from iterator.
-
- * xterm.c (x_draw_fringe_bitmap): Handle overlayed fringe bitmaps.
- Use cursor color for displaying cursor in fringe.
- (x_redisplay_interface): Add null handlers for
- define_fringe_bitmap and destroy_fringe_bitmap functions.
-
-2004-02-07 Jan Dj,Ad(Brv <[email protected]>
-
- * macfns.c (Fx_change_window_property): Make doc string and
- parameters same as for X version.
-
- * w32fns.c (Fx_change_window_property): Ditto.
-
-2004-02-07 Kim F. Storm <[email protected]>
-
- * xdisp.c (hscroll_window_tree): Position cursor near to right
- margin in hscrolled window when jumping to end of line (rather
- than centering cursor).
-
- * process.c (wait_reading_process_input): Don't do adaptive read
- buffering if waiting for a specific process.
-
-2004-02-05 Luc Teirlinck <[email protected]>
-
- * minibuf.c (Fminibufferp, Fread_from_minibuffer)
- (Fread_minibuffer, Feval_minibuffer)
- (Fread_string, Fread_no_blanks_input)
- (Fcompleting_read): Doc fixes.
- (syms_of_minibuf): Doc fixes for minibuffer-completion-table and
- completion-regexp-list. Define Qcase_fold_search and staticpro it.
- (read_minibuf): Fix initial comment.
- (Ftry_completion, Fall_completions, Ftest_completion): Bind
- case-fold-search to the value of completion-ignore-case when
- checking completion-regexp-list.
- (Fdisplay_completion_list): Make it handle arguments that are
- symbols. Doc fix.
-
-2004-02-05 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h: Add declaration of free_frame_menubar.
-
- * xfns.c (x_create_bitmap_mask): Removed unused variable depth.
- (x_set_menu_bar_lines): Added ! defined USE_GTK for olines.
- (Fx_change_window_property): Add declaration of parameters type and
- format. Remove unused variable cons.
-
- * xselect.c: Include stdio.h.
-
-2004-02-05 Kenichi Handa <[email protected]>
-
- * fns.c (Fset_char_table_range): Fix previous change.
-
- * buffer.c (Fset_buffer_multibyte): Fix docstring.
-
-2004-02-04 Luc Teirlinck <[email protected]>
-
- * editfns.c (Fchar_after, Fchar_before): Doc fixes.
-
-2004-02-04 Stefan Monnier <[email protected]>
-
- * keymap.c (Vmouse_events): Rename from Vmenu_events.
- (syms_of_keymap): Add mouse-[45], header-line, and mode-line to it.
-
-2004-02-04 Kenichi Handa <[email protected]>
-
- * fns.c (Fset_char_table_range): Handle charsets ascii,
- eight-bit-control, and eight-bit-graphic correctly.
-
-2004-02-03 Jason Rumney <[email protected]>
-
- * w32select.c (Fw32_set_clipboard_data): Make coding iso2022 safe.
-
- * w32fns.c (x_to_w32_font): Likewise.
-
-2004-02-03 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h: Add x_handle_dnd_message, x_check_property_data,
- x_fill_property_data, x_property_data_to_lisp and check_x_display_info.
-
- * xterm.c (handle_one_xevent): Call x_handle_dnd_message for
- ClientMessages.
-
- * xselect.c: Include termhooks.h and X11/Xproto.h.
- (x_check_property_data, x_fill_property_data)
- (x_property_data_to_lisp, mouse_position_for_drop)
- (Fx_get_atom_name, x_handle_dnd_message): New functions for DND support.
- (Fx_send_client_event): Move here from xfns.c.
- (syms_of_xselect): Add Sx_get_atom_name and Sx_send_client_message.
-
- * xfns.c (x-send-client-message): Move to xselect.c.
- (Fx_change_window_property): Add optional arguments TYPE, FORMAT and
- OUTER_P.
- (Fx_window_property): Add optional arguments TYPE, SOURCE, DELETE_P,
- VECTOR_RET_P. Handle AnyPropertyType. Call x_property_data_to_lisp
- if vector_ret_p is true.
- (syms_of_xfns): Sx_send_client_message moved to xselect.c.
-
-2004-02-02 Eli Zaretskii <[email protected]>
-
- * fileio.c (Fcopy_file): If NEWNAME is a directory, expand the
- basename of FILE relative to it, not FILE itself.
-
-2004-02-02 Kenichi Handa <[email protected]>
-
- * coding.c (coding_restore_composition): Check invalid
- composition data more rigidly.
-
-2004-01-30 Luc Teirlinck <[email protected]>
-
- * fileio.c (Fread_file_name_internal): Correctly handle the case
- where insert-default-directory is nil.
- (Fread_file_name): Always return an empty string if the user exits
- with an empty minibuffer. Adapt the docstring accordingly.
- (syms_of_fileio): Adapt the docstring of insert-default-directory
- to the change in Fread_file_name.
-
-2004-01-29 Eli Zaretskii <[email protected]>
-
- * alloca.c [!alloca]: Fix the prototype for xfree.
-
-2004-01-29 Kenichi Handa <[email protected]>
-
- * fns.c (string_char_to_byte): Optimize for ASCII only string.
- (string_byte_to_char): Likewise.
-
-2004-01-28 Peter Runestig <[email protected]>
-
- * makefile.w32-in, w32fns.c: Add `default-printer-name' function.
-
-2004-01-27 Steven Tamm <[email protected]>
-
- * unexmacosx.c (unexec_copy): Do not copy more than was
- requested to prevent overwriting during unexec.
-
-2004-01-27 Jan Dj,Ad(Brv <[email protected]>
-
- * process.c (sigchld_handler): Add comment about not calling malloc.
-
- * process.h: Add extern to synch_process_termsig.
-
-2004-01-27 Steven Tamm <[email protected]>
-
- * macterm.c (make_mac_frame, make_mac_terminal_frame):
- Move setting of scroll bars from make_mac_frame to
- make_mac_terminal_frame to prevent clobbering of scroll-bar-mode.
-
-2004-01-26 Richard M. Stallman <[email protected]>
-
- * search.c (Freplace_match): Handle nonexistent
- back-references properly.
-
-2004-01-03 Richard M. Stallman <[email protected]>
-
- * window.c (decode_any_window): New function.
- (Fwindow_height, Fwindow_width, Fwindow_edges)
- (Fwindow_pixel_edges, Fwindow_inside_edges)
- (Fwindow_inside_pixel_edges): Use decode_any_window.
-
-2004-01-27 Jan Dj,Ad(Brv <[email protected]>
-
- * process.h: synch_process_termsig new variable.
-
- * callproc.c: Define synch_process_termsig.
- (Fcall_process): Initiate synch_process_termsig to zero and
- check if non-zero and get signal name after subprocess has ended.
-
- * process.c (sigchld_handler): Set synch_process_termsig
- if terminated by a signal. synch_process_death setting removed.
-
- * sysdep.c (mkdir, rmdir): Also check synch_process_termsig.
-
-2004-01-26 Andreas Schwab <[email protected]>
-
- * print.c (print_preprocess): Declare size as EMACS_INT to not
- lose bits.
- (print_object): Likewise.
- * alloc.c (Fpurecopy): Likewise.
-
-2004-01-25 Luc Teirlinck <[email protected]>
-
- * window.c (Fwindow_minibuffer_p): Doc fix.
-
-2004-01-24 Jonathan Yavner <[email protected]>
-
- * editfns.c (Fformat): Make both passes accept the same set of flags.
-
-2004-01-23 Kenichi Handa <[email protected]>
-
- * fns.c (Fmd5): If OBJECT is a buffer different from the current
- one, set buffer to OBJECT temporarily.
-
-2004-01-21 Stefan Monnier <[email protected]>
-
- * keyboard.c (kbd_buffer_gcpro): Remove.
- (kbd_buffer_store_event, clear_event, Fdiscard_input)
- (stuff_buffered_input, init_keyboard, syms_of_keyboard):
- Don't initialize and/or maintain the variable any more. It was made
- redundant by my commit of 2003-06-15.
-
- * lisp.h [USE_LSB_TAG && !DECL_ALIGN]: Signal an error.
-
-2004-01-21 Jan Dj,Ad(Brv <[email protected]>
-
- * lisp.h: Add undef DECL_ALIGN.
-
-2004-01-21 Stefan Monnier <[email protected]>
-
- * process.c (wait_reading_process_input) [SYNC_INPUT]:
- Check interrupt_input_pending explicitly.
-
- * lisp.h (QUIT) [SYNC_INPUT]: Check interrupt_input_pending as well.
-
- * keyboard.c (handle_async_input): New fun,
- extracted from input_available_signal.
- (input_available_signal, reinvoke_input_signal): Use it.
-
-2004-01-20 Stefan Monnier <[email protected]>
-
- * buffer.c (buffer_defaults, buffer_local_symbols): Use DECL_ALIGN.
-
- * lisp.h [USE_LSB_TAG]: Add definitions for Lisp_Object value
- manipulation macros for when tags are in the lower bits.
- (struct Lisp_Free) [USE_LSB_TAG]: Add padding.
- (DECL_ALIGN): New macro.
- (DEFUN): Use it.
-
- * lisp.h [ENABLE_CHECKING]: Don't force union type.
-
- * s/darwin.h (__attribute__): Remove outdated workaround.
-
- * macterm.c (main) [USE_LSB_TAG]: Don't range check the ram.
-
- * alloc.c (lisp_malloc, lisp_align_malloc) [USE_LSB_TAG]:
- Don't check range of malloc address.
- (pure_alloc) [USE_LSB_TAG]: Enforce alignment.
-
- * process.c (wait_reading_process_input): Lisp_Object/int mixup.
-
- * dired.c (Ffile_attributes): Lisp_Object/int mixup.
-
-2004-01-19 Kenichi Handa <[email protected]>
-
- * fontset.c (fontset_font_pattern): Fix previous change.
-
-2004-01-16 Miles Bader <[email protected]>
-
- * xdisp.c (Voverflow_newline_into_fringe)
- (move_it_in_display_line_to, redisplay_internal)
- (update_window_fringes, redisplay_window, display_line, window):
- Add `#ifdef HAVE_WINDOW_SYSTEM' around fringe-drawing stuff, so
- that it compiles without a window-system.
- * dispnew.c (direct_output_for_insert, update_window): Likewise.
-
-2004-01-16 Kim F. Storm <[email protected]>
-
- * buffer.h (struct buffer): New member indicate_buffer_boundaries.
-
- * buffer.c (init_buffer_once): Set buffer_defaults and
- buffer_local_flags for indicate_buffer_boundaries.
- (syms_of_buffer): Defvar_per_buffer it, and defvar_lisp_nopro
- default- variable for it.
-
- * dispextern.h (struct glyph_row): New members left_fringe_bitmap,
- right_fringe_bitmap, redraw_fringe_bitmaps_p for new fringe handling.
- New members exact_window_width_line_p and cursor_in_fringe_p for
- overflowing newlines into right fringe.
- New members indicate_bob_p, indicate_top_line_p, indicate_eob_p,
- and indicate_bottom_line_p for buffer boundaries and scrolling.
- (enum fringe_bitmap_type): Add UP_ARROW_BITMAP, DOWN_ARROW_BITMAP,
- FIRST_LINE_BITMAP, LAST_LINE_BITMAP, FILLED_BOX_CURSOR_BITMAP,
- HOLLOW_BOX_CURSOR_BITMAP, BAR_CURSOR_BITMAP, HBAR_CURSOR_BITMAP,
- and HOLLOW_SQUARE_BITMAP.
- (draw_fringe_bitmap, draw_window_fringes, update_window_fringes):
- Add prototypes.
-
- * dispnew.c (row_equal_p, update_window_line): Compare fringe bitmaps
- instead of related indicator fields.
- Compare exact_window_width_line_p and cursor_in_mouse_face_p indicators.
- (direct_output_for_insert): Handle exact width lines like
- contined lines. Call update_window_fringes.
- (update_window): Call update_window_fringes.
- (scrolling_window): Don't skip desired rows with changed bitmaps.
- Check if fringe bitmaps changes when assigning scrolled rows.
-
- * xdisp.c (Voverflow_newline_into_fringe): New variable.
- (IT_OVERFLOW_NEWLINE_INTO_FRINGE): New macro.
- (move_it_in_display_line_to): Overflow newline into fringe for
- rows that are exactly as wide as the window.
- (up_arrow_bits, down_arrow_bits, first_line_bits, last_line_bits)
- (filled_box_cursor_bits, hollow_box_cursor_bits, bar_cursor_bits)
- (hbar_cursor_bits, hollow_square_bits): New fringe bitmaps.
- (fringe_bitmaps): Add new bitmaps.
- (draw_fringe_bitmap): Make extern. Remove WHICH arg.
- Select proper bitmap for cursor in fringe when appropriate.
- Handle alignment of bitmap to top or bottom of row.
- (draw_row_fringe_bitmaps): Don't select bitmaps here; that is now
- done by update_window_fringes.
- (update_window_fringes, draw_window_fringes): New functions.
- (redisplay_internal): Call update_window_fringes in case only
- cursor row is updated.
- (redisplay_window): Call update_window_fringes.
- Explicitly call draw_window_fringes if redisplay was done using
- the current matrix or the overlay arrow is in the window.
- (try_window_reusing_current_matrix): Mark scrolled rows for
- fringe update (to update buffer-boundaries / scrolling icons).
- (find_last_unchanged_at_beg_row): Handle exact width lines line
- continued lines.
- (display_line): Overflow newline into fringe for rows that are
- exactly as wide as the window. Don't append space for newline
- in this case.
- (notice_overwritten_cursor): Explicitly clear cursor bitmap
- in fringe as if it had been overwritten.
- (erase_phys_cursor): Erase cursor bitmap in fringe.
- (syms_of_xdisp): Mark show-trailing-whitespace and
- void-text-area-pointer as user options.
- DEFVAR_LISP Voverflow_newline_into_fringe. Enable by default.
-
- * xterm.c (x_update_window_end): Call draw_window_fringes.
- (x_after_update_window_line): Just set redraw_fringe_bitmaps_p
- in row instead of actually drawing fringe bitmaps.
- (x_draw_fringe_bitmap): Handle bottom aligned bitmaps.
- (x_draw_window_cursor): Draw cursor in fringe.
-
- * w32term.c (x_update_window_end): Call draw_window_fringes.
- (x_after_update_window_line): Just set redraw_fringe_bitmaps_p
- in row instead of actually drawing fringe bitmaps.
- (w32_draw_fringe_bitmap): Handle bottom aligned bitmaps.
- (w32_draw_window_cursor): Draw cursor in fringe.
-
- * macterm.c (x_update_window_end): Call draw_window_fringes.
- (x_after_update_window_line): Just set redraw_fringe_bitmaps_p
- in row instead of actually drawing fringe bitmaps.
- (x_draw_fringe_bitmap): Handle bottom aligned bitmaps.
- (mac_draw_window_cursor): Draw cursor in fringe.
-
-2004-01-16 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): Don't handle characters that are part
- of an old style (XLookupString) compose sequence.
-
-2004-01-15 Kenichi Handa <[email protected]>
-
- * search.c (Freplace_match): Use make_multibyte_string or
- make_unibyte_string according to the buffer multibyteness.
-
-2004-01-14 Stefan Monnier <[email protected]>
-
- * alloc.c (struct interval_block, struct string_block)
- (struct symbol_block, struct marker_block, live_string_p)
- (live_cons_p, live_symbol_p, live_float_p, live_misc_p):
- Better preserve alignment for objects in blocks.
- (FLOAT_BLOCK_SIZE): Adjust for possible alignment padding.
-
- * lread.c (defvar_per_buffer): Remove dead declaration.
-
- * macterm.c (do_check_ram_size): Don't hardcode the lisp address
- space size.
-
-2004-01-12 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (popup_get_selection): Check new parameter down_on_keypress
- if a key press should pop down. Only pop down if a key is pressed
- outside the menu/dialog.
- (create_and_show_popup_menu): Pass 0 for down_on_keypress to
- popup_get_selection.
- (create_and_show_dialog): Pass 1 for down_on_keypress to
- popup_get_selection.
-
-2004-01-11 Jan Dj,Ad(Brv <[email protected]>
-
- * alloc.c (allocate_vectorlike): Surround calls to mallopt with
- BLOCK/UNBLOCK_INPUT.
-
-2004-01-08 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (Fx_popup_dialog): Add an Ok button if no buttons are
- specified.
-
-2004-01-08 Kenichi Handa <[email protected]>
-
- * editfns.c (Fformat): Fix '&' to '&&'.
-
-2004-01-08 Andreas Schwab <[email protected]>
-
- * print.c (print_preprocess) <case Lisp_Vectorlike>: Only mask
- size if PSEUDOVECTOR_FLAG is set.
-
-2004-01-07 Kenichi Handa <[email protected]>
-
- * charset.c (Fdeclare_equiv_charset): Fix docstring.
-
- * fontset.c (fontset_ref_via_base): Fix previous change.
-
-2004-01-07 Kim F. Storm <[email protected]>
-
- * process.c (read_process_output): Only activate adaptive
- buffering if we read less than 256 bytes at a time.
-
-2004-01-06 Kim F. Storm <[email protected]>
-
- * dispnew.c (buffer_posn_from_coords): Return both buffer/string
- object and image object. Return glyph width and height.
- (mode_line_string, marginal_area_string): Ditto.
-
- * dispextern.h (buffer_posn_from_coords, mode_line_string)
- (marginal_area_string): Fix prototypes.
-
- * keyboard.h (POSN_POSN, POSN_SET_POSN): Rename macros from
- POSN_BUFFER_POSN and POSN_SET_BUFFER_POSN. All uses changed.
- (POSN_INBUFFER_P, POSN_BUFFER_POSN): New macros.
-
- * keyboard.c (make_lispy_position): Use modified mode_line_string,
- buffer_posn_from_coords, and marginal_area_string functions to
- include both string object and image object in the lispy position.
- Also add actual glyph width and height to position.
- (read_key_sequence): Use real buffer position from mouse
- event to find keymap property even when click is in marginal area.
-
- * xdisp.c (note_mode_line_or_margin_highlight): Use modified
- mode_line_string and marginal_area_string functions to handle
- both string object and image object properties.
-
-2004-01-06 Andreas Schwab <[email protected]>
-
- * syntax.c (skip_chars): Treat '-' at end of string as ordinary
- character.
-
-2004-01-02 Andreas Schwab <[email protected]>
-
- * macterm.c (emacs_options, x_initialized, same_x_server):
- Remove unused (and duplicated) definitions.
-
-2004-01-02 Kim F. Storm <[email protected]>
-
- * process.h (struct Lisp_Process): New members for adaptive read
- buffering: adaptive_read_buffering, read_output_delay, and
- read_output_skip.
-
- * process.c (ADAPTIVE_READ_BUFFERING): New conditional.
- (READ_OUTPUT_DELAY_INCREMENT, READ_OUTPUT_DELAY_MAX)
- (READ_OUTPUT_DELAY_MAX_MAX): New constants.
- (process_output_delay_count, process_output_skip): New vars.
- (Vprocess_adaptive_read_buffering): New variable.
- (make_process): Initialize adaptive read buffering members.
- (Fstart_process): Set adaptive_read_buffering member.
- (deactivate_process): Cleanup adaptive read buffering.
- (wait_reading_process_input): Temporarily omit delayed
- subprocesses from the set of file descriptors to read from;
- adjust the select timeout if we skipped any subprocesses.
- (read_process_output): Increase adaptive read buffering delay if
- we read less than a full buffer; reduce delay when we read a
- full buffer.
- (send_process): Simplify using local Lisp_Process var.
- Reset adaptive read buffering delay after write.
- (init_process): Initialize process_output_delay_count and
- process_output_skip.
- (syms_of_process): DEFVAR_LISP Vprocess_adaptive_read_buffering.
-
-2004-01-01 Jason Rumney <[email protected]>
-
- * w32term.c (w32_text_out): Use s->font, for consistency with callers.
-
-2003-12-30 Luc Teirlinck <[email protected]>
-
- * print.c (Ferror_message_string): Add hyperlink in the docstring
- to the definition of `signal' in the Elisp manual.
- * eval.c (Fsignal): Ditto.
-
-2003-12-29 James Clark <[email protected]>
-
- * fns.c (internal_equal): Return t for two NaN arguments.
-
-2003-12-29 Richard M. Stallman <[email protected]>
-
- * data.c (store_symval_forwarding): Handle setting
- default-fill-column, etc., by changing the value in
- buffers that use the default.
-
- * minibuf.c (Fset_minibuffer_window): Doc fix.
-
- * fileio.c (choose_write_coding_system): Ignore auto_saving
- if using the visited file for auto saves.
- (Fwrite_region): Don't update SAVE_MODIFF
- if auto-saving in visited file.
-
-2003-12-29 Kenichi Handa <[email protected]>
-
- * dispextern.h (face_font_available_p): Extern it.
-
- * fontset.c (Voverriding_fontspec_alist): New variable.
- (lookup_overriding_fontspec): New function.
- (fontset_ref_via_base): Call lookup_overriding_fontspec if necessary.
- (fontset_font_pattern): Likewise.
- (regulalize_fontname): New function.
- (Fset_fontset_font): Call regulalize_fontname.
- (Fset_overriding_fontspec_internal): New function.
- (syms_of_fontset): Initialize and staticpro Voverriding_fontspec_alist.
- Defsubr Sset_overriding_fontspec_internal.
-
- * xfaces.c (face_font_available_p): New function.
-
-2003-12-28 Richard M. Stallman <[email protected]>
-
- * buffer.c (Fother_buffer): Don't crash if BUF is nil
- or if its name is nil.
-
- * buffer.c (Fkill_buffer): Don't delete auto-save file
- if it's the same as the visited file.
-
-2003-12-28 Luc Teirlinck <[email protected]>
-
- * coding.c (Fcheck_coding_system): Doc fix.
-
-2003-12-28 Kim F. Storm <[email protected]>
-
- * Makefile.in (eval.o): Depend on dispextern.h.
-
- * dispnew.c (buffer_posn_from_coords): Fix calculation of dy for
- image glyph using image's ascent.
- (mode_line_string): Return image glyph as object clicked on.
- Adjust y0 for image glyph using image's ascent.
-
- * dispextern.h (FACE_ID_BITS, MAX_FACE_ID): New defines.
- (struct glyph): New members, ascent and descent. Used to save
- this glyph's ascent and descent, instead of having.
- (struct glyph): Declare member face_id using FACE_ID_BITS.
- (find_hot_spot): Add prototype.
-
- * keyboard.c (Qimage): Remove extern (now in lisp.h).
- (QCmap): Declare extern.
- (make_lispy_position): When position is inside image hot-spot,
- use hot-spot element's id as posn element.
-
- * lisp.h (IMAGEP): New macro to test for image object type.
- (Qimage): Declare extern.
-
- * macfns.c (Qimage): Remove extern (now in lisp.h).
- (valid_image_p, parse_image_spec): Use IMAGEP macro.
-
- * macterm.c (Qface, Qmouse_face): Remove unused externs.
-
- * w32fns.c (Qimage): Remove extern (now in lisp.h).
- (valid_image_p, parse_image_spec): Use IMAGEP macro.
-
- * w32menu.c (Qmouse_click, Qevent_kind): Remove unused externs.
-
- * w32term.c (Qface, Qmouse_face): Remove unused externs.
-
- * xdisp.c (Qarrow, Qhand, Qtext, Qpointer): New variables for
- pointer types.
- (Qrelative_width, Qalign_to): Remove unused variables.
- (Vvoid_text_area_pointer): Replace Vshow_text_cursor_in_void.
- (QCmap, QCpointer, Qrect, Qcircle, Qpoly): New variables for image
- maps.
- (x_y_to_hpos_vpos): Return glyph relative coordinates through new
- dx and dy args. Remove buffer_only_p arg (always 0). Simplify
- code accordingly.
- (get_glyph_string_clip_rect): Draw cursor using glyph's rather
- than row's ascent and height, to get sensible height on tall rows.
- (build_desired_tool_bar_string): Remove Qimage extern.
- (get_tool_bar_item): Fix call to x_y_to_hpos_vpos.
- (produce_image_glyph): Adjust it.ascent to minimum row ascent if
- image glyph is alone on the last line.
- (append_glyph, append_composite_glyph, produce_image_glyph)
- (append_stretch_glyph): Set glyph's ascent and descent.
- (on_hot_spot_p): New function to check if position is inside an
- rectangular, circular, or polygon-shaped image hot-spot,
- (find_hot_spot): New function to search for image hot-spot.
- (Flookup_image_map): New defun to search for image hot-spot.
- (define_frame_cursor1): New aux function to determine frame
- pointer.
- (note_mode_line_or_margin_highlight, note_mouse_highlight): Handle
- `pointer' text property and :pointer image property to control
- frame pointer shape. Detect image hot-spots for pointer and
- help_echo properties. Use define_frame_cursor1.
- (note_mouse_highlight): Use Vvoid_text_area_pointer.
- (syms_of_xdisp): Defsubr new defun. Intern and staticpro new
- variables. DEFVAR_LISP Vvoid_text_area_pointer instead of
- Vshow_text_cursor_in_void.
-
- * xfaces.c (cache_face): Abort if c->size exceeds MAX_FACE_ID.
-
- * xfns.c (x_set_mouse_color): Remove bogus x_check_errors call.
- (Qimage): Remove extern (now in lisp.h).
- (valid_image_p, parse_image_spec): Use IMAGEP macro.
-
- * xmenu.c (show_help_event): Remove unused code.
-
- * xterm.c (Qface, Qmouse_face): Remove unused externs.
- (x_draw_hollow_cursor): Draw cursor using glyph's rather than
- row's ascent and descent, to get a sensible height on tall rows.
-
-2003-12-25 Luc Teirlinck <[email protected]>
-
- * minibuf.c (Fcompleting_read): Undo previous change.
-
-2003-12-25 Lars Hansen <[email protected]>
-
- * dired.c (Fdirectory_files, Fdirectory_files_and_attributes):
- Arguments GCPRO'ed in call to file name handler.
-
-2003-12-25 Thien-Thi Nguyen <[email protected]>
-
- * termcap.c (tgetst1): Scan for "%pN"; if all
- N are continuous in [1,9], remove all "%pN".
-
-2003-12-24 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_frame_set_char_size): Call x_wm_set_size_hint.
-
- * xfaces.c (lface_fully_specified_p): Take into account that
- MAC OS always have unspecified stipple.
-
-2003-12-24 Thien-Thi Nguyen <[email protected]>
-
- * tparam.c (tparam1): Add handling for `%pN', which
- means use param N for the next substitution.
-
-2003-12-24 Thien-Thi Nguyen <[email protected]>
-
- * xfaces.c (Fcolor_gray_p): Fix omission bug:
- In case `frame' is nil, consult the selected frame.
- (Fcolor_supported_p): Likewise.
-
-2003-12-23 Luc Teirlinck <[email protected]>
-
- * fns.c (Frandom, Fstring_make_multibyte, Fset_char_table_range):
- Doc fixes.
-
- * minibuf.c (read_minibuf): Allow INITIAL to be a cons of a string
- and an integer. Adapt the introductory comment accordingly.
- (Fread_from_minibuffer): Delete code moved into read_minibuf.
- Doc fix.
- (Fread_minibuffer, Fread_no_blanks_input): Adapt to changes in
- read_minibuf.
- (Fcompleting_read): Delete code moved into read_minibuf.
- (Ftest_completion): Make it handle obarrays and hash tables correctly.
-
-2003-12-03 Kenichi Handa <[email protected]>
-
- * coding.c (decode_coding_iso2022): Fix for preserving UTF-8
- encoding sequence.
-
-2003-12-01 Kenichi Handa <[email protected]>
-
- * composite.c (syms_of_composite): Don't make the compostion hash
- table week.
-
-2003-11-30 Luc Teirlinck <[email protected]>
-
- * intervals.h: Add EXFUN for Fget_char_property_and_overlay.
- * textprop.c (Fget_char_property_and_overlay): New function.
- (syms_of_textprop): Defsubr it.
-
-2003-11-29 Jan Dj,Ad(Brv <[email protected]>
-
- * dispnew.c (buffer_posn_from_coords): Add ifdef HAVE_WINDOW_SYSTEM
- to compile on terminal configuration.
-
- * fileio.c (Fread_file_name): Check use_file_dialog also before
- calling Fx_file_dialog.
-
- * fns.c (use_file_dialog): New variable.
- (syms_of_fns): DEFVAR_BOOL use-file-dialog.
-
-2003-11-29 Kim F. Storm <[email protected]>
-
- * msdos.c (Qcursor_type, Qbar, Qhbar): Declare extern.
- (syms_of_msdos): Don't intern and staticpro them.
-
-2003-11-27 Kim F. Storm <[email protected]>
-
- * dispnew.c (buffer_posn_from_coords): Calculate and return pixel
- coordinates relative to glyph at posn. If glyph is an image,
- return that as object at posn. Callers changed.
- (mode_line_string, marginal_area_string): Calculate and return
- pixel coordinates relative to glyph. Callers changed.
-
- * dispextern.h (buffer_posn_from_coords, mode_line_string)
- (marginal_area_string): Fix prototypes.
- (window_box_left_offset, window_box_right_offset): Add prototypes.
-
- * frame.h (get_specified_cursor_type, get_window_cursor_type):
- Remove prototypes.
-
- * keyboard.h (EVENT_CLICK_COUNT, POSN_SCROLLBAR_PART): Fix defines.
-
- * keyboard.c (make_lispy_position): Add x and y coordinates
- relative to the current glyph as 7th element of position.
- If glyph is an image, return it in the object element.
- (read_key_sequence): Skip checks for keymap property in cases
- where POSN_STRING is not a string (e.g. an image).
-
- * xdisp.c (Vdisplay_pixels_per_inch): New variable.
- (Vshow_text_cursor_in_void): New variable.
- (glyph_to_pixel_coords): Don't use negative hpos.
- (x_y_to_hpos_vpos): Fix for partially visible first glyph.
- (append_stretch_glyph): Change ascent arg to be actual value
- in pixels rather than ratio to height. Callers changed.
- (calc_pixel_width_or_height): New aux function, implementing
- pixel based artihmetic for glyph widths and heights.
- (produce_stretch_glyph): Use calc_pixel_width_or_height for
- :width, :height, :align-to, and :ascent, thus allowing these to
- be specified in pixels as well as multiples of characters.
- Don't produce stretch glyphs with zero width or height.
- (get_specified_cursor_type): Declare static.
- (get_window_cursor_type): Declare static. Add glyph arg to be
- able to know when cursor is on an image; always substitute
- hollow-box cursor for filled-box cursor on images, to avoid
- negative images and flicker when blinking the cursor.
- (display_and_set_cursor): Pass glyph to get_window_cursor_type.
- (note_mode_line_or_margin_highlight): Use non-text cursor rather
- than vertical scroll-bar cursor in display margins.
- (note_mouse_highlight): Use non-text cursor rather than text
- cursor in fringes and over images in the text area.
- Use non-text cursor when mouse pointer is outside editable text,
- i.e. in the void after end-of-line or end-of-buffer; this was
- already done for W32, but is now standard for all systems --
- user can toggle show-text-cursor-in-void to get old behaviour.
- (syms_of_xdisp): DEFVAR_LISP Vshow_text_cursor_in_void and
- Vdisplay_pixels_per_inch.
-
-2003-11-25 Andreas Schwab <[email protected]>
-
- * fns.c (internal_equal) <case Lisp_Vectorlike>: Declare size as
- EMACS_INT to not lose bits.
- (Ffillarray): Don't set bits beyond the size of a bool vector.
-
-2003-11-25 Kim F. Storm <[email protected]>
-
- * print.c (Fredirect_debugging_output) [!GNU_LINUX]: Do not
- define this defun on systems that cannot use stderr as lvalue.
-
-2003-11-24 Gerd Moellmann <[email protected]>
-
- * s/freebsd.h (LD_SWITCH_SYSTEM_TEMACS)
- [__FreeBSD_version >= 500042]: Define as -znocombreloc because
- ld's default is incompatible with unexec.
-
-2003-11-23 Kim F. Storm <[email protected]>
-
- * window.c (enum window_loop): Add REDISPLAY_BUFFER_WINDOWS.
- (window_loop): Handle REDISPLAY_BUFFER_WINDOWS.
- (Fforce_window_update): New defun.
- (syms_of_window): Defsubr it.
- (Fset_window_margins, Fset_window_fringes): Doc fix.
-
- * print.c (Fredirect_debugging_output): New defun.
- (syms_of_print): Defsubr it.
-
-2003-11-22 Luc Teirlinck <[email protected]>
-
- * fns.c (Fset_char_table_parent): Doc fix.
-
-2003-11-22 Kim F. Storm <[email protected]>
-
- * dispnew.c (buffer_posn_from_coords): Return actual row/column
- for glyph clicked on, rather than (unused) pixel positions.
- (mode_line_string, marginal_area_string): Change X and Y args to
- pointers for returning actual row/column for glyph clicked on.
- Simplify and optimize loops.
-
- * dispextern.h (mode_line_string, marginal_area_string):
- Update prototypes.
-
- * keyboard.c (make_lispy_position): New function for generating
- mouse click positions from frame and pixel coordinates.
- Enhanced to return buffer position and actual row/column for
- events outside the text area using updated mode_line_string and
- marginal_area_string functions.
- Return left-fringe and right-fringe clicks as such, rather than
- clicks in text area.
- (make_lispy_event) [USE_X_TOOLKIT, USE_GTK]: Don't call
- pixel_to_glyph_coords, as we never use the results.
- (make_lispy_event): Use make_lispy_position for MOUSE_CLICK_EVENT,
- WHEEL_EVENT, and DRAG_N_DROP_EVENT to replace redundant code.
- Eliminate unused code in WHEEL_EVENT handling.
- (make_lispy_movement): Use make_lispy_position.
-
- * window.c (coordinates_in_window): Remove redundant tests.
- Fix returned X pixel value for left-margin.
-
- * xdisp.c (note_mode_line_or_margin_highlight): Adapt to new
- mode_line_string and marginal_area_string parameters.
-
-2003-11-22 Lars Hansen <[email protected]>
-
- * w32.c (struct the_group, getgrgid): Add.
- * mac.c (struct my_group, getgrgid): Add.
-
-2003-11-21 Luc Teirlinck <[email protected]>
-
- * fns.c (Fassq, Fassoc, Frassq, Frassoc): Doc fixes.
-
-2003-11-21 Lars Hansen <[email protected]>
-
- * dired.c (Ffile_attributes): Add parameter ID-FORMAT and
- include in call to file name handler. Optionally translate numeric
- UID and GID to strings. Update docstring.
- (directory_files_internal): Add parameter ID-FORMAT.
- (Fdirectory_files_and_attributes): Add parameter ID-FORMAT and
- include in call to file name handler and call to
- directory_files_internal. Update Docstring.
- (Fdirectory_files): Add dummy parameter in call to
- directory_files_internal.
- * lisp.h (Qinteger): Add.
- (Qinteger_or_floatp, Qinteger_or_float_or_marker_p): Remove.
- (Ffile_attributes): Add parameter.
- * data.c (Qinteger): Export.
-
-2003-11-21 Luc Teirlinck <[email protected]>
-
- * fns.c (Freverse, Fnreverse): Doc fixes.
-
-2003-11-19 Kim F. Storm <[email protected]>
-
- * xdisp.c (init_iterator): Initialize it->start to position
- before reseating (in case start position is invisible).
- (init_to_row_start): Set it->start to row-start.
- (redisplay_window): Accept optional_new_start if start position
- is invisible (in which case IT_CHARPOS overshoots PT).
- (display_line): Setup row->start from it->start (rather than
- it->current which is wrong if first char on line is invisible).
- When done, reseat it->start to it->current (= start of next row).
- (expose_area): Fix exposure of text area when first char (e.g. TAB)
- is only partially visible.
-
- * dispextern.h (struct it): New member start.
-
-2003-11-17 Stefan Monnier <[email protected]>
-
- * alloc.c (make_float, Fcons): Clear the markbit at init time.
- (make_float, Fcons, Fmake_symbol, allocate_misc): Move the increment
- of block_index outside of the macro call.
- (Fgarbage_collect): Remove null code.
-
- * m/amdx86-64.h: Don't redefine XPNTR.
-
- * keyboard.c (parse_modifiers, apply_modifiers): Use INTMASK instead
- of VALMASK.
-
- * fns.c (hashfn_eq, hashfn_eql, hashfn_equal, hash_put)
- (sxhash_string, sxhash): Use INTMASK instead of VALMASK.
- (maybe_resize_hash_table): Use MOST_POSITIVE_FIXNUM.
-
- * lisp.h (VALMASK): Only define for non-union type.
- (MARKBIT): Remove.
- (ARRAY_MARK_FLAG): Use previous value of MARKBIT.
- (XTYPE): Define unconditionally.
- (XSETTYPE): Remove one more remnant.
- (EQ): Define differently for the union and non-union cases.
- (INTMASK): New bit mask.
- (struct Lisp_Marker): Move down to prepare for upcoming patch.
- (GC_EQ): Delegate to EQ.
-
- * coding.c (coding_restore_composition): Lisp_Object/int mixup.
-
-2003-11-17 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_window_to_scroll_bar): Move check of display to
- where window_id is compared.
-
-2003-11-17 Kim F. Storm <[email protected]>
-
- * dispextern.h (struct it): New member first_vpos.
-
- * xdisp.c (start_display): Set it->first_vpos.
- (try_window_id): Use first_vpos to start display in first _text_
- line if no reusable lines at start of window with header line.
-
-2003-11-16 Jan Dj,Ad(Brv <[email protected]>
-
- * w32fns.c (XPutPixel):
- * w32bdf.c (w32_init_bdf_font):
- * sunfns.c (sel_read):
- * process.c (Fmake_network_process):
- * frame.c (store_frame_param):
- * fontset.c (Fset_fontset_font):
- * emacs.c (shut_down_emacs):
- * ccl.c (ccl_driver): Remove period at end of error message.
-
- * config.in: Regenerate.
-
- * xfns.c (x_window_to_frame, x_any_window_to_frame)
- (x_non_menubar_window_to_frame, x_menubar_window_to_frame)
- (x_top_window_to_frame): Add Display* argument to xg_win_to_widget.
- (x_create_bitmap_mask, xg_set_icon, create_frame_xic)
- (xic_set_statusarea, x_window, gif_load): Formatting adjustments.
-
- * xterm.h (struct x_display_info): New field xg_cursor for GTK.
-
- * xterm.c: Add Display * to x_window_to_scroll_bar declaration.
- (XTmouse_position, handle_one_xevent): Pass Display* to
- x_window_to_scroll_bar.
- (x_window_to_scroll_bar): Take a Display* argument.
- Check that display for frame is equal to Display* argument.
- (event_handler_gdk): Remove current_dpyinfo. Get dpyinfo from
- x_display_info_for_display instead. Use Display in xev instead
- of GDK_DISPLAY.
- (x_dispatch_event): Call x_display_info_for_display.
- (XTread_socket): Move GTK part out of loop. current_dpyinfo removed.
- (x_connection_closed): Call xg_display_close for GTK.
- (x_term_init): Call xg_display_open for additional displays.
- Initiate dpyinfo->xg_cursor with call to xg_create_default_cursor
- for GTK.
-
- * xmenu.c (single_menu_item, mouse_position_for_popup)
- (x_activate_menubar): Formatting adjustments.
-
- * xdisp.c (update_tool_bar, redisplay_tool_bar): Formatting
- adjustments.
-
- * gtkutil.c (xg_get_gdk_display, xg_set_screen, xg_display_open)
- (xg_display_close, xg_create_default_cursor)
- (xg_get_gdk_pixmap_and_mask): New functions for multiple display
- handling.
- (xg_left_ptr_cursor): Remove.
- (xg_set_cursor): Change cursor to GdkCursor*. Do not create
- cursor here.
- (xg_win_to_widget): Take Display* argument, call
- gdk_xid_table_lookup_for_display.
- (xg_create_frame_widgets, xg_get_file_name, create_menus)
- (xg_create_widget, xg_modify_menubar_widgets): Call xg_set_screen.
- (xg_create_widget, xg_create_scroll_bar): Use xg_cursor
- in FRAME_X_DISPLAY_INFO.
- (xg_get_scroll_id_for_window): Take Display* argument.
- (update_frame_tool_bar): Call xg_get_gdk_pixmap_and_mask.
- (xg_initialize): Remove xg_left_ptr_cursor.
-
- * gtkutil.h (xg_get_scroll_id_for_window, xg_win_to_widget): Add
- Display* argument.
- (xg_display_open, xg_display_close, xg_create_default_cursor): Declare.
-
-2003-11-14 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_detect_focus_change): Do not change focus frame for
- Enter/LeaveNotify if the current focus frame has explicit focus.
-
-2003-11-14 Kim F. Storm <[email protected]>
-
- * dispnew.c (update_text_area): Fix redisplay error when hscroll
- is active and first glyph is only partially visible.
-
-2003-11-13 Kenichi Handa <[email protected]>
-
- * xdisp.c (select_frame_for_redisplay): New function.
- (redisplay_internal): Record also selected_frame for
- unwind_redisplay. Call select_frame_for_redisplay before
- redrawing each frame.
- (unwind_redisplay): Argument changed to a cons.
-
-2003-11-12 Luc Teirlinck <[email protected]>
-
- * fns.c (Fstring_to_multibyte): Doc fix.
-
-2003-11-11 Kenichi Handa <[email protected]>
-
- * xterm.c (x_list_fonts): Fix excluding of auto-scaled fonts.
-
-2003-11-09 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_window): Set XtNx and XtNy in shell widget for
- program specified positions.
-
-2003-11-08 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (XAW_ARROW_SCROLLBARS): Define it for Xaw 1.5E.
-
-2003-11-08 Kenichi Handa <[email protected]>
-
- * Makefile.in (lisp): Add kannada.el.
- (shortlisp): Likewise.
-
-2003-11-07 Kenichi Handa <[email protected]>
-
- * coding.c (coding_allocate_composition_data):
- Reset coding->composing to COMPOSITION_NO.
- (coding_restore_composition): Detect invalid composition data.
- Give Fstring and Fvector a Lispy integer, not C int.
-
-2003-11-05 Stefan Monnier <[email protected]>
-
- * floatfns.c (Flogb): Don't use VALMASK.
-
- * m/amdx86-64.h (VALBITS, XINT, XUINT): Remove.
- * m/ia64.h (VALBITS, XINT, XUINT): Remove.
-
- * lisp.h (XINT): Move the cast to clarify what is going on.
- (GCTYPEMASK, XSETTYPE): Remove.
- (XGCTYPE): Make it an alias of XTYPE.
-
-2003-11-03 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_term_init): Fix formatting.
-
-2003-11-02 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.h (xg_have_tear_offs): Declare.
- (xg_keep_popup, xg_did_tearoff): Remove.
-
- * gtkutil.c: Remove variable xg_did_tearoff.
- (xg_have_tear_offs): New function.
- (tearoff_remove): Just decrease xg_detached_menus.
- (tearoff_activate): Increase xg_detached_menus and call
- tearoff_remove when tearoff is removed.
- (xg_keep_popup): Remove function.
- (create_menus): Give add_tearoff_p as argument to recursive
- call to create_menus.
- (xg_create_widget): Use variables instead of multiple
- strcmp. Tell create_menus to create tear off only for
- menu bar menus.
- (xg_update_menubar): Change title for a detached menu also.
- (xg_modify_menubar_widgets): Always call xg_update_menubar, regardless
- of deep_p.
- (xg_initialize): Initialize xg_detached_menus, remove
- initialization of xg_did_tearoff.
-
- * xmenu.c (set_frame_menubar): For GTK, set deep_p if
- xg_have_tear_offs returns non-zero.
- (create_and_show_popup_menu): Remove setting of xg_did_tearoff and
- call to xg_keep_popup.
-
-2003-11-01 Andrew Choi <[email protected]>
-
- * macterm.c (XTread_socket): Handle menubar selection and grow
- window only for mouseDown events.
-
-2003-10-31 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_term_init): For GTK part, increase x_initialized
- to check for more than one display. Use error instead of return 0.
-
-2003-10-31 Andrew Choi <[email protected]>
-
- * unexmacosx.c (unrelocate): New function (contributed by Nozomu Ando).
- (copy_dysymtab): Call it.
-
-2003-10-31 Luc Teirlinck <[email protected]>
-
- * eval.c (Fdefvaralias): Doc fix.
-
-2003-10-26 Luc Teirlinck <[email protected]>
-
- * data.c (Fsetplist): Doc fix.
-
-2003-10-14 Lute Kamstra <[email protected]>
-
- * window.c (Fset_window_fringes): Clarify docstring.
-
-2003-10-14 Kim F. Storm <[email protected]>
-
- * window.c (Fset_window_margins): Simplify arg checking.
-
-2003-10-13 Richard M. Stallman <[email protected]>
-
- * regex.c (MAX_BUF_SIZE): Reduce to 2**15.
- (print_partial_compiled_pattern): Replace assert with a printout.
- (skip_noops, mutually_exclusive_p): Change args, values to re_char *.
-
- * alloc.c (lisp_align_malloc): If BASE is 0, call memory_full.
-
- * window.c (Fset_window_margins): Allow only integers as args.
- (syms_of_window) <special-display-buffer-names,
- special-display-regexps>: Doc fixes.
-
-2003-10-13 Lute Kamstra <[email protected]>
-
- * window.c (Fset_window_fringes): Elaborate docstring.
-
-2003-10-12 Andrew Choi <[email protected]>
-
- * macterm.c (XTread_socket): Call DragWindow only for mouseDown events.
-
- * s/darwin.h (GC_MARK_STACK): Define.
-
-2003-10-12 Jan Dj,Ad(Brv <[email protected]>
-
- * window.c (shrink_windows): New function.
- (size_window): Call shrink_windows to calculate window sizes when
- shrinking frame with more than one window.
-
-2003-10-12 Kim F. Storm <[email protected]>
-
- * xdisp.c (compute_fringe_widths): Doc fix.
-
-2003-10-08 Kenichi Handa <[email protected]>
-
- * coding.c (Fcoding_system_p): Return t for auto-loading coding system.
-
-2003-10-07 Kenichi Handa <[email protected]>
-
- * coding.c (Qcoding_system_define_form): New variable.
- (syms_of_coding): Intern and staticpro it.
- (Fcheck_coding_system): Try to autoload the definition of
- CODING-SYSTEM.
-
-2003-10-05 Luc Teirlinck <[email protected]>
-
- * fns.c (Frequire): Doc fix.
-
-2003-10-05 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (Fx_send_client_event): New function as a base for
- manipulating extended window manager hints.
- (Fx_send_client_event): Remove unused variable s.
-
- * w32term.c (w32_read_socket): Remove call to x_check_fullscreen_move,
- that function is removed.
-
- * xterm.c (x_set_offset): Use move_offset_left/top instead of
- x/y_pixels_outer_diff.
- (x_check_expected_move): Calculate move_offset_left/top.
-
- * xterm.h (struct x_output): New members: move_offset_top/left.
-
- * frame.c (x_set_frame_parameters): Remove x_fullscreen_move,
- call x_set_offset directly.
-
- * frame.h (enum): FULLSCREEN_MOVE_WAIT removed.
-
- * frame.c (Fdelete_frame): Free decode_mode_spec_buffer.
-
- * xterm.c (x_delete_display): Free font names and font_encoder
- in dpyinfo->font_table.
-
- * xfns.c (Fx_close_connection): Only call XFreeFont here.
- Move xfree of font names to x_delete_display.
-
- * xterm.h (struct x_display_info): New member, wm_type.
- (struct x_output): New members, expected_top/left and
- check_expected_move.
-
- * xterm.c (handle_one_xevent): Reset wm_type when ReparentNotify
- is received.
- (handle_one_xevent): Rename x_check_expected_move from
- x_check_fullscreen_move.
- (x_set_offset): Only add WM decoration sizes to modified_top/left
- for X_WMTYPE_A. Set check_expected_move when WM type is unknown.
- (x_check_expected_move): Rename from x_check_fullscreen_move.
- Removed fullscreen specific code. Use check_expected_move,
- expected_left/top instead. Also, set wm_type.
- (x_term_init): Initialize wm_type to unknown.
-
- * frame.c (x_fullscreen_move): Remove addition of WM decoration
- sizes to move_x/y.
-
-2003-10-03 Kenichi Handa <[email protected]>
-
- * macterm.c (x_load_font): Clear all members of FONTP before start
- filling them.
-
-2003-10-02 Kenichi Handa <[email protected]>
-
- * fontset.c (fs_load_font): Don't set fontp->font_encoder to NULL
- before calling find_ccl_program_func. Call find_ccl_program_func
- only when fontp->font_encoder is not NULL.
-
- * xterm.c (x_load_font): Clear all members of FONTP before start
- filling them.
-
-2003-10-03 John Paul Wallington <[email protected]>
-
- * keymap.c (map_keymap): Don't abort when binding is a vector.
-
-2003-10-02 Jason Rumney <[email protected]>
-
- * makefile.w32-in (emacs.o, coding.o, bytecode.o):
- Sync dependencies with Makefile.in.
- (alloca.o): Remove.
-
- * w32fns.c (w32_load_system_font): Clear all members of FONTP before
- filling them.
-
- * w32bdf.c (w32_load_bdf_font): Likewise.
-
-2003-09-30 Richard M. Stallman <[email protected]>
-
- * term.c (set_tty_color_mode): Calculate current_mode_spec
- regardless of value of VAL.
-
- * intervals.c (graft_intervals_into_buffer):
- Set BUF_INTERVALS (buffer)->up_obj when appropriate.
- Handle over_used when splitting UNDER.
-
-2003-09-30 YAMAMOTO Mitsuharu <[email protected]>
-
- * regex.c (regex_compile): Free the stack when returning from function.
-
-2003-09-28 Kenichi Handa <[email protected]>
-
- * fontset.c (Finternal_char_font): Change return value to
- cons (FONT-NAME . GLYPH-CODE).
-
-2003-09-28 Eli Zaretskii <[email protected]>
-
- * term.c (tty_setup_colors): Treat any negative argument as -1.
-
-2003-09-27 Gaute B Strokkenes <[email protected]> (tiny change)
-
- * process.c (send_process): Delete unused temp_buf.
-
-2003-09-26 Dave Love <[email protected]>
-
- * xterm.c (x_bitmap_mask): Declare.
-
-2003-09-25 Dave Love <[email protected]>
-
- * Makefile.in (fns.o): Depend on md5.h.
-
-2003-09-25 Kim F. Storm <[email protected]>
-
- * window.c (set_window_buffer): Fix redisplay problems when
- switching between buffers with different display margin widths.
-
-2003-09-23 Kim F. Storm <[email protected]>
-
- * process.c (set_socket_option): Fix :bindtodevice option.
- (Fset_network_process_option): Update process contact list when
- setting option succeeds.
- (Fmake_network_process): Doc fix.
-
-2003-09-23 Dave Love <[email protected]>
-
- * process.c (Fnetwork_interface_info): Use HAVE_STRUCT_IFREQ... macros.
-
-2003-09-22 Eli Zaretskii <[email protected]>
-
- * term.c (set_tty_color_mode): Use INTEGERP to test whether a
- color mode is an integer number (it could be -1).
-
-2003-09-22 Richard M. Stallman <[email protected]>
-
- * intervals.c (graft_intervals_into_buffer): Correct the main loop
- in the case where OVER is longer than UNDER.
-
-2003-09-22 Masatake YAMATO <[email protected]>
-
- * window.c (Fset_window_scroll_bars): Validate the value of
- `vertical_type'.
-
-2003-09-21 Kim F. Storm <[email protected]>
-
- * frame.c (Vdefault_frame_scroll_bars): New variable.
- (x_set_vertical_scroll_bars): Use it instead of hardcoded values.
- (syms_of_frame): DEFVAR_LISP it, and initialize according to
- window-system default scroll bar position.
-
- * window.c (Fwindow_scroll_bars): Doc fix.
-
-2003-09-19 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_set_offset): Take window manager decorations into account.
-
-2003-09-19 Richard M. Stallman <[email protected]>
-
- * atimer.h: Don't include lisp.h.
- (P_): Define it here (as well as elsewhere).
-
- * print.c (Fprin1_to_string): Move the PRINTPREPARE
- later, so that PRINTFINISH won't unbind Qinhibit_modification_hooks.
-
- * data.c (Fvariable_binding_locus): New function.
- (syms_of_data): defsubr it.
- (Flocal_variable_p): Delete duplicate call to indirect_variable.
-
-2003-09-18 Dave Love <[email protected]>
-
- * alloc.c (GC_MALLOC_CHECK): Move conditional undef after lisp.h.
-
- * process.c (Fnetwork_interface_info): Fix type error.
- (Fnetwork_interface_list): Doc fix.
- (read_process_output, read_process_output): Delete unused var.
-
-2003-09-17 Kim F. Storm <[email protected]>
-
- * process.c (Fnetwork_interface_list, Fnetwork_interface_info):
- Require HAVE_NET_IF_H and HAVE_SYS_IOCTL_H to include these fns.
- (Fnetwork_interface_info): Check that ifreq struct has required
- fields before accessing them; this requires that those fields are
- defined as macros, which may be too restrictive on some platforms,
- but it is better than failing on other platforms.
- (syms_of_process): Only defsubr above fns when included.
-
-2003-09-17 Dave Love <[email protected]>
-
- * unexalpha.c: Don't include varargs.h.
-
-2003-09-17 Kim F. Storm <[email protected]>
-
- * process.c (Fset_process_sentinel): Add sentinel to childp plist
- for network process.
- (socket_options): Add `:' prefix to option names. Add optbit field.
- (set_socket_option): Remove no_error arg and special handling of s < 0.
- Return 1<<optbit for known option, 0 for unknown.
- Do not interpret 0 as false for boolean option (only nil).
- Pass failed option and value to report_file_error.
- (Fset_network_process_options): Replace by Fset_network_process_option.
- (Fset_network_process_option): New function to set just one option.
- (Fmake_network_process): Allow :coding arg to be a cons.
- Allow :server arg to be an integer specifying backlog size.
- Remove :options arg, and allow options to be specified directly
- as :KEY, VALUE pairs. Parse these options before binding socket.
- As before, :reuseaddr t is default for a server process, but this
- can now be disabled by specifying :reuseaddr nil.
- (Fnetwork_interface_info): Rename from Fget_network_interface_info.
- (init_process): Availability of network options is now checked with
- simpler syntax (featurep 'make-network-process :OPTION); use loop to
- setup features.
- (syms_of_process): Fix defsubr's for the replaced functions.
-
-2003-09-16 Dave Love <[email protected]>
-
- * Makefile.in: Depend on coding.h.
-
-2003-09-14 Kim F. Storm <[email protected]>
-
- * process.c [HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
- (Fnetwork_interface_list, Fget_network_interface_info): New defuns.
- (syms_of_process): Defsubr them.
-
- * config.in: Regenerate.
-
-2003-09-12 Stefan Monnier <[email protected]>
-
- * m/sr2k.h (XMARKBIT, XUNMARK): Remove.
- * m/news-r6.h (XUNMARK): Remove.
- * m/mips.h (XUNMARK): Remove.
- * m/mips-siemens.h (XUNMARK): Remove.
- * m/iris4d.h (XUNMARK): Remove.
- * m/hp800.h (XMARKBIT, XUNMARK): Remove.
-
-2003-09-11 Stefan Monnier <[email protected]>
-
- * lisp.h (VALBITS): Don't remove 1 for the markbit.
- (union Lisp_Object): Use unsigned int for types. Remove markbit.
- (MARKBIT): Remove 1 from VALBITS so we still use same old val.
- (XTYPE): Use unsigned right-shift.
- (XMARKBIT, XMARK, XUNMARK): Remove.
-
- * alloc.c (init_intervals, init_symbol, init_marker):
- Don't preallocate anything.
- (Fgarbage_collect, mark_object): Ignore the markbit.
-
- * bytecode.c (mark_byte_stack, unmark_byte_stack): Ignore the markbit.
-
-2003-09-08 Lute Kamstra <[email protected]>
-
- * xdisp.c (pint2hrstr): New function.
- (decode_mode_spec): Add `%i' and `%I' specs.
- * buffer.c (syms_of_buffer): Document `%i' and `%I' constructs
- for `mode-line-format'.
-
-2003-09-07 Andreas Schwab <[email protected]>
-
- * alloc.c: Use long instead of int when casting ABLOCKS_BUSY to
- avoid warning.
-
-2003-09-07 Eli Zaretskii <[email protected]>
-
- * editfns.c (region_limit): Support any non-zero value of BEGINNINGP.
-
-2003-09-03 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_window_cursor_type): Partially undo 2002-03-01
- change (superseded by 2002-08-30 change); the default blink-off
- cursor is now again "no cursor".
-
-2003-09-01 Jason Rumney <[email protected]>
-
- * makefile.w32-in (alloca.o): Remove.
- (coding.o): Depend on intervals.h
- (emacs.o, bytecode.o): Depend on window.h.
-
-2003-09-01 Dave Love <[email protected]>
-
- * Makefile.in (alloca.o): Remove commands.
- (coding.o): Depend on intervals.h composite.h window.h.
- (emacs.o): Depend on window.h keyboard.h keymap.h.
- (gtkutil.o): Depend on keyboard.h charset.h coding.h.
- (bytecode.o): Depend on window.h.
-
-2003-08-31 Jason Rumney <[email protected]>
-
- * w32term.c (w32_per_char_metric): Allow cached metrics to be
- returned even when font_type is unknown.
-
- * xdisp.c (init_iterator): Remove old WINDOWSNT conditional.
-
-2003-08-30 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_term_init): Initialize new fields in x_display_info.
-
- * xterm.h (struct x_display_info): Add red/green/blue_bits and
- *_offset.
-
- * xfns.c (lookup_rgb_color): Use new fields in x_display_info to
- calculate pixel value.
-
-2003-08-29 Gerd Moellmann <[email protected]>
-
- * xdisp.c (redisplay_internal): Fix change of 2003-04-30.
- Don't tell redisplay display is accurate when it's actually been
- paused for pending input.
-
-2003-08-29 Richard M. Stallman <[email protected]>
-
- * dispnew.c (adjust_glyph_matrix): Call window_box
- whenever W is nonzero.
-
- * data.c (Fmake_variable_buffer_local, Fmake_local_variable)
- (Fkill_local_variable, Fmake_variable_frame_local)
- (Flocal_variable_p, Flocal_variable_if_set_p):
- Use indirect_variable to trace thru variable aliases.
-
- * config.in: Updated.
-
- * callint.c (Fcall_interactively): Save and restore
- Vthis_command, Vthis_original_command, real_this_command,
- and current_kboard->Vlast_command.
-
- * abbrev.c (Fexpand_abbrev): Insert before deleting.
-
-2003-08-29 Gerd Moellmann <[email protected]>
-
- * xfns.c (lookup_rgb_color): Handle TrueColor visuals specially.
-
-2003-08-28 David Abrahams <[email protected]> (tiny change)
-
- * coding.c (decode_coding_iso2022): Initialize local variable c2.
- (decode_coding_sjis_big5): Likewise.
-
-2003-08-27 Jason Rumney <[email protected]>
-
- * w32.c (sys_pipe): Protect against file descriptor overflow.
-
- * w32fns.c (syms_of_w32fns): Remove non-existent functions.
-
- * w32term.c (w32_read_socket): Fix WM_MOUSEWHEEL assignment.
-
-2003-08-26 Terje Rosten <[email protected]>
-
- * xfns.c (Vgtk_version_string): New variable.
- (syms_of_xfns): DEFVAR_LISP it. Provide gtk.
-
-2003-08-24 Eli Zaretskii <[email protected]>
-
- * term.c (term_init): Remove `const' from buffer_size's declaration.
-
- * Makefile.in (msdos.o): Depend on intervals.h.
-
- * msdos.c: Include intervals.h, since STRING_INTERVALS requires that.
-
-2003-08-21 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h (struct x_display_info): New fields: client_leader_window
- and Xatom_wm_client_leader.
-
- * xterm.c (x_initialize): Move call to x_session_initialize to ...
- (x_term_init): ... here. Initialize client_leader fields in dpyinfo.
-
- * xsmfns.c (create_client_leader_window): New function.
- (x_session_initialize): Call create_client_leader_window, take
- dpyinfo as argument.
-
- * xfns.c (Fx_create_frame): Set property WM_CLIENT_LEADER.
-
- * Makefile.in (xsmfns.o): Add more depenedencies.
-
-2003-08-21 Dave Love <[email protected]>
-
- * m/iris4d.h: Use _MIPS_SZLONG, not _LP64.
-
-2003-08-21 Kenichi Handa <[email protected]>
-
- * term.c (term_init): Fix previous change; don't rely on the
- length of `buffer' if TERMINFO is defined.
-
-2003-08-20 Dave Love <[email protected]>
-
- * atimer.h: Include lisp.h.
-
- * lisp.h (EMACS_LISP_H): New.
- (popup_activated_flag): Don't declare.
-
- * alloca.c: Some merging with gnulib. Change logic and doc
- concerning (x)malloc/(x)free -- no longer Emacs-specific.
- [DO_BLOCK_INPUT]: Don't include lisp.h.
- (xmalloc, xfree): Declare.
- (malloc): Don't declare.
-
- * Makefile.in (LWLIB_OPTIONS): Remove (unused).
- (alloca.o): Remove obsolete stuff concerning alloca.s. Depend on
- atimer.h, blockinput.h.
-
- * alloc.c (lisp_align_malloc): Change type of `aligned'.
-
- * alloca.s: Remove.
-
-2003-08-19 Gerd Moellmann <[email protected]>
-
- * s/freebsd.h [__FreeBSD_version >= 400000]: Define TERMINFO,
- use -lncurses.
-
- * term.c (term_init): Use a buffer of size 4096 for tgetent since
- FreeBSD returns something longer than 2044. Abort if the end of
- the buffer is overwritten.
-
-2003-08-19 Miles Bader <[email protected]>
-
- * xterm.c (x_term_init): Correctly use result of Ffile_readable_p.
-
-2003-08-19 Gerd Moellmann <[email protected]>
-
- * alloc.c (lisp_align_malloc): Check for memory full when
- allocating ablocks, which also avoids freeing a pointer into an
- ablocks structure.
-
- * puresize.h (BASE_PURESIZE): Increase to 1100000.
-
- * buffer.c (Fmove_overlay): Set overlay's next pointer unconditionally.
-
-2003-08-16 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fencode_time): Doc fix.
-
-2003-08-16 David Ponce <[email protected]>
-
- * fileio.c (Fwrite_region): Fix conditional expression to issue
- the right message.
-
-2003-08-16 Juri Linkov <[email protected]>
-
- * syntax.c (Fforward_word): Argument changed to optional.
- Set default value to 1.
-
-2003-08-15 Kenichi Handa <[email protected]>
-
- * xfaces.c (better_font_p): Prefer a real scalable font; i.e. not
- what autoscaled.
- (best_matching_font): Once we find a better scalable font, set
- non_scalable_has_exact_height_p to 1.
- (try_font_list): Call try_alternative_families to try any family
- with the given registry.
-
-2003-08-09 Andreas Schwab <[email protected]>
-
- * alloc.c (mark_object): Handle Lisp_Misc_Save_Value.
-
- * print.c (print_string): Fix printing of multibyte string with
- nontrivial printcharfun.
-
-2003-07-31 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (xg_set_icon): Rewrite to compile with GTK 2.0 and 2.2.
-
- * xterm.c (x_bitmap_icon): Return if xg_set_icon succeeds.
-
-2003-07-31 Kenichi Handa <[email protected]>
-
- * process.c (read_process_output): Return the actually read bytes
- instead of the result of decoding.
-
-2003-07-31 Kenichi Handa <[email protected]>
-
- * xterm.h (struct x_bitmap_record): New member have_mask.
-
- * xfns.c (x_create_bitmap_from_data): Initialize have_mask member
- to 0.
- (x_create_bitmap_from_file): Likewise.
- (x_destroy_bitmap): Check have_mask member before freeing a mask.
- (x_destroy_all_bitmaps): Likewise.
- (x_create_bitmap_mask): Set have_mask member to 1.
-
-2003-07-30 Richard M. Stallman <[email protected]>
-
- * Makefile.in (CFLAGS) [!OPTIMIZE]: Undo previous change.
-
-2003-07-29 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_mark_data): Update calls to mark_object.
-
-2003-07-29 Richard M. Stallman <[email protected]>
-
- * xterm.c (xim_open_dpy, xim_initialize, xim_close_dpy):
- Conditionalize XIM code on HAVE_XIM.
-
- * fns.c (Fclear_string): New function.
- (syms_of_fns): defsubr it.
-
-2003-07-28 KOBAYASHI Yasuhiro <[email protected]>
-
- * xfns.c (xic_set_preeditarea): Add the left fringe width to spot.x.
-
-2003-07-22 Stefan Monnier <[email protected]>
-
- * xfns.c: Don't check HAVE_PNG_H: autoconf doesn't seem to find it.
-
- * buffer.c (delete_all_overlays): New function.
- * buffer.h (delete_all_overlays): Declare.
- * coding.c (run_pre_post_conversion_on_str):
- * print.c (temp_output_buffer_setup):
- * fileio.c (Finsert_file_contents):
- * minibuf.c (get_minibuffer): Use it.
-
-2003-07-22 Andrew Choi <[email protected]>
-
- * unexmacosx.c (unexec_regions_sort_compare):
- (unexec_regions_merge): New functions. Sort and merge unexec
- regions before dumping them.
-
-2003-07-22 Dave Love <[email protected]>
-
- * xfns.c [HAVE_PNG]: Consider both png.h and libpng/png.h.
-
-2003-07-21 Stefan Monnier <[email protected]>
-
- * alloc.c (MARK_STRING, UNMARK_STRING, STRING_MARKED_P)
- (GC_STRING_CHARS, string_bytes): Use ARRAY_MARK_FLAG rather than
- MARKBIT as the gcmarkbit for strings.
-
-2003-07-21 Richard M. Stallman <[email protected]>
-
- * s/openbsd.h (LD_SWITCH_SYSTEM_TEMACS): Add undef.
-
- * fns.c (Flocale_info): Rename from Flanginfo. Doc fixes.
- (syms_of_fns): Corresponding change.
-
- * alloc.c (syms_of_alloc): Doc fixes.
-
-2003-07-20 Han Boetes <[email protected]> (tiny change)
-
- * s/netbsd.h: Use -Wl syntax.
-
-2003-07-17 Richard M. Stallman <[email protected]>
-
- * xterm.c (xim_initialize): Redo 6/24 change.
-
-2003-07-15 Stefan Monnier <[email protected]>
-
- * buffer.c (copy_overlays): Use EMACS_INT for positions.
- (Fswitch_to_buffer): Don't signal an error when switching to the same
- buffer in a dedicated window.
-
- * alloc.c: Use bitmaps for cons, as was done for floats.
- (init_float, init_cons): Let the normal code allocate the first block.
- (CONS_BLOCK_SIZE): Redefine based on BLOCK_BYTES and bitmap size.
- (CONS_BLOCK, CONS_INDEX, CONS_MARKED_P, CONS_MARK, CONS_UNMARK):
- New macros.
- (struct cons_block): Move conses to the beginning. Add gcmarkbits.
- (Fcons): Use lisp_align_malloc and CONS_UNMARK.
- (live_cons_p): Check the pointer is not past the `conses' array.
- (mark_maybe_object, mark_maybe_pointer): Use CONS_MARKED_P.
- (mark_object, mark_buffer): Use CONS_MARKED_P and CONS_MARK.
- (survives_gc_p): Use CONS_MARKED_P and simplify.
- (gc_sweep): Use CONS_MARKED_P, CONS_UNMARK, and lisp_align_free.
-
-2003-07-13 Paul Eggert <[email protected]>
-
- GCC 3.3 (sparc) no longer puts "int foo = 0;" into data; it
- puts it into BSS instead, at least on Solaris 8 and 9.
- This is a valid optimization, and it may occur on other platforms,
- so Emacs should not assume that initializing a static variable to
- zero puts it into data.
- * alloc.c (pure, staticvec):
- Initialize these arrays to nonzero, so that they're not
- put into BSS by that optimization.
-
-2003-07-13 Stefan Monnier <[email protected]>
-
- * alloc.c (BLOCK_PADDING): Rename from ABLOCKS_PADDING. Update users.
- (lisp_align_malloc): Use posix_memalign is available.
- (ABLOCKS_BASE): Use HAVE_POSIX_MEMALIGN as an optimization.
- (STRING_BLOCK_SIZE): Rename from STRINGS_IN_STRING_BLOCK
- for consistency. Update users.
-
-2003-07-13 Richard M. Stallman <[email protected]>
-
- * s/netbsd.h (START_FILES_1, END_FILES_1): Always define them.
-
-2003-07-13 Terje Rosten <[email protected]>
-
- * xterm.c (x_bitmap_icon, x_wm_set_icon_pixmap): Modify to add mask,
- and use the Gtk+ function gtk_window_icon_from_file if available.
-
- * xfns.c (x_bitmap_mask, x_create_bitmap_mask): New functions to
- handle mask of bitmaps.
- (x_allocate_bitmap_record, x_destroy_bitmap): Modify to handle the
- mask property.
- (xg_set_icon): New function, wrapper for gtk_window_icon_from_file.
-
- * xterm.h (xg_set_icon): New function.
-
-2003-07-12 Paul Eggert <[email protected]>
-
- * unexelf.c (unexec): Consider a section to precede the .bss
- section if its addresses overlap that of .bss.
-
-2003-07-12 Richard M. Stallman <[email protected]>
-
- * Makefile.in (CFLAGS) [!OPTIMIZE]: Set CFLAGS to -g.
-
- * config.in (HAVE_CRTIN): Add #undef.
- (INLINE): Really inline only if OPTIMIZE is defined.
-
- * s/netbsd.h (START_FILES, LIB_STANDARD): Use START_FILES_1,
- END_FILES_1.
- (START_FILES_1, END_FILES_1): New macros (conditional).
- (LD_SWITCH_SYSTEM_TEMACS): Define.
-
- * s/openbsd.h: Don't include bsd4-3.h.
- (TERMINFO): Define.
- (LIBS_TERMCAP): Define.
- (LD_SWITCH_SYSTEM): Define (two definitions).
-
- * xfns.c: Include libpng/png.h instead of png.h.
-
-2003-07-11 Andreas Schwab <[email protected]>
-
- * buffer.c (modify_overlay): Update prototype.
- * lisp.h (adjust_overlays_for_insert, adjust_overlays_for_delete):
- Likewise.
-
-2003-07-09 Stefan Monnier <[email protected]>
-
- * lisp.h (VALBITS): Define in terms of GCTYPEBITS.
- (struct interval): Move to intervals.h.
- (struct Lisp_Marker): Use EMACS_INT for position info.
- (forward_point): Remove prototype of defunct function.
- (Qmodification_hooks, Qrear_nonsticky, Fnext_property_change)
- (Fget_text_property, Fset_text_properties, Ftext_propertes_not_all)
- (syms_of_textprop, set_text_properties): Remove prototypes that are
- already in intervals.h.
-
- * intervals.h (struct interval): Move from lisp.h.
- Use EMACS_INT for position and size info.
-
- * coding.c: Include intervals.h for Fset_text_properties.
-
- * buffer.h (struct buffer_text, struct buffer): Use EMACS_INT for
- position and length information.
-
-2003-07-09 Stefan Monnier <[email protected]>
-
- * buffer.h (struct buffer_text, struct buffer): Use EMACS_INT for
- position and length information.
-
-2003-07-09 Stefan Monnier <[email protected]>
-
- Change overlays_after and overlays_before so the overlays themselves
- are linked into lists, rather than using cons cells. After all each
- Lisp_Misc already occupies 5 words, so we can add a `next' field to
- Lisp_Overlay for free and save up one cons cell per overlay (not
- to mention one indirection when traversing the list of overlay).
-
- * lisp.h (struct Lisp_Overlay): New field `next'.
-
- * buffer.h (struct buffer): Change overlays_before and overlays_after
- from Lisp lists of overlays to pointers to overlays.
-
- * buffer.c (overlay_strings, recenter_overlay_lists):
- Fix typo in eassert in last commit.
- (unchain_overlay): New function.
- (add_overlay_mod_hooklist): Use AREF.
- (copy_overlays, reset_buffer, overlays_at, overlays_in)
- (overlay_touches_p, overlay_strings, recenter_overlay_lists)
- (fix_overlays_in_range, fix_overlays_before, Fmake_overlay)
- (Fmove_overlay, Fdelete_overlay, Foverlay_lists)
- (report_overlay_modification, evaporate_overlays, init_buffer_once):
- Adjust to new type of overlays_(before|after).
-
- * alloc.c (mark_object): Mark the new `next' field of overlays.
- (mark_buffer): Manually mark the overlays_(after|before) fields.
-
- * coding.c (run_pre_post_conversion_on_str):
- * editfns.c (overlays_around):
- * xdisp.c (load_overlay_strings):
- * fileio.c (Finsert_file_contents):
- * indent.c (current_column):
- * insdel.c (signal_before_change, signal_after_change):
- * intervals.c (set_point_both):
- * print.c (temp_output_buffer_setup): Use new type for
- overlays_(before|after).
-
-2003-07-08 Stefan Monnier <[email protected]>
-
- * buffer.c (report_overlay_modification): Don't run hooks while
- traversing the list of overlays.
-
- * buffer.h (struct buffer): Use an int for overlay_center.
- (overlays_at, evaporate_overlays, recenter_overlay_lists)
- (overlay_strings, fix_overlays_before): Use EMACS_INT for positions.
-
- * buffer.c (reset_buffer, recenter_overlay_lists)
- (adjust_overlays_for_insert, adjust_overlays_for_delete)
- (fix_overlays_in_range, Fmake_overlay, Fmove_overlay)
- (evaporate_overlays, init_buffer_once): Update use of overlay_center.
- (overlays_at, evaporate_overlays, recenter_overlay_lists)
- (overlay_strings, fix_overlays_before): Use EMACS_INT for positions.
-
- * xdisp.c (fast_find_position): Remove unused var.
-
- * cmds.c (Qexpand_abbrev): New sym.
- (syms_of_cmds): Initialize it.
- (internal_self_insert): Use it to call expand-abbrev.
-
-2003-07-09 Kim F. Storm <[email protected]>
-
- * xterm.c (use_xim) [!USE_XIM]: Default to disable XIM if Emacs
- was configured with --without-xim.
- (x_term_init) [!USE_XIM]: Use `useXIM' resource to turn on XIM.
-
-2003-07-07 Richard M. Stallman <[email protected]>
-
- * xdisp.c (reseat_1): Set it->area to TEXT_AREA.
-
- * alloc.c (Fgarbage_collect): Doc fix.
-
-2003-07-07 Nozomu Ando <[email protected]>
-
- * buffer.c (Fkill_buffer): Clear charpos cache if necessary.
-
-2003-07-06 Stefan Monnier <[email protected]>
-
- * minibuf.c (read_minibuf): UNGCPRO before returning.
- (Ftry_completion, Fall_completions): Doc fix.
-
- * alloc.c (live_float_p): Check that p is not past the `floats' array,
- now that `floats' is not the last element of the struct any more.
-
-2003-07-06 Jason Rumney <[email protected]>
-
- * w32term.h (ClipboardSequence_Proc): New type.
-
- * w32fns.c (clipboard_sequence_fn): New variable.
- (globals_of_w32fns): Initialize it.
-
- * w32select.c (last_clipboard_sequence_number): New variable.
- (Fw32_set_clipboard_data, Fw32_get_clipboard_data): Use sequence
- number if possible.
-
-2003-07-06 Stefan Monnier <[email protected]>
-
- * m/amdx86-64.h (MARKBIT):
- * m/ia64.h (MARKBIT): Remove definition since lisp.h does not compare
- MARKBIT and ARRAY_MARK_FLAG any more.
-
- * m/hp800.h (XSETMARKBIT):
- * m/sr2k.h (XSETMARKBIT):
- * lisp.h (XSETMARKBIT): Remove unused macro.
-
- * lisp.h (mark_object): Change prototype.
-
- * alloc.c (mark_object): Change arg *Lisp_Object -> Lisp_Object.
- (last_marked): Change accordingly.
- (mark_interval, mark_maybe_object, mark_maybe_pointer)
- (Fgarbage_collect, mark_glyph_matrix, mark_face_cache, mark_image)
- (mark_buffer): Update calls to mark_object.
-
- * bytecode.c (mark_byte_stack):
- * fns.c (sweep_weak_table):
- * keyboard.c (mark_kboards): Update calls to mark_object.
-
-2003-07-06 Jason Rumney <[email protected]>
-
- * alloc.c (struct ablock): Only include padding when there is some.
-
-2003-07-04 Stefan Monnier <[email protected]>
-
- * alloc.c (ALIGN): Add casts to simplify usage.
- (BLOCK_ALIGN, BLOCK_BYTES, ABLOCKS_PADDING, ABLOCKS_SIZE)
- (ABLOCKS_BYTES, ABLOCK_ABASE, ABLOCKS_BUSY, ABLOCKS_BASE): New macros.
- (struct ablock, struct ablocks): New types.
- (free_ablock): New global var.
- (lisp_align_malloc, lisp_align_free): New functions.
- (FLOAT_BLOCK_SIZE): Redefine in terms of BLOCK_BYTES.
- (struct float_block): Reorder and add gcmarkbits.
- (GETMARKBIT, SETMARKBIT, UNSETMARKBIT, FLOAT_BLOCK, FLOAT_INDEX)
- (FLOAT_MARKED_P, FLOAT_MARK, FLOAT_UNMARK): New macros.
- (init_float, make_float): Use lisp_align_malloc.
- (free_float, live_float_p): Don't use `type' any more.
- (make_float): Use FLOAT_UNMARK to access to mark bit.
- (mark_maybe_object, mark_maybe_pointer, survives_gc_p):
- Use FLOAT_MARKED_P to access the mark bit.
- (pure_alloc): Simplify use of ALIGN.
- (mark_object): Use FLOAT_MARK to access the mark bit.
- (gc_sweep): Use new macros to access the float's mark bit.
- (init_alloc_once): Init free_ablock.
-
- * lisp.h (struct Lisp_Float): Remove unused field `type'.
-
-2003-06-27 Stefan Monnier <[email protected]>
-
- * alloc.c (VECTOR_MARK, VECTOR_UNMARK, VECTOR_MARKED_P): New macros.
- (GC_STRING_BYTES): Don't mask markbit (it's only used on `size').
- (allocate_buffer): Move.
- (string_bytes): Don't mask markbit of `size_byte'.
- (mark_maybe_object, mark_maybe_pointer, Fgarbage_collect)
- (mark_object, mark_buffer, survives_gc_p, gc_sweep):
- Use the `size' field of buffers (rather than the `name' field) for
- the mark bit, as is done for all other vectorlike objects.
- Use the new macros to access the mark bit of vectorlike objects.
-
-2003-06-26 Richard M. Stallman <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increment base size.
-
- * xdisp.c (fast_find_position): Enable Gerd's new definition.
-
- * xterm.c (xim_initialize): Undo previous change.
-
-2003-06-26 Stefan Monnier <[email protected]>
-
- * alloc.c (survives_gc_p): Simplify.
-
- * buffer.c (set_buffer_internal_1): Test CONSP for lists.
-
- * window.c (Fset_window_dedicated_p): Simplify.
- (display_buffer_1): Don't raise the win from which minibuf was entered.
- (temp_output_buffer_show): Don't assume BEG == 1. Simplify.
- (Fminibuffer_selected_window): Simplify.
-
- * buffer.h (struct buffer_text): Lisp_Object `markers' => Lisp_Marker.
-
- * lisp.h (unchain_marker): Lisp_Object arg => Lisp_Marker.
- (struct Lisp_Marker): Lisp_Object `chain' => Lisp_Marker `next'.
-
- * insdel.c (check_markers, adjust_markers_for_delete)
- (adjust_markers_for_insert, adjust_markers_for_replace)
- (prepare_to_modify_buffer, RESTORE_VALUE):
- * marker.c (buf_charpos_to_bytepos, buf_bytepos_to_charpos)
- (Fset_marker, set_marker_restricted, set_marker_both, unchain_marker)
- (set_marker_restricted_both, Fbuffer_has_markers_at, count_markers):
- * alloc.c (Fmake_marker, free_marker, gc_sweep):
- * buffer.c (Fget_buffer_create, Fkill_buffer, Fset_buffer_multibyte):
- * editfns.c (save_excursion_restore, transpose_markers):
- * window.c (delete_window):
- * xdisp.c (message_dolog): Update for new types.
-
-2003-06-26 Jan Dj,Ad(Brv <[email protected]>
-
- * xfaces.c (set_font_frame_param): Set default_face_done_p to zero.
- (realize_default_face): Use default_face_done_p for the force_p
- argument to set_lface_from_font_name. Set default_face_done_p to one.
-
- * frame.c (make_frame): Initialize default_face_done_p.
-
- * frame.h (struct frame): Add default_face_done_p.
-
- * config.in: Add XRegisterIMInstantiateCallback_arg6 so it
- will be defined.
-
-2003-06-25 Stefan Monnier <[email protected]>
-
- * alloc.c (make_interval, Fmake_symbol, allocate_misc):
- Initialize the new field `gcmarkbit'.
- (mark_interval, MARK_INTERVAL_TREE): Use the new `gcmarkbit' field.
- (mark_interval_tree): Don't mark the tree separately from the nodes.
- (UNMARK_BALANCE_INTERVALS): Don't unmark the tree.
- (mark_maybe_object, mark_maybe_pointer, Fgarbage_collect)
- (mark_object, survives_gc_p, gc_sweep): Use new `gcmarkbit' fields.
-
- * lisp.h (struct interval, struct Lisp_Symbol, struct Lisp_Free)
- (struct Lisp_Marker, struct Lisp_Intfwd, struct Lisp_Boolfwd)
- (struct Lisp_Kboard_Objfwd, struct Lisp_Save_Value)
- (struct Lisp_Buffer_Local_Value, struct Lisp_Overlay)
- (struct Lisp_Objfwd, struct Lisp_Buffer_Objfwd): Add `gcmarkbit' field.
-
-2003-06-24 Dave Love <[email protected]>
-
- * xterm.c (xim_initialize): Use XRegisterIMInstantiateCallback_arg6.
-
- * strftime.c: Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
- from gnulib.
-
-2003-06-21 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fwrite_region): Alternate messages
- for append and partial write.
-
- * keyboard.c (read_key_sequence): When converting upcase fn key to
- downcase, update fkey and keytran so `backspace' gets translated.
-
- * keyboard.c (read_avail_input): Don't signal SIGHUP in batch mode.
-
- * process.c (wait_reading_process_input): Don't signal SIGIO
- in batch mode.
-
-2003-06-17 Kenichi Handa <[email protected]>
-
- * Makefile.in (xselect.o): Don't depend on charset.h, coding.h,
- composite.h.
-
- * xselect.c: Don't include charset.h, coding.h, composite.h.
- (Qforeign_selection): New variable.
- (syms_of_xselect): Intern and static it.
- (selection_data_to_lisp_data): Return a unibyte string made from
- data with `foreign-selection' text property.
-
-2003-06-15 Stefan Monnier <[email protected]>
-
- * termhooks.h (EVENT_INIT): New macro.
-
- * keyboard.c (mark_kboards): Move from alloc.c. Mark kbd_buffer.
-
- * alloc.c (mark_kboards): Move to keyboard.c.
-
- * keyboard.c (record_asynch_buffer_change, read_avail_input):
- * xterm.c (x_dispatch_event):
- * xmenu.c (find_and_call_menu_selection):
- * xdisp.c (handle_tool_bar_click):
- * w32menu.c (menubar_selection_callback):
- * sysdep.c (kbd_input_ast, read_input_waiting):
- * msdos.c (dos_rawgetc):
- * macterm.c (mac_check_for_quit_char):
- * macmenu.c (menubar_selection_callback):
- * gtkutil.c (xg_tool_bar_callback): Don't pass uninitialized
- data to kbd_buffer_store_event.
-
-2003-06-15 Kim F. Storm <[email protected]>
-
- * xdisp.c (x_fix_overlapping_area): Always use area relative X
- to fix redisplay problem with tall characters (such as ,AC(B).
-
-2003-06-13 Kai Gro,A_(Bjohann <[email protected]>
-
- * fileio.c (Fcopy_file): Doc fix: copies file modes, too.
-
-2003-06-12 Kenichi Handa <[email protected]>
-
- * fileio.c (Fwrite_region): Save and restore restriction.
-
-2003-06-12 Dave Love <[email protected]>
-
- * alloca.c (alloca): Declare arg as size_t.
-
- * sysdep.c: Remove redundant include of unistd.h, stdlib.h.
- Use HAVE_DECL_SYS_SIGLIST, not SYS_SIGLIST_DECLARED.
-
-2003-06-11 Dave Love <[email protected]>
-
- * search.c (shrink_regexp_cache): Use xrealloc.
- (syms_of_search): Use xmalloc.
-
-2003-06-10 Kim F. Storm <[email protected]>
-
- * xdisp.c (phys_cursor_in_rect_p): Fix 2003-05-24 change.
- Adjust phys_cursor.x to be relative to window box, rather than
- text area before checking -- to ensure cursor is redrawn when
- exposing window.
- Note: This also fixes a similar (older) bug if display margins
- are present.
-
-2003-06-06 Kenichi Handa <[email protected]>
-
- * coding.c (encoding_buffer_size): If coding->type is
- coding_type_ccl, double magnification on CRLF encoding.
-
-2003-06-06 Jason Rumney <[email protected]>
-
- * w32reg.c (SYSTEM_DEFAULT_RESOURCES): New constant.
- (w32_get_string_resource): Try SYSTEM_DEFAULT_RESOURCES last.
-
- * xfaces.c (Finternal_face_x_get_resource): Do it on Windows and
- Mac too.
-
-2003-06-05 Dave Love <[email protected]>
-
- * strftime.c: Merge changes from gnulib.
-
- * mktime.c (__mktime_internal): Merge changes from gnulib
- involving year 69 and dst2.
-
- Changes to merge with gnulib version and be consistent with the
- autoconf test:
-
- * getloadavg.c: Set NLIST_STRUCT from HAVE_NLIST_H.
- Use HAVE_STRUCT_NLIST_N_UN_N_NAME, not NLIST_NAME_UNION.
- [HAVE_LOCALE_H]: Include locale.h.
- (getloadavg) [HAVE_SETLOCALE]: Run sscanf in C locale.
-
-2003-06-05 Kim F. Storm <[email protected]>
-
- * window.c (coordinates_in_window): Convert X and Y to window
- relative coordinates inside mode-line and header-line parts.
- Convert X and Y to margin area relative coordinates inside left
- and right display margin parts.
-
-2003-06-05 Jason Rumney <[email protected]>
-
- * w32fns.c (add_system_logical_colors_to_map): New function.
- (Fx_open_connection): Use it.
-
-2003-06-04 Stefan Monnier <[email protected]>
-
- * process.c (allocate_pty): Revert part of the previous patch.
- (Faccept_process_output): Simplify.
-
-2003-06-04 Jason Rumney <[email protected]>
-
- * termhooks.h (enum event_kind): Remove MOUSE_WHEEL_EVENT.
-
- * keyboard.c (Qmouse_wheel, mouse_wheel_syms)
- (lispy_mouse_wheel_names): Remove.
- (syms_of_keyboard): Remove Qmouse_wheel and mouse_wheel_syms.
- Always define drag_and_drop_syms.
-
- * macterm.c (XTread_socket): Map mouse wheel events to Emacs
- WHEEL_EVENT events.
-
-2003-06-03 Stefan Monnier <[email protected]>
-
- * xdisp.c (update_tool_bar): Add missing UNGCPRO.
-
- * buffer.c (init_buffer_once): Make kill-buffer-hook permanent-local.
-
-2003-06-03 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (make_menu_item): Make sure we don't crash on a NULL
- menu item label.
-
-2003-06-03 Richard M. Stallman <[email protected]>
-
- * window.c (Fwindow_edges): Doc fix.
- (Fwindow_pixel_edges, Fwindow_inside_edges)
- (Fwindow_inside_pixel_edges): New functions.
- (syms_of_window): defsubr them.
-
- * window.h (WINDOW_LEFT_FRINGE_COLS, WINDOW_RIGHT_FRINGE_COLS)
- (WINDOW_MODE_LINE_LINES, WINDOW_HEADER_LINE_LINES): New macros.
-
-2003-06-02 Stefan Monnier <[email protected]>
-
- * dispnew.c (Fsit_for): Don't lie about the number of args.
-
-2003-06-02 Dave Love <[email protected]>
-
- * callproc.c: Use HAVE_FCNTL_H, not USG5.
- (syms_of_callproc) <process-environment>: Doc fix.
-
- * doc.c: Use HAVE_FCNTL_H, not USG5.
-
- * xfaces.c (font_rescale_ratio): Fix for K&R.
-
- * termcap.c: Use HAVE_FCNTL_H, not _POSIX_VERSION.
-
- * mem-limits.h: Use HAVE_SYS_RESOURCE_H, HAVE_SYS_VLIMIT_H.
-
- * lread.c [HAVE_FCNTL_H]: Include fcntl.h.
-
- * gtkutil.c: Include keyboard.h, charset.h, coding.h.
- (xg_create_frame_widgets): Use ENCODE_UTF_8.
-
- * xterm.c (Qutf_8): Move to coding.c.
-
- * xmenu.c (ENCODE_MENU_STRING): New.
- (list_of_panes, list_of_items, digest_single_submenu, xmenu_show):
- Use it.
-
- * coding.h (ENCODE_UTF_8): New.
- (Qutf_8): Declare.
-
- * coding.c (Qutf_8): New.
- (syms_of_coding): Intern it.
-
- * fns.c: Doc fixes.
-
-2003-06-02 Kenichi Handa <[email protected]>
-
- * buffer.c (Fset_buffer_multibyte): Fix previous change.
-
-2003-06-01 Stefan Monnier <[email protected]>
-
- * lread.c (openp): Make sure STR is a string.
-
-2003-06-01 David Ponce <[email protected]>
-
- * termhooks.h (enum event_kind): Add new WHEEL_EVENT event.
- Declare MOUSE_WHEEL_EVENT only if MAC_OSX defined.
-
- * keyboard.c (Qmouse_wheel): Declare only if MAC_OSX defined.
- (mouse_wheel_syms, lispy_mouse_wheel_names): Likewise.
- (discard_mouse_events): Discard WHEEL_EVENT events too.
- (lispy_wheel_names, wheel_syms): New.
- (syms_of_keyboard): Init and staticpro `wheel_syms'. Init and
- staticpro `Qmouse_wheel' and `mouse_wheel_syms' only if MAC_OSX defined.
- (make_lispy_event): Add WHEEL_EVENT handler.
-
- * w32term.c (construct_mouse_wheel): Construct WHEEL_EVENT.
- (w32_read_socket): Map w32 WM_MOUSEWHEEL events to Emacs
- WHEEL_EVENT events.
-
-2003-05-31 John Paul Wallington <[email protected]>
-
- * Makefile.in (lisp, shortlisp): byte-run, float-sup, map-ynp, and
- timer are in lisp/emacs-lisp.
-
-2003-05-31 Kenichi Handa <[email protected]>
-
- * buffer.c (Fset_buffer_multibyte): Correctly recover a narrowed
- region when a buffer is changed to unibyte.
-
- * charset.h (VALID_LEADING_CODE_P): New macro.
- (UNIBYTE_STR_AS_MULTIBYTE_P): Check more rigidly.
-
- * coding.c (DECODE_EMACS_MULE_COMPOSITION_CHAR): If coding->flags
- is nonzero, accept multibyte form of eight-bit-control chars.
- (decode_composition_emacs_mule): Likewise.
- (decode_coding_emacs_mule): Likewise.
- (encode_coding_emacs_mule): If coding->flags is nonzero, produce
- multibyte form of eight-bit-control chars.
-
- * fileio.c (Qauto_save_coding, auto_save_coding): New variables.
- (Finsert_file_contents): If coding-system-for-read is bound to
- Qauto_save_coding, use the coding system emacs-mule with special
- setting for recovering a file.
- (choose_write_coding_system): On auto saving, use the coding
- system emacs-mule with special setting for auto saving.
- (syms_of_fileio) <Qauto_save_coding>: Intern and staticpro it.
-
-2003-05-30 Kenichi Handa <[email protected]>
-
- * coding.c (ccl_coding_driver): Set ccl->eight_bit_control
- properly before calling ccl_driver.
-
- * ccl.h (struct ccl_program) <eight_bit_control>: Comment fixed.
-
- * ccl.c (CCL_WRITE_CHAR): Increment extra_bytes only when it is nonzero.
- (ccl_driver): Initialize extra_bytes to ccl->eight_bit_control.
- (setup_ccl_program): Initialize ccl->eight_bit_control to zero.
-
-2003-05-29 Glenn Morris <[email protected]>
-
- * xfaces.c (realize_default_face): Do not abort if lface is
- non-existent - reverts change from 2003-05-19.
-
-2003-05-29 Kenichi Handa <[email protected]>
-
- * coding.c (decode_coding_iso2022): Pay attention to the byte
- sequence of CTEXT extended segment, and retain those bytes as is.
-
-2003-05-28 Kenichi Handa <[email protected]>
-
- * coding.c (ENCODE_UNSAFE_CHARACTER): Adjust for the name change
- of CODING_REPLACEMENT_CHARACTER.
- (decode_coding_iso2022): If CODING_FLAG_ISO_SAFE, set
- CODING_MODE_INHIBIT_UNENCODABLE_CHAR flag in coding->mode, and
- check this flag on encoding.
- (encode_coding_sjis_big5):
- Check CODING_MODE_INHIBIT_UNENCODABLE_CHAR flag of coding->mode.
- (Fset_terminal_coding_system_internal):
- Set CODING_MODE_INHIBIT_UNENCODABLE_CHAR flag in terminal_coding.mode
- instead of setting CODING_FLAG_ISO_SAFE flag in terminal_coding.flags.
-
- * coding.h (CODING_REPLACEMENT_CHARACTER): Rename from
- CODING_INHIBIT_CHARACTER_SUBSTITUTION.
- (CODING_MODE_INHIBIT_UNENCODABLE_CHAR): New macro.
-
-2003-05-28 Richard M. Stallman <[email protected]>
-
- * print.c (syms_of_print) <print-escape-nonascii>: Doc fix.
-
- * eval.c (unbind_to): Move init of this_binding to separate statement.
-
-2003-05-28 Kim F. Storm <[email protected]>
-
- * xdisp.c (expose_window): Fix error in calculation of
- window relative coordinates of area to redisplay.
-
-2003-05-27 Jason Rumney <[email protected]>
-
- * w32term.c (GET_WHEEL_DELTA_WPARAM): New macro.
-
-2003-05-27 David Ponce <[email protected]>
-
- Handle W32 mouse wheel events as mouse click events, like in X.
-
- * keyboard.c (make_lispy_event) [WINDOWSNT]: Don't handle
- MOUSE_WHEEL_EVENT anymore.
-
- * w32term.c (construct_mouse_wheel): Result is a MOUSE_CLICK_EVENT.
- Scrolling down/up the mouse wheel is respectively mapped to mouse
- button 4 and 5.
- (w32_read_socket): Map w32 WM_MOUSEWHEEL events to Emacs
- MOUSE_CLICK_EVENT events. Forward w32 MSH_MOUSEWHEEL events as
- WM_MOUSEWHEEL events.
-
-2003-05-27 Andreas Schwab <[email protected]>
-
- * buffer.c (syms_of_buffer) <default-direction-reversed>: Doc fix.
-
- * xdisp.c (try_window_id): Avoid aborting if PT is inside a
- partially visible line.
-
- * alloc.c (Fgarbage_collect): Fix last change.
-
-2003-05-26 John Paul Wallington <[email protected]>
-
- * xfns.c (Fx_create_frame): Don't call Qface_set_after_frame_default.
-
-2003-05-25 Stefan Monnier <[email protected]>
-
- * window.c (Fset_window_buffer): Add type of `keep_margins'.
- (Fset_window_fringes, Fset_window_scroll_bars): Declare before use.
-
- * window.h (window_box_text_cols): Declare.
-
- * xdisp.c (window_text_bottom_y, draw_row_fringe_bitmaps)
- (x_draw_vertical_border): Remove unused var `f'.
-
- * xfaces.c (build_scalable_font_name): Remove `unused var
- pixel_size' warning.
-
- * xfns.c (png_load): Remove `unused vars intent, image_gamma' warning.
-
- * unexelf.c (unexec): Remove `unused var n' warning.
-
- * strftime.c (my_strftime_localtime_r): Remove `defined but
- unused' warning.
-
- * process.c (allocate_pty): Remove `unused var stb' and
- `cp might be used uninitialized' warnings.
-
- * dispnew.c (mode_line_string): Remove unused var `f'.
-
- * coding.c (find_safe_codings): Remove unused var `i'.
-
- * bytecode.c (Fbyte_code): Remove `unused val' warning.
-
- * buffer.c (Fkill_buffer): Remove unused var `list'.
-
- * alloc.c (Fgarbage_collect): Remove `unused var tail' warning.
-
-2003-05-25 Jan Dj,Ad(Brv <[email protected]>
-
- * frame.c (make_frame): Condition want_fullscreen with
- HAVE_WINDOW_SYSTEM.
-
-2003-05-25 Juanma Barranquero <[email protected]>
-
- * window.c (Fset_window_scroll_bars): Fix typo in argument name.
- (Fwindow_scroll_bars): Fix typo in docstring.
-
-2003-05-24 Kim F. Storm <[email protected]>
-
- The following changes serve several purposes:
-
- 1) Swap the position of fringes and display margins in windows, i.e.
- the fringes are now displayed between the margins and the text area
- (by default).
-
- 2) Allow fringe and scroll bar parameters to be set per-buffer and
- per-window (like display margins). Such settings are now stored
- in window configurations, preserved when frames are resized, and
- copied when windows are split vertically or horizontally.
- Several bugs related to display margins have been fixed.
-
- 3) Consistently use FRAME_FONT and FRAME_FONTSET macros.
-
- 4) Use FRAME_COLUMN_WIDTH (f) consistently throughout the code
- rather than FRAME_WIDTH (FRAME_FONT (f)).
-
- 5) Introduce a consistent naming of variables, members and macros
- depending on whether their value is measured in pixels or in
- canonical columns/lines. Pixel dimensions are named *_width and
- *_height, while canonical columns/lines are named *_cols and
- *_lines. Pixel positions are named *_x and *_y, while column/line
- positions are named *_col and *_line.
-
- 6) Consolidate more of the X, W32, and MAC gui code by moving
- common data into struct frame, and generalize it for the non-gui
- case by using suitable defaults.
-
- 7) Cleanup and consolidate the macros controlling frame and window
- layout into frame.h and window.h, and generalize the use of the
- various window_box_* functions (enhanced to handle the new fringe
- position and the per-window fringe and scroll bar settings).
-
- * frame.h (struct frame): Rename members height to text_lines,
- width to text_cols, window_height to total_lines, window_width to
- total_cols, new_height to new_text_lines, new_width to
- new_text_cols. All uses changed.
- (struct frame): New members which consolidate common members of
- x_output, w32_output, and mac_output structures: left_pos,
- top_pos, pixel_height, pixel_width, x_pixels_diff, y_pixels_diff,
- win_gravity, size_hint_flags, border_width, internal_border_width,
- line_height, fringe_cols, left_fringe_width, right_fringe_width,
- want_fullscreen. All uses changed.
- (struct frame): New member column_width contaning the canonical
- column width, analogue to line_height. All uses changed.
- (struct frame): Rename members scroll_bar_pixel_width to
- config_scroll_bar_width, and scroll_bar_cols to
- config_scroll_bar_cols. All uses changed.
- (struct frame): New member scroll_bar_actual_width which
- consolidates and renames the vertical_scroll_bar_extra member of
- x_output, w32_output, and mac_output structures. All uses changed.
- (FRAME_PIXEL_HEIGHT): Rename from PIXEL_HEIGHT and moved
- from x/w32/macterm.h files. All uses changed. Also change code
- which referred to f->output_data...->pixel_height.
- (FRAME_PIXEL_WIDTH): Rename from PIXEL_WIDTH and moved
- from x/w32/macterm.h files. All uses changed. Also change code
- which referred to f->output_data...->pixel_width.
- (FRAME_LINES): Rename from FRAME_HEIGHT. All uses changed.
- Also change code which referred to f->height.
- (FRAME_COLS): Rename from FRAME_WIDTH. All uses changed.
- Also change code which referred to f->width.
- (FRAME_NEW_HEIGHT, FRAME_NEW_WIDTH): Remove macros; change uses
- to update new_text_lines and new_text_cols members directly.
- (FRAME_CONFIG_SCROLL_BAR_WIDTH): Rename from
- FRAME_SCROLL_BAR_PIXEL_WIDTH. All uses changed.
- (FRAME_CONFIG_SCROLL_BAR_COLS): Rename from
- FRAME_SCROLL_BAR_COLS. All uses changed.
- (FRAME_LEFT_SCROLL_BAR_COLS, FRAME_RIGHT_SCROLL_BAR_COLS):
- Rename from FRAME_LEFT_SCROLL_BAR_WIDTH and
- FRAME_RIGHT_SCROLL_BAR_WIDTH, resp. All uses changed.
- (FRAME_SCROLL_BAR_AREA_WIDTH, FRAME_LEFT_SCROLL_BAR_AREA_WIDTH)
- (FRAME_RIGHT_SCROLL_BAR_AREA_WIDTH): New macros.
- (FRAME_TOTAL_COLS): Rename from FRAME_WINDOW_WIDTH.
- (SET_FRAME_COLS): Rename from SET_FRAME_WIDTH.
- (FRAME_TOTAL_COLS_ARG): Rename from FRAME_WINDOW_WIDTH_ARG.
- (WINDOW_VERTICAL_SCROLL_BAR_COLUMN): Remove unused macro.
- (WINDOW_VERTICAL_SCROLL_BAR_HEIGHT): Remove unused macro.
- (FRAME_LINE_HEIGHT): Rename from CANON_Y_UNIT.
- Unconditionally return line_height member (it now has proper value
- also for non-window frames).
- (FRAME_COLUMN_WIDTH): Rename from CANON_X_UNIT. Unconditionally
- return new column_width member (rather than the default font width).
- (FRAME_FRINGE_COLS, FRAME_LEFT_FRINGE_WIDTH)
- (FRAME_RIGHT_FRINGE_WIDTH): Rename from FRAME_X_... and moved
- from x/w32/macterm.h files. Unconditionally return corresponding
- member of frame structure (they now have proper values also for
- non-window frames).
- (FRAME_TOTAL_FRINGE_WIDTH): Rename from FRAME_FRINGE_WIDTH.
- Calculate return value from left and right widths.
- (FRAME_INTERNAL_BORDER_WIDTH): Unconditionally return
- internal_border_width member (has proper value for non-window frame).
- (FRAME_PIXEL_X_FROM_CANON_X): Rename from PIXEL_X_FROM_CANON_X.
- (FRAME_PIXEL_Y_FROM_CANON_Y): Rename from PIXEL_Y_FROM_CANON_Y.
- (FRAME_CANON_X_FROM_PIXEL_X): Rename from CANON_X_FROM_PIXEL_X.
- (FRAME_CANON_Y_FROM_PIXEL_Y): Rename from CANON_Y_FROM_PIXEL_Y.
- (FRAME_LINE_TO_PIXEL_Y): Rename from CHAR_TO_PIXEL_ROW,
- consolidated from xterm.h, macterm.h, and w32term.h.
- (FRAME_COL_TO_PIXEL_X): Rename from CHAR_TO_PIXEL_COL,
- consolidated from xterm.h, macterm.h, and w32term.h.
- (FRAME_TEXT_COLS_TO_PIXEL_WIDTH): Rename from
- CHAR_TO_PIXEL_WIDTH consolidated from x/mac/w32term.h.
- (FRAME_TEXT_LINES_TO_PIXEL_HEIGHT): Rename from
- CHAR_TO_PIXEL_HEIGHT consolidated from x/mac/w32term.h.
- (FRAME_PIXEL_Y_TO_LINE): Rename from PIXEL_TO_CHAR_ROW
- consolidated from x/mac/w32term.h.
- (FRAME_PIXEL_X_TO_COL): Rename from PIXEL_TO_CHAR_COL
- consolidated from x/mac/w32term.h.
- (FRAME_PIXEL_WIDTH_TO_TEXT_COLS): Rename from
- PIXEL_TO_CHAR_WIDTH consolidated from x/mac/w32term.h.
- (FRAME_PIXEL_HEIGHT_TO_TEXT_LINES): Rename from
- PIXEL_TO_CHAR_HEIGHT consolidated from x/mac/w32term.h.
-
- * window.h (struct window): Rename members left to left_col,
- top to top_line, height to total_lines, width to total_cols,
- left_margin_width to left_margin_cols, right_margin_width to
- right_margin_cols, orig_height to orig_total_lines, orig_top to
- orig_top_line. All uses changed.
- (struct window): New members left_fringe_width, right_fringe_width,
- fringes_outside_margins, scroll_bar_width, vertical_scroll_bar_type.
- (WINDOW_XFRAME, WINDOW_FRAME_COLUMN_WIDTH, WINDOW_FRAME_LINE_HEIGHT):
- New macros primarily used to simplify other macros.
- (WINDOW_TOTAL_COLS): New macro. Change relevant code that
- referred to XINT (w->width).
- (WINDOW_TOTAL_LINES): New macro. Change relevant code that
- referred to XINT (w->height).
- (WINDOW_TOTAL_WIDTH): New macro. Change relevant code that
- referred to XINT (w->width) * canon_x_unit.
- (WINDOW_TOTAL_HEIGHT): New macro. Change relevant code that
- referred to XINT (w->height) * canon_y_unit.
- (WINDOW_LEFT_EDGE_COL): New macro. Change relevant code that
- referred to XINT (w->left).
- (WINDOW_RIGHT_EDGE_COL): Rename from WINDOW_RIGHT_EDGE. Change
- all uses and code that referred to XINT (w->left) + XINT (w->width).
- (WINDOW_TOP_EDGE_LINE): New macro. Change relevant code that
- referred to XINT (w->top).
- (WINDOW_BOTTOM_EDGE_LINE): New macro. Change relevant code that
- referred to XINT (w->top) + XINT (w->height).
- (WINDOW_LEFT_EDGE_X): New macro. Change relevant code that
- referred to XINT (w->left) * canon_x_unit.
- (WINDOW_RIGHT_EDGE_X): New macro. Change relevant code that
- referred to (XINT (w->left) + XINT (w->width)) * canon_x_unit.
- (WINDOW_TOP_EDGE_Y): New macro. Change relevant code that
- referred to XINT (w->top) * canon_y_unit.
- (WINDOW_BOTTOM_EDGE_Y): New macro. Change relevant code that
- referred to (XINT (w->top) + XINT (w->height)) * canon_y_unit.
- (WINDOW_LEFTMOST_P): New macro.
- (WINDOW_BOX_LEFT_EDGE_COL): Rename from WINDOW_LEFT_MARGIN.
- All uses changed.
- (WINDOW_BOX_RIGHT_EDGE_COL): Rename from WINDOW_RIGHT_MARGIN.
- All uses changed.
- (WINDOW_BOX_LEFT_EDGE_X): Rename from
- WINDOW_DISPLAY_LEFT_EDGE_PIXEL_X, moved from dispextern.h.
- Do not exclude left fringe width.
- (WINDOW_BOX_RIGHT_EDGE_X): Rename from
- WINDOW_DISPLAY_RIGHT_EDGE_PIXEL_X, moved from dispextern.h.
- Do not exclude fringe widths.
- (WINDOW_LEFT_FRINGE_WIDTH, WINDOW_RIGHT_FRINGE_WIDTH)
- (WINDOW_FRINGE_COLS, WINDOW_TOTAL_FRINGE_WIDTH): New macros.
- Change relevant code that referred to FRAME_LEFT_FRINGE_WIDTH,
- FRAME_RIGHT_FRINGE_WIDTH, FRAME_FRINGE_COLS, and
- FRAME_TOTAL_FRINGE_WIDTH to allow per-window fringe settings.
- (WINDOW_HAS_FRINGES_OUTSIDE_MARGINS): New macro.
- (WINDOW_VERTICAL_SCROLL_BAR_TYPE, WINDOW_HAS_VERTICAL_SCROLL_BAR)
- (WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT)
- (WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT)
- (WINDOW_CONFIG_SCROLL_BAR_WIDTH, WINDOW_CONFIG_SCROLL_BAR_COLS):
- New macros. Change code which referenced corresponding
- FRAME_VERTICAL_SCROLL_BAR_TYPE, FRAME_HAS_VERTICAL_SCROLL_BARS,
- FRAME_HAS_VERTICAL_SCROLL_BARS_ON_LEFT,
- FRAME_HAS_VERTICAL_SCROLL_BARS_ON_RIGHT,
- FRAME_SCROLL_BAR_PIXEL_WIDTH, and FRAME_SCROLL_BAR_COLS macros to
- allow per-window scroll-bar settings.
- (WINDOW_LEFT_SCROLL_BAR_COLS, WINDOW_RIGHT_SCROLL_BAR_COLS): New macros.
- (WINDOW_LEFT_SCROLL_BAR_AREA_WIDTH): New macro. Change code that
- referred to FRAME_LEFT_SCROLL_BAR_WIDTH.
- (WINDOW_RIGHT_SCROLL_BAR_AREA_WIDTH): New macro. Change code
- that referred to FRAME_HAS_VERTICAL_SCROLL_BARS_ON_RIGHT and
- FRAME_SCROLL_BAR_WIDTH.
- (WINDOW_SCROLL_BAR_COLS, WINDOW_SCROLL_BAR_AREA_WIDTH)
- (WINDOW_SCROLL_BAR_AREA_X): New macros.
- (WINDOW_HEADER_LINE_HEIGHT): Rename from
- WINDOW_DISPLAY_HEADER_LINE_HEIGHT, moved from dispextern.h.
- (WINDOW_BOX_HEIGHT_NO_MODE_LINE): Rename from
- WINDOW_DISPLAY_HEIGHT_NO_MODE_LINE, moved from dispextern.h.
- (WINDOW_BOX_TEXT_HEIGHT): Rename from
- WINDOW_DISPLAY_PIXEL_WIDTH, moved from dispextern.h.
- (WINDOW_TO_FRAME_PIXEL_X, WINDOW_TO_FRAME_PIXEL_Y)
- (FRAME_TO_WINDOW_PIXEL_X, FRAME_TO_WINDOW_PIXEL_Y)
- (WINDOW_TEXT_TO_FRAME_PIXEL_X): Move here from dispextern.h.
- (WINDOW_LEFT_MARGIN_WIDTH): Rename from
- WINDOW_DISPLAY_LEFT_AREA_PIXEL_WIDTH, moved from dispextern.h.
- (WINDOW_RIGHT_MARGIN_WIDTH): Rename from
- WINDOW_DISPLAY_RIGHT_AREA_PIXEL_WIDTH, moved from dispextern.h.
- (window_from_coordinates): Update prototype.
- (Fset_window_buffer): Update EXFUN.
- (set_window_buffer): Update prototype.
-
- * dispextern.h (struct glyph_matrix): Rename members window_left_x
- to window_left_col, window_top_y to window_top_line. All uses
- changed.
- (FRAME_INTERNAL_BORDER_WIDTH_SAFE): Remove macro; can now safely
- use FRAME_INTERNAL_BORDER_WIDTH macro instead as
- internal_border_width is now set to 0 for non-window frames.
- (WINDOW_DISPLAY_PIXEL_WIDTH, WINDOW_DISPLAY_PIXEL_HEIGHT)
- (WINDOW_DISPLAY_MODE_LINE_HEIGHT, WINDOW_DISPLAY_HEADER_LINE_HEIGHT)
- (WINDOW_DISPLAY_HEIGHT_NO_MODE_LINE, WINDOW_DISPLAY_TEXT_HEIGHT)
- (WINDOW_DISPLAY_LEFT_EDGE_PIXEL_X, WINDOW_DISPLAY_RIGHT_EDGE_PIXEL_X)
- (WINDOW_DISPLAY_TOP_EDGE_PIXEL_Y, WINDOW_DISPLAY_BOTTOM_EDGE_PIXEL_Y)
- (WINDOW_TO_FRAME_PIXEL_X, WINDOW_TO_FRAME_PIXEL_Y)
- (FRAME_TO_WINDOW_PIXEL_X, FRAME_TO_WINDOW_PIXEL_Y)
- (WINDOW_DISPLAY_LEFT_AREA_PIXEL_WIDTH)
- (WINDOW_DISPLAY_RIGHT_AREA_PIXEL_WIDTH, WINDOW_WANTS_MODELINE_P):
- Move to window.h and renamed [see window.h changes].
- (WINDOW_AREA_TO_FRAME_PIXEL_X, WINDOW_AREA_PIXEL_WIDTH)
- (WINDOW_DISPLAY_TEXT_AREA_PIXEL_WIDTH): Remove macros.
- (WINDOW_WANTS_MODELINE_P, WINDOW_WANTS_HEADER_LINE_P):
- Use WINDOW_TOTAL_LINES.
- (frame_update_line_height): Remove prototype.
-
- * buffer.h (struct buffer): Rename members measured in columns:
- left_margin_width to left_margin_cols, right_margin_width to
- right_margin_cols. All uses changed.
- New members left_fringe_width, right_fringe_width,
- fringes_outside_margins for per-buffer fringe settings.
- New members scroll_bar_width and vertical_scroll_bar_type for
- per-buffer scroll bar settings.
-
- * buffer.c (init_buffer_once): Set buffer_defaults and
- buffer_local_flags for new buffer-local variables
- left_fringe_width, right_fringe_width, fringes_outside_margins,
- scroll_bar_width, and vertical_scroll_bar_type.
- (syms_of_buffer): Defvar_per_buffer them, and defvar_lisp_nopro
- default-* variables for them.
-
- * dispnew.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (mode_line_string): No need to adjust width for mode lines, as it
- is already adjusted by the caller.
- (marginal_area_string): Handle fringes inside/outside margins.
-
- * frame.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (make_frame): Initialize left_fringe_width, right_fringe_width,
- fringe_cols, scroll_bar_actual_width, border_width,
- internal_border_width, column_width, line_height, x_pixels_diff,
- y_pixels_diff, want_fullscreen, size_hint_flags, and win_gravity
- members with values suitable for a non-window frames.
-
- * gtkutil.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * indent.c: Make (few) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * keyboard.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (make_lispy_event): Use window positions returned from
- window_from_coordinates when constructing the lisp event for
- MOUSE_CLICK_EVENT and DRAG_N_DROP_EVENT, rather than calculating
- (incorrect) values locally.
- (make_lispy_movement): Use window positions returned from
- window_from_coordinates when constructing the lisp event, rather
- than calculating (incorrect) values locally.
-
- * scroll.c: Make (some) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * sunfns.c (Fsun_menu_internal): Adapt to per-window fringes and
- scroll-bars.
-
- * sysdep.c: Make (few) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * term.c: Make (some) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * widget.c: Make (few) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * window.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (make_window): Initialize new members
- left_margin_cols, right_margin_cols, left_fringe_width,
- right_fringe_width, fringes_outside_margins, scroll_bar_width,
- and vertical_scroll_bar_type.
- (coordinates_in_window): Adapt to new fringe/margin positions
- and per-window fringes and scroll-bars.
- Fix bug related to incorrectly adjusting coordinates by
- frame's internal_border_width (the effect normally negible since
- the internal_border_width is typically 0 or 1 pixel, but very
- noticeable for an internal_border_width of e.g. 25 pixels).
- Upon successful return (other than ON_NOTHING), the coordinates
- are now always properly converted to window relative for the
- given display element.
- (window_from_coordinates): Add new parameters wx and wy to
- return the window relative x and y position in the returned
- window and part. A null arg means, don't return the position.
- All callers changed.
- (adjust_window_margins): New function which may reduce the width
- of the display margins if a window's text area is too small after
- resizing or splitting windows.
- (size_window): Fix bug that did not account for display margin
- widths when checking the minimum width of a window; use
- adjust_window_margins.
- (set_window_buffer): Call Fset_window_fringes and
- Fset_window_scroll_bars to setup per-window elements.
- Add new arg KEEP_MARGINS_P. Non-nil means to keep window's
- existing display margin, fringe widths, and scroll bar settings
- (e.g. after splitting a window or resizing the frame).
- All callers changed.
- (Fset_window_buffer): New arg KEEP_MARGINS. All callers changed.
- (Fsplit_window): Duplicate original window's display margin,
- fringe, and scroll-bar settings; then call Fset_window_buffer with
- KEEP_MARGINS non-nil. This fixes a bug which caused a split
- window to only preserve the display margins in one of the windows.
- When splitting horizontally, call adjust_window_margins on both
- windows to ensure that the text area of the new windows is non too
- narrow. This fixes a bug which could cause Emacs to trap if the
- width of the split window was less than the width of the display
- margins.
- (window_box_text_cols): Rename from window_internal_width.
- All uses changed. Adapt to per-window fringes and scroll bars.
- Fix bug that caused vertical separator to be subtracted also on
- window frames. Fix another bug that did not reduce the returned
- value by the columns used for display margins.
- (window_scroll_line_based): Fix bug related to scrolling too much
- when display margins are present (implicitly fixed by the fix to
- window_box_text_cols).
- (scroll_left, scroll_right): Fix bug related to scrolling too far
- by default when display margins are present (implicitly fixed by
- the fix to window_box_text_cols).
- (struct saved_window): Rename members left to left_col, top to
- top_line, width to total_cols, height to total_lines, orig_top to
- orig_top_line, orig_height to orig_total_lines. All uses changed.
- New members left_margin_cols, right_margin_cols,
- left_fringe_width, right_fringe_width, fringes_outside_margins,
- scroll_bar_width, and vertical_scroll_bar_type for saving
- per-window display elements.
- (Fset_window_configuration): Restore display margins, fringes,
- and scroll bar settings. This fixes a bug which caused display
- margins to be discarded when saving and restoring a window
- configuration.
- (save_window_save): Save display margins, fringes, and scroll bar
- settings. This fixes a bug which caused display margins to be
- discarded when saving and restoring a window configuration.
- (Fset_window_margins): Do nothing if display margins are not
- really changed. Otherwise, call adjust_window_margins to ensure
- the text area doesn't get too narrow. This fixes a bug which
- could cause Emacs to trap if setting display margins wider than
- the width of the window.
- (Fset_window_fringes): New defun to allow user to specifically set
- this window's fringe widths and position vs. display margins.
- (Fwindow_fringes): New defun to return window's actual fringe settings.
- (Fset_window_scroll_bars): New defun to allow user to specifically
- set this window's scroll bar width and position.
- (Fwindow_scroll_bars): New defun to return window's actual scroll
- bar settings.
- (compare_window_configurations): Also compare display margins,
- fringes, and scroll bar settings.
- (syms_of_window): Defsubr new defuns for fringe and scroll bars.
-
- * xdisp.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (window_box_width): Adapt to per-window fringes and scroll bars,
- and new fringe vs. display margin position. Note that returned
- value is no longer guaranteed to be a whole multiple of the frame
- column width, since per-window fringes may now be any width.
- (window_box_left_offset): New function like window_box_left, but
- value is relative to left border of window (rather than frame).
- (window_box_right_offset): New function like window_box_right,
- but value is relative to left border of window.
- (window_box_left): Adapt to per-window fringes and scroll bars,
- and new fringe vs. display margin position. Simplify by using
- WINDOW_LEFT_EDGE_X and window_box_left_offset.
- (window_box): Allow null args for unnecessary return values;
- change/simplify relevant callers.
- (x_y_to_hpos_vpos): Adapt to per-window fringes and scroll bars,
- and new fringe vs. display margin position.
- Use window_box_left_offset and window_box_right_offset
- (get_glyph_string_clip_rect): Adapt to per-window fringes and
- scroll bars, and new fringe vs. display margin position.
- Use WINDOW_LEFT_EDGE_X and WINDOW_TOTAL_WIDTH.
- (draw_fringe_bitmap): Rework to handle per-window fringes and new
- fringe vs. display margin position.
- (hscroll_window_tree): Use window_box_width instead of window_box.
- (redisplay_window): Adapt to per-window scroll bars.
- (draw_glyphs): Rework to handle per-window fringes and scroll
- bars, and new fringe vs. display margin position.
- Use WINDOW_LEFT_EDGE_X, WINDOW_TOTAL_WIDTH, and window_box_left.
- (x_clear_end_of_line): Adapt to per-window fringes and scroll
- bars, and new fringe vs. display margin position. Fix bug which
- increased total width of full_width rows by width of scroll bars
- although window's total width already includes that.
- (x_fix_overlapping_area): Simplify using window_box_left_offset.
- (expose_area): Simplify using window_box_left_offset.
- (x_draw_vertical_border): Handle per-window scroll bar settings,
- mixing windows with left, right and no scroll bars.
-
- * xfaces.c [WINDOWSNT]: Move redefinition of FONT_WIDTH macro to
- where it's used in x_list_fonts (for clarity).
- (frame_update_line_height): Remove unused function; functionality
- is now done directly when setting the default font in x_set_font.
-
- * xfns.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * xmenu.c: Make (some) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * xterm.h (struct x_output): Move members left_pos, top_pos,
- border_width, pixel_height, pixel_width, line_height,
- internal_border_width, vertical_scroll_bar_extra,
- left_fringe_width, right_fringe_width, fringe_cols,
- fringes_extra, win_gravity, size_hint_flags, want_fullscreen,
- x_pixels_diff, and y_pixels_diff to struct frame (frame.h).
- (FRAME_INTERNAL_BORDER_WIDTH, FRAME_LINE_HEIGHT): Move to frame.h.
- (FRAME_DEFAULT_FONT_WIDTH): Remove macro.
- (PIXEL_WIDTH, PIXEL_HEIGHT)
- (FRAME_X_FRINGE_COLS, FRAME_X_FRINGE_WIDTH)
- (FRAME_X_LEFT_FRINGE_WIDTH, FRAME_X_RIGHT_FRINGE_WIDTH): Move to
- frame.h and renamed [see frame.h changes].
- (CHAR_TO_PIXEL_ROW, CHAR_TO_PIXEL_COL, CHAR_TO_PIXEL_WIDTH)
- (CHAR_TO_PIXEL_HEIGHT, PIXEL_TO_CHAR_ROW, PIXEL_TO_CHAR_COL)
- (PIXEL_TO_CHAR_WIDTH, PIXEL_TO_CHAR_HEIGHT): Move to frame.h
- and renamed [see frame.h changes].
-
- * xterm.c: Make (several) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (x_draw_glyph_string_box): Adapt to per-window fringes and scroll-bars.
- (scroll_run): Adapt to new fringe position.
- (glyph_rect): Use window coordinates returned from
- window_from_coordinates rather than frame_to_window_pixel_xy.
- (XTset_vertical_scroll_bar): Adapt to per-window fringes and
- scroll-bars.
- (handle_one_xevent): Simplify a USE_GTK conditional.
- (x_clip_to_row): Remove superfluous whole_line_p arg and code
- (fringes are now inside margins, i.e. always in the clipping area).
- All callers changed.
- (x_new_font): Set FRAME_COLUMN_WIDTH and FRAME_LINE_HEIGHT
- directly, then call compute_fringe_widths. Don't call
- frame_update_line_height.
-
- * w32term.h (struct w32_output): Move members left_pos, top_pos,
- border_width, pixel_height, pixel_width, line_height,
- internal_border_width, vertical_scroll_bar_extra,
- left_fringe_width, right_fringe_width, fringe_cols,
- fringes_extra, win_gravity, size_hint_flags, want_fullscreen,
- x_pixels_diff, and y_pixels_diff to struct frame (frame.h).
- (FRAME_INTERNAL_BORDER_WIDTH, FRAME_LINE_HEIGHT): Move to frame.h.
- (FRAME_DEFAULT_FONT_WIDTH): Remove macro.
- (PIXEL_WIDTH, PIXEL_HEIGHT)
- (FRAME_X_FRINGE_COLS, FRAME_X_FRINGE_WIDTH)
- (FRAME_X_LEFT_FRINGE_WIDTH, FRAME_X_RIGHT_FRINGE_WIDTH): Move to
- frame.h and renamed [see frame.h changes].
- (CHAR_TO_PIXEL_ROW, CHAR_TO_PIXEL_COL, CHAR_TO_PIXEL_WIDTH)
- (CHAR_TO_PIXEL_HEIGHT, PIXEL_TO_CHAR_ROW, PIXEL_TO_CHAR_COL)
- (PIXEL_TO_CHAR_WIDTH, PIXEL_TO_CHAR_HEIGHT): Move to frame.h
- and renamed [see frame.h changes].
-
- * w32term.c: Make (several) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (x_draw_glyph_string_box): Adapt to per-window fringes and scroll-bars.
- (glyph_rect): Use window coordinates returned from
- window_from_coordinates rather than frame_to_window_pixel_xy.
- (XTset_vertical_scroll_bar): Adapt to per-window fringes and
- scroll-bars.
- (w32_clip_to_row): Remove superfluous whole_line_p arg and code
- (fringes are now inside margins, i.e. always in the clipping area).
- All callers changed.
- (x_new_font): Set FRAME_COLUMN_WIDTH and FRAME_LINE_HEIGHT
- directly, then call compute_fringe_widths. Don't call
- frame_update_line_height.
-
- * w32console.c: Make (few) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * w32fns.c: Make (many) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * w32menu.c: Make (few) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * macterm.h (struct mac_output): Move members left_pos, top_pos,
- border_width, pixel_height, pixel_width, line_height,
- internal_border_width, vertical_scroll_bar_extra,
- left_fringe_width, right_fringe_width, fringe_cols,
- fringes_extra, win_gravity, size_hint_flags, want_fullscreen,
- x_pixels_diff, y_pixels_diff to struct frame (frame.h).
- (FRAME_INTERNAL_BORDER_WIDTH, FRAME_LINE_HEIGHT): Move to frame.h.
- (FRAME_DEFAULT_FONT_WIDTH): Remove macro.
- (PIXEL_WIDTH, PIXEL_HEIGHT)
- (FRAME_X_FRINGE_COLS, FRAME_X_FRINGE_WIDTH)
- (FRAME_X_LEFT_FRINGE_WIDTH, FRAME_X_RIGHT_FRINGE_WIDTH): Move to
- frame.h and renamed [see frame.h changes].
- (CHAR_TO_PIXEL_ROW, CHAR_TO_PIXEL_COL, CHAR_TO_PIXEL_WIDTH)
- (CHAR_TO_PIXEL_HEIGHT, PIXEL_TO_CHAR_ROW, PIXEL_TO_CHAR_COL)
- (PIXEL_TO_CHAR_WIDTH, PIXEL_TO_CHAR_HEIGHT): Move to frame.h
- and renamed [see frame.h changes].
-
- * macterm.c: Make (several) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (x_draw_glyph_string_box): Adapt to per-window fringes and scroll-bars.
- (glyph_rect): Use window coordinates returned from
- window_from_coordinates rather than frame_to_window_pixel_xy.
- (XTset_vertical_scroll_bar): Adapt to per-window fringes and
- scroll-bars.
- (x_clip_to_row): Remove superfluous whole_line_p arg and code
- (fringes are now inside margins, i.e. always in the clipping area).
- All callers changed.
- (x_new_font): Set FRAME_COLUMN_WIDTH and FRAME_LINE_HEIGHT
- directly, then call compute_fringe_widths. Don't call
- frame_update_line_height.
-
- * macfns.c: Make (several) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (x_real_positions): Set f->x_pixels_diff and f->y_pixels_diff to 0.
-
- * macmenu.c: Make (few) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
-
- * msdos.h (struct x_output): Remove members left_pos, top_pos,
- and line_height, and use corresponding new members in struct
- frame. All uses changed.
- (FRAME_LINE_HEIGHT, FRAME_INTERNAL_BORDER_WIDTH): Remove macros;
- superseeded by corresponding macros in frame.h.
-
- * msdos.c: Make (several) trivial substitutions for renamed and
- new macros in dispextern.h, frame.h and window.h.
- (IT_note_mouse_highlight): Use updated window coordinates returned
- by window_from_coordinates, rather than adjusting them locally.
- (internal_terminal_init): No need to initialize line_height here;
- it now defaults to 1.
-
-2003-05-24 Stefan Monnier <[email protected]>
-
- * keyboard.c (read_key_sequence): Adjust fkey and keytran when
- dropping `down' events.
-
-2003-05-24 Andreas Schwab <[email protected]>
-
- * coding.c (find_safe_codings): Fix last change.
-
-2003-05-24 Istvan Marko <[email protected]> (tiny change)
-
- * xfns.c (x_window): Fix typo from 2003-05-21 change.
-
-2003-05-23 Stefan Monnier <[email protected]>
-
- * xdisp.c (display_mode_element): Increase max depth.
- Simplify the error handling code. Use a different error string
- for the case where we hit the depth limit.
-
- * lisp.h (Vfundamental_mode_abbrev_table): Don't declare.
-
- * buffer.c (reset_buffer_local_variables): Remove redundant setting.
-
-2003-05-21 Stefan Monnier <[email protected]>
-
- * intervals.c (get_local_map): Don't get char-property of previous
- point any more: get_pos_property already does it and better.
-
-2003-05-21 Dave Love <[email protected]>
-
- [Merged from unicode branch.]
-
- * xfns.c (x_window, x_window): Use use_xim.
-
- * xterm.c (use_xim): Initialize.
- (xim_open_dpy, xim_initialize, xim_close_dpy): Use use_xim.
- (x_term_init): Maybe set use_xim.
-
- * xterm.h (use_xim) [HAVE_X_I18N]: Declare.
-
-2003-05-21 Jason Rumney <[email protected]>
-
- * unexw32.c (_start): Remove _fmode initialization.
-
- * emacs.c (main) [WINDOWSNT]: Move it here.
-
-2003-05-20 Dave Love <[email protected]>
-
- * s/gnu-linux.h (MAIL_USE_FLOCK): Make it conditional.
-
-2003-05-19 Richard M. Stallman <[email protected]>
-
- * xfaces.c (Finternal_set_lisp_face_attribute): Handle Qunspecified
- as value for QCfont attribute.
- (realize_default_face): lface should already exist; crash if not.
- Specify 0 for FORCE_P when calling set_lface_from_font_name.
-
- * frame.c (Fignore_event): Doc fix.
-
-2003-05-19 Kenichi Handa <[email protected]>
-
- * coding.c (decode_coding_string): Handle post-read-conversion
- even if the coding doesn't require decoding.
-
-2003-05-18 Richard M. Stallman <[email protected]>
-
- * callproc.c (Fcall_process_region): Doc fix.
-
-2003-05-17 Stefan Monnier <[email protected]>
-
- * lread.c (Fload): Print a message if package is obsolete.
-
- * window.c (Fselect_window): Add optional `norecord' arg.
- (select_window_1): Fold into Fselect_window.
- (select_window_norecord): New function.
- (temp_output_buffer_show): Use it. Preserve current buffer.
-
- * window.h (Fselect_window): Update declaration.
-
- * window.c (delete_window, Fother_window, Fset_window_configuration):
- * minibuf.c (read_minibuf):
- * macterm.c (x_new_focus_frame):
- * frame.c (do_switch_frame, Fset_frame_selected_window, Fdelete_frame):
- * callint.c (Fcall_interactively):
- * xterm.c (x_new_focus_frame): Pass nil as new arg to Fselect_window.
-
- * buffer.c (Fpop_to_buffer): Pass norecord to Fselect_window.
-
-2003-05-17 David Kastrup <[email protected]>
-
- * process.c (read_process_output): Back out change from 2003-03-09.
-
-2003-05-17 Stefan Monnier <[email protected]>
-
- * editfns.c (get_pos_property): Don't assume that `object' = nil.
-
- * textprop.c (text_property_stickiness): New arg `buffer'.
-
- * intervals.h (text_property_stickiness): New arg `buffer'.
- (get_pos_property): Declare.
-
- * intervals.c (get_local_map): Use get_pos_property, to obey
- stickiness and empty overlays.
- (create_root_interval, graft_intervals_into_buffer): Use BEG.
- (merge_properties, intervals_equal, merge_properties_sticky):
- Use XCAR, XCDR.
- (adjust_for_invis_intang): Pass new arg to text_property_stickiness.
-
-2003-05-17 Richard M. Stallman <[email protected]>
-
- * minibuf.c (read_minibuf): If buffer is empty, record the default
- in the history.
- (Fminibuffer_complete_word): When deleting the overlap, take account
- of its real position.
-
- * fns.c (map_char_table): Fix previous change.
-
- * syntax.c (find_defun_start):
- When open_paren_in_column_0_is_defun_start,
- return beginning of buffer.
-
- * lisp.h (map_char_table): Declare added arg.
-
- * fns.c (map_char_table): New arg TABLE gets the master table.
- All calls changed.
- Process default and inheritance, resorting to Faref if necessary.
-
- * keymap.c (Fset_keymap_parent, map_keymap, Fcopy_keymap)
- (Faccessible_keymaps): Pass new arg to map_char_table.
-
- * fontset.c (Ffontset_info): Pass new arg to map_char_table.
-
- * casetab.c (set_case_table): Pass new arg to map_char_table.
-
- * data.c (let_shadows_buffer_binding_p): Make target of p volatile.
-
- * lisp.h (specbinding_func): New typedef.
- (struct specbinding): Use specbinding_func, to put the `volatile'
- in the right place.
-
- * alloc.c (Fgarbage_collect): Cast pointers into specpdl
- to avoid GCC warning.
-
-2003-05-16 Ralph Schleicher <[email protected]>
-
- * fileio.c (Fdelete_file): Handle symlinks pointing to directories.
-
-2003-05-15 Stefan Monnier <[email protected]>
-
- * keyboard.c (apply_modifiers): Don't fill the other cache.
-
-2003-05-14 Stefan Monnier <[email protected]>
-
- * .gdbinit-union: New file, for USE_LISP_UNION_TYPE users.
-
- * window.h (Qwindowp, Qwindow_live_p, Vwindow_list)
- (Fwindow_end, Fselected_window, Fdelete_window, Fwindow_buffer)
- (Fget_buffer_window, Fsave_window_excursion, Fsplit_window)
- (Fset_window_configuration, Fcurrent_window_configuration)
- (compare_window_configurations, Fcoordinates_in_window_p, Fwindow_at)
- (Fpos_visible_in_window_p, mark_window_cursors_off)
- (window_internal_height, window_internal_width, Frecenter)
- (Fscroll_other_window, Fset_window_start, temp_output_buffer_show)
- (replace_buffer_in_all_windows, init_window_once, init_window)
- (syms_of_window, keys_of_window): Move from lisp.h.
- * lisp.h: Move window.c declarations to window.h.
-
- * bytecode.c: Include window.h.
- * emacs.c: Include window.h.
-
- * keyboard.c (make_lispy_event): Apply modifiers to multibyte-char key.
- (keyremap): Add `parent' field.
- (keyremap_step): Use it. Remove `parent' argument.
- (read_key_sequence): Setup and use the new `parent' field.
-
-2003-05-11 Stefan Monnier <[email protected]>
-
- * keyboard.c (adjust_point_for_property): Ensure termination.
-
-2003-05-10 Stefan Monnier <[email protected]>
-
- * keyboard.c (follow_key): Remove dead variable `did_meta'.
- (access_keymap_keyremap, keyremap_step): New funs, extracted from the
- duplicated handling of function-key-map and key-translation-map
- in read_key_sequence.
- (read_key_sequence): Use them.
-
- * keyboard.c (adjust_point_for_property): Try harder to move point
- to the non-sticky end of an invisible property.
-
- * xdisp.c (single_display_prop_intangible_p): Make `space' display
- property intangible as well.
-
-2003-05-10 Andreas Schwab <[email protected]>
-
- * xmenu.c (single_menu_item): Change last parameter to void* to
- avoid warning.
-
-2003-05-09 Richard M. Stallman <[email protected]>
-
- * print.c (Fprin1_to_string): Instead of gcpro, set abort_on_gc.
- Bind Qinhibit_modification_hooks to t so there will be no GC.
- Rename local `tem' to `save_deactivate_mark'.
-
- * eval.c (specpdl_ptr): Declare volatile.
- (unbind_to): Copy the whole binding and decrement specpdl_ptr
- before doing the work of unbinding it.
-
- * lisp.h (struct specbinding): Declare elements volatile.
- (specpdl_ptr): Declare volatile.
-
- * Makefile.in (alloca.o): Specify -DDO_BLOCK_INPUT in compiling.
-
- * alloca.c: Test DO_BLOCK_INPUT rather than `emacs'
- for use of BLOCK_INPUT and inclusion of lisp.h and blockinput.h.
-
-2003-05-08 Dave Love <[email protected]>
-
- * coding.c (Vlast_coding_system_used): Doc fix.
-
-2003-05-07 Jason Rumney <[email protected]>
-
- * fileio.c (Ffile_symlink_p): Let handlers handle symlinks even
- when system does not support them.
-
-2003-05-05 Stefan Monnier <[email protected]>
-
- * fileio.c (Qwrite_region_annotate_functions): New var.
- (build_annotations): Use it to process the global part of the hook.
- (syms_of_fileio): Init and staticpro it.
-
- * keyboard.c (safe_run_hooks_error): Display a message instead of
- silently ignoring the error.
-
-2003-05-03 Stefan Monnier <[email protected]>
-
- * keyboard.c (input_available_signal): Mark static.
- (menu_bar_items): Use map_keymap.
- (menu_bar_one_keymap): Remove.
- (menu_bar_item): Adjust arglist (for use in map_keymap).
- Properly hide a second binding when not both are keymaps.
-
- * xmenu.c (struct skp): New struct, to pass args through map_keymap.
- (single_keymap_panes): Use it and map_keymap.
- (single_menu_item): Use skp as well.
-
- * keymap.h (map_keymap_function_t): New type.
- (map_keymap): Declare.
-
- * keymap.c (map_keymap_item, map_keymap_char_table_item, map_keymap)
- (map_keymap_call, Fmap_keymap): New functions.
- (syms_of_keymap): Defsubr map-keymap.
-
-2003-05-02 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (create_dialog, make_widget_for_menu_item)
- (make_menu_item, create_menus, xg_update_menu_item): Don't call
- ..._with_mnemonic functions for menu items.
-
-2003-05-01 Kenichi Handa <[email protected]>
-
- * coding.c (coding_system_accept_latin_extra_p): Delete this
- function.
- (find_safe_codings): Pay attention to
- the property tranlsation-table-for-encode of each codings.
- (syms_of_coding): Give Qtranslation_table the extra slot number 2.
-
-2003-05-01 Stefan Monnier <[email protected]>
-
- * eval.c (Funwind_protect): Use func=Fprogn rather than symbol=Qnil.
-
-2003-04-30 Stefan Monnier <[email protected]>
-
- * eval.c (unbind_to): Don't handle symbol = Qnil any more.
-
- * lisp.h (CHECK): Wrap args in parenthesis.
- (specbind): Fix doc: symbol = Qnil is not supported any more.
-
- * bytecode.c (Fbyte_code) <unwind-protect>:
- Use Fprogn rather than 0 and Qnil.
-
- * keyboard.c (parse_modifiers_uncached): Parse `down', `drag',
- `double', and `triple' modifiers as well.
-
-2003-04-30 Richard M. Stallman <[email protected]>
-
- * keyboard.c (echo_char): Don't clear out a dash that follows a space.
-
- * alloc.c (abort_on_gc): New variable.
- (Fgarbage_collect): Abort if abort_on_gc is set.
-
- * lisp.h (abort_on_gc): Add decl.
-
- * eval.c (Fsignal): Clear abort_on_gc.
-
- * editfns.c (Fformat): Set abort_on_gc during first scan of format.
- Reinit FORMAT_START and END before second scan.
-
- * xdisp.c (move_it_vertically_backward): Do the final big else
- even if nlines is 0.
-
- * xdisp.c (redisplay_internal): Finish the per-frame loop
- even if redisplay is suspended by input.
-
-2003-04-24 Andrew Choi <[email protected]>
-
- * macterm.c (x_list_fonts): Return all fonts that match if
- maxnames = -1.
-
-2003-04-25 Kenichi Handa <[email protected]>
-
- * syntax.c (skip_chars): Fix previous change.
-
-2003-04-24 Kenichi Handa <[email protected]>
-
- * syntax.c (skip_chars): Make the code faster by using the common
- technique of *p, *stop, and *endp.
-
-2003-04-23 Jan Dj,Ad(Brv <[email protected]>
-
- * xdisp.c (update_tool_bar): BLOCK_INPUT before calling
- tool_bar_items so GTK tool bar expose callback does not access items
- being updated.
-
-2003-04-19 Stefan Monnier <[email protected]>
-
- * eval.c (Fapply): Undo last change and add a comment about why.
-
-2003-04-18 Miles Bader <[email protected]>
-
- * data.c (Faset): Calculate nbytes earlier, to satisfy the now
- pickier PARSE_MULTIBYTE_SEQ.
-
-2003-04-17 Stefan Monnier <[email protected]>
-
- * eval.c (For, Fand, Fprogn, un_autoload, do_autoload):
- Use XCDR, XCAR, CONSP.
- (Fdefmacro): Fix docstring. Use XCAR, XCDR.
- (Fapply): Remove unnecessary GCPRO.
-
- * doc.c (Fsubstitute_command_keys): Remove spurious casts.
-
- * charset.h (PARSE_MULTIBYTE_SEQ): Pretend `length' is used.
-
- * buffer.h: Don't hardcode BEG==1.
-
- * abbrev.c (Fdefine_abbrev_table): Use XCAR, XCDR.
-
-2003-04-16 Richard M. Stallman <[email protected]>
-
- * xdisp.c (try_window, try_window_reusing_current_matrix):
- When at end of window, set window_end_pos to Z-ZV.
-
- * buffer.c (Foverlay_recenter): Doc fix.
-
-2003-04-14 Stefan Monnier <[email protected]>
-
- * dispnew.c (Fsit_For): Support XEmacs-style arg list.
-
-2003-04-14 Andrew Choi <[email protected]>
-
- * macterm.c (mac_check_for_quit_char): Don't check more often than
- once a second.
-
-2003-04-11 Stefan Monnier <[email protected]>
-
- * keyboard.c (kbd_buffer_get_event): Don't handle SELECT_WINDOW_EVENT
- specially, so that they can't hide an implicit switch-frame event.
- (make_lispy_event): Handle SELECT_WINDOW_EVENT.
- (head_table): Use switch-frame as event_kind for select-window.
- (keys_of_keyboard): Don't bind [select-window] in special-event-map.
-
- * editfns.c (Fformat): Lisp_Object/int mixup.
- (format2): Remove unused var numargs.
-
-2003-04-11 Kenichi Handa <[email protected]>
-
- * fileio.c (Vafter_insert_file_adjust_coding_function): Delete.
- (Qafter_insert_file_set_coding): New variable.
- (syms_of_fileio): Initialize and staticpro it. Delete declaration
- for after-insert-file-adjust-coding-function.
- (Finsert_file_contents): Call Qafter_insert_file_set_coding
- instead of Vafter_insert_file_adjust_coding_function.
-
-2003-04-11 Kenichi Handa <[email protected]>
-
- * lisp.h (temp_echo_area_glyphs): Adjust prototype.
-
- * minibuf.c (temp_echo_area_glyphs): Change the arg to Lisp
- string. Callers changed.
-
-2003-04-10 Kenichi Handa <[email protected]>
-
- * fileio.c (Vafter_insert_file_adjust_coding_function): New variable.
- (syms_of_fileio): Declare it as a lisp variable.
- (Finsert_file_contents):
- Call Vafter_insert_file_adjust_coding_function before calling
- decode-format.
-
-2003-04-09 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (xg_scroll_callback): Call gtk_range_get_adjustment to
- get GtkAdjustment as widget now is a GtkRange.
-
- * gtkutil.c (xg_create_scroll_bar): Connect to value-changed on
- GtkRange to avoid memory leak.
-
-2003-04-09 Kenichi Handa <[email protected]>
-
- * xfaces.c (Vface_font_rescale_alist): New variable.
- (struct font_name): New member rescale_ratio.
- (font_rescale_ratio): New function.
- (split_font_name): If NUMERIC_P is nonzero, set font->rescale_ratio.
- (better_font_p): On comparing point sized, pay attention to
- recale_ratio member of fonts.
- (build_scalable_font_name): Reflect font->rescale_ratio in the
- font name.
- (syms_of_xfaces): Declare Vface_font_rescale_alist as a Lisp variable.
-
- * lread.c (read1): Before calling index, check if the 2nd
- arguemnt is in ASCII range.
-
-2003-04-08 Richard M. Stallman <[email protected]>
-
- * fileio.c (Ffile_symlink_p): Doc fix.
-
- * editfns.c (Fformat): Translate positions of text properties
- in the format string to apply them to the result.
-
- * fileio.c (Finsert_file_contents): Doc fix.
- (syms_of_fileio) <after-insert-file-functions>: Doc fix.
-
-2003-04-08 Ivan Zakharyaschev <[email protected]> (tiny change)
-
- * lread.c (openp): Get the Qfile_exists_p handler for STRING, not FN.
-
-2003-04-08 Steven Tamm <[email protected]>
-
- * mac.c (init_mac_osx_environment): Switch libexec and bin so
- that self-contained application finds libexec files.
-
-2003-04-08 Kenichi Handa <[email protected]>
-
- * coding.c (code_convert_region_unwind):
- Set Vlast_coding_system_used to the argument.
- (code_convert_region): If post-read-conversion function changed
- the value of last-coding-sytem, keep the new value in
- coding->symbol so that it won't be overridden.
- (run_pre_post_conversion_on_str): Likewise.
- (coding_system_accept_latin_extra_p): New function.
- (find_safe_codings): Pay attention to characters registered in
- latin-extra-code-table.
-
-2003-04-07 Thien-Thi Nguyen <[email protected]>
-
- * Makefile.in (md5.o): Add missing dependency info.
-
-2003-04-06 Richard M. Stallman <[email protected]>
-
- * xselect.c (x_handle_selection_request): Move UNGCPRO to very end.
-
- * marker.c (verify_bytepos): New function.
-
- * intervals.c (set_intervals_multibyte_1): When becoming
- multibyte, adjust right and left child sizes to a whole set of
- characters. If an interval gets zero total-length, delete it.
- If an interval consists of just its children, delete one of them.
-
- * intervals.h (CHECK_TOTAL_LENGTH): New macro.
- * intervals.c: Add many calls to CHECK_TOTAL_LENGTH.
-
- * alloc.c (VALIDATE_LISP_STORAGE): Macro deleted.
- All calls deleted.
- (lisp_malloc): Do the work here directly.
-
-2003-04-06 Gareth Jones <[email protected]> (tiny change)
-
- * fns.c (Flength): Return SUB_CHAR_TABLE_ORDINARY_SLOTS for sub
- char tables.
-
-2003-04-04 Kenichi Handa <[email protected]>
-
- * editfns.c (Fformat): Use a copy of FORMAT string so that we can
- destructively change "%S" to "%s".
-
-2003-04-03 Miles Bader <[email protected]>
-
- * xfaces.c (choose_face_font): Make sure *NEEDS_OVERSTRIKE is
- always set.
-
-2003-04-01 Dave Love <[email protected]>
-
- * xfns.c (xpm_lookup_color): Grok "opaque".
-
-2003-03-31 Andrew Choi <[email protected]>
-
- * frame.c (x_report_frame_params) [HAVE_CARBON]: Do not report
- parent window ID.
-
- * macfns.c (syms_of_macfns): Remove call to init_x_parm_symbols.
-
- * macterm.h (struct mac_output): Define x_pixels_diff and
- y_pixels_diff.
-
-2003-03-31 Juanma Barranquero <[email protected]>
-
- * makefile.w32-in ($(BLD)/frame.$(O)): Add dependency on
- blockinput.h and files included from it.
-
-2003-03-31 Kim F. Storm <[email protected]>
-
- The following changes consolidates the common code related to
- frame-parameter handling from the xfns.c, w32fns.c, and macfns.c
- files into frame.c.
-
- * frame.c: Include blockinput.h.
- (Vx_resource_name, Vx_resource_class, Qx_frame_parameter)
- (Qx_resource_name, Qface_set_after_frame_default): Define vars here.
- (Qauto_raise, Qauto_lower, ...): Define all frame parameter
- related vars here.
- (struct frame_parm_table, frame_parms): New table for describing
- frame parameters and their associated Q-variable.
- The order of the parameters corresponds to the sequence of the
- frame_parm_handlers table in redisplay_interface.
- (x_fullscreen_move, x_set_frame_parameters)
- (x_report_frame_params, x_set_fullscreen, x_set_line_spacing)
- (x_set_screen_gamma, x_set_font, x_set_fringe_width)
- (x_set_border_width, x_set_internal_border_width, x_set_visibility)
- (x_set_autoraise, x_set_autolower, x_set_unsplittable)
- (x_set_vertical_scroll_bars, x_set_scroll_bar_width, x_icon_type):
- Generic functions for processing of frame parameters.
- (validate_x_resource_name, xrdb_get_resource, Fx_get_resource)
- (display_x_get_resource, x_get_resource_string): Functions for
- generic access to X resources.
- (x_get_arg, x_frame_get_arg, x_frame_get_and_record_arg)
- (x_default_parameter, Fx_parse_geometry): Functions for generic
- access to frame parameters.
- (x_figure_window_size): Generic calculation of frame size.
- Fixed to add space needed for tool bar. Also setup size_hint_flags.
- (syms_of_frame): Intern and staticpro frame parameter variables.
- Defvar_lisp Vx_resource_class and Vx_resource_name here.
- Defsubr Sx_get_resource and Sx_parse_geometry.
-
- * frame.h (Qauto_raise, Qauto_lower, ...): Declare extern all frame
- parameter related vars defined in frame.c.
- (EMACS_CLASS): Define here.
- (enum FULLSCREEN_*): Define here.
- (x_set_scroll_bar_default_width, x_wm_set_icon_position)
- (x_set_offset, x_new_font, x_new_fontset): Add prototypes.
- (x_fullscreen_adjust, x_set_frame_parameters, x_report_frame_params)
- (x_set_fullscreen, x_set_line_spacing, x_set_screen_gamma, x_set_font)
- (x_set_fringe_width, x_set_border_width, x_set_internal_border_width)
- (x_set_visibility, x_set_autoraise, x_set_autolower)
- (x_set_unsplittable, x_set_vertical_scroll_bars)
- (x_set_scroll_bar_width, x_icon_type, validate_x_resource_name)
- (x_figure_window_size): Add prototypes.
-
- * dispextern.h (frame_parm_handler): New typedef.
- (struct redisplay_interface): New member frame_parm_handlers.
- (enum resource_types): Move declaration here.
- (x_get_arg, x_frame_get_arg, x_frame_get_and_record_arg)
- (x_default_parameter): Add prototypes.
-
- * window.c: Remove extern decl for frame parameter vars.
- (change_window_heights): New generic function;
- replaces x_change_window_heights. All users changed.
-
- * window.h (change_window_heights): Add prototype.
-
- * xfaces.c: Remove extern decl for frame parameter vars.
-
- * xterm.h (EMACS_CLASS): Remove. Use generic define.
- (struct w32_display_info): Fix type of xrdb member.
- (enum FULLSCREEN_*): Remove.
- Remove prototypes for generic functions (in frame.h).
-
- * xfns.c (Qauto_raise, Qauto_lower, ...): Remove vars for frame
- parameters now defined in frame.h and frame.c.
- (Vx_resource_name): Remove. Use generic var.
- (enum x_frame_parms): Remove (bogus, unused enum).
- (check_x_display_info): Make non-static (for frame.c).
- (struct x_frame_parm_table, x_frame_parms): Remove.
- (init_x_parm_symbols, x_set_frame_parameters, x_report_frame_params)
- (x_set_line_spacing, x_set_screen_gamma, x_icon_type, x_set_font)
- (x_set_border_width, x_set_internal_border_width, x_set_visibility)
- (x_change_window_heights, x_set_autoraise, x_set_autolower)
- (x_set_vertical_scroll_bars, x_set_scroll_bar_width)
- (validate_x_resource_name, Fx_get_resource, x_get_resource_string)
- (x_default_parameter, Fx_parse_geometry, x_figure_window_size):
- Remove. Use generic functions instead.
- (enum resource_types): Remove.
- (x_set_scroll_bar_default_width): New global function (for frame.c).
- (Fx_create_frame): Depend on x_figure_window_size to add space for
- toolbar and setup size_hint_flags.
- (x_frame_parm_handlers): New table for redisplay_interface.
- (syms_of_xfns): Don't intern/staticpro removed vars.
-
- * xterm.c: Remove unnecessary extern declarations.
- (x_fullscreen_adjust): Remove. Use generic instead.
- (x_redisplay_interface): Add x_frame_parm_handlers member.
-
- * w32gui.h (XrmDatabase): New (dummy) typedef.
-
- * w32term.h (EMACS_CLASS): Remove. Use generic define.
- (struct w32_display_info): Fix type of xrdb member.
- (enum FULLSCREEN_*): Remove.
- (x_fullscreen_adjust): Remove prototype.
-
- * w32fns.c (Qauto_raise, Qauto_lower, ...): Remove vars for frame
- parameters now defined in frame.h and frame.c.
- (Vx_resource_name): Remove. Use generic var.
- (enum x_frame_parms): Remove (bogus, unused enum).
- (check_x_display_info): Make non-static (for frame.c).
- (struct x_frame_parm_table, x_frame_parms): Remove.
- (init_x_parm_symbols, x_set_frame_parameters, x_report_frame_params)
- (x_set_line_spacing, x_set_screen_gamma, x_icon_type, x_set_font)
- (x_set_border_width, x_set_internal_border_width, x_set_visibility)
- (x_change_window_heights, x_set_autoraise, x_set_autolower)
- (x_set_vertical_scroll_bars, x_set_scroll_bar_width)
- (validate_x_resource_name, Fx_get_resource, x_get_resource_string)
- (x_default_parameter, Fx_parse_geometry, x_figure_window_size):
- Remove. Use generic functions instead.
- (enum resource_types): Remove.
- (x_set_scroll_bar_default_width): New global function (for frame.c).
- (Fx_create_frame): Depend on x_figure_window_size to add space for
- toolbar and setup size_hint_flags.
- (w32_frame_parm_handlers): New table for redisplay_interface.
- (syms_of_w32fns): Don't intern/staticpro removed vars.
-
- * w32term.c: Remove unnecessary extern declarations.
- (x_fullscreen_adjust): Remove. Use generic instead.
- (x_redisplay_interface): Add w32_frame_parm_handlers member.
-
- * w32reg.c (x_get_string_resource): Use XrmDatabase.
-
- * macgui.h (XrmDatabase): New (dummy) typedef.
-
- * macterm.h (EMACS_CLASS): Remove.
- (struct mac_display_info): Add xrdb member.
- (struct mac_output): Add want_fullscreen member.
-
- * macfns.c (Qauto_raise, Qauto_lower, ...): Remove vars for frame
- parameters now defined in frame.h and frame.c.
- (Vx_resource_name): Remove. Use generic var.
- (check_x_display_info): Make non-static (for frame.c).
- (struct x_frame_parm_table, x_frame_parms): Remove.
- (init_x_parm_symbols, x_set_frame_parameters, x_report_frame_params)
- (x_set_line_spacing, x_set_screen_gamma, x_icon_type, x_set_font)
- (x_set_border_width, x_set_internal_border_width, x_set_visibility)
- (x_change_window_heights, x_set_autoraise, x_set_autolower)
- (x_set_vertical_scroll_bars, x_set_scroll_bar_width)
- (validate_x_resource_name, Fx_get_resource, x_get_resource_string)
- (x_default_parameter, Fx_parse_geometry, x_figure_window_size):
- Remove. Use generic functions instead.
- (enum resource_types): Remove.
- (x_set_scroll_bar_default_width): New global function (for frame.c).
- (mac_frame_parm_handlers): New table for redisplay_interface.
- (syms_of_macfns): Don't intern/staticpro removed vars.
-
- * macterm.c: Remove unnecessary extern declarations.
- (x_redisplay_interface): Add mac_frame_parm_handlers member.
-
- * Makefile.in (frame.o): Add dependency on blockinput.h and files
- included from it (atimer.h and systime.h).
-
-2003-03-30 Andreas Schwab <[email protected]>
-
- * xdisp.c (x_insert_glyphs): Fix swapped width and height
- parameters for shift_glyphs_for_insert.
-
- * macterm.c (x_redisplay_interface): Add missing entry for
- draw_vertical_window_border.
-
-2003-03-29 Kai Gro,A_(Bjohann <[email protected]>
-
- * fileio.c (Fexpand_file_name): In the no-handler case, after
- expanding, look again for a handler and invoke it. This is needed
- for filenames like "/foo/../user@host:/bar/../baz" -- the first
- expansion produces "/user@host:/bar/../baz" which needs to be
- expanded again for the finame result "/user@host:/baz".
-
-2003-03-28 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_tool_bar_item_expose_callback): Reduce size
- of area to be redrawn for better performance.
-
-2003-03-28 Stefan Monnier <[email protected]>
-
- * xterm.c (take_vertical_position_into_account): Remove.
- (xt_action_hook): Call set_vertical_scroll_bar if needed.
- (XM_SB_MIN, XM_SB_RANGE): Remove (min is now set to 0).
- (xm_scroll_callback, x_create_toolkit_scroll_bar)
- (x_set_toolkit_scroll_bar_thumb): Simplify.
- (x_scroll_bar_expose): Only compile if !USE_TOOLKIT_SCROLL_BARS.
- (XTread_socket): Remove unused var.
- (x_make_frame_invisible): Replace goto with else.
-
- * xdisp.c (set_vertical_scroll_bar): New fun.
- (redisplay_window): Use it.
-
-2003-03-26 Richard M. Stallman <[email protected]>
-
- * xdisp.c (update_tool_bar): Recompute tool bar if
- update_mode_lines is set. Set w->update_mode_line
- only if the tool bar contents actually change.
- (update_menu_bar): Undo previous change.
-
-2003-03-26 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_resize_widgets): Don't call xg_frame_cleared.
- (xg_frame_set_char_size): Calculate scroll bar width before frame
- width. Call SET_FRAME_GARBAGED and cancel_mouse_face.
- (xg_separator_p): Check for all documented separator types.
- (xg_update_scrollbar_pos): Variable gheight not needed, use height.
- (update_frame_tool_bar): Don't call gdk_window_process_all_updates.
-
- * xdisp.c (update_menu_bar): Set w->update_mode_line to Qt
- so tool bar gets updated.
-
-2003-03-26 Stefan Monnier <[email protected]>
-
- * data.c (store_symval_forwarding): Re-instate part of the code
- that was deleted with too much enthusiasm.
-
-2003-03-25 Stefan Monnier <[email protected]>
-
- * data.c (store_symval_forwarding): Delete special read-only
- hack for type == -1, since we now use ->constant instead.
- (Fkill_local_variable): Don't use XBUFFER if it can be nil.
-
- * buffer.c (overlays_in): Declare static.
- (syms_of_buffer) <enable-multibyte-characters>: Use the symbol's
- `constant' field rather than the variable's `type' field.
-
-2003-03-24 Andrew Choi <[email protected]>
-
- * config.in [MAC_OSX]: Do not redefine bcopy, bzero, and bcmp.
-
- * dispextern.h [HAVE_CARBON]: Include Carbon.h.
-
- * fns.c [MAC_OSX]: Do not redefine vector.
-
- * keyboard.c [MAC_OSX]: Handle SIGINT with interrupt_signal.
-
- * macgui.h: Remove definition of No_Cursor.
-
- * macterm.h: Include Carbon.h. Replace (struct Cursor *) by Cursor.
-
- * xdisp.c: Define No_Cursor.
- (x_write_glyphs, notice_overwritten_cursor)
- (draw_phys_cursor_glyph, note_mode_line_or_margin_highlight)
- (note_mouse_highlight): Remove Mac-specific code.
- (note_mouse_highlight): Use bcmp instead of == to compare Cursors.
-
-2003-03-24 John Paul Wallington <[email protected]>
-
- * xdisp.c (redisplay_window): If mini window's buffer is not
- empty, then redisplay it like other windows.
-
-2003-03-23 Kim F. Storm <[email protected]>
-
- * w32term.c (w32_draw_window_cursor): Fix last change.
-
-2003-03-23 Kenichi Handa <[email protected]>
-
- * alloc.c (make_string_from_bytes, make_specified_string):
- Add `const' for the arg CONTENTS.
-
- * lisp.h (make_string_from_bytes, make_specified_string):
- Prototypes adjusted.
-
-2003-03-23 Jan Dj,Ad(Brv <[email protected]>
-
- * xdisp.c (get_glyph_string_clip_rect): Remove ; at end of #endif.
-
- * gtkutil.h: Take two more arguments to xg_update_scrollbar_pos.
- (XG_SB_RANGE): New define.
-
- * gtkutil.c (xg_fixed_handle_expose): New function.
- (xg_create_frame_widgets): Call xg_fixed_handle_expose for
- expose events.
- (xg_update_scrollbar_pos): Take two more arguments, left and width
- of scroll bar including borders.
- Clear left and right part outside scroll bar separately as some
- themes have bars that are not an even number of pixels.
- Don't set reallocate_redraws, don't call
- gdk_window_process_all_updates.
- (xg_set_toolkit_scroll_bar_thumb): Upper value is fixed,
- so no need to change it. Calculate size and value with XG_SB_RANGE.
-
- * xterm.c (x_scroll_bar_create, XTset_vertical_scroll_bar):
- Pass left and width of scroll bar including borders to
- xg_update_scrollbar_pos.
-
-2003-03-22 Thien-Thi Nguyen <[email protected]>
-
- * Makefile.in: Make sure space precedes end-of-line backslashes.
-
-2003-03-22 Kim F. Storm <[email protected]>
-
- * xdisp.c (pixel_to_glyph_coords, glyph_to_pixel_coords):
- Add generic versions here. Remove system specific versions
- defined elsewhere.
-
- * dispextern.h (pixel_to_glyph_coords, glyph_to_pixel_coords):
- Add prototypes.
-
- * xterm.h (STORE_NATIVE_RECT): New macro.
-
-2003-03-21 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_glyph_string_clip_rect):
- Use FRAME_INTERNAL_BORDER_WIDTH.
-
- * dispextern.h (struct redisplay_interface): Add active_p
- argument to draw_window_cursor member. All uses changed.
-
-2003-03-21 Kim F. Storm <[email protected]>
-
- The following changes consolidate code related to writing and
- inserting glyphs, exposing frame, the tool bar, the mouse face,
- the output cursor, and help echo from xterm.c, w32term.c and
- macterm.c into xdisp.c. It also generalizes the use of the
- window_part enum instead of using numeric values throughout.
-
- * xdisp.c: Consolidate gui-independent code here.
- Include keymap.h.
- (Qhelp_echo): Import.
- (mouse_autoselect_window, x_stretch_cursor_p): Declare here.
- (help_echo_string, help_echo_window, help_echo_object)
- (previous_help_echo_string, help_echo_pos): Declare here.
- (output_cursor, last_mouse_frame, last_tool_bar_item): Declare here.
- (estimate_mode_line_height): Define here. Handle windowing
- systems directly (without using estimate_mode_line_height_hook).
- (x_y_to_hpos_vpos, get_tool_bar_item, note_tool_bar_highlight):
- (update_window_cursor, update_cursor_in_window_tree)
- (fast_find_position, fast_find_string_pos)
- (note_mode_line_highlight, note_mode_line_or_margin_highlight)
- (expose_area, expose_line, expose_overlaps, expose_window)
- (expose_window_tree, phys_cursor_in_rect_p): New generic versions;
- declared static as they are only used locally in xdisp.c.
- (draw_glyphs): Rename from x_draw_glyphs and make static.
- (tool_bar_item_info, notice_overwritten_cursor): Make static.
- (frame_to_window_pixel_xy, get_glyph_string_clip_rect)
- (set_output_cursor, x_cursor_to, handle_tool_bar_click)
- (x_write_glyphs, x_insert_glyphs, x_clear_end_of_line):
- (x_fix_overlapping_area, draw_phys_cursor_glyph, erase_phys_cursor)
- (display_and_set_cursor, x_update_cursor, x_clear_cursor)
- (show_mouse_face, clear_mouse_face, cursor_in_mouse_face_p)
- (note_mouse_highlight, x_clear_window_mouse_face)
- (cancel_mouse_face, x_draw_vertical_border, expose_frame)
- (x_intersect_rectangles): New generic functions for use by xdisp.c
- and GUI front-ends.
- (syms_of_xdisp): Initialize and staticpro help_echo* variables.
- Defvar_bool "x-streach-cursor" and "mouse-autoselect-window" here.
-
- * dispextern.h (Display_Info): Generic typedef for *_display_info.
- (NativeRectangle): Generic typedef for rectangle type.
- (enum window_part): Move here from window.c.
- (struct redisplay_interface): New members flush_display_optional,
- define_frame_cursor, clear_frame_area, draw_window_cursor,
- draw_vertical_window_border, shift_glyphs_for_insert.
- Rename member clear_mouse_face to clear_window_mouse_face.
- (estimate_mode_line_height_hook): Remove hook.
- (auto_raise_tool_bar_buttons_p): Don't declare extern.
- (tool_bar_item_info): Remove prototype.
- (help_echo_string, help_echo_window, help_echo_object)
- (previous_help_echo_string, help_echo_pos)
- (last_mouse_frame, last_tool_bar_item, mouse_autoselect_window):
- (x_stretch_cursor_p, output_cursor): Declare extern.
- (x_draw_glyphs, notice_overwritten_cursor): Remove prototypes.
- (x_write_glyphs), x_insert_glyphs, x_clear_end_of_line)
- (x_fix_overlapping_area, draw_phys_cursor_glyph, erase_phys_cursor)
- (display_and_set_cursor, set_output_cursor, x_cursor_to)
- (x_update_cursor, x_clear_cursor, x_draw_vertical_border)
- (frame_to_window_pixel_xy, get_glyph_string_clip_rect)
- (note_mouse_highlight, x_clear_window_mouse_face, cancel_mouse_face)
- (handle_tool_bar_click, clear_mouse_face, show_mouse_face)
- (cursor_in_mouse_face_p, expose_frame, x_intersect_rectangles):
- Add prototypes.
- (mode_line_string, marginal_area_string): Fix prototypes.
-
- * window.c (enum window_part): Move to dispextern.h.
- (coordinates_in_window): Use enum window_part member names
- instead of numbers to describe return value.
- (struct check_window_data): Change part member to window_part.
- (check_window_containing): Return window_part unaltered.
- (window_from_coordinates): Change part arg from int to enum
- window_part. Allow part arg to be null. All users changed.
-
- * window.h (window_from_coordinates): Fix prototype.
-
- * term.c (estimate_mode_line_height): Move to xdisp.c.
-
- * keyboard.c (make_lispy_event): Use enum window_part.
-
- * dispnew.c (mode_line_string, marginal_area_string): Use enum
- window_part instead of int in arg list. Users changed.
-
- * xterm.h (No_Cursor): Declare as None for X.
- (struct mac_output): Replace member cross_cursor by hand_cursor.
-
- * xterm.c: Remove consolidated defines and code.
- (BETWEEN): Remove unused macro.
- (x_draw_vertical_window_border, x_shift_glyphs_for_insert)
- (x_define_frame_cursor, x_clear_frame_area)
- (x_draw_window_cursor): New X-specific functions for RIF.
- (x_redisplay_interface): Add new members.
-
- * xfns.c: Setup and use hand_cursor instead of cross_cursor.
-
- * w32term.h (struct w32_output): Remove cross_cursor member.
-
- * w32term.c: Remove consolidated defines and code.
- (BETWEEN): Remove unused macro.
- (w32_draw_vertical_window_border, w32_shift_glyphs_for_insert)
- (w32_define_frame_cursor, w32_clear_frame_area)
- (w32_draw_window_cursor): New W32-specific functions for RIF.
- (w32_redisplay_interface): Add new members.
-
- * w32gui.h (No_Cursor): Define as 0 for W32.
- (XRectangle): Add X compatible rectangle type.
- (NativeRectangle): Declare as RECT for W32.
- (CONVERT_TO_XRECT, CONVERT_FROM_XRECT, STORE_NATIVE_RECT): New macros.
-
- * w32fns.c: Remove setup of cross_cursor (already has hand_cursor).
-
- * w32console.c: Remove consolidated defines and code.
-
- * msdos.h (Display_Info): Add generic typedef.
-
- * msdos.c: Remove consolidated defines and code.
- (IT_note_mouse_highlight, dos_rawgetc): Use enum window_part.
-
- * macterm.h (struct mac_output): Replace member cross_cursor by
- hand_cursor.
- (activate_scroll_bars, deactivate_scroll_bars): Add prototypes.
-
- * macterm.c: Remove consolidated defines and code.
- (BETWEEN): Remove unused macro.
- (mac_draw_vertical_window_border, mac_shift_glyphs_for_insert)
- (mac_define_frame_cursor, mac_clear_frame_area)
- (mac_draw_window_cursor): New Mac-specific functions for RIF.
- (x_redisplay_interface): Add new members.
-
- * macgui.h (No_Cursor): Define as 0 for Mac.
- (XRectangle): Add X compatible rectangle type.
- (NativeRectangle): Declare as Rect for Mac.
- (CONVERT_TO_XRECT, CONVERT_FROM_XRECT, STORE_NATIVE_RECT): New macros.
-
- * macfns.c (x_set_mouse_color): Setup hand_cursor.
- (x_set_cursor_color): Use x_display_and_set_cursor.
-
- * Makefile.in (xdisp.o): Add dependency on blockinput.h and files
- included from it. Add dependency on keymap.h.
-
- * makefile.w32-in (xdisp.o): Add dependency on keymap.h.
-
-2003-03-21 Kenichi Handa <[email protected]>
-
- * fileio.c (Fexpand_file_name): Fix previous change.
-
-2003-03-19 Kenichi Handa <[email protected]>
-
- * fileio.c (Ffile_name_directory): Reconstruct file name by
- make_specified_string.
- (Ffile_name_nondirectory, Ffile_name_as_directory)
- (Fdirectory_file_name, Fexpand_file_name)
- (Fsubstitute_in_file_name): Likewise.
- (Fread_file_name): Compare decoded homedir with DIR and
- DEFAULT_FILENAME.
-
- * alloc.c (make_specified_string): If NCHARS is negative, count
- the number of characters.
-
-2003-03-18 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_frame_cleared): Call gtk_widget_queue_draw for
- all widgets.
-
- * gtkutil.h: Removed xg_ignore_next_thumb.
-
-2003-03-18 Kenichi Handa <[email protected]>
-
- * coding.c (Vchar_coding_system_table): Remove this variable.
- (Vcoding_system_safe_chars): New variable.
- (intersection): Remove this function.
- (find_safe_codings): Don't use Vchar_coding_system_table, but try
- all codings in SAFE_CODINGS.
- (Ffind_coding_systems_region_internal): Adjust for the change of
- find_safe_codings. Get generic coding systems from
- Vcoding_system_safe_chars.
- (Fdefine_coding_system_internal): New function.
- (syms_of_coding): Defsubr Sdefine_coding_system_internal.
- Initialize and staticpro Vcoding_system_safe_chars.
-
-2003-03-18 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_set_toolkit_scroll_bar_thumb): Check if new values
- equal old values before updating.
-
- * xterm.c (xg_scroll_callback): Remove xg_ignore_next_thumb.
-
- * gtkutil.c (xg_initialize): Remove xg_ignore_next_thumb.
-
-2003-03-17 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c: Removed handle_fixed_child, struct xg_last_sb_pos.
- (xg_resize_widgets): Don't call foreach(handle_fixed_child).
- (xg_gtk_scroll_destroy): Remove free of struct xg_last_sb_pos.
- (scroll_bar_button_cb): Set bar->dragging to nil on button release.
- (xg_create_scroll_bar): Pass bar to button event callback.
- (xg_find_top_left_in_fixed): New function.
- (xg_update_scrollbar_pos): Don't call gdk_window_clear on
- whole scroll bar area. Get old position with
- xg_find_top_left_in_fixed, calculate and only clear needed areas.
- (xg_set_toolkit_scroll_bar_thumb): Do not adjust scroll bar if
- dragging is in progress. Calculate whole as for Motif.
- Remove code that saved last values. Call gtk_range functions to
- set scroll bar sizes.
-
- * gtkutil.h: Removed xg_ignore_next_thumb.
-
-2003-03-17 Juanma Barranquero <[email protected]>
-
- * makefile.w32-in ($(BLD)/xdisp.$(O)): Add dependency on blockinput.h
- and files included from it.
-
-2003-03-18 Stefan Monnier <[email protected]>
-
- * keymap.c (accessible_keymaps_1): Break cycles but without preventing
- multiple occurrences of the same keymap under different prefixes.
- (Faccessible_keymaps): Remove code redundant since 1994-08-03T07:39:[email protected].
-
-2003-03-16 Jason Rumney <[email protected]>
-
- * w32gui.h: Use HDC for Display.
-
- * w32term.c (w32_encode_char): Prevent double-byte chars from
- crashing Emacs.
-
- * w32fns.c (jpeg_load, png_load, slurp_file): Read image files
- as binary.
-
-2003-03-16 Juanma Barranquero <[email protected]>
-
- * xdisp.c (x_produce_glyphs): Use FRAME_BASELINE_OFFSET.
-
-2003-03-16 Kim F. Storm <[email protected]>
-
- The following changes consolidate some of the gui-independent
- parts of the processing and drawing of "glyph strings" from
- xterm.c, w32term.c, and macterm.c into xdisp.c.
-
- * dispextern.h (struct glyph): Reduce face_id member from 22 to
- 21 bits (this reduces number of faces from 4M to 2M).
- Replace W32 specific w32_font_type member (2 bits) by generic
- font_type member (3 bits) for portability.
- (FONT_TYPE_UNKNOWN): New define, default for font_type member.
- (enum draw_glyphs_face): Define here.
- (struct glyph_string): Define here. Merge W32 and X versions.
- (struct redisplay_interface): New members per_char_metric,
- encode_char, compute_glyph_string_overhangs, draw_glyph_string.
- (VCENTER_BASELINE_OFFSET): Define here.
- (dump_glyph_string, x_get_glyph_overhangs, x_produce_glyphs)
- (x_draw_glyphs, notice_overwritten_cursor): Declare prototypes here.
-
- * xdisp.c: Consolidate gui-independent "glyph string" code here.
- (dump_glyph_string): Moved here.
- (init_glyph_string, append_glyph_string_lists, append_glyph_string)
- (prepend_glyph_string_lists, get_glyph_face_and_encoding)
- (fill_composite_glyph_string, fill_glyph_string)
- (fill_image_glyph_string, fill_stretch_glyph_string)
- (left_overwritten, left_overwriting, right_overwritten)
- (right_overwriting, get_char_face_and_encoding)
- (set_glyph_string_background_width, compute_overhangs_and_x)
- (append_glyph, append_composite_glyph, produce_image_glyph)
- (take_vertical_position_into_account, append_stretch_glyph)
- (produce_stretch_glyph): New generic functions (based on X version).
- Call platform specific functions through rif.
- (INIT_GLYPH_STRING): New macro, hides W32 details.
- (BUILD_STRETCH_GLYPH_STRING, BUILD_IMAGE_GLYPH_STRING)
- (BUILD_CHAR_GLYPH_STRINGS, BUILD_COMPOSITE_GLYPH_STRING)
- (BUILD_GLYPH_STRINGS): Generic macros (based on X version).
- (x_draw_glyphs, x_get_glyph_overhangs, x_produce_glyphs)
- (notice_overwritten_cursor):
- Generic functions exported to platform modules. Users changed.
-
- * xterm.h (FONT_DESCENT, FRAME_X_OUTPUT, FRAME_BASELINE_OFFSET)
- (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE)
- (STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2):
- New macros for consolidated code.
-
- * xterm.c: Remove consolidated defines and code.
- (x_per_char_metric, x_encode_char)
- (x_compute_glyph_string_overhangs): Adapt to RIF requirements.
- (x_redisplay_interface): Add new members.
-
- * w32gui.h (Display): Add dummy typedef for consolidation.
- (XChar2b): Define alias for wchar_t for consolidation.
- (STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2): New macros.
-
- * w32term.h (FRAME_X_OUTPUT, FRAME_X_WINDOW, FRAME_X_DISPLAY)
- (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE):
- New macros for consolidation.
-
- * w32term.c: Remove consolidated defines and code.
- (BUILD_WCHAR_T, BYTE1, BYTE2): Macros removed; callers changed
- to use STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2 instead.
- (w32_per_char_metric): Change font_type arg to int for RIF.
- (w32_encode_char): Return int according to RIF requirements.
- (w32_compute_glyph_string_overhangs): Adapt to RIF.
- (w32_get_glyph_overhangs): New function for RIF. Uses generic
- x_get_glyph_overhangs.
- (w32_redisplay_interface): Add new members.
-
- * macgui.h (XChar2b): Move typedef here for consolidation.
- (STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2): New macros.
-
- * macterm.h (FRAME_X_OUTPUT, FRAME_X_WINDOW, FRAME_X_DISPLAY):
- (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE): New macros for
- consolidation.
-
- * macterm.c: Remove consolidated defines and code.
- (mac_per_char_metric): New function for RIF.
- (mac_encode_char): Adapt to new RIF requirements.
- (mac_compute_glyph_string_overhangs): Adapt for RIF.
- (x_redisplay_interface): Add new members.
-
-2003-03-15 Stefan Monnier <[email protected]>
-
- * keymap.c (Vmenu_events): New var.
- (syms_of_keymap): Initialize it.
- (where_is_internal): Check more carefully what is a menu event.
-
-2003-03-14 Richard M. Stallman <[email protected]>
-
- * lread.c (read1): After #!, exit loop on eof.
-
-2003-03-14 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.h: Add declaration for xg_frame_cleared.
-
- * xterm.c (x_clear_frame): Call xg_frame_cleared for GTK.
-
- * gtkutil.c (struct xg_last_sb_pos): New structure.
- (handle_fixed_child): New function.
- (xg_resize_widgets): Call handle_fixed_child on all scroll bar widgets
- and force a redraw on them.
- (xg_gtk_scroll_destroy): Free struct xg_last_sb_pos also.
- (xg_create_scroll_bar): Add struct xg_last_sb_pos to scroll bar
- so we can avoid unneeded redraws.
- (xg_update_scrollbar_pos): Invalidate data in xg_last_sb_pos
- and force a redraw on the scroll bar.
- (xg_set_toolkit_scroll_bar_thumb): Do not change/redraw scroll bar
- if xg_last_sb_pos shows the positions are up to date.
- (xg_frame_cleared): New function.
-
-2003-03-13 Kenichi Handa <[email protected]>
-
- * coding.c (Fdetect_coding_region): Fix docstring.
- (Fdetect_coding_string): Fix docstring.
-
-2003-03-13 Andreas Schwab <[email protected]>
-
- * gtkutil.c: Add prototype for create_menus.
-
- * data.c (long_to_cons): Fix type of top.
-
- * xselect.c (selection_data_to_lisp_data): Use int instead of
- long for an integer of size 4.
-
- * gtkutil.c (xg_update_frame_menubar): Add missing return value.
- (xg_tool_bar_help_callback): Likewise.
-
-2003-03-12 Andreas Schwab <[email protected]>
-
- * xterm.c (x_term_init) [USE_GTK]: Fix typo.
-
-2003-03-12 Kim F. Storm <[email protected]>
-
- The following changes consolidate the fringe handling from
- xterm.c, w32term.c, and macterm.c into xdisp.c.
-
- * xdisp.c: Consolidate fringe handling code here.
- (left_bits, right_bits, continued_bits, continuation_bits)
- (ov_bits, zv_bits): Define fringe bitmaps.
- (fringe_bitmaps): New array holding fringe bitmaps.
- (draw_fringe_bitmap): Draw a specific bitmap; call display
- specific drawing routine via rif->draw_fringe_bitmap.
- (draw_row_fringe_bitmaps): Generic replacement for
- x_draw_row_fringe_bitmaps; all callers changed.
- (compute_fringe_widths): Generic replacement for
- x_compute_fringe_widths; all callers changed.
-
- * dispextern.h (enum fringe_bitmap_type): Define here.
- (struct fringe_bitmap, struct draw_fringe_bitmap_params): New.
- (fringe_bitmaps): Declare extern.
- (struct redisplay_interface): New member draw_fringe_bitmap.
- (draw_row_fringe_bitmaps, compute_fringe_widths): Declare extern.
-
- * xterm.c: Remove generic fringe code.
- (x_draw_fringe_bitmap): Only perform actual fringe drawing.
- (x_redisplay_interface): Add x_draw_fringe_bitmap member.
-
- * w32term.c: Remove generic fringe code.
- (w32_draw_fringe_bitmap): Only perform actual fringe drawing.
- (w32_redisplay_interface): Add w32_draw_fringe_bitmap member.
-
- * macterm.c: Remove generic fringe code.
- (x_draw_fringe_bitmap): Only perform actual fringe drawing.
- (x_redisplay_interface): Add x_draw_fringe_bitmap member.
-
-2003-03-11 Stefan Monnier <[email protected]>
-
- * print.c (Fprin1_to_string): Return unibyte string if possible.
-
-2003-03-09 David Kastrup <[email protected]>
-
- * process.c (read_process_output): We have allocated enough space
- for readmax and carryover, so actually use the alloted space.
-
-2003-03-09 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c (make_lispy_event): Extend mouse_syms if needed for
- toolkit scrollbar click.
-
- * xterm.c (x_window_to_scroll_bar): Call xg_get_scroll_id_for_window
- for USE_GTK.
- (x_scroll_bar_handle_click): Use this function for toolkit scrollbars
- also.
- (handle_one_xevent): ButtonPress/Release: If event is for a toolkit
- scrollbar and control is pressed, call x_scroll_bar_handle_click.
-
- * gtkutil.h (xg_get_scroll_id_for_window): Declare.
-
- * gtkutil.c (xg_get_scroll_id_for_window): New function.
- (xg_tool_bar_item_expose_callback): New function.
- (xg_tool_bar_expose_callback): Call update_frame_tool_bar.
- (xg_create_tool_bar): Connect xg_tool_bar_expose_callback to expose
- on the tool bar widget.
- (update_frame_tool_bar): Connect xg_tool_bar_item_expose_callback
- to expose on the tool bar item widgets.
-
-2003-03-08 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): Compare pixmap ID instead of
- struct image* when deciding to update (struct image* may have been
- deleted from the image cache).
-
- * xterm.c (handle_one_xevent): Pass ReparentNotify to Xt even if
- the event isn't for a frame (i.e. for dialogs).
-
-2003-03-07 Kenichi Handa <[email protected]>
-
- * coding.c (CODING_ADD_COMPOSITION_COMPONENT): If the number of
- composition components reaches the limit, terminate composing.
- (COMPOSITION_OK): New macro.
- (detect_coding_iso2022): Use it if an escape sequence for
- composition is found.
- (coding_restore_composition): Adjust the number of composition
- components if it is not sane.
-
-2003-03-06 Juanma Barranquero <[email protected]>
-
- * w32term.h (struct w32_display_info): Add xrdb member to support
- passing resources via -xrm on Windows.
-
- * w32term.c (w32_make_rdb): New function.
- (w32_term_init): Use it to initialize xrdb member of w32_display_info
- struct. Delete leftover code.
-
- * w32fns.c (Fx_get_resource, x_get_resource_string): Pass xrdb to check
- for resources passed on the command line.
-
- * w32reg.c (w32_get_rdb_resource): New function.
- (x_get_string_resource): Use it, so resources passed with -xrm
- supercede the ones in the registry.
-
-2003-03-04 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_detect_focus_change): Call x_any_window_to_frame
- instead of x_top_window_to_frame.
-
-2003-03-03 Jan Dj,Ad(Brv <[email protected]>
-
- * xsmfns.c (smc_save_yourself_CB): Add --no-splash to options
- when restarting Emacs.
-
-2003-03-03 Richard M. Stallman <[email protected]>
-
- * buffer.c (Fkill_buffer): Use Frun_hook_with_args_until_failure
- to run kill-buffer-query-functions.
- (Qkill_buffer_query_functions): New var.
- (syms_of_buffer): Init and staticpro it.
-
-2003-03-02 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h (XSync): Define as gdk_window_process_all_updates for GTK.
-
-2003-02-25 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Fix infinite loop in redisplay.
- If centering point failed to make whole line visible and vscroll
- is non-zero, disable vscroll and try centering point again.
-
- * lread.c (read1): Accept `single space' syntax like (? x).
-
-2003-02-25 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c (cancel_hourglass_unwind): Surround with
- #ifdef HAVE_X_WINDOWS.
-
-2003-02-25 Kenichi Handa <[email protected]>
-
- * buffer.c (Fset_buffer_multibyte): Pay attention to the buffer
- process only when "subprocesses" is defined.
-
-2003-02-24 Stefan Monnier <[email protected]>
-
- * syntax.c (back_comment): Only check nestedness of 2nd char if needed.
-
-2003-02-24 Juanma Barranquero <[email protected]>
-
- * callint.c (fix_command): Declare as static void and move before
- Fcall_interactively.
-
- * xdisp.c (Qwhen): Declare external; it's now defined in callint.c.
- (syms_of_xdisp): Don't initialize Qwhen.
-
-2003-02-23 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c (cancel_hourglass_unwind): New function.
- (command_loop_1): Cancel hourglass with unwind-protect.
-
-2003-02-23 Richard M. Stallman <[email protected]>
-
- * callint.c (fix_command): New subroutine, from Fcall_interactively.
- Detect (when ... (region-beginning)) etc.
- (Fcall_interactively): Call fix_command.
- (Qif, Qwhen): New variables.
- (syms_of_callint): Init and staticpro them.
-
- * regex.c (print_partial_compiled_pattern): Output to stderr.
-
-2003-02-23 Kai Gro,A_(Bjohann <[email protected]>
-
- * dired.c (directory_files_internal): Don't expand directory.
- (Fdirectory_files, Fdirectory_files_and_attributes): Do it here
- instead. From Lars Hansen <[email protected]>.
-
-2003-02-22 Stefan Monnier <[email protected]>
-
- * fns.c (string_to_multibyte): Remove unused var i.
- (Flanginfo): Fix int/Lisp_Object mixup.
- (void_call2): New fun.
- (Fmap_char_table): Use it in place of call2.
-
- * xfaces.c (x_face_list_fonts): Fix int/Lisp_Object mixup.
-
- * macros.c (Fstart_kbd_macro): Remove redundant assignment.
-
- * keymap.c (copy_keymap_1): Make it static.
-
- * alloc.c (Fgarbage_collect): Don't use XSETFLOAT.
-
-2003-02-22 David Ponce <[email protected]>
-
- * lread.c (Fload): Don't check STRING_MULTIBYTE.
-
-2003-02-21 Jan Dj,Ad(Brv <[email protected]>
-
- * process.h: Removed subtty field from struct Lisp_Process.
-
- * process.c (create_process): Remove setting of subtty.
- (emacs_get_tty_pgrp): New function.
- (Fprocess_running_child_p, process_send_signal):
- Call emacs_get_tty_pgrp instead of ioctl.
- (process_send_signal): Call EMACS_KILLPG if ioctl TIOCSIGSEND fails.
-
-2003-02-21 Kai Gro,A_(Bjohann <[email protected]>
-
- * keymap.c (Fdefine_key): Doc fix.
-
-2003-02-21 Juanma Barranquero <[email protected]>
-
- Port of patch for RC by Klaus Zeitler <[email protected]>.
-
- * s/hpux10.h: Define POLL_INTERRUPTED_SYS_CALL, not
- POLLING_PROBLEM_IN_SELECT.
-
- * s/hpux11.h: Include hpux10-20.h instead of hpux10.h.
- Delete #undef of POLLING_PROBLEM_IN_SELECT.
-
- * s/hpux10-20.h: New file.
-
- * process.c (wait_reading_process_input):
- Use POLL_INTERRUPTED_SYS_CALL, not POLLING_PROBLEM_IN_SELECT.
-
-2003-02-20 Kenichi Handa <[email protected]>
-
- * fontset.c (check_fontset_name): If NAME is nil, return the
- default fontset.
- (override_font_info): New function.
- (Fset_fontset_font): Document that NAME nil means the default fontset.
- (Ffontset_info): If FONTSET is not the default fontset, merge
- FONTSET onto the copy of the default fontset, and work on that
- copy. Document that NAME nil means the default fontset.
- (Ffontset_font): Document that NAME nil means the default fontset.
-
- * process.c (setup_process_coding_systems): If the process's
- in/out descriptor is -1, do nothing.
-
-2003-02-19 Andreas Schwab <[email protected]>
-
- * lisp.h (Fcancel_kbd_macro_events, Fstring_to_multibyte):
- Add prototypes.
-
-2003-02-19 Kenichi Handa <[email protected]>
-
- * xfaces.c (try_alternative_families): Try all scalable fonts if
- Vscalable_fonts_allowed is not Qt.
-
-2003-02-19 Jan Dj,Ad(Brv <[email protected]>
-
- * xfaces.c (x_face_list_fonts): Set *pfonts to 0 if no fonts found.
-
-2003-02-18 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_list_fonts): If maxnames is less than 0, get all font
- names.
-
- * xfaces.c (x_face_list_fonts): Allocate struct font_name here.
- (sorted_font_list): Move allocation of struct font_name to
- x_face_list_fonts.
- (Fx_font_family_list): Set font-list-limit to -1 to get all font names.
- (Fx_list_fonts): Set maxnames to -1 to get all font names.
-
-2003-02-18 Kim F. Storm <[email protected]>
-
- * lread.c (read1): Fix last change.
- "`" is not always special. Allow "?" after a character constant.
-
-2003-02-18 Andrew Choi <[email protected]>
-
- * unexmacosx.c (copy_data_segment): Also copy __cfstring section.
-
-2003-02-18 Andreas Schwab <[email protected]>
-
- * window.c (window_scroll_pixel_based): Move outside a
- multi-glyph character before setting new window start.
-
- * xdisp.c (in_display_vector_p): New function.
- * dispextern.h (in_display_vector_p): Declare.
-
-2003-02-18 Kim F. Storm <[email protected]>
-
- * lread.c (read1): Fix and relax read syntax.
- Recognize "[", ";", "#", and "?" after a dotted-pair dot.
- Only recognize "," after dotted-pair dot if inside backquote.
- Never include "`" or "," (inside backquote) in a symbol.
- Allow dotted-pair dot after a character constant.
- Allow "`" and "," (inside backquote) after a character constant.
-
-2003-02-17 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_tool_bar_expose_callback): New function.
- (xg_create_tool_bar): Force style of tool bar to be horizontal with
- icons. Set name of tool bar to emacs-toolbar.
- (update_frame_tool_bar): Connect expose event to
- xg_tool_bar_expose_callback.
-
-2003-02-17 Richard M. Stallman <[email protected]>
-
- * keyboard.c (this_command_key_count_reset): New variable.
- Initiatize to 0 where this_command_key_count is set.
- (read_char): Save and restore this_command_key_count_reset
- around input method code.
- (read_char): If this_command_key_count_reset, echo reread commands.
- (Freset_this_command_lengths): Set this_command_key_count_reset to 1.
-
-2003-02-17 Kenichi Handa <[email protected]>
-
- * fns.c (string_to_multibyte): Always return a multibyte string.
-
-2003-02-16 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_list_bdf_fonts, w32_list_fonts):
- Negative max_fonts parameter means list all.
-
-2003-02-14 Dave Love <[email protected]>
-
- * fns.c (Flanginfo): Doc fix.
-
-2003-02-13 Kim F. Storm <[email protected]>
-
- * lread.c (read_escape): Interpret \s as a SPACE character, except
- for \s-X in a character constant which still is the super modifier.
- (read1): Signal an `invalid read syntax' error if a character
- constant is immediately followed by a digit or symbol character.
-
- * search.c (Fmatch_data): Doc fix. Explicitly state that
- match-data is undefined if last search failed.
-
- * keymap.c (Fcommand_remapping): Rename from Fremap_command.
- All uses changed.
-
-2003-02-12 Juanma Barranquero <[email protected]>
-
- * eval.c (Fdefmacro): Fix typo.
-
-2003-02-12 Kim F. Storm <[email protected]>
-
- * macros.c (Fstart_kbd_macro): If appending, and last keyboard
- macro is a string, convert meta modifiers in string when copying
- the string into a vector.
-
-2003-02-11 Kim F. Storm <[email protected]>
-
- * keymap.c (Fremap_command): Return nil if arg is not a symbol.
-
-2003-02-11 Kenichi Handa <[email protected]>
-
- * Makefile.in (lisp, shortlisp): Add malayalam.el and tamil.el.
-
-2003-02-10 Kim F. Storm <[email protected]>
-
- * process.c: Doc fixes.
- (syms_of_process): Add `:' prefix to QCfilter_multibyte.
-
-2003-02-10 Kenichi Handa <[email protected]>
-
- * fns.c (Fstring_to_multibyte): Fix typo in the docstring.
-
- * process.c (QCfilter_multibyte): New variable.
- (setup_process_coding_systems): New function.
- (Fset_process_buffer, Fset_process_filter):
- Call setup_process_coding_systems.
- (Fstart_process): Initialize the member `filter_multibyte' of
- struct Lisp_Process.
- (create_process): Call setup_process_coding_systems.
- (Fmake_network_process): New keyward `:filter-multibyte'.
- Initialize the member `filter_multibyte' of struct Lisp_Process.
- Call setup_process_coding_systems.
- (server_accept_connection): Call setup_process_coding_systems.
- (read_process_output): If the process has a filter, decide the
- multibyteness of a string to given to the filter by
- `filter_multibyte' member of the process. If the process doesn't
- have a filter and the result of conversion is unibyte, use
- Fstring_to_multibyte (not Fstring_make_multibyte) to get the
- multibyte form.
- (Fset_process_coding_system): Call setup_process_coding_systems.
- (Fset_process_filter_multibyte): New function.
- (Fprocess_filter_multibyte_p): New function.
- (syms_of_process): Intern and staticpro QCfilter_multibyte.
- Defsubr Sset_process_filter_multibyte and
- Sprocess_filter_multibyte_p.
-
- * process.h (struct Lisp_Process): New member filter_multibyte.
-
- * lisp.h (setup_process_coding_systems): Add prototype.
-
- * buffer.c (Fset_buffer_multibyte): If the current buffer has a
- process, update coding systems for the process.
-
-2003-02-09 Kenichi Handa <[email protected]>
-
- * fns.c (string_to_multibyte): New function.
- (Fstring_to_multibyte): New function.
- (syms_of_fns): Defsubr it.
-
-2003-02-08 Andreas Schwab <[email protected]>
-
- * Makefile.in (EXEEXT): Define to @EXEEXT@ and use this variable
- instead of the substitution.
-
-2003-02-08 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_make_frame_visible): Call gtk_window_deiconify.
-
- * xmenu.c (menu_position_func): Adjust menu popup position so that
- the menu is fully visible.
-
-2003-02-07 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (x_text_icon, x_raise_frame, x_lower_frame)
- (x_make_frame_invisible, x_wm_set_icon_position):
- Use FRAME_OUTER_WINDOW instead of ifdef X_TOOLKIT/else/endif.
-
- * xfns.c (x_set_name, x_set_title): Ditto.
-
-2003-02-04 Richard M. Stallman <[email protected]>
-
- * keyboard.c (echo_now): Update before_command_echo_length.
- (Freset_this_command_lengths): Reset this_command_key_count etc.
- immediately rather than arranging to do it later.
- (before_command_key_count_1, before_command_echo_length_1)
- (before_command_restore_flag): Vars deleted.
- (add_command_key): Don't handle before_command_restore_flag.
- (read_char, record_menu_key): Don't update before_command_key_count or
- before_command_echo_length.
- (read_char): Don't handle before_command_restore_flag.
-
- * keyboard.c (command_loop_1): Don't call adjust_point_for_property
- in direct-output clauses if it wouldn't be called in the ordinary case.
-
-2003-02-04 Kim F. Storm <[email protected]>
-
- * keyboard.c (syms_of_keyboard) <this-original-command>: Doc fix.
-
-2003-02-02 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (remove_from_container): Copying list is not needed.
- (xg_update_menubar, xg_update_menu_item, xg_update_submenu)
- (xg_modify_menubar_widgets, update_frame_tool_bar): Call g_list_free
- on list returned from gtk_container_get_children to avoid memory leak.
-
-2003-02-01 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_create_pixmap_from_bitmap_data): Use alloca for
- local malloc.
- [HAVE_XPM]: Avoid clashes with XColor, XImage and Pixel
- definitions in xpm.h.
- (init_xpm_functions): New function.
- (xpm_load): Sync with xfns.c. Adapt for Windows version of libXpm.
- (init_external_image_libraries): Try to load libXpm.dll.
-
- * fileio.c (Fcopy_file) [WINDOWSNT]: Reverse logic for setting
- timestamp.
-
-2003-01-31 Dave Love <[email protected]>
-
- * syntax.c (Fskip_chars_forward)
- (open-paren-in-column-0-is-defun-start): Doc fix.
-
-2003-01-31 Joe Buehler <[email protected]>
-
- * fileio.c: Support // at start of name for Cygwin (just added proper
- preprocessor tests).
-
- * keyboard.c: Port to Cygwin (just added proper preprocessor tests).
-
- * Makefile.in: Use @EXEEXT@ for Cygwin.
-
- * mem-limits.h: Added ifdef to define BSD4_2 for Cygwin.
-
- * s/cygwin.h: Added for Cygwin port.
-
-2003-01-31 Juanma Barranquero <[email protected]>
-
- * w32fns.c (DrawText): Kludge to avoid a redefinition on Windows
- when including gif_lib.h.
- (init_gif_functions, init_tiff_functions): New functions.
- (gif_load, tiff_load): Sync with xfns.c version. Adjust colors for
- Windows. Disable color table lookups. Call library functions
- through pointers determined at runtime.
- (init_external_image_libraries): Try to load libungif.dll and
- libtiff.dll.
-
-2003-01-31 Kenichi Handa <[email protected]>
-
- * xdisp.c (SKIP_GLYPHS): New macro.
- (set_cursor_from_row): Skip all glyphs that comes from overlay string.
-
-2003-01-30 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (free_frame_tool_bar): Remove debug printf.
-
-2003-01-30 Dave Love <[email protected]>
-
- * alloc.c (Vgc_elapsed, gcs_done): New variables.
- (Fgarbage_collect): Use them.
- (init_alloc, syms_of_alloc): Set them up.
-
-2003-01-30 Juanma Barranquero <[email protected]>
-
- * w32fns.c (init_external_image_libraries): Add missing operator.
-
-2003-01-29 Jason Rumney <[email protected]>
-
- * w32fns.c (init_external_image_libraries): Allow jpeg-62.dll as
- an alternative name for jpeg.dll.
-
-2003-01-29 Kenichi Handa <[email protected]>
-
- * xdisp.c (set_cursor_from_row): Pay attention to string display
- properties.
-
-2003-01-28 Benjamin Riefenstahl <[email protected]>
-
- * macterm.c (keycode_to_xkeysym_table): Add <tab>, <backspace>,
- <escape>.
- (keycode_to_xkeysym_table): Reformat and add more comments.
- (XTread_socket): Drop special case for backspace.
-
-2003-01-28 Andrew Choi <[email protected]>
-
- * macfns.c (x_to_mac_color): Correct the order for parsing the RGB
- values in old-style RGB specs.
-
-2003-01-27 Juanma Barranquero <[email protected]>
-
- * w32fns.c (init_external_image_libraries): Try alternate names for the
- jpeg dll.
-
-2003-01-27 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (create_dialog, xg_separator_p)
- (xg_item_label_same_p, xg_update_menu_item): Check for NULL string
- before calling strcmp or strlen.
-
-2003-01-26 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (update_frame_tool_bar): Call prepare_image_for_display
- and handle image load failure.
-
-2003-01-26 Jason Rumney <[email protected]>
-
- * w32fns.c (init_jpeg_functions, jpeg_resync_to_restart_wrapper):
- New functions.
- (jpeg_load): Sync with xfns.c version. Adjust colors for Windows.
- Disable color table lookups. Call jpeg library functions
- through pointers determined at runtime.
- (init_external_image_libraries): Try to load jpeg.dll.
-
-2003-01-25 Richard M. Stallman <[email protected]>
-
- * lisp.h: Declare format2 instead of format1.
-
- * fileio.c (barf_or_query_if_file_exists):
- Call format2 instead of format1.
-
- * editfns.c (format2): New function, replaces format1
- but takes exactly two Lisp Objects as format args.
-
- * buffer.c (Fkill_buffer): Call format2 instead of format1.
-
-2003-01-25 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h: Change to return value of x_dispatch_event to int.
-
- * xterm.c (x_filter_event): New function.
- (event_handler_gdk, XTread_socket): Call x_filter_event.
- (x_dispatch_event): Change to return value of finish.
- (event_handler_gdk): Use return value from x_dispatch_event.
-
- * xfns.c (x_window): Call create_frame_xic for GTK version to
- initialize input methods.
-
- * gtkutil.h: Add (void) prototypes.
-
- * gtkutil.c (create_menus): Remove code that puts the help menu to
- the right.
-
-2003-01-25 Jason Rumney <[email protected]>
-
- * w32fns.c (XPutPixel): Handle monochrome images; used for masks.
- [HAVE_PNG]: Sync with xfns.c version.
- (png_load): Adjust colors for Windows. Use Windows
- bitmaps. Disable color table lookups.
- (DEF_IMGLIB_FN, LOAD_IMGLIB_FN): New macros.
- (init_png_functions): New function.
- (png_read_from_memory, png_load): Call png library functions
- through pointers determined at runtime.
- (QCloader, QCbounding_box, QCpt_width, QCpt_height): Declare.
- (init_external_image_libraries): New function.
- (init_xfns): Call it.
-
-2003-01-24 Andreas Schwab <[email protected]>
-
- * minibuf.c (Fminibuffer_message): Verify type of parameter.
-
-2003-01-24 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_initialize): Initialize id_to_widget here instead
- of static initializer.
-
-2003-01-24 Dave Love <[email protected]>
-
- * s/gnu-linux.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define for more
- architectures.
-
- * alloc.c (mark_stack) [!GC_LISP_OBJECT_ALIGNMENT && __GNUC__]:
- Use __alignof__.
-
-2003-01-24 Kenichi Handa <[email protected]>
-
- * keyboard.c (adjust_point_for_property): New second arg MODIFIED.
- It it is nonzero, don't pretend that an invisible area doesn't exist.
- (command_loop_1): Call adjust_point_for_property with proper
- second arg.
-
-2003-01-22 Jason Rumney <[email protected]>
-
- Sync changes with xterm.c and xfns.c.
-
- * w32term.c (x_draw_glyph_string_foreground)
- (x_draw_composite_glyph_string_foreground): Implement overstriking.
-
- * w32term.c (x_write_glyphs): Clear phys_cursor_on_p if current
- phys_cursor's hpos is overwritten. This is still not completely
- correct, as it doesn't really make sense to use hpos at all to
- get the cursor glyph (as that is relative to the width of the
- characters on the line, which may have changed during the update).
-
- * w32term.c (notice_overwritten_cursor): Handle the special case
- of the cursor being in the first blank non-text line at the
- end of a window.
-
- * w32term.c (x_draw_hollow_cursor, x_draw_bar_cursor)
- (x_draw_phys_cursor_glyph): Set phys_cursor_width here.
- Compute from the x position returned by x_draw_glyphs.
-
- (x_display_and_set_cursor): Don't set phys_cursor_width here,
- except for NO_CURSOR and system caret, to make phys_cursor_width
- contain what its name suggests.
- (notice_overwritten_cursor): Consider the cursor image erased if
- the output area intersects the cursor image in y-direction.
-
- * w32term.c (note_mode_line_or_margin_highlight): Rename from
- note_mode_line_highlight and extend.
-
- * w32term.c (last_window): New variable.
- (w32_read_socket) <WM_MOUSEMOVE>: Generate SELECT_WINDOW_EVENTs.
- (note_mouse_movement): Remove reimplemented code in #if 0.
-
- * w32fns.c (x_set_cursor_type): Set cursor_type_changed,
- not update_mode_lines, and always set it to 1.
-
-2003-01-21 Jason Rumney <[email protected]>
-
- * w32fns.c (IDC_HAND): Define it if system headers don't.
-
-2003-01-21 KOBAYASHI Yasuhiro <[email protected]>
-
- * w32term.h (struct w32_output): New member hand_cursor.
- (WM_EMACS_SETCURSOR): New message definition.
-
- * w32term.c (note_mode_line_highlight): Delete #if 0 to enable
- function w32_define_cursor.
- (note_mouse_highlight): Initialize, setup cursor accoding to mouse
- position, change member name output_data.x to output_data.w32 and
- add function w32_define_cursor.
- (show_mouse_face): Delete #if 0 to enable function w32_define_cursor
- and change member name output_data.x to output_data.w32.
- (w32_initialize_display_info):
- Setup dpyinfo->vertical_scroll_bar_cursor.
-
- * w32fns.c (Vx_hand_shape): New variable.
- (w32_wnd_proc): Add message entries for WM_SETCURSOR and
- WM_EMACS_SETCURSOR.
- (x-create-frame): Setup Cursor types.
-
-2003-01-21 David Ponce <[email protected]>
-
- * w32term.c (w32_encode_char): For DIM=1 charset, set
- ccl->reg[2] to -1 before calling ccl_driver.
- (Sync. with xterm.c x_encode_char change by Kenichi Handa
- <[email protected]> on 2002-09-30.)
- (w32_draw_relief_rect): Declare all args.
- (w32_define_cursor): New.
-
- * w32fns.c (w32_load_cursor): New function.
- (w32_init_class): Use it.
- (x_put_x_image): Declare all args.
-
-2003-01-21 Richard Dawe <[email protected]>
-
- * Makefile.in (ALL_CFLAGS): Include MYCPPFLAGS, not MYCPPFLAG.
-
-2003-01-21 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c: Must include stdio.h before termhooks.h.
-
-2003-01-21 Dave Love <[email protected]>
-
- * alloc.c (Fgc_status): Print zombie list.
- (mark_maybe_object) [GC_MARK_STACK==GC_USE_GCPROS_CHECK_ZOMBIES]:
- Fix assignment of zombies.
- (Fgarbage_collect) [GC_MARK_STACK==GC_USE_GCPROS_CHECK_ZOMBIES]:
- Don't take car of non-cons.
-
- * s/sol2-5.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
-
- * s/sunos4-0.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
-
-2003-01-20 David Ponce <[email protected]>
-
- * w32menu.c (digest_single_submenu): Declare all args.
-
- Sync with 2002-12-23 Richard M. Stallman <[email protected]>
- changes in xmenu.c:
-
- (parse_single_submenu): Use individual keymap's prompt
- string as pane name, if there is one.
- (set_frame_menubar): Save menu_items_n_panes from each call to
- parse_single_submenu and use it when calling digest_single_submenu.
-
-2003-01-20 Steven Tamm <[email protected]>
-
- * macterm.c (XTread_socket): Check for valid, visible window
- before sending a scroll-wheel event.
-
-2003-01-20 Richard M. Stallman <[email protected]>
-
- * xdisp.c (redisplay_window): If mini window's buffer is not
- a minibuffer, then redisplay it like other windows.
-
-2003-01-20 Jan Dj,Ad(Brv <[email protected]>
-
- * gtkutil.c (xg_create_frame_widgets): Check if there is an
- external tool bar before setting tool bar height.
-
-2003-01-19 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (handle_one_xevent): Surround popup_activated
- with #ifdef:s for non-toolkit version.
-
- * Makefile.in (XOBJ): Add gtkutil.o if USE_GTK.
- (gtkutil.o): New file.
- (TOOLKIT_DEFINES): Set to -DUSE_GTK if HAVE_GTK.
- (LIBW): Set to @GTK_LIBS@ if USE_GTK.
-
- * gtkutil.c: New file for GTK version.
-
- * gtkutil.h: New file for GTK version.
-
- * xterm.h: Add xt_or_gtk_widget.
- Include gtk files for USE_GTK.
- (struct x_output): Add toolbar_height.
- (struct x_output): Add GTK widgets and Gdk size_hints.
- (GTK_WIDGET_TO_X_WIN, FRAME_GTK_OUTER_WIDGET, FRAME_GTK_WIDGET)
- (FRAME_OUTER_WINDOW): New macros for USE_GTK.
- (FRAME_OUTER_TO_INNER_DIFF_Y): Add FRAME_TOOLBAR_HEIGHT to calculation.
-
- * xterm.c: Include gtkutil.h for USE_GTK.
- (free_frame_menubar): Declare extern void for USE_GTK.
- (note_mouse_highlight): Check popup_activated for USE_GTK.
- (xt_action_hook): Don't compile if USE_GTK.
- (x_scroll_bar_to_input_event): Use CurrentTime for USE_GTK.
- (xg_scroll_callback): New function.
- (x_create_toolkit_scroll_bar): Call xg_create_scroll_bar for USE_GTK.
- (x_set_toolkit_scroll_bar_thumb): Call xg_set_toolkit_scroll_bar_thumb
- for USE_GTK.
- (x_scroll_bar_create): Call xg_update_scrollbar_pos and
- xg_show_scroll_bar for USE_GTK.
- (x_scroll_bar_remove): Call xg_remove_scroll_bar for USE_GTK.
- (XTset_vertical_scroll_bar): Call xg_update_scrollbar_pos for USE_GTK.
- (event_handler_gdk): New function for USE_GTK.
- (handle_one_xevent): Call xg_resize_widgets for USE_GTK.
- (handle_one_xevent): Make sure widget is mapped before
- calling x_real_positions for USE_GTK.
- (XTread_socket): Add GTK event loop for USE_GTK.
- (x_set_window_size): Call xg_frame_set_char_size for USE_GTK.
- (x_make_frame_visible): Call gtk_widget_show_all for USE_GTK.
- (x_make_frame_invisible): Call gtk_widget_hide for USE_GTK.
- (x_iconify_frame): Add code for USE_GTK.
- (x_free_frame_resources): Call gtk_widget_destroy for USE_GTK.
- (x_wm_set_size_hint): Only compile if not USE_GTK. GTK version
- is in gtkutil.c.
- (x_term_init): Add initialization for GTK.
- (syms_of_xterm): Set Vx_toolkit_scroll_bars for USE_GTK.
-
- * xmenu.c: Include gtkutil.h for USE_GTK.
- (Fx_popup_menu): Use current position if x and y are nil.
- (single_menu_item, single_menu_item, Fx_popup_dialog):
- Check for USE_GTK.
- (popup_widget_loop): New function for USE_GTK.
- (x_activate_menubar): Add code for USE_GTK.
- (popup_activate_callback, popup_deactivate_callback)
- (menu_highlight_callback, menubar_selection_callback):
- Add USE_GTK versions.
- (update_frame_menubar): Call xg_update_frame_menubar for USE_GTK.
- (set_frame_menubar): Call xg_modify_menubar_widgets for USE_GTK.
- (free_frame_menubar): Only compile if not USE_GTK. GTK version
- is in gtkutil.c.
- (popup_selection_callback): New version for USE_GTK.
- (create_and_show_popup_menu): New fuction, one USE_GTK version and
- one USE_X_TOOLKIT version.
- (xmenu_show): Call create_and_show_popup_menu.
- (dialog_selection_callback): New version for USE_GTK.
- (create_and_show_dialog): New fuction, one USE_GTK version and
- one USE_X_TOOLKIT version.
- (xdialog_show): Call create_and_show_dialog.
-
- * xfns.c: Include gtkutil for USE_GTK.
- (x_window_to_frame, x_any_window_to_frame)
- (x_non_menubar_window_to_frame, x_menubar_window_to_frame)
- (x_top_window_to_frame): Add code for USE_GTK.
- (x_set_background_color): Call xg_set_background_color for GTK.
- (x_set_menu_bar_lines): Check for USE_GTK.
- (x_set_tool_bar_lines): Call update_frame_tool_bar for USE_GTK.
- (x_set_name, x_set_title): Call gtk_window_set_title for USE_GTK.
- (x_window): Call xg_create_frame_widgets for USE_GTK.
- (Fx_create_frame): Check for USE_GTK.
- (Fx_file_dialog): New implementation for USE_GTK.
-
- * xdisp.c: Add check for USE_GTK for extern void set_frame_menubar.
- (update_menu_bar): Add check for USE_GTK.
- (update_tool_bar): Add check for USE_GTK and external tool bar.
- (redisplay_tool_bar): Add check for USE_GTK and external tool bar.
- (redisplay_internal): Add check for USE_GTK and popup_activated.
- (redisplay_window): Add check for USE_GTK and FRAME_EXTERNAL_MENU_BAR.
- (redisplay_window): Add check for USE_GTK and FRAME_EXTERNAL_TOOL_BAR.
- (display_menu_bar): Add check for USE_GTK.
-
- * lisp.h (Vx_resource_name): Declare extern.
-
- * keyboard.c (kbd_buffer_get_event): Check MENU_BAR_ACTIVATE_EVENT
- for USE_GTK.
- (make_lispy_event): Check MENU_BAR_EVENT for USE_GTK.
-
- * frame.h (struct frame): Add external_tool_bar. Check for USE_GTK.
- (FRAME_EXTERNAL_TOOL_BAR): New macro.
- (FRAME_EXTERNAL_MENU_BAR): Check for USE_GTK.
-
- * fileio.c (Fread_file_name): Add check for USE_GTK.
-
- * dispnew.c (adjust_frame_glyphs_for_window_redisplay):
- Add check for USE_GTK.
-
- * config.in: Added HAVE_GTK.
-
- * alloc.c (Fgarbage_collect): Call xg_mark_data for GTK.
-
-2003-01-18 Stefan Monnier <[email protected]>
-
- * charset.h (Funibyte_char_to_multibyte): Export.
-
-2003-01-18 Jan Dj,Ad(Brv <[email protected]>
-
- * xmenu.c (mouse_position_for_popup): New function.
- (Fx_popup_menu): Call mouse_position_for_popup for X and
- mouse_position_hook for others.
-
-2003-01-17 Kim F. Storm <[email protected]>
-
- * editfns.c (Finsert): Mention `string-make-multibyte' and
- `string-as-multibyte' in doc string.
-
-2003-01-17 Kenichi Handa <[email protected]>
-
- * fontset.c (syms_of_fontset): Setup Vfont_encoding_alist here.
-
- * editfns.c (Fformat): Convert an unibyte char argument that is
- formatted by "%c" to multibyte if the total result must be a
- multibyte string.
-
-2003-01-16 Kim F. Storm <[email protected]>
-
- * process.c (set-process-filter): Document unibyte/multibyte-ness
- of string argument.
-
-2003-01-16 Kenichi Handa <[email protected]>
-
- * charset.h (NEXT_CHAR_BOUNDARY, PREV_CHAR_BOUNDARY): New macros.
-
- * regex.c (GET_CHAR_BEFORE_2): Use PREV_CHAR_BOUNDARY.
- (re_search_2): Likewise.
-
-2003-01-15 Kenichi Handa <[email protected]>
-
- * xdisp.c (message_dolog): Fix bug of the case that *Message*
- buffer is unibyte.
-
-2003-01-15 Francesco Potort,Al(B <[email protected]>
-
- * fns.c (Fsubstring): Clarify doc string.
-
- * textprop.c (Ftext_properties_at, Fnext_char_property_change)
- (Fprevious_char_property_change)
- (Fnext_single_char_property_change)
- (Fprevious_single_char_property_change, Fnext_property_change)
- (Fnext_single_property_change, Fprevious_property_change)
- (Fprevious_single_property_change, Fadd_text_properties)
- (Fput_text_property, Fset_text_properties)
- (Fremove_text_properties, Fremove_list_of_text_properties)
- (Ftext_property_any, Ftext_property_not_all): Clarify doc strings.
-
-2003-01-14 Kim F. Storm <[email protected]>
-
- * process.h (struct Lisp_Process): New member plist replaces old
- member private_vars. All uses changed.
-
- * process.c: Reworked 2003-01-12 change -- call a plist a plist!
- (QCplist): Rename from QCvars. Change all uses.
- (Fprocess_plist): Replaces Fprocess_variable. Simplified.
- (Fset_process_plist): Replaces Fset_process_variable. Simplify.
- (syms_of_process): Intern, staticpro, defsubr these.
- (Fmake_network_process): Describe :plist arg. Remove :vars arg.
-
-2003-01-14 Francesco Potort,Al(B <[email protected]>
-
- * m/delta.h: Remove (obsolete).
-
-2003-01-13 Francesco Potort,Al(B <[email protected]>
-
- * fileio.c (Fdelete_directory, Fdelete_file): Document the
- behaviour in front of symlinks.
- (Fdelete_file): Raise an error on directories.
-
-2003-01-13 Dave Love <[email protected]>
-
- * fns.c (Freverse): Use QUIT.
-
-2003-01-13 Richard M. Stallman <[email protected]>
-
- * minibuf.c (minibuffer_completion_contents):
- Error if point is inside prompt.
-
- * keyboard.c (command_loop_1): Don't redisplay directly
- if there's a post-command-hook.
-
- * fileio.c (syms_of_fileio) <directory-sep-char>: Doc fix.
- (Fdo_auto_save): Add gcpros around Ffile_name_directory.
-
-2003-01-12 Kim F. Storm <[email protected]>
-
- * process.h (struct Lisp_Process): New member private_vars.
-
- * process.c (QCvars): New variable.
- (syms_of_process): Intern and staticpro it.
- (Fset_process_contact): Removed function.
- (Fprocess_variable, Fset_process_variable): New functions.
- (syms_of_process): Defsubr them.
- (Fstart_process): Initialize private_vars plist to nil.
- (Fmake_network_process): New arg :vars to setup the private
- variables for new network process.
- (server_accept_connection): Copy server's private variables to
- client process.
-
- * alloc.c (pure_alloc): Fixed 2003-01-10 changed (caused spurious
- crashes). Code rewritten and simplified. Now directly aligns the
- pointer and recalculates pure_bytes_used, rather than aligning the
- size and adjusting the pointer.
-
-2003-01-11 Kim F. Storm <[email protected]>
-
- * process.c (Fset_process_contact): New function.
- (syms_of_process): defsubr it.
- (make-network-process): Update doc.
-
-2003-01-10 Andreas Schwab <[email protected]>
-
- * alloc.c (pure_alloc): Correct alignment for Lisp_Floats.
- Reported by Berthold Gunreben <[email protected]>.
-
-2003-01-10 Dave Love <[email protected]>
-
- * composite.c (syms_of_composite): Make composition_hash_table weak.
-
-2003-01-09 Kim F. Storm <[email protected]>
-
- * process.c (Fmake_network_process): Convert new port number
- to host byte order for `:service t' case. From Mario Lang.
-
-2003-01-08 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (Fx_file_dialog): Call XtAppNextEvent and x_dispatch_event
- instead of XtAppProcessEvent.
-
- * xterm.c (handle_one_xevent): New function.
- (x_dispatch_event): New function.
- (XTread_socket): Call handle_one_xevent.
-
- * xterm.h (FRAME_OUTER_TO_INNER_DIFF_X/Y): New.
-
- * xmenu.c (Fx_popup_menu): If popping up at mouse position,
- call XQueryPointer to get coordinates.
- (popup_get_selection): Do not set popup_activated_flag to zero,
- let popup_deactivate_callback do that. Needed for Motif.
- Call x_dispatch_event instead of XtDispatchEvent.
- (xmenu_show): Calculate root coordinate from frame top/left position.
-
-2003-01-08 Kim F. Storm <[email protected]>
-
- * process.c (server_accept_connection): Fix recording of new
- connection's local address in :local property of contact info.
- (Fmake_network_process): Record local network address for new
- client processes in :local property of contact info.
- (format-network-address): Add arg OMIT-PORT. Change callers.
-
-2003-01-07 Dave Love <[email protected]>
-
- * Makefile.in (fns.o): Depend on coding.h.
-
-2003-01-06 Dave Love <[email protected]>
-
- * fns.c: Include coding.h. Use POINTER_TYPE*, not void*.
- (Vlocale_coding_system): Declare.
- (Qcodeset, Qdays, Qmonths, Qpaper): New.
- (Flanginfo): New.
- (syms_of_fns): Initialize new stuff.
-
-2003-01-07 Markus Rost <[email protected]>
-
- * minibuf.c (Fread_variable): Doc fix.
-
- * eval.c (Fuser_variable_p): Doc change. For custom variables,
- use the same test as for custom-variable-p.
-
-2003-01-05 Richard M. Stallman <[email protected]>
-
- * xdisp.c (try_scrolling): New arg LAST_LINE_MISFIT.
- Count LAST_LINE_MISFIT in scroll margin for end of window.
- Move label too_near_end before setting SCROLL_MARGIN_POS.
- Set LAST_LINE_MISFIT before jumping there.
-
- * xdisp.c (try_scrolling): Calculate amount_to_scroll better in
- scroll_conservatively case. If scrolling that much doesn't change
- STARTP, move it down one line.
-
- * xdisp.c (redisplay_window): Pass last_line_misfit arg to
- try_scrolling. Make it 1 after make_cursor_line_fully_visible fails.
-
- * xdisp.c (setup_echo_area_for_printing): Kill Emacs if no
- selected frame.
-
- * keymap.c (apropos_predicate, apropos_accumulate): Make them static.
- (syms_of_keymap): Staticpro them.
- (Fapropos_internal): Initialize them and clear them out.
- Don't GCPRO them.
-
- * buffer.c (syms_of_buffer) <scroll-up|down-aggressively>: Doc fixes.
-
- * lisp.h: New misc type Lisp_Save_Value.
- (enum Lisp_Misc_Type): Add Lisp_Misc_Save_Value.
- (XSAVE_VALUE): New macro.
- (struct Lisp_Save_Value): New data type.
- (union Lisp_Misc): Add u_save_value alternative.
- (make_save_value): Declare.
-
- * alloc.c (make_save_value): New function.
-
- * xterm.c (x_catch_errors): Save dpy using make_save_value.
- (x_catch_errors_unwind): Call XSync.
-
-2003-01-01 Richard M. Stallman <[email protected]>
-
- * window.c (window_scroll_pixel_based): Partially undo last change.
-
- * keyboard.c (command_loop_1): Call adjust_point_for_property
- in direct action cases for Qforward_char and Qbackward_char.
- Set already_adjusted so it won't be done twice.
-
-2002-12-30 Richard Dawe <[email protected]>
-
- * src/config.in (!HAVE_SIZE_T): Fix order of arguments in
- type definition of size_t.
-
-2003-01-02 Steven Tamm <[email protected]>
-
- * macterm.c (syms_of_macterm): Provide the feature "mac-carbon" to
- distinguish Carbon GUI builds from X11 builds on darwin.
-
-2002-12-30 Steven Tamm <[email protected]>
-
- * macterm.c (syms_of_macterm): Set mac-wheel-button-is-mouse-2
- to default to t.
-
-2002-12-29 Francesco Potort,Al(B <[email protected]>
-
- * data.c (Fstring_to_number, Fminus): Better English in doc strings.
-
-2002-12-28 Steven Tamm <[email protected]>
-
- * Makefile.in (macosx-bundle): Fix Mac OS X/Carbon port to
- allow building in a different directory than source. Uses some
- GNU Make extensions, but there is no other make on Mac OS X.
-
-2002-12-26 Francesco Potort,Al(B <[email protected]>
-
- * data.c (Fmakunbound, Ffmakunbound, Fmake_variable_buffer_local)
- (Fsetq_default, Fmake_local_variable, Fkill_local_variable)
- (Fmake_variable_frame_local, Faset, Fnumber_to_string, Fminus)
- (Fstring_to_number): Mention the returned value in the doc strings.
-
-2002-12-23 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer) <scroll-up-aggressively>
- <scroll-down-aggressively>: Doc fix.
-
- * xmenu.c (parse_single_submenu): Use individual keymap's prompt
- string as pane name, if there is one.
- (set_frame_menubar): Save menu_items_n_panes from each call to
- parse_single_submenu and use it when calling digest_single_submenu.
-
- * window.c (window_scroll_pixel_based): Fix check for reaching BEGV.
- Don't try to make last line fully visible if it is past end of window.
-
-2002-12-22 Steven Tamm <[email protected]>
-
- * macmenu.c (MIN_POPUP_SUBMENU_ID): Add.
- (mac_menu_show): Add support for hierarchical popup menus.
- (add_menu_item): Remove indentation support.
- (fill_submenu, fill_menu): Create hierarchical menus
- instead of using indentation.
-
-2002-12-22 Richard M. Stallman <[email protected]>
-
- * xdisp.c (try_cursor_movement): Don't call try_window here.
- (redisplay_window): Never redisplay minibuffer when inactive.
-
- * window.c (select_window_1): Undo 9/21 change.
-
-2002-12-22 Steven Tamm <[email protected]>
-
- * macterm.c (XTread_socket): Call KeyTranslate for control and
- meta to deal correctly shifted non-alpha characters, like C-S-5
- being treated like C-%. Do not look for shift key to deal
- with masking off control-key with mac-reverse-ctrl-meta.
-
-2002-12-21 Richard M. Stallman <[email protected]>
-
- * xmenu.c (popup_get_selection): Now static. New arg DO_TIMERS.
- If it is non-nil, run timers. Use an unwind-protect to requeue
- the events that were read ahead.
- (popup_get_selection_unwind): New subroutine.
- (popup_get_selection_queue): File-scope variable now holds that queue.
- (xmenu_show): Pass 0 for DO_TIMERS to popup_get_selection.
- (xdialog_show): Pass 1 for DO_TIMERS to popup_get_selection.
- Use an unwind-protect to pop down the dialog box.
- (xdialog_show_unwind): New subroutine implements that.
-
- * xdisp.c (row_containing_pos): Change exit test using last_y.
- (try_window_id): Abort if row_containing_pos returns null.
-
- * lread.c (load_error_handler): New function.
- (Fload): Handle errors in Fsubstitute_in_file_name.
- Don't expect Fsignal to return.
-
- * eval.c: Errors and throws work right with interrupt blocking.
- (struct catchtag): New elt interrupt_input_blocked.
- (unwind_to_catch): Restore interrupt_input_blocked from saved value.
- (internal_catch, Fcondition_case, internal_condition_case)
- (internal_condition_case_1, internal_condition_case_2): Save it.
- (Fsignal): Don't do TOTALLY_UNBLOCK_INPUT.
-
- * editfns.c (Fformat): Add parens.
-
- * dired.c (file_name_completion): Fix that change.
- Delete special quit-handling code; just use QUIT.
-
-2002-12-21 Tak Ota <[email protected]>
-
- * dired.c (file_name_completion): Close directory on error
- just as in directory_files_internal.
-
-2002-12-19 David Kastrup <[email protected]>
-
- * window.c (Fset_window_configuration): Set old_point to correct
- value when new_current_buffer == current_buffer.
-
-2002-12-17 Ben Key <[email protected]>
-
- Revisited my earlier fix for the following entry in etc/PROBLEMS:
- "Emacs built on Windows 9x/ME crashes at startup on Windows XP,
- or Emacs builtpart of on XP crashes at startup on Windows 9x/ME."
-
- These changes were in part based upon suggestions made by Peter
- 'Luna' Runestig [[email protected]].
-
- * w32.c (g_b_init_is_windows_9x, g_b_init_open_process_token)
- (g_b_init_get_token_information, g_b_init_lookup_account_sid)
- (g_b_init_get_sid_identifier_authority ): Add several static
- global variables.
-
- * w32.c (globals_of_w32): New function. Used to initialize those
- global variables that must always be initialized on startup even
- when the global variable initialized is non zero. Its primary
- purpose at this time is to set the global variables
- g_b_init_is_windows_9x, g_b_init_open_process_token,
- g_b_init_get_token_information, g_b_init_lookup_account_sid, and
- g_b_init_get_sid_identifier_authority to 0 on startup.
- Called from main.
-
- * w32.c (is_windows_9x): Perform initialization only if
- g_b_init_is_windows_9x is equal to 0. On initialization set
- g_b_init_is_windows_9x equal to 1.
-
- * w32.c (open_process_token): Perform initialization only if
- g_b_init_open_process_token is equal to 0. On initialization set
- g_b_init_open_process_token equal to 1.
-
- * w32.c (get_token_information): Perform initialization only if
- g_b_init_get_token_information is equal to 0. On initialization
- set g_b_init_get_token_information equal to 1.
-
- * w32.c (lookup_account_sid): Perform initialization only if
- g_b_init_lookup_account_sid is equal to 0. On initialization
- set g_b_init_lookup_account_sid equal to 1.
-
- * w32.c (get_sid_identifier_authority): Perform initialization
- only if g_b_init_get_sid_identifier_authority is equal to 0.
- On initialization set g_b_init_get_sid_identifier_authority equal to 1.
-
- * w32fns.c (globals_of_w32fns): New function. Used to initialize
- those global variables that must always be initialized on startup
- even when the global variable initialized is non zero.
- Its primary purpose at this time is to initialize the global variable
- track_mouse_event_fn.
-
- * w32fns.c (w32_wnd_proc): Remove initialization of
- track_mouse_event_fn from the handler for the WM_SETFOCUS message.
-
- * w32fns.c (syms_of_w32fns): Call globals_of_w32fns.
-
- * w32menu.c (globals_of_w32menu): New function. Used to
- initialize those global variables that must always be initialized
- on startup even when the global variable initialized is non zero.
- Its primary purpose at this time is to initialize the global
- variables get_menu_item_info and set_menu_item_info.
-
- * w32menu.c (initialize_frame_menubar): Remove initialization of
- get_menu_item_info and set_menu_item_info.
-
- * w32menu.c (syms_of_w32menu): Call globals_of_w32menu.
-
- * w32.h (globals_of_w32, globals_of_w32fns, globals_of_w32menu):
- Declare them.
-
- * emacs.c (main): Call globals_of_w32 prior to calling
- init_environment if WINDOWSNT is defined. Call globals_of_w32fns
- and globals_of_w32menu if initialized is non zero and HAVE_NTGUI
- is defined.
-
- * w32term.c (x_update_window_begin): Fix Windows API error
- detected by BoundsChecker. Test to determine if
- w32_system_caret_hwnd is NULL prior to attempting to use
- SendMessage to send the WM_EMACS_HIDE_CARET message to it.
-
- * w32term.c (x_update_window_end): Fix Windows API error
- detected by BoundsChecker. Test to determine if
- w32_system_caret_hwnd is NULL prior to attempting to use
- SendMessage to send the WM_EMACS_SHOW_CARET message to it.
-
-2002-12-17 Kenichi Handa <[email protected]>
-
- * coding.c (coding_system_require_warning): New variable.
- (syms_of_coding): DEFVAR it.
-
- * coding.h (coding_system_require_warning): Extern it.
-
- * fileio.c (choose_write_coding_system): Even if
- Vcoding_system_for_write is non-nil, if
- coding_system_require_warning is nonzero, call
- Vselect_safe_coding_system_function.
-
-2002-12-17 Markus Rost <[email protected]>
-
- * Makefile.in (lisp, shortlisp): Add cus-face and timer.
- (lisp): Add font-core.
-
-2002-12-13 Stefan Monnier <[email protected]>
-
- * textprop.c (text_read_only): New arg `propval'.
- (get_char_property_and_overlay): Remove unused var `next_overlay'.
- (verify_interval_modification): Use text_read_only's new arg.
-
-2002-12-13 Kenichi Handa <[email protected]>
-
- * coding.c (Funencodable_char_position): Set pend correctly.
-
-2002-12-12 Jason Rumney <[email protected]>
-
- * w32term.c (last_mousemove_x, last_mousemove_y): New variables.
- (w32_read_socket) <WM_MOUSEMOVE>: Use them to detect non-movement.
- Be more careful about when help_events are generated.
-
-2002-12-12 Steven Tamm <[email protected]>
-
- * macterm.c (mac_check_for_quit_char): Correctly set the
- modifiers of the event to 0.
- * mac.c (sys_select): Duplicate rfds before calling select to
- ensure that rfds survive the while loop.
-
-2002-12-11 Kim F. Storm <[email protected]>
-
- * xdisp.c (try_window_id): Don't call set_cursor_from_row if
- row_containing_pos returned NULL.
-
-2002-12-10 Steven Tamm <[email protected]>
-
- * mac.c (sys_read): Fix sys_read to not call select if IO is
- non-blocking.
- (sys_select): Fix sys_select to not use a timeout larger than
- the one given.
-
-2002-12-10 Juanma Barranquero <[email protected]>
-
- * editfns.c (Fformat): Use alloca, not _alloca.
-
-2002-12-09 Richard M. Stallman <[email protected]>
-
- * buffer.c (Fget_buffer_create): Call Qucs_set_table_for_input
- as the last thing.
-
-2002-12-09 Dave Love <[email protected]>
-
- * s/sol2-8.h: Removed. (Not necessary.)
-
-2002-12-09 Matthew Swift <[email protected]>
-
- * editfns.c (Fformat): Handle precision in string conversion
- specifiers like libc functions do (ie, print at most that many
- characters).
-
-2002-12-08 Richard M. Stallman <[email protected]>
-
- * xdisp.c (row_containing_pos): Check more carefully
- whether charpos is really in the row before returning it.
-
-2002-12-07 Steven Tamm <[email protected]>
-
- * sysdep.c (emacs_read) [HAVE_CARBON]: Have emacs_read use sys_read.
-
- * eval.c (Feval) [HAVE_CARBON]: Calls mac_check_for_quit_char at
- each stack frame. This may change as it could be time consuming.
-
- * macterm.c (mac_check_for_quit_char, quit_char_comp)
- (init_quit_char_handler, mac_determine_quit_char_modifiers)
- (mac_initialize): Add code to check for pressing of quit_char
- in the OS event queue.
-
- * mac.c (sys_select): Call mac_check_for_quit_char every second
- while blocking on select.
-
- * mac.c (sys_read): Use sys_select to test for input first
- before calling read, to allow C-g to break.
-
-2002-12-07 Richard M. Stallman <[email protected]>
-
- * minibuf.c (Fcompleting_read): Doc fix.
-
- * lread.c (syms_of_lread) <load-history>: Doc fix.
-
- * fileio.c (Fcopy_file): Set immediate_quit around emacs_open call.
-
- * eval.c (Fdefun, Fdefmacro): Record in load-history redefining an
- autoload.
-
- * data.c (Fdefalias): Record in load-history redefining an autoload.
-
- * alloca.c: Undo ifdef change accidentally made on 12-04.
-
-2002-12-06 Francesco Potort,Al(B <[email protected]>
-
- * xfns.c (png_load): Avoid double gamma correction for PNG images.
-
-2002-12-04 Richard M. Stallman <[email protected]>
-
- * sysdep.c (fcntl.h): Test only HAVE_FCNTL_H.
-
- * fileio.c (fcntl.h): Test only HAVE_FCNTL_H.
-
- * alloca.c: Don't use #error.
-
-2002-12-03 Dave Love <[email protected]>
-
- * buffer.c (Qucs_set_table_for_input): New.
- (Fget_buffer_create): Use it.
- (Qset_buffer_major_mode_hook): Deleted.
- (Fset_buffer_major_mode): Revert previous change.
- (init_buffer_once): Intern ucs-set-table-for-input.
- (syms_of_buffer): Delete Qset_buffer_major_mode_hook.
- Add &Qucs_set_table_for_input.
-
-2002-12-03 Andreas Schwab <[email protected]>
-
- * callint.c (Fcall_interactively): Use next_event only if less
- than key_count.
-
-2002-12-02 Andrew Choi <[email protected]>
-
- * macmenu.c (add_menu_item, fill_menubar): Truncate menu item
- names to 255 characters.
-
- * macterm.c (XTread_socket): If all frames have been collapsed,
- expand the first one before handling drag-and-drop events.
-
- * s/darwin.h (GETPGRP_NO_ARG): Delete. Replaced by GETPGRP_VOID,
- which is detected by autoconf.
-
-2002-12-01 Steven Tamm <[email protected]>
-
- * unexmacosx.c (copy_twolevelhints, dump_it): Now corrects the
- offset in two hints table to allow prebinding to be redone and
- allow the executable to be stripped.
-
-2002-11-29 Dave Love <[email protected]>
-
- * fns.c (Frequire): Don't call LOADHIST_ATTACH if feature was
- already provided.
-
-2002-11-29 Richard M. Stallman <[email protected]>
-
- * xdisp.c (start_display): Check more intelligently for
- whether the line is continued.
- (move_it_vertically_backward): Clear it->continuation_lines_width.
-
-2002-11-28 Dave Love <[email protected]>
-
- * s/amdahl.h, s/unipl5-0.h, m/sgi3000.h, s/3700.h, s/alliant-2800.h:
- * s/alliant.h, s/altos.h: Deleted. (Unused/empty.)
-
-2002-11-27 Steven Tamm <[email protected]>
-
- * fns.c (Frequire): Change nesting allowance from 2 to 3 to cause
- more descriptive error output from lread.c:Fload upon most require
- cycles during boostrapping.
-
-2002-11-27 Jason Rumney <[email protected]>
-
- * fileio.c (Finsert_file_contents): Give a more appropriate error
- for files bigger than 2Gb when off_t is 32 bit.
-
- * dired.c (Ffile_attributes): Don't return negative file sizes for
- files bigger than 2Gb when off_t is 32 bit.
-
-2002-11-27 Dave Love <[email protected]>
-
- * s/irix6-0.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
-
- * systty.h: Don't conditionally define GETPGRP_NO_ARG.
- Test GETPGRP_VOID instead.
- [BSD_TERMIOS]: Remove definitions (never used).
-
- * s/osf5-0.h (WAIT_USE_INT, SYS_SIGLIST_DECLARED, sys_siglist):
- Don't define.
- (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
-
- * m/mips.h (WORDS_BIG_ENDIAN): Define conditionally.
-
-2002-11-25 Jason Rumney <[email protected]>
-
- * w32.c (sys_write): Avoid non-blocking mode, which is not fully
- supported.
-
-2002-11-25 Dave Love <[email protected]>
-
- * unexalpha.c (update_dynamic_symbols): Cast arg of fatal_unexec.
-
- * Makefile.in (TEMACS_LDFLAGS): Update last change.
-
-2002-11-25 Andreas Schwab <[email protected]>
-
- * m/ia64.h: Restore `#ifndef NOT_C_CODE' deleted by last change.
-
-2002-11-24 Steven Tamm <[email protected]>
-
- * unexmacosx.c (unexec_realloc): Use malloc_default_zone to
- determine the size of pointers alloced in unexed space instead
- of using possibly invalid emacs_zone pointers. This fixes the
- binary incompatibility problems caused by updates to libSystem.B.
-
-2002-11-24 Richard M. Stallman <[email protected]>
-
- * search.c (Fstring_match): Doc fix.
-
- * callint.c (Fcall_interactively): If a command fails because
- `*' detects a read-only buffer, but RECORD_FLAG is set,
- record it anyway if the args don't actually do tty input.
-
-2002-11-22 Dave Love <[email protected]>
-
- * sysdep.c (stuff_char) [PROTOTYPES]: Provide ISO C arglist.
-
- * keyboard.c (interrupt_signal): Provide forward declaration.
- (kbd_buffer_store_event): Don't declare interrupt_signal.
-
- * xdisp.c (store_frame_title_char) [PROTOTYPES]: Provide ISO C arglist.
-
-2002-11-21 Richard M. Stallman <[email protected]>
-
- * eval.c (interactive_p): Skip any number of bytecode
- and special form frames, in any order.
-
-2002-11-20 Jason Rumney <[email protected]>
-
- * w32fns.c (convert_mono_to_color_image): New function.
- (xbm_load, xbm_load_image): Use it when foreground or background
- is explicitly set.
-
-2002-11-19 Dave Love <[email protected]>
-
- * s/usg5-4.h, sco4.h (bcopy, bzero, bcmp): Don't define.
-
-2002-11-18 Jason Rumney <[email protected]>
-
- * w32fns.c (x_build_heuristic_mask): Filter palette info from color.
- (XPutPixel): Swap blue and red.
- (xpm_format, pbm_format, png_format, jpeg_format, tiff_format)
- (gif_format, gs_format): Use IMAGE_ASCENT_VALUE.
- (xpm_image_p, pbm_image_p, png_image_p, jpeg_image_p)
- (tiff_image_p, gif_image_p, gs_image_p): Don't check ascent.
-
-2002-11-18 Dave Love <[email protected]>
-
- * m/orion105.h (HAVE_ALLOCA): Don't define.
-
- * m/m68k.h, m/arm.h, mtekxd88.h, m/tower32v3.h: Don't define alloca.
-
- * m/intel386.h: Don't include alloca.h or define alloca.
-
- * m/ia64.h: Don't include alloca.h, stdlib.h. Don't declare
- malloc, realloc, calloc.
-
- * m/hp800.h, m/sr2k.h, m/ns16000.h, m/wicat.h (bcopy, bzero)
- (bcmp): Don't define.
-
- * m/delta.h (bcopy, bzero, bcmp, alloca): Don't define.
-
- * m/amdahl.h: Don't define LIB_STANDARD.
-
- * m/alpha.h: Move OSF1 stuff from here to s/osf1.h.
-
- * s/osf1.h: Move OSF1 stuff from m/alpha.h to here.
-
- * s/irix4-0.h, s/irix5-0.h, m/powerpcle.h, m/sparc.h:
- Don't include alloca.h.
-
- * s/aix3-2.h (HAVE_FSYNC): Don't define.
-
- * regex.c (_GNU_SOURCE): Don't define.
-
- * process.c (_GNU_SOURCE): Don't define.
-
- * fileio.c (_GNU_SOURCE, HAVE_FSYNC): Don't define.
-
-2002-11-18 Markus Rost <[email protected]>
-
- * s/sol2-8.h: Include sol2-6.h.
-
-2002-11-18 Miles Bader <[email protected]>
-
- * dispextern.h (struct face): Add `overstrike' field.
- * xterm.c (x_draw_glyph_string_foreground)
- (x_draw_composite_glyph_string_foreground): Implement overstriking.
- * xfaces.c (load_face_font): Set `face->overstrike' based on
- result from choose_face_font.
- (best_matching_font, choose_face_font): Add `needs_overstrike'
- argument, and use it to return whether overstriking is desirable
- for this face/font combo.
- (set_font_frame_param): Pass new argument to choose_face_font.
-
-2002-11-17 Ben Key <[email protected]>
-
- This change is my fix for the following entry in etc/PROBLEMS:
- "Emacs built on Windows 9x/ME crashes at startup on Windows XP,
- or Emacs builtpart of on XP crashes at startup on Windows 9x/ME."
-
- * w32.c: Added wrapper functions around the win32 API functions
- OpenProcessToken, GetTokenInformation, LookupAccountSid, and
- GetSidIdentifierAuthority. These wrapper functions serve two
- purposes:
- 1. They ensure that the wrapped function can never be called
- when Emacs is running on an operating system on which they are
- not supported (Microsoft Windows 95 / 98 / ME).
- 2. They call the wrapped functions via function pointers rather
- than calling them directly. This avoids taking advantage of the
- undocumented fact that although these functions are not supported
- in the 9x branch of Microsoft Windows, the functions do exist in
- the version of advapi32.dll that is found in the 9x branch of
- Microsoft Windows.
-
- * w32.c (init_user_info): Replace the calls to the win32 API
- functions OpenProcessToken, GetTokenInformation, LookupAccountSid,
- and GetSidIdentifierAuthority with calls to the newly added
- wrapper functions.
-
- * w32.h: Added extern declarations for the following functions:
- syms_of_w32term, syms_of_w32fns, syms_of_w32select,
- syms_of_w32menu, and void syms_of_fontset.
-
- * w32fns.c (w32_wnd_proc): Add code to reinitialize the
- function pointer track_mouse_event_fn in the handler for the
- WM_SETFOCUS message.
-
- * w32menu.c (initialize_frame_menubar): Add code to
- reinitialize the function pointers set_menu_item_info and
- get_menu_item_info.
-
-2002-11-17 Ben Key <[email protected]>
-
- * sound.c: Added a partial implementation of play-sound-internal
- for Microsoft Windows. Added various #ifdef / #else / #endif
- code blocks to separate the code that will compile under
- Microsoft Windows from the code that is specific to GNU/Linux.
- Moved several blocks of code around to make this separation of code
- into Windows compatible and GNU/Linux compatible code blocks easier.
-
- * makefile.w32-in: Include sound.c and link with WinMM.lib.
-
- * s/ms-w32.h: Defined the symbol HAVE_SOUND so that the newly
- added support for play-sound-internal under Windows would be
- included in the build of Emacs.
-
-2002-11-16 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_load_system_font): Don't disable Cleartype.
-
- * w32term.c (w32_get_glyph_string_clip_rect): Clip cursor tightly.
-
-2002-11-15 Stefan Monnier <[email protected]>
-
- * keyboard.c (command_loop_1): Fix int/Lisp_Object mixup.
- (adjust_point_for_property): Move out of display and invisible even if
- we were already inside before (in case a property was added while
- we weren't looking). Be more careful when handling invisible props.
- Skip invisible text as if it really wasn't there at all.
-
-2002-11-15 Jason Rumney <[email protected]>
-
- * w32term.c (x_draw_image_foreground)
- (w32_draw_image_foreground_1): Use standard copy and invert
- operations to draw images.
-
- * w32fns.c (x_create_x_image_and_pixmap): Fill in palette for
- depth of 1.
- (xbm_read_bitmap_data): Invert bits as xbm is read in.
- (XPutPixel): Don't invert bits here.
-
-2002-11-15 Jason Rumney <[email protected]>
-
- * w32term.c (x_draw_image_foreground, x_draw_image_glyph_string)
- (w32_draw_image_foreground_1): Handle image masks.
- (x_draw_image_glyph_string): Don't BitBlt transparently.
-
- * w32fns.c (w32_defined_color): Adjust RGB values for Emacs.
- (x_from_xcolors): Adjust RGB values for W32.
- (image_background, image_background_transparent)
- (postprocess_image, x_to_xcolors, x_disable_image)
- (x_build_heuristic_mask): Adapt for W32 and enable.
- (x_create_x_image_and_pixmap): Mark images with palettes as such.
- (xbm_load): Remove unused variable.
-
-2002-11-14 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer): Doc fix.
-
-2002-11-14 Dave Love <[email protected]>
-
- * alloc.c (SETJMP_WILL_NOT_WORK): Add note.
-
- * xterm.c (x_draw_relief_rect, x_draw_box_rect, x_update_cursor):
- * xmenu.c (unuse_menu_items, digest_single_submenu):
- * xfns.c (x_put_x_image):
- * xdisp.c (message2_nolog, set_message):
- * undo.c (record_point):
- * terminfo.c (tparam):
- * syntax.c (scan_sexps_forward):
- * scroll.c (calculate_scrolling, calculate_direct_scrolling):
- * composite.c (update_compositions):
- * cm.c (calccost, cmgoto):
- * charset.c (c_string_width): Declare all args (per C99).
-
- * frame.h (get_specified_cursor_type, get_window_cursor_type): Declare.
-
- * lisp.h (get_specified_cursor_type, get_window_cursor_type):
- Don't declare.
-
- * emacs.c (main) [!VMS]: Avoid third arg.
-
- * fns.c (Fcopy_sequence): Doc fix.
- (Fmap_char_table): Cast `call2'.
-
-2002-11-14 Francesco Potort,Al(B <[email protected]>
-
- * s/sol2-8.h: New file.
-
-2002-11-14 Kim F. Storm <[email protected]>
-
- * buffer.c (syms_of_buffer) <mode-line-format>: Document symbol
- dependency on `risky-local-variable' and the :propertize form.
-
-2002-11-12 Stefan Monnier <[email protected]>
-
- * fns.c (Fmap_char_table): Don't use map_char_table's function arg.
-
- * syntax.c (scan_sexps_forward): Undo last patch.
- Use a more obvious fix: check eob before updating the syntax table.
-
-2002-11-09 Stefan Monnier <[email protected]>
-
- * syntax.c (scan_sexps_forward): Update syntax table before reading
- a char rather than after so we don't update the table past eob.
-
-2002-11-09 Dave Love <[email protected]>
-
- * buffer.c (Fset_buffer_major_mode): Fix last change.
-
- * regex.c (regexec): Fix pmatch declaration.
-
- * cmds.c (Fself_insert_command): Apply Vtranslation_table_for_input.
-
- * keyboard.c (command_loop_1): Apply Vtranslation_table_for_input
- to self-inserting characters.
- (syms_of_keyboard) <keyboard-translate-table>: Doc fix.
-
- * coding.c (Vtranslation_table_for_input): New.
- (syms_of_coding): DEFVAR it.
-
-2002-11-08 Juanma Barranquero <[email protected]>
-
- * w32term.c (w32_draw_fringe_bitmap): Remove unused local variable
- window.
-
-2002-11-08 Pavel Jan,Am(Bk <[email protected]>
-
- * process.c (Fformat_network_address): Remove unused locals p,
- cp, and i.
-
-2002-11-06 Dave Love <[email protected]>
-
- * buffer.c (Qset_buffer_major_mode_hook): New.
- (Fset_buffer_major_mode): Use it.
-
-2002-11-06 Richard M. Stallman <[email protected]>
-
- * xterm.c (x_term_init): Use turn_on_atimers, not start_polling
- and stop_polling.
-
- * process.c (wait_reading_process_input):
- Test POLLING_PROBLEM_IN_SELECT, not hpux.
- Avoid initialization for auto Lisp_Object var.
-
- * s/hpux11.h (POLLING_PROBLEM_IN_SELECT): Add #undef.
-
- * s/hpux10.h (POLLING_PROBLEM_IN_SELECT): Defined.
-
-2002-11-05 Richard M. Stallman <[email protected]>
-
- * s/sol2-5.h (BROKEN_SIGIO): Turn off the #undef.
-
- * callint.c (Fcall_interactively): New local filter_specs.
- (Fcall_interactively): Check for progn as well as let.
- Add a gcpro.
- (Qprogn): New variable.
- (syms_of_callint): Staticpro and init Qprogn.
-
-2002-11-04 John Paul Wallington <[email protected]>
-
- * lread.c (Feval_buffer): Doc fix.
-
-2002-11-04 Dave Love <[email protected]>
-
- * keyboard.c (read_char): Always translate iff
- Vkeyboard_translate_table is a char table and c is valid.
-
- * xterm.c (XTread_socket): Check Lisp types for Vx_keysym_table
- and fix C types.
-
-2002-11-03 Stefan Monnier <[email protected]>
-
- * xdisp.c (single_display_prop_intangible_p): Strings are intangible.
-
- * editfns.c (get_pos_property): Don't hardcode Qfield.
-
- * keyboard.c (adjust_point_for_property): Handle `display' prop on
- overlays. Also handle `invisible' prop.
-
-2002-11-02 Stefan Monnier <[email protected]>
-
- * coding.c (decode_coding_emacs_mule, decode_coding_iso2022)
- (decode_coding_sjis_big5, decode_eol): Allow lone \r in DOS EOL.
-
-2002-11-01 Andreas Schwab <[email protected]>
-
- * editfns.c (Fmessage): Revert last change to properly handle %%.
-
-2002-11-01 Stefan Monnier <[email protected]>
-
- * xmenu.c (unuse_menu_items): New fun.
- (menu_items_inuse): New var.
- (syms_of_xmenu): Initialize it.
- (init_menu_items): Use it to detect re-entrance.
- (Fx_popup_menu, Fx_popup_dialog, set_frame_menubar): Reset when done.
- (Fx_popup_menu): Remove spurious XSETFRAME.
-
- * editfns.c (find_field): Make an exception for nil fields.
-
-2002-11-01 Dave Love <[email protected]>
-
- * m/gec63.h: Deleted.
-
-2002-10-31 Dave Love <[email protected]>
-
- * xterm.c (XTread_socket): Fix last change.
- (xaw_scroll_callback): Cast call_data to long to avoid warning.
-
-2002-10-31 Stefan Monnier <[email protected]>
-
- * process.c (Fformat_network_address): Fix int/Lisp_Object mixup.
-
-2002-10-30 Stefan Monnier <[email protected]>
-
- * editfns.c (overlays_around, get_pos_property): New funs.
- (find_field): Use them.
- Also be careful not to modify POS before its last use.
- (Fmessage): Don't Fformat if there's nothing to format.
-
-2002-10-30 Dave Love <[email protected]>
-
- * process.c [HAVE_SYS_WAIT]: Include sys/wait.h.
- [HAVE_PTY_H]; Include pty.h.
-
- * lread.c (Fload) <!load_dangerous_libraries>: Close fd.
-
- * xterm.c (Qeql): Declare.
- (Vx_keysym_table): New.
- (syms_of_xterm): Initialize it.
- (XTread_socket): Use it. Deal with ASCII keysyms.
- (XSetIMValues) [HAVE_X11R6]: Prototype.
-
- * keyboard.c (lispy_accent_codes, lispy_accent_keys): Extended.
- (lispy_kana_keys): Comment out.
- (make_lispy_event) [XK_kana_A]: Comment out.
- (modify_event_symbol) <sizeof (long) == sizeof (EMACS_INT)>:
- Fix sprintf call.
-
- * s/osf5-0.h (C_SWITCH_SYSTEM): Revert last change (fixed by
- regexp.h change).
- (TERMINFO, LIBS_TERMCAP): Define.
-
- * s/usg5-4.h (bcopy, bzero): Define conditional on HAVE_BCOPY.
- (bcmp): Define conditional on HAVE_BCMP.
- (NO_SIOCTL_H): Don't define.
- (TIOCSIGSEND): Don't make conditional on IRIX6.
-
- * s/sol2-5.h: Don't include strings.h.
- (bcopy, bzero, bcmp) [HAVE_BCOPY]: Don't undef.
-
- * s/irix6-0.h (IRIX6): Don't define.
- (bcopy, bcmp, bzero): Don't undef.
-
- * s/irix6-5.h: Don't include strings.h.
- (IRIX6): Don't define.
- (bcopy, bcmp, bzero): Don't undef.
-
- * syntax.c (Fforward_comment): Doc fix.
-
-2002-10-29 Kim F. Storm <[email protected]>
-
- * process.c (Fsignal_process): Allow PROCESS to be specified by
- name in addition to pid (as integer or string).
-
-2002-10-28 Harald Maier <[email protected]> (tiny change)
-
- * w32heap.c: Don't redefine _heap_init and _heap_term on MSVC 7 build
- environments.
-
-2002-10-27 Kim F. Storm <[email protected]>
-
- * xterm.c (note_mouse_highlight): Don't use mouse-face if hidden.
-
- * w32term.c (note_mouse_highlight): Don't use mouse-face if hidden.
-
- * msdos.c (IT_note_mouse_highlight): Don't use mouse-face if hidden.
-
- * macterm.c (note_mouse_highlight): Don't use mouse-face if hidden.
-
-2002-10-26 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fformat): Detect invalid format letters for floats.
-
-2002-10-25 Kenichi Handa <[email protected]>
-
- * xfns.c (x_set_name): Encode by Qcompound_text unconditionally.
- (x_set_title): Likewise.
-
-2002-10-25 Juanma Barranquero <[email protected]>
-
- * macgui.h:
- * w32gui.h: Remove definition of XColor.
-
- * dispextern.h [!HAVE_X_WINDOWS]: Define XColor.
-
-2002-10-24 Kim F. Storm <[email protected]>
-
- * xdisp.c (get_window_cursor_type): New arg ACTIVE_CURSOR.
- Callers changed (supply dummy arg).
-
- * lisp.h (get_window_cursor_type): Update prototype.
-
- * w32term.c (x_display_and_set_cursor): Get active_cursor from
- get_window_cursor_type to track system caret.
-
-2002-10-24 Kim F. Storm <[email protected]>
-
- * process.c (Fformat_network_address): New function.
- (syms_of_process): Defsubr it.
- (list_processes_1): Use it to format :local/:remote address if
- service/host is not set; before Emacs would crash in that case.
- (Fmake_network_process): Don't use Ffind_operation_coding_system
- to setup coding system if host or service is not set.
-
-2002-10-23 Juanma Barranquero <[email protected]>
-
- Patch suggested by Jay Finger <[email protected]>.
-
- * w32term.c (w32_term_init): Pass XColor to w32_define_color, not
- COLORREF.
-
- * macgui.h:
- * w32gui.h: Add definition of XColor.
-
- * macfns.c:
- * w32fns.c:
- * xfaces.c: Remove definition of XColor.
-
-2002-10-22 Stefan Monnier <[email protected]>
-
- * xfns.c (x_set_name, x_set_title): `icon.value' has unsigned char.
-
- * window.c (window_loop): For GET_LRU_WINDOW and GET_LARGEST_WINDOW>,
- Only ignore truly dedicated windows. For UNSHOW_BUFFER, delete the
- window if it is dedicated.
- (Fshrink_window): Add preserve_before as was done for enlarge_window.
- (Vspecial_display_function): Update docstring.
-
- * buffer.c (assoc_ignore_text_properties, Fother_buffer, Fkill_buffer)
- (call_overlay_mod_hooks): Use CONSP and XCAR/XCDR.
- (Fget_buffer_create, advance_to_char_boundary): Use BEG and BEG_BYTE.
-
-2002-10-21 Stefan Monnier <[email protected]>
-
- * casefiddle.c (casify_region): Don't treat a prefix char as part
- of a word when at the beginning.
-
-2002-10-17 Juanma Barranquero <[email protected]>
-
- * lread.c (syms_of_lread): Fix typos.
-
-2002-10-17 Dave Love <[email protected]>
-
- * Makefile.in (TEMACS_LDFLAGS): Add trailing comment.
-
-2002-10-16 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fcopy_file): Fix backward test of KEEP_TIME.
-
-2002-10-14 Juanma Barranquero <[email protected]>
-
- * w16select.c (syms_of_win16select): Fix docstring for
- `selection-coding-system'.
-
- * w32select.c (syms_of_w32select): Likewise.
-
-2002-10-14 Stefan Monnier <[email protected]>
-
- * syntax.c (scan_lists): Don't get fooled by a symbol ending with
- a backslash-quoted char.
- (scan_lists, scan_sexps_forward): Pacify the compiler.
-
-2002-10-13 Richard M. Stallman <[email protected]>
-
- * window.c (window_scroll): Set immediate_quit.
-
- * print.c (print): When backquote form is the car of a list,
- output in old style. Use old_backquote_output to output all
- comma forms inside it in old style too.
-
- * buffer.h (struct buffer): Move `undo_list' down below `name'.
-
-2002-10-11 Markus Rost <[email protected]>
-
- * emacs.c (syms_of_emacs) <kill-emacs-hook>: Doc fix (not run in
- batch mode).
-
- * lread.c (Fload): Doc fix (load-suffixes).
-
-2002-10-10 Steven Tamm <[email protected]>
-
- * macterm.c (syms_of_macterm, mac_get_mouse_btn):
- Reverse functionality of mac-wheel-button-is-mouse-2 to be correct.
- Also switch the default to Qnil from Qt.
-
-2002-10-08 Kenichi Handa <[email protected]>
-
- * coding.c (code_convert_region): When we need more GAP for
- conversion, pay attention to the case that coding->produced is not
- greater than coding->consumed.
-
-2002-10-07 Richard M. Stallman <[email protected]>
-
- * unexelf.c (unexec): Redo 9/16 change, but only if IRIX6_5.
-
-2002-10-06 Andrew Choi <[email protected]>
-
- * macmenu.c (mac_menu_show): Add j to count menu items; match
- menu_item_selection to it to find selected item.
-
-2002-10-06 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (XTread_socket): Fix from 2002-10-03 didn't cover all
- cases. The correct fix is to pass ReparentNotify to Xt.
- The shell widget interprets ConfigureNotify differently depending
- on if it has been reparented or not.
-
-2002-10-05 Markus Rost <[email protected]>
-
- * editfns.c (Fformat_time_string): Doc fix.
-
-2002-10-05 John Paul Wallington <[email protected]>
-
- * fns.c (Flength): Doc fix.
-
-2002-10-04 Stefan Monnier <[email protected]>
-
- * keyboard.c (keyremap): New struct.
- (read_key_sequence): Use it: globally replace keytran_foo with
- keytran.foo and fkey_foo with fkey.foo. Rename temp vars
- keytran_next and fkey_next to just `next'.
-
-2002-10-04 Steven Tamm <[email protected]>
-
- * macterm.c (keycode_to_xkeysym_table): Change return to be
- treated like an X keysym.
-
-2002-10-03 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.c (XTread_socket): For ConfigureNotify, with x and y == 0,
- and USE_MOTIF, call XTranslateCoordinates to get the real x and y.
- This is to also handle x/y changes that occur because of a resize.
-
-2002-10-02 John Paul Wallington <[email protected]>
-
- * frame.c (Vdelete_frame_functions): New variable.
- (syms_of_frame): Initialize and defvar it.
- (Fdelete_frame): Use it instead of delete-frame-hook. Don't run
- it when frame's `tooltip' parameter is non-nil.
-
- * xfns.c (x_create_tip_frame): Set `tooltip' frame parameter to t.
-
- * w32fns.c (x_create_tip_frame): Likewise.
-
- * macfns.c (x_create_tip_frame): Likewise.
-
-2002-09-30 Kenichi Handa <[email protected]>
-
- * xterm.c (x_encode_char): For DIM=1 charset, set ccl->reg[2] to
- -1 before calling ccl_driver.
-
- * coding.c (decode_coding_emacs_mule): Check coding->cmp_data.
- Only when it is non-nil, handle composition sequence.
- (setup_coding_system) <0>: Don't force composition handling.
-
- * Makefile.in (lisp, shortlisp): Add utf-16.elc.
-
-2002-09-29 Richard M. Stallman <[email protected]>
-
- * search.c (Freplace_match): Adjust match data for the substitution
- just made in the buffer.
-
- * xdisp.c (STOP_POLLING, RESUME_POLLING): New macros.
- (redisplay_internal): Use them. Do RESUME_POLLING at end of function.
-
-2002-09-27 Richard M. Stallman <[email protected]>
-
- * keyboard.c (STOP_POLLING, RESUME_POLLING): New macros.
- (read_char): Use them. Do all exits thru the end of the function.
-
-2002-09-27 Kenichi Handa <[email protected]>
-
- * xfaces.c (try_font_list): Pay attention to the case that FAMILY
- is nil.
-
-2002-09-26 Richard M. Stallman <[email protected]>
-
- * regex.h (__restrict_arr): Don't define if already defined.
-
- * coding.c (run_pre_post_conversion_on_str):
- Save and restore Vdeactivate_mark.
-
-2002-09-26 John Paul Wallington <[email protected]>
-
- * minibuf.c (Fminibufferp): Add an optional `buffer' argument.
-
-2002-09-26 Kenichi Handa <[email protected]>
-
- * xfaces.c (try_font_list): New arg PREFER_FACE_FAMILY. If it is
- nonzero, try face's family at first. Otherwise try FAMILY at first.
- (choose_face_font): If C is a single byte char or latin-1, call
- try_font_list with PREFER_FACE_FAMILY 1.
-
-2002-09-21 Richard M. Stallman <[email protected]>
-
- * window.c (select_window_1): Don't select frame.
- Set frame's selected window only when frame itself is selected.
- (Fselect_window): Doc fix.
-
-2002-09-18 Kim F. Storm <[email protected]>
-
- * process.c (make-network-process): Doc fix (there is no
- network-server-log-function hook).
-
-2002-09-18 Richard M. Stallman <[email protected]>
-
- * print.c (print): Clear out the unused parts of Vprint_number_table.
- (syms_of_print): Doc fix for `print-number-table'.
-
- * unexelf.c (unexec): Undo previous change.
-
-2002-09-17 Andreas Schwab <[email protected]>
-
- * m/alpha.h [LINUX]: Don't define DATA_START.
-
-2002-09-16 Dave Love <[email protected]>
-
- * unexelf.c (unexec): Deal with .got, reinstating change from
- 25-08-1999.
-
-2002-09-13 Richard M. Stallman <[email protected]>
-
- * s/sol2-6.h (UNEXEC): Comment out definition.
-
- * unexsol.c (unexec): Don't downcase first letter of error msg.
-
- * xfaces.c (Fcolor_supported_p): Just one arg is required.
-
-2002-09-12 Markus Rost <[email protected]>
-
- * unexsol.c: Include buffer.h, charset.h, coding.h.
-
-2002-09-11 Richard M. Stallman <[email protected]>
-
- * unexsol.c: Don't use report_file_error; do it by hand
- using dlerror.
-
- * process.c (wait_reading_process_input, both versions):
- Before calling turn_on_atimers, call stop_polling.
-
- * emacs.c (syms_of_emacs) <command-line-args>: Doc fix.
-
- * xdisp.c (try_scrolling): If after make_cursor_line_fully_visible
- we go to too_near_end, call clear_glyph_matrix.
- (redisplay_window): After make_cursor_line_fully_visible,
- call clear_glyph_matrix and bypass `goto done'.
-
- * xfns.c (x_report_frame_params): If FRAME_SCROLL_BAR_PIXEL_WIDTH is 0
- and we have non-toolkit scroll bars, return nil for scroll-bar-width.
-
-2002-09-10 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fdo_auto_save): Catch error making directory.
- Only call push_message if we need to.
- At the same time, make an unwind-protect to pop it.
- Rename local message_p to old_message_p.
- (do_auto_save_make_dir, do_auto_save_eh): New functions.
- (do_auto_save_unwind): Don't call pop_message.
-
- * lisp.h (pop_message_unwind): Renamed from push_message_unwind.
-
- * keyboard.c (Fexecute_extended_command): Use pop_message_unwind.
-
- * alloc.c (Fgarbage_collect): Use pop_message_unwind.
-
- * xdisp.c (pop_message_unwind): Renamed from push_message_unwind.
-
-2002-09-10 Stefan Monnier <[email protected]>
-
- * regex.c (DISCARD_FAILURE_REG_OR_COUNT): Delete.
- (CHECK_INFINITE_LOOP): Don't pop anything: just set `cycle' to 1.
- (re_match_2_internal): Be more careful with infinite loops.
-
-2002-09-10 Kim F. Storm <[email protected]>
-
- * macros.c (end_kbd_macro): New function.
- (Fend_kbd_macro): Use it.
-
- * macros.h (end_kbd_macro): Declare extern.
-
- * keyboard.c (Fdiscard_input): If defining keyboard macro,
- end and save it instead of discarding it.
-
-2002-09-09 Markus Rost <[email protected]>
-
- * s/sol2-6.h: Fix typo. Add comment.
-
-2002-09-09 Richard M. Stallman <[email protected]>
-
- * regex.c (regnum_t): Use signed int, not unsigned int.
-
- * s/sol2-6.h: New file.
-
- * s/sol2-5.h (UNEXEC): Definition deleted.
-
-2002-09-08 Kim F. Storm <[email protected]>
-
- * macros.c (executing_macro_index): Change type to EMACS_INT.
- (syms_of_macros): DEFVAR_INT it (needed by kmacro).
-
- * macros.h (executing_macro_index): Change type to EMACS_INT.
-
-2002-09-06 Richard M. Stallman <[email protected]>
-
- * casetab.c (set_case_table): Make canon table point to eqv table.
-
-2002-09-06 Juanma Barranquero <[email protected]>
-
- * coding.c (syms_of_coding): Fix spacing.
-
- * composite.c (Fcompose_region_internal)
- (Fcompose_string_internal): Likewise.
-
- * data.c (Flsh): Likewise.
-
- * fontset.c (Fset_fontset_font): Likewise.
-
- * macfns.c (Fx_server_max_request_size): Likewise.
-
- * w16select.c (syms_of_win16select): Likewise.
-
- * w32select.c (syms_of_w32select): Likewise.
-
- * xselect.c (syms_of_xselect): Likewise.
-
-2002-09-05 Richard M. Stallman <[email protected]>
-
- * regex.c (set_image_of_range_1): In no-TRANSLATE case,
- call EXTEND_RANGE_TABLE and return a proper value.
- (set_image_of_range): Don't call set_image_of_range_1
- if no TRANSLATE or if range includes all of Latin-1.
- Only call it for the Latin-1 part of the range.
- For other cases, make two separate ranges,
- one for the original specified characters and one for
- their case-conversions.
-
-2002-09-04 Richard M. Stallman <[email protected]>
-
- * s/sol2-5.h (UNEXEC): Use unexsol.o.
-
- * window.c (displayed_window_lines): Correct for one-off bug
- in HEIGHT on non-window displays.
-
- * regex.c (set_image_of_range_1): New function.
- (set_image_of_range): Use set_image_of_range_1 for Latin-1.
- Return a value to indicate running out of memory.
- (SET_RANGE_TABLE_WORK_AREA): Check value from set_image_of_range.
- (extend_range_table_work_area): New subroutine.
- (EXTEND_RANGE_TABLE): Replaces EXTEND_RANGE_TABLE_WORK_AREA.
- Different calling conventions, and used from set_image_of_range{,_1}.
- (IMMEDIATE_QUIT_CHECK): Definitions moved.
-
-2002-09-04 Juanma Barranquero <[email protected]>
-
- * makefile.w32-in: All dependencies updated.
-
-2002-09-01 Richard M. Stallman <[email protected]>
-
- * unexsol.c: New file.
-
- * xfns.c (Qbox): Declare external, don't define.
-
- * xdisp.c (redisplay_window) <force-start case>:
- If point is on semi-visible last line, reposition
- it at previous line.
-
- * alloc.c (display_malloc_warning): Use display-warning.
- (malloc_warning_1): Function deleted.
-
- * alloc.c [ALLOC_DEBUG]: #undef INLINE.
-
- * lread.c (read1): Handle #! by skipping the line.
-
-2002-08-31 Richard M. Stallman <[email protected]>
-
- * Makefile.in (TEMACS_LDFLAGS): Renamed from ALL_LDFLAGS.
- Don't include LDFLAGS.
- (temacs): Pass LDFLAGS separately, and not via YMF_PASS_LDFLAGS.
-
-2002-08-31 Eli Zaretskii <[email protected]>
-
- * xdisp.c (get_window_cursor_type): Don't use x_highlight_frame
- member of x_display_info unless we compile for some window system.
-
-2002-08-31 Kim F. Storm <[email protected]>
-
- * xdisp.c (Valternate_cursor_type, Qalternate_cursor_type): Removed.
- (get_window_cursor_type): Don't use them.
- (syms_of_xdisp): Remove intern, staticpro, and defvar for them.
-
-2002-08-30 Kenichi Handa <[email protected]>
-
- * xdisp.c (get_next_display_element): Fix previous change.
-
-2002-08-30 Andrew Choi <[email protected]>
-
- * macterm.c (expose_overlaps): New function (merge code from xterm.c).
- (expose_window): Use it to fix the display of overlapping
- rows (merge code from xterm.c).
-
- * macfns.c (Qbox): Add extern declaration.
-
-2002-08-30 Juanma Barranquero <[email protected]>
-
- * w32fns.c (Qbox): Make extern.
- (syms_of_w32fns): Remove initialization of Qbox.
-
-2002-08-30 Rune Kleveland <[email protected]> (tiny change)
-
- * xfns.c (Fx_open_connection): Fix error message.
-
-2002-08-30 Kim F. Storm <[email protected]>
-
- The following changes consolidates the handling of the cursor
- type in xdisp.c, moving duplicate code and functionality from
- xfns.c, xterm.c, w32fns.c, w32term.c, macfns.c, and macterm.c.
-
- * frame.h (enum text_cursor_kinds): Consolidated here.
- Added DEFAULT_CURSOR value.
- (struct frame) <desired_cursor, cursor_width>
- <blink_off_cursor, blink_off_cursor_width>: New fields.
- Consolidated from output_x, output_w32 and output_mac structs.
- (FRAME_DESIRED_CURSOR, FRAME_CURSOR_WIDTH, FRAME_BLINK_OFF_CURSOR)
- (FRAME_BLINK_OFF_CURSOR_WIDTH): Macros consolidated here.
-
- * xdisp.c (Qbar, Qhbar, Qbox, Qhollow, Vblink_cursor_alist):
- Variables consolidated here.
- (Valternate_cursor_type, Qalternate_cursor_type): New variables.
- (Vcursor_in_non_selected_windows): Renamed from
- cursor_in_non_selected_windows and changed to Lisp_Object.
- (syms_of_xdisp): Define and staticpro new and moved variables.
- (get_specified_cursor_type): Renamed from x_specified_cursor_type;
- consolidated here. Recognize Qhollow setting.
- (set_frame_cursor_types): New function to set frame cursor types
- based on the frame parameters.
- (get_window_cursor_type): New function to calculate new cursor
- type and width for the specified window. Based on duplicated
- code consolidated here.
- Enhancements: cursor-in-non-selected-windows may be a cursor type,
- check buffer-local alternate-cursor-type and blink-cursor-alist
- before using built-in blink off methods.
-
- * dispextern.h (cursor_in_non_selected_windows): Extern removed.
-
- * lisp.h (Qcursor_in_non_selected_windows): Extern removed.
- (get_specified_cursor_type, get_window_cursor_type)
- (set_frame_cursor_types): Added prototypes.
-
- * macfns.c (x_specified_cursor_type): Removed.
- (x_set_cursor_type): Use set_frame_cursor_types.
- (Qbar, Qbox): Removed.
- (syms_of_macfns): Don't intern or staticpro them.
-
- * macterm.c (x_specified_cursor_type): Remove prototype.
- (x_draw_bar_cursor): Use FRAME_CURSOR_WIDTH.
- (x_display_and_set_cursor): Use get_window_cursor_type.
- Remove unused local variables cursor_non_selected, active_cursor.
- Redraw cursor if hbar cursor width changes.
- (make_mac_frame): Set FRAME_DESIRED_CURSOR.
-
- * macterm.h (enum text_cursor_kinds): Removed.
- (struct output_mac) <current_cursor, desired_cursor, cursor_width>
- <blink_off_cursor, blink_off_cursor_width>: Members removed.
- (FRAME_DESIRED_CURSOR): Macro removed.
-
- * w32fns.c (Vblink_cursor_alist): Removed.
- (Qbar, Qhbar, Qbox, Qhollow): Removed.
- (syms_of_w32fns): Don't intern, staticpro, or define them.
- (x_specified_cursor_type): Removed.
- (x_set_cursor_type): Use set_frame_cursor_types.
-
- * w32term.c (x_specified_cursor_type): Remove prototype.
- (x_draw_bar_cursor): Use FRAME_CURSOR_WIDTH.
- (x_display_and_set_cursor): Use get_window_cursor_type.
- Remove unused local variables cursor_off_state.
- Redraw cursor if hbar cursor width changes.
- Changed all occurrences of w32_highlight_frame to x_highlight_frame.
-
- * w32term.h (enum text_cursor_kinds): Removed.
- (struct output_w32) <current_cursor, desired_cursor, cursor_width>
- <blink_off_cursor, blink_off_cursor_width>: Members removed.
- (FRAME_DESIRED_CURSOR, FRAME_CURSOR_WIDTH, FRAME_BLINK_OFF_CURSOR)
- (FRAME_BLINK_OFF_CURSOR_WIDTH): Macros removed.
- (struct w32_display_info) <x_highlight_frame>: Renamed member from
- w32_highlight_frame.
-
- * xfns.c (Vblink_cursor_alist): Removed.
- (Qbar, Qhbar, Qbox, Qhollow): Removed.
- (syms_of_xfns): Don't intern, staticpro, or define them.
- (x_specified_cursor_type): Removed.
- (x_set_cursor_type): Use set_frame_cursor_types.
-
- * xterm.c (x_specified_cursor_type): Remove prototype.
- (x_draw_bar_cursor): Use FRAME_CURSOR_WIDTH.
- (x_display_and_set_cursor): Use get_window_cursor_type.
- Remove unused local variables cursor_off_state.
- Redraw cursor if hbar cursor width changes.
-
- * xterm.h (enum text_cursor_kinds): Removed.
- (struct output_x) <current_cursor, desired_cursor, cursor_width>
- <blink_off_cursor, blink_off_cursor_width>: Members removed.
- (FRAME_DESIRED_CURSOR, FRAME_CURSOR_WIDTH, FRAME_BLINK_OFF_CURSOR)
- (FRAME_BLINK_OFF_CURSOR_WIDTH): Macros removed.
- (x_specified_cursor_type): Remove prototype.
-
-2002-08-28 Richard M. Stallman <[email protected]>
-
- * w32fns.c (x_set_cursor_type): Set FRAME_BLINK_OFF_CURSOR and
- FRAME_BLINK_OFF_CURSOR_WIDTH using defaults and Vblink_cursor_alist.
- (Vblink_cursor_alist): New variable.
- (syms_of_w32fns): Initialize and defvar it.
- (x_specified_cursor_type): Recognize Qbox for filled box.
- Exceptions are hollow boxes.
- (Qbox, Qhollow): New variables.
- (syms_of_w32fns): Initialize and staticpro them.
-
- * w32term.h (FRAME_BLINK_OFF_CURSOR, FRAME_BLINK_OFF_CURSOR_WIDTH):
- New macros.
- (struct w32_output): New fields blink_off_cursor,
- blink_off_cursor_width.
- (FRAME_CURSOR_WIDTH): New macro.
-
- * w32term.c (x_display_and_set_cursor): Use FRAME_BLINK_OFF_CURSOR
- and FRAME_BLINK_OFF_CURSOR_WIDTH for blinking cursor off.
-
- * w32term.c (x_display_and_set_cursor): Check FRAME_CURSOR_WIDTH
- for bar cursor.
-
- * w32term.c (expose_overlaps): New function.
- (expose_window): Use it to fix the display of overlapping rows.
-
-2002-08-28 Simon Josefsson <[email protected]>
-
- * xfns.c (Fx_open_connection): Improve help when X connection
- fails, xhost is insecure and xauth is better.
-
-2002-08-28 Juanma Barranquero <[email protected]>
-
- * makefile.w32-in: Add missing dependencies on w32term.h and
- composite.h.
-
- * emacs.c (USAGE1): Add missing newline.
-
-2002-08-27 Andrew Choi <[email protected]>
-
- * s/darwin.h [HAVE_LIBNCURSES]: Define HAVE_TERMINFO.
-
-2002-08-27 Richard M. Stallman <[email protected]>
-
- * xfns.c (x_set_cursor_type): Set FRAME_BLINK_OFF_CURSOR and
- FRAME_BLINK_OFF_CURSOR_WIDTH using defaults and Vblink_cursor_alist.
- (Vblink_cursor_alist): New variable.
- (syms_of_xfns): Initialize and defvar it.
- (x_specified_cursor_type): Recognize Qbox for filled box.
- Exceptions are hollow boxes.
- (Qbox, Qhollow): New variables.
- (syms_of_xfns): Initialize and staticpro them.
-
- * xterm.h (FRAME_BLINK_OFF_CURSOR, FRAME_BLINK_OFF_CURSOR_WIDTH):
- New macros.
- (struct x_output): New fields blink_off_cursor, blink_off_cursor_width.
-
- * xterm.c (x_display_and_set_cursor): Use FRAME_BLINK_OFF_CURSOR
- and FRAME_BLINK_OFF_CURSOR_WIDTH for blinking cursor off.
-
- * emacs.c (main): Handle --script.
- (USAGE1): Mention --script.
- (standard_args): Define sort order for --script.
-
-2002-08-27 Gerd Moellmann <[email protected]>
-
- * xdisp.c (redisplay_updating_p): Variable removed.
- (inhibit_free_realized_faces, Qinhibit_free_realized_faces):
- New variables.
- (init_iterator): Don't free realized faces if
- inhibit_free_realized_faces is set.
- (redisplay_internal): Bind Qinhibit_free_realized_faces to nil.
- (syms_of_xdisp): DEFVAR_BOOL inhibit-free-realized-faces,
- initialize Qinhibit_free_realized_faces.
-
- * dispextern.h (PRODUCE_GLYPHS): Set inhibit_free_realized_faces
- when iterator is adding glyphs to a glyph matrix.
-
-2002-08-27 Kenichi Handa <[email protected]>
-
- * xdisp.c (get_next_display_element): In unibyte case, don't use
- octal form for such eight-bit characters that can be converted to
- multibyte char.
-
-2002-08-26 Kim F. Storm <[email protected]>
-
- * frame.c (make_terminal_frame) [CANNOT_DUMP]: Initialize
- foreground and background colors. From Joe Buehler.
-
-2002-08-26 Miles Bader <[email protected]>
-
- * bytecode.c (Fbyte_code): Fsub1 can GC, so protect it.
-
-2002-08-25 Andrew Choi <[email protected]>
-
- * emacs.c (main): Call init_mac_osx_environment if HAVE_CARBON is
- defined instead of MAC_OSX.
-
- * s/darwin.h (select): Define select to sys_select only if
- HAVE_CARBON is defined.
- (HAVE_WORKING_VFORK): #undef it. Define vfork to fork.
- (DONT_REOPEN_PTY): #def it.
-
- * macterm.c (XTread_socket): Remove code to call
- SendEventToEventTarget for keys with command modifiers when
- mac_command_key_is_meta is nil.
-
-2002-08-24 Andreas Schwab <[email protected]>
-
- * eval.c (Fdefvar): Fix last change.
-
-2002-08-23 Richard M. Stallman <[email protected]>
-
- * eval.c (Fdefvar, Fdefconst, Fdefvaralias):
- Record variables in load history as (defvar . VAR).
- (Fdefvar): Don't record in load history if no initial value.
- (Qdefvar): New variable.
- (syms_of_eval): Init and staticpro it.
-
- * lread.c (syms_of_lread): Doc fix.
- (build_load_history): Use Fmember to see if a definition
- is already in the Vload_history element.
-
- * process.c (Fstart_process): Remove /: from program name.
-
- * emacs.c (decode_env_path): Don't add /: if file name handler
- has a `safe-magic' property.
-
- * callproc.c (Fcall_process): Remove /: from program name.
-
-2002-08-23 Stefan Monnier <[email protected]>
-
- * regex.c (PATFETCH): Remove the translating fetch.
- (PATFETCH_RAW): Rename to PATFETCH.
- (set_image_of_range): New fun.
- (SET_RANGE_TABLE_WORK_AREA): Use it.
- (regex_compile): Don't translate the pattern chars so eagerly.
- Only do it when inserting an `exactn' bytecode or when handling
- a char-range.
- (mutually_exclusive_p): Avoid empty statement.
-
-2002-08-22 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Do not `goto try_to_scroll' when we
- end up on a partially visible line; this reverts a specific part
- of the 2002-07-07 change by Richard M. Stallman to "fix" a nasty
- display error which has been reported several times now.
- However it introduces the problem that changes was supposed to fix.
- See my comments in the source if you want to debug this further.
-
-2002-08-20 Kenichi Handa <[email protected]>
-
- * abbrev.c (Fexpand_abbrev): Fix for the multibyte case.
-
-2002-08-19 Eli Zaretskii <[email protected]>
-
- * msdos.c (croak): Add `void' to definition.
-
- * sysdep.c (request_sigio, unrequest_sigio) [MSDOS]:
- Don't define them, they are defined in msdos.c.
-
- * mem-limits.h [MSDOS]: Declare etext.
-
- * fileio.c (Ffile_name_directory) [DOS_NT]: Don't declare `beg'
- `const' since CORRECT_DIR_SEPS modifies its target.
-
-2002-08-19 Kim F. Storm <[email protected]>
-
- * keyboard.c (Fclear_this_command_keys): Add optional arg
- KEEP-RECORD to avoid clearing lossage when we just want to clear
- the current key sequence (kmacro needs this).
-
-2002-08-19 Kenichi Handa <handa@localhost>
-
- * composite.c (run_composition_function): Call FUNC if it is fboundp.
-
- * composite.h (COMPOSITION_MODIFICATION_FUNC): If PROP is not a
- cons, return Qnil.
-
-2002-08-17 Richard M. Stallman <[email protected]>
-
- * s/sol2-5.h (BROKEN_SIGIO): Add #undef.
-
- * sysdep.c [!VMS]: Include sys/files.h.
-
- * editfns.c (save_restriction_restore): Defend from unchained marker.
-
- * buffer.c (overlays_at): Handle extending vec uniformly.
- (overlays_in): Handle extending vec from length 0 as in overlays_at.
-
-2002-08-15 Andrew Choi <[email protected]>
-
- * mac.c (init_mac_osx_environment): New function.
-
- * emacs.c (main) [MAC_OSX]: Call init_mac_osx_environment.
-
-2002-08-14 Kim F. Storm <[email protected]>
-
- * macros.c (Fstart_kbd_macro): Added NO-EXEC argument to inhibit
- executing macro before appending to it (when used from Lisp).
- (Fexecute_kbd_macro): Added LOOPFUNC argument to supply function
- which is called prior to each iteration of macro (for kmacro.el).
- (Fend_kbd_macro, Fcall_last_kbd_macro): Likewise.
-
- * lisp.h (Fexecute_kbd_macro): Update prototype.
-
- * keyboard.c (Fcommand_execute): Update call to Fexecute_kbd_macro.
-
-2002-08-14 Kenichi Handa <[email protected]>
-
- * xselect.c (QUTF8_STRING): New variable.
- (symbol_to_x_atom): Pay attention to QUTF8_STRING.
- (x_atom_to_symbol): Likewise.
- (x_get_local_selection): New argument local_request. If it is
- nonzero, call handler_fn with the second arg nil.
- (x_handle_selection_request): Call x_get_local_selection with
- local_request 0.
- (lisp_data_to_selection_data): Don't encode the string here.
- (Fx_get_selection_internal): Call x_get_local_selection with
- local_request 1.
- (syms_of_xselect): Intern and staticpro QUTF8_STRING.
-
- * xterm.c (x_term_init): Initialize dpyinfo->Xatom_UTF8_STRING.
-
- * xterm.h (struct x_display_info): New member Xatom_UTF8_STRING.
-
-2002-08-13 Richard M. Stallman <[email protected]>
-
- * minibuf.c (Fminibufferp): New function.
- (syms_of_minibuf): Defsubr it.
- (Fminibuffer_prompt_end): Handle non-minibuffers specially.
-
-2002-08-13 Gerd Moellmann <[email protected]>
-
- * coding.c (Funencodable_char_position): Lisp_Object/int mixup.
-
-2002-08-12 Richard M. Stallman <[email protected]>
-
- * syswait.h: Only the include of sys/wait.h tests HAVE_SYS_WAIT_H.
- [!VMS] (WCOREDUMP, WEXITSTATUS, WIFEXITED, WIFSTOPPED, WIFSIGNALED)
- (WSTOPSIG, WTERMSIG): Define each one independently if not defined
- already.
-
- * buffer.c (syms_of_buffer) <fill-column>: Doc fix.
-
-2002-08-11 Andrew Choi <[email protected]>
-
- * macterm.c (XTmouse_position): Check wp with is_emacs_window.
- (Vmac_pass_command_to_system): New variable.
- (Vmac_pass_control_to_system): New variable.
- (do_mouse_moved): Check wp with is_emacs_window.
- (XTread_socket): Check window_ptr with is_emacs_window.
- Call FrontNonFloatingWindow instead of FrontWindow. Send keydown
- events back to Mac Toolbox for processing, depending on values of
- Vmac_pass_command_to_system and Vmac_pass_control_to_system.
- (syms_of_macterm): DEFVAR_LISP Vmac_pass_command_to_system and
- Vmac_pass_control_to_system.
-
-2002-08-10 Kenichi Handa <[email protected]>
-
- * coding.c (unencodable_char_position): New function.
- (Funencodable_char_position): New function.
- (syms_of_coding): Defsubr Funencodable_char_position.
-
-2002-08-10 Andrew Choi <[email protected]>
-
- * mac.c (sys_select) [MAC_OSX]: New function.
-
- * macterm.c (MakeMeTheFrontProcess): New function.
- (mac_initialize): Call MakeMeTheFrontProcess.
-
- * s/darwin.h: Define select to sys_select.
-
-2002-08-09 Richard M. Stallman <[email protected]>
-
- * keyboard.c (make_lispy_event): Test WINDOWSNT, not WINDOWS_NT.
-
-2002-08-09 Gerd Moellmann <[email protected]>
-
- * xdisp.c (forward_to_next_line_start): Return 0 when reaching the
- end of the buffer.
-
-2002-08-08 Ken Raeburn <[email protected]>
-
- * coding.c (Ffind_operation_coding_system): Fix Lisp_Object/int mixup.
-
- * puresize.h (BASE_PURESIZE): Increase to 910000.
-
-2002-08-08 Kenichi Handa <[email protected]>
-
- * coding.c (Ffind_operation_coding_system): For write-region, if
- VISIT is a filename, make it the target.
-
-2002-08-07 Richard M. Stallman <[email protected]>
-
- * alloc.c (mark_object): Detect long lists for debugging.
- (mark_object_loop_halt): New variable.
-
- * s/hpux10.h (C_SWITCH_SYSTEM): #undef it.
-
- * data.c (Fmake_variable_frame_local): Doc fix.
-
-2002-08-01 David Ponce <[email protected]>
-
- * w32menu.c (local_heap, local_alloc, local_free): New macros.
- (malloc_widget_value, free_widget_value)
- (w32_free_submenu_strings): Use them.
-
- (push_submenu_start, push_submenu_end, push_left_right_boundary)
- (push_menu_pane, push_menu_item, single_keymap_panes)
- (single_menu_item, Fx_popup_menu, menubar_selection_callback)
- (single_submenu, set_frame_menubar)
- (w32_menu_show, w32_dialog_show): Use AREF, ASET, ASIZE.
-
- (Fx_popup_menu): Don't show pop up menu until preceding one is
- actually cleaned up. Moved UNGCPRO outside #ifdef HAVE_MENUS block.
-
- * w32menu.c: Changes adapted from xmenu.c
- (set_frame_menubar): First parse all submenus,
- then make widget_value trees from them.
- Don't allocate any widget_value objects
- until we are done with the parsing.
- (parse_single_submenu): New function.
- (digest_single_submenu): New function.
- (single_submenu): Function deleted, replaced by those two.
-
-2002-08-04 Andrew Choi <[email protected]>
-
- * macterm.c (XTread_socket): Check that FrontNonFloatingWindow
- returns a valid window pointer before proceeding for keyDown and
- autoKey events.
-
-2002-08-03 Andrew Choi <[email protected]>
-
- * macterm.c (USE_CARBON_EVENTS): New macro.
- (macCtrlKey, macShiftKey, macMetaKey, macAltKey): New macros.
- (x_iconify_frame): Call CollapseWindow.
- (Vmac_reverse_ctrl_meta): New variable.
- (Vmac_wheel_button_is_mouse_2): New variable.
- (init_mac_drag_n_drop): New function.
- (mac_do_receive_drag): New function.
- (mac_handle_service_event): New function.
- (init_service_handler): New function.
- (mac_to_emacs_modifiers): New function.
- (mac_event_to_emacs_modifiers): New function.
- (mac_get_mouse_btn): New function.
- (mac_convert_event_ref): New function.
- (XTread_socket) [USE_CARBON_EVENTS]: Call ReceiveNextEvent,
- SendEventToEventTarget, mac_event_to_emacs_modifiers, and
- mac_get_mouse_btn.
- (mac_initialize): Call init_mac_drag_n_drop and init_service_handler.
-
- * keyboard.c: Define Qmouse_wheel, mouse_wheel_syms, and
- lispy_mouse_wheel_names for MAC_OSX as well as for WINDOWS_NT.
- (kbd_buffer_get_event): Set used_mouse_menu for MENU_BAR_EVENT and
- TOOL_BAR_EVENT for MAC_OS as well.
- (make_lispy_event): Handle MOUSE_WHEEL_EVENT for MAC_OSX as well
- as for WINDOWS_NT.
- (syms_of_keyboard): Initialize Qmouse_wheel for MAC_OSX.
-
- * termhooks.h (event_kind): Define MOUSE_WHEEL_EVENT also for MAC_OSX.
-
-2002-08-03 Gerd Moellmann <[email protected]>
-
- * xdisp.c (forward_to_next_line_start): Fix a condition that
- lead to a newline being skipped.
-
-2002-08-02 Andrew Choi <[email protected]>
-
- * mac.c (syms_of_mac): Defsubr Sx_selection_exists_p.
-
-2002-08-01 Richard M. Stallman <[email protected]>
-
- * Makefile.in (SOME_MACHINE_OBJECTS): Add fontset.o.
-
-2002-07-31 Andrew Choi <[email protected]>
-
- * macfns.c: #undef init_process before #define-ing it.
-
- * s/darwin.h: Define MAC_OS, SYMS_SYSTEM, and OTHER_FILES only if
- HAVE_CARBON is defined.
-
-2002-07-31 Richard M. Stallman <[email protected]>
-
- * xmenu.c (set_frame_menubar): First parse all submenus,
- then make widget_value trees from them.
- Don't allocate any widget_value objects
- until we are done with the parsing.
- (parse_single_submenu): New function.
- (digest_single_submenu): New function.
- (single_submenu): Function deleted, replaced by those two.
-
-2002-07-30 Juanma Barranquero <[email protected]>
-
- * w32proc.c (syms_of_ntproc): Fix docstring of
- `w32-get-true-file-attributes'.
-
-2002-07-28 Richard M. Stallman <[email protected]>
-
- * s/hpux8.h (HPUX8): Define this before including hpux.h.
- (HAVE_SYS_WAIT_H): #define deleted; we let Autoconf decide.
-
- * s/hpux.h (HAVE_SYS_WAIT_H): The #undef is conditional on HPUX8.
-
- * keyboard.c (make_lispy_event):
- Use #ifdef to test USE_TOOLKIT_SCROLL_BARS.
- Explicitly clear up_modifier in event->modifiers.
-
-2002-07-27 Richard M. Stallman <[email protected]>
-
- * xterm.h (FRAME_CURSOR_WIDTH): New macro.
-
- * xterm.c (x_display_and_set_cursor): Check FRAME_CURSOR_WIDTH
- for bar cursor.
-
-2002-07-26 Kenichi Handa <[email protected]>
-
- * coding.c (detect_coding_iso2022): While checking a byte sequence
- for CODING_CATEGORY_MASK_ISO_8_2, if we read one extra byte, check
- it in the normal loop.
-
-2002-07-24 Gerd Moellmann <[email protected]>
-
- * xterm.c (expose_overlaps): New function.
- (expose_window): Use it to fix the display of overlapping rows.
-
- * xdisp.c (unwind_redisplay): Clear redisplay_updating_p.
-
-2002-07-23 Ken Raeburn <[email protected]>
-
- * lisp.h (XPNTR): Use NO_UNION_TYPE version for union as well,
- since it only depends on XUINT.
-
- * m/alpha.h (BITS_PER_LONG, BITS_PER_EMACS_INT, EMACS_INT,
- EMACS_UINT, SPECIAL_EMACS_INT, DATA_SEG_BITS,
- PNTR_COMPARISON_TYPE, VALBITS, MARKBIT, XINT, XUINT, XPNTR):
- Macros deleted.
-
- * mem-limits.h (start_of_data): If DATA_START is defined, prefer
- its value over other approaches.
- * sysdep.c (start_of_data): Don't define the function if a macro
- form has been defined.
-
-2002-07-23 Gerd Moellmann <[email protected]>
-
- * xdisp.c (redisplay_updating_p): New variable.
- (init_iterator): Don't free realized faces when
- redisplay_updating_p is set.
- (redisplay_internal): Set redisplay_updating_p while updating
- the display.
-
-2002-07-23 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fmessage): Treat "" like nil.
-
-2002-07-23 Kenichi Handa <[email protected]>
-
- * xdisp.c (face_before_or_after_it_pos):
- Call FETCH_MULTIBYTE_CHAR with byte postion, not char position.
-
-2002-07-22 Juanma Barranquero <[email protected]>
-
- * callproc.c (init_callproc) [DOS_NT]:
- Initialize Vshared_game_score_directory to nil.
- (syms_of_callproc) [DOS_NT]: Likewise.
-
-2002-07-22 Gerd Moellmann <[email protected]>
-
- * xdisp.c (display_line): Replace an abort with xassert.
-
-2002-07-21 Richard M. Stallman <[email protected]>
-
- * xdisp.c (redisplay_window): Don't test BEG_UNCHANGED
- and END_UNCHANGED when setting buffer_unchanged_p.
- Use current_matrix_up_to_date_p to decide whether to use
- try_cursor_movement.
-
- * config.in (HAVE_SHARED_GAME_DIR): Undef deleted.
-
- * epaths.in (PATH_GAME): New macro, edited by ../Makefile.in.
-
- * callproc.c (init_callproc): Set up Vshared_game_score_directory.
- Set to nil if dir does not exist.
- (syms_of_callproc): Init unconditionally and simply.
-
- * buffer.c (Fbuffer_list): Doc fix.
-
-2002-07-21 Ken Raeburn <[email protected]>
-
- * sysdep.c (end_of_text, end_of_data): Unused functions deleted.
-
- * buffer.c (mmap_realloc): When shrinking, make sure number of
- pages to unmap is rounded towards zero.
-
- * m/mips-siemens.h (XSETUINT, XSETPNTR): Unused macros deleted.
- (XSETINT): Deleted.
-
- * m/att3b.h (XINT): Don't define.
- (VALBITS, VALMASK, XTYPE): Deleted.
- (DATA_SEG_BITS): Define.
- * m/gec63.h (VALBITS, VALAMASK, XTYPE, XSETTYPE, XPNTR, XSET,
- ARRAY_MARK_FLAG): Deleted.
- (DATA_SEG_BITS): Define.
- * m/pfa50.h (VALBITS, VALMASK, XTYPE): Deleted.
- (DATA_SEG_BITS): Define.
-
-2002-07-20 Richard M. Stallman <[email protected]>
-
- * print.c (print_error_message): New args CONTEXT and CALLER.
- Calls changed.
-
- * lisp.h (print_error_message): Declare new args.
-
- * keyboard.c (cmd_error_internal): Pass Vsignaling_function
- and CONTEXT to print_error_message, don't print them here.
- For a Quit, don't use Vsignaling_function.
- Call message_log_maybe_newline.
-
- * Makefile.in (xsmfns.o): Don't depend on lisp.h.
-
-2002-07-20 Kim F. Storm <[email protected]>
-
- * xdisp.c (redisplay_window): Test MODIFF to set buffer_unchanged_p.
-
-2002-07-19 Ken Raeburn <[email protected]>
-
- * bytecode.c (struct byte_stack): Pointers into byte string now
- point to const.
- * callproc.c (Fcall_process): Make NEW_ARGV array hold pointer to
- const.
- * charset.h (BCOPY_SHORT): Source pointer now points to const.
- * coding.c (encode_eol, detect_coding, detect_eol):
- (decode_coding, encode_coding, detect_coding_system):
- Source strings now treated as const.
- (decode_coding_string, encode_coding_string): Use STRING_COPYIN to
- modify Lisp string contents.
- * coding.h (decode_coding, encode_coding, detect_coding,
- detect_eol): Declarations updated.
- * composite.c (compose_chars_in_text): Treat Lisp string contents
- as const.
- * dispnew.c (safe_bcopy): Source pointer now points to const.
- * lisp.h (STRING_COPYIN): New macro.
- (detect_coding_system, safe_bcopy, temp_output_buffer_setup):
- (internal_with_output_to_temp_buffer): Declarations updated.
- * print.c (temp_output_buffer_setup):
- (internal_with_output_to_temp_buffer): Buffer name argument is now
- pointer to const.
- * sound.c (struct sound_device): Function pointer field "write"
- buffer argument now points to const.
- (vox_write): Buffer argument points to const.
- * syntax.c (Fstring_to_syntax, skip_chars): Treat Lisp string
- contents as const.
- * sysdep.c (emacs_write): Buffer pointer now const.
- * term.c (encode_terminal_code): Buffer pointer now const.
- * xfaces.c (may_use_scalable_font_p): Argument now points to const.
- (x_face_list_fonts, x_update_menu_appearance):
- (hash_string_case_insensitive): Treat Lisp string contents as const.
-
-2002-07-19 Juanma Barranquero <[email protected]>
-
- * xdisp.c (syms_of_xdisp): Remove redundant deprecation info.
-
- * fileio.c (syms_of_fileio): Likewise.
- (Ffile_name_as_directory): Fix argument name in docstring.
- (file_name_as_directory): Use literal '/' instead of DIRECTORY_SEP.
-
-2002-07-18 Richard M. Stallman <[email protected]>
-
- * data.c (Fdefalias): Doc fix.
-
-2002-07-17 Dave Love <[email protected]>
-
- * intervals.h (text_property_stickiness): Use P_.
-
- * ccl.c: Remove `emacs' conditionals.
- (ccl_backtrace_table): Fix size spec.
- (ccl_driver): Fix type errors.
-
-2002-07-16 Ken Raeburn <[email protected]>
-
- * alloc.c (xstrdup, make_string, make_unibyte_string)
- (make_multibyte_string, build_string): String pointer args now
- point to const.
- * charset.c (find_charset_in_text, c_string_width):
- (chars_in_text, multibyte_chars_in_text, parse_str_as_multibyte):
- * fileio.c (report_file_error):
- * insdel.c (copy_text, count_size_as_multibyte, insert_1):
- (count_combining_before, count_combining_after, insert_1_both):
- (insert, insert_and_inherit, insert_string):
- (insert_before_markers, insert_before_markers_and_inherit):
- * lread.c (intern, oblookup, hash_string):
- * minibuf.c (temp_echo_area_glyphs):
- * search.c (fast_c_string_match_ignore_case):
- * sysdep.c (emacs_open, set_file_times):
- * xfaces.c (xstricmp):
- * xdisp.c (store_frame_title, string_char_and_length):
- (message_dolog, message2, message2_nolog, set_message): Likewise.
- (set_message_1): Cast message string argument to const pointer.
- * editfns.c (general_insert_function): Insertion function now
- takes pointer to const for input data.
- * charset.h (find_charset_in_text, c_string_width):
- (parse_str_as_multibyte): Declarations updated.
- * dispextern.h (xstricmp): Declaration updated.
- * lisp.h (chars_in_text, multibyte_chars_in_text, copy_text):
- (count_size_as_multibyte, count_combining_before):
- (count_combining_after, insert_1, insert_1_both, message_dolog):
- (insert, insert_and_inherit, insert_before_markers)
- (insert_before_markers_and_inherit, set_message, message2):
- (message2_dolog, build_string, make_string, make_unibyte_string):
- (make_multibyte_string, intern, oblookup, report_file_error):
- (fast_c_string_match_ignore_case, temp_echo_area_glyphs):
- (emacs_open, xstrdup): Declarations updated.
- * systime.h (set_file_times): Declaration updated.
-
- * charset.c (find_charset_in_text, lisp_string_width): Use const
- for pointer to lisp string data.
- * charset.h (FETCH_STRING_CHAR_ADVANCE):
- (FETCH_STRING_CHAR_ADVANCE_NO_CHECK):
- * coding.c (Ffind_coding_systems_region_interval):
- * fileio.c (Ffile_name_directory, Ffile_name_nondirectory):
- (Fmake_directory_internal, Fdelete_directory):
- (Ffile_name_absolute_p, Fwrite_region, double_dollars):
- * fontset.c (font_family_registry, fs_query_fontset):
- (list_fontsets):
- * frame.c (Fframe_parameter):
- * keyboard.c (cmd_error_internal):
- * keymap.c (Fdescribe_buffer_bindings):
- * lread.c (complete_filename_p, openp):
- * minibuf.c (Fminibuffer_complete_word):
- * xdisp.c (string_pos_nchars_ahead, init_from_display_pos):
- (face_before_or_after_it_pos, next_element_from_string):
- (get_overlay_arrow_glyph_row, display_mode_element):
- (decode_mode_spec_coding):
- * xterm.c (same_x_server): Likewise.
-
- * buffer.c (reset_buffer_local_variables): Delete "#if 0"
- settings of non-existent fields.
-
- * editfns.c (Fstring_to_char): Don't use XSTRING/XSETSTRING to
- copy a lisp value.
-
- * lread.c (Fintern_soft): Use string macros instead of
- Lisp_String fields.
- * keyboard.c (echo_char, parse_modifiers_uncached):
- (parse_solitary_modifier, Fexecute_extended_command): Likewise.
- * textprop.c (validate_interval_range, interval_of): Likewise.
-
- * fontset.c (Fset_fontset_font): Use SDATA instead of XSTRING()->data.
-
- * charset.h (FETCH_STRING_CHAR_ADVANCE)
- (FETCH_STRING_CHAR_ADVANCE_NO_CHECK): Use SBYTES instead of
- XSTRING()->size_byte.
-
- * lisp.h (SDATA, SREF): Produce rvalue.
- (SSET): New macro.
- * alloc.c (make_event_array): Use SSET for storing into a string.
- * buffer.c (Fother_buffer): Use SREF when retrieving a byte from
- a string.
- * casefiddle.c (casify_object): Use SSET.
- * charset.h (FETCH_STRING_CHAR_ADVANCE)
- (FETCH_STRING_CHAR_ADVANCE_NO_CHECK): Use SDATA when getting
- address of string contents.
- * data.c (Faref): Use SDATA.
- (Faset): Use SDATA, SSET.
- * dired.c (directory_files_internal): Use SSET.
- * fileio.c (Fmake_symbolic_link, Fexpand_file_name): Use SSET.
- (Fread_file_name): Use SREF, SSET.
- * fns.c (concat): Use SSET.
- (concat, Fdelete): Use SDATA.
- * insdel.c (insert_from_string_1): Use SDATA.
- * keyboard.c (Fevent_convert_list): Use SREF.
- * lread.c (Fload): Use SDATA, SSET.
- * macfns.c (validate_x_resource_name): Use SSET.
- * process.c (status_message): Use SSET.
- * search.c (wordify): Use SDATA.
- (Freplace_match): Use SREF.
- * w32fns.c (validate_x_resource_name): Use SSET.
- * xfns.c (validate_x_resource_name): Use SSET.
- * xterm.c (x_catch_errors, x_clear_errors): Use SSET.
-
-2002-07-16 Richard M. Stallman <[email protected]>
-
- * s/hpux11.h (USG_SUBTTY_WORKS): Defined.
-
- * xdisp.c (reconsider_clip_changes):
- Don't test prevent_redisplay_optimizations_p.
- (redisplay_internal): Test prevent_redisplay_optimizations_p
- along with clip_changed in some cases.
- (try_window_id): Likewise.
- (redisplay_window): New local var buffer_unchanged_p.
-
- * keyboard.c (cmd_error) [HAVE_X_WINDOWS]: Maybe call cancel_houglass.
-
- * process.c (create_process): Test USG_SUBTTY_WORKS.
- (process_send_signal): Clean up handling of GID.
- Detect errors in ioctls meant to set GID.
-
- * window.c (temp_output_buffer_show):
- Don't set prevent_redisplay_optimizations_p.
-
-2002-07-15 Juanma Barranquero <[email protected]>
-
- * eval.c (Fdefvaralias): Add docstring argument.
-
-2002-07-15 Ken Raeburn <[email protected]>
-
- * lisp.h (STRING_INTERVALS): Produce rvalue.
- (STRING_SET_INTERVALS): New macro.
- * buffer.c (Fget_buffer_create, Fmake_indirect_buffer): Use it.
- * fns.c (Fstring_as_multibyte): Likewise.
- * intervals.c (balance_possible_root_interval, delete_interval)
- (create_root_interval, copy_intervals_to_string): Likewise.
- * textprop.c (set_text_properties): Likewise. Use NULL_INTERVAL
- instead of 0.
-
-2002-07-14 Ken Raeburn <[email protected]>
-
- * lisp.h (STRING_SET_CHARS): New macro.
- (SCHARS, SBYTES): Produce rvalues.
- * dired.c (directory_files_internal): Use STRING_SET_CHARS.
- * fns.c (concat): Likewise.
- * lread.c (read_vector): Likewise.
-
- * lisp.h (SMBP): Delete. All uses changed to STRING_MULTIBYTE.
- (STRING_SET_UNIBYTE): New macro.
- (SET_STRING_BYTES): Delete. Callers (all of which supplied a
- length of -1) changed to use STRING_SET_UNIBYTE.
- * abbrev.c, alloc.c, buffer.c, bytecode.c, callint.c, callproc.c,
- casefiddle.c, category.c, ccl.c, charset.c, charset.h, coding.c,
- composite.c, data.c, dired.c, dispnew.c, disptab.h, doc.c,
- dosfns.c, editfns.c, emacs.c, eval.c, fileio.c, filelock.c, fn.c,
- fontset.c, frame.c, indent.c, insdel.c, intervals.c, keyboard.c,
- keymap.c, lread.c, mac.c, macfns.c, macmenu.c, macterm.c,
- minibuf.c, msdos.c, print.c, process.c, search.c, sound.c,
- sunfns.c, syntax.c, syntax.h, sysdep.c, textprop.c, undo.c,
- w16select.c, w32.c, w32fns.c, w32menu.c, w32proc.c, w32select.c,
- w32term.c, window.c, xdisp.c, xfaces.c, xfns.c, xmenu.c,
- xselect.c, xsmfns.c, xterm.c: Most uses of XSTRING combined with
- STRING_BYTES or indirection changed to SCHARS, SBYTES,
- STRING_INTERVALS, SREF, SDATA; explicit size_byte references left
- unchanged for now.
-
-2002-07-13 Kim F. Storm <[email protected]>
-
- * keyboard.c (command_loop_1): Invert check on Vmemory_full.
-
-2002-07-12 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fwrite_region): Doc fix.
-
- * print.c (print_error_message): Don't handle Vsignaling_function here.
-
- * keyboard.c (cmd_error_internal): Handle Vsignaling_function here.
- (command_loop_1): Avoid certain actions after memory-full error.
-
- * eval.c (Fsignal): Don't call cancel_hourglass.
- For a memory-full error, don't call Vsignal_hook_function
- and don't set Vsignaling_function.
-
- * process.c (process_send_signal): Add abort call.
-
-2002-07-11 Markus Rost <[email protected]>
-
- * keymap.c (Fkey_binding): Fix typo.
-
-2002-07-11 Richard M. Stallman <[email protected]>
-
- * alloc.c (Vmemory_full): New variable.
- (Vmemory_signal_data): Rename from memory_signal_data.
- Uses changed.
- (syms_of_alloc): Defvar them.
- (memory_full, buffer_memory_full): Set Vmemory_full.
-
- * lisp.h (Vmemory_full): Add declaration.
- (current_column, indented_beyond_p): Change declaration.
-
- * indent.c (last_known_column): Declare as double, not float.
- (current_column, current_column_1, string_display_width)
- (position_indentation): Return `double'.
- (indented_beyond_p): Arg `column' is `double'. Callers changed.
-
- * xdisp.c (message_dolog): Do nothing if Vmemory_full is non-nil.
- (back_to_previous_visible_line_start)
- (reseat_at_next_visible_line_start, next_element_from_buffer):
- Use `double', not `float', when calling indented_beyond_p.
-
- * s/hpux11.h (BROKEN_SA_RESTART): Define.
-
- * sysdep.c (sys_signal): Test BROKEN_SA_RESTART.
-
-2002-07-11 Juanma Barranquero <[email protected]>
-
- * alloc.c, buffer.c, bytecode.c, callint.c, callproc.c, coding.c,
- * composite.c, dired.c, dispnew.c, editfns.c, emacs.c, eval.c,
- * fileio.c, fns.c, insdel.c, keyboard.c, keymap.c, lread.c, macfns.c,
- * macmenu.c, macros.c, minibuf.c, print.c, process.c, sound.c,
- * textprop.c, w32fns.c, w32menu.c, window.c, xfaces.c, xfns.c,
- * xmenu.c, xselect.c, xterm.c: Use SPECPDL_INDEX wherever makes sense.
-
-2002-07-10 Juanma Barranquero <[email protected]>
-
- * lisp.h (SPECPDL_INDEX): Rename from BINDING_STACK_SIZE.
- All callers changed.
-
-2002-07-09 Stefan Monnier <[email protected]>
-
- * data.c (Fdefalias): Add an optional `docstring' argument.
- (set_internal, Fsetq_default): Use XCAR/XCDR.
-
- * composite.c (HASH_VALUE, HASH_KEY):
- * ccl.c (HASH_VALUE): Remove (it's in lisp.h now).
-
-2002-07-09 Kenichi Handa <[email protected]>
-
- * callproc.c (Fcall_process): Fix previous change.
-
-2002-07-07 Stefan Monnier <[email protected]>
-
- * minibuf.c (Ftry_completion, Fall_completions, Ftest_completion):
- Add support for hash-tables.
- (Ftry_completion): Return t even if the string appears multiple times.
-
- * fns.c (Fnconc): Use XCDR.
- (Fprovide): Use CONSP and XCDR.
- (HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
- (HASH_TABLE_SIZE): Delete: moved to lisp.h.
- (Fmake_hash_table): Accept `:size nil'.
- (Fmakehash): Delete: moved to subr.el.
- (syms_of_fns): Don't defsubr makehash.
-
- * lisp.h (HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
- (HASH_TABLE_SIZE): Move from fns.c.
-
-2002-07-07 Richard M. Stallman <[email protected]>
-
- * xdisp.c (make_cursor_line_fully_visible): Don't try short scrolls.
- Instead just return 0 when there is something to be done.
- (try_scrolling): If make_cursor_line_fully_visible returns 0,
- retry scrolling as if cursor were off the bottom.
- (try_cursor_movement): If make_cursor_line_fully_visible returns 0,
- return CURSOR_MOVEMENT_MUST_SCROLL.
- (redisplay_window): If make_cursor_line_fully_visible returns 0,
- go to try_to_scroll.
-
- * buffer.c (Fbuffer_local_value): Store current value into its binding
- so we get the up-to-date value for the binding that is loaded.
-
- * eval.c (Fdefmacro): Doc fix.
-
-2002-07-05 Dave Love <[email protected]>
-
- * keyboard.c (read_key_sequence): Set initial_idleness_start_time
- correctly.
-
- * ccl.c (Vtranslation_hash_table_vector, GET_HASH_TABLE)
- (HASH_VALUE, CCL_LookupIntConstTbl, CCL_LookupCharConstTbl): New.
- (ccl_driver): Add cases for CCL_LookupIntConstTbl,
- CCL_LookupCharConstTbl.
- (syms_of_ccl): Defvar translation-hash-table-vector.
-
-2002-07-05 Pavel Jan,Am(Bk <[email protected]>
-
- * xdisp.c: Remove unused variable `face'.
-
-2002-07-04 Juanma Barranquero <[email protected]>
-
- * keyboard.c (post_command_idle_hook): Remove redundant (and inexact)
- obsolescence information.
-
-2002-07-03 Andrew Choi <[email protected]>
-
- * macterm.c (x_list_fonts): Fix comment. Cache fonts matching
- pattern. Search cache first.
- (init_font_name_table): Also add entry for jisx0201.1976-0 coding
- for Japanese font.
- (XLoadQueryFont): Use it.
-
-2002-07-02 Richard M. Stallman <[email protected]>
-
- * keymap.c (Fdefine_key): Doc fix.
-
- * xterm.c (x_term_init): Turn off polling around XtOpenDisplay.
-
-2002-07-02 Juanma Barranquero <[email protected]>
-
- * keymap.c (syms_of_keymap): Fix typo.
-
-2002-07-01 Andrew Choi <[email protected]>
-
- * s/darwin.h: Define POSIX_SIGNALS.
-
- * macterm.c (do_ae_open_documents) [MAC_OSX]: Call FSpMakeFSRef
- and FSRefMakePath to convert FSSpec returned with Apple Event to
- Posix pathname.
- (mac_initialize) [TARGET_API_MAC_CARBON]:
- Call init_required_apple_events and disable the `Quit' menu item
- provided automatically by the Carbon Toolbox.
-
-2002-07-01 Dave Love <[email protected]>
-
- * keyboard.c (kbd_buffer_store_event): Fix interrupt_signal decl
- for K&R.
-
- * xterm.c: Fix prototype for K&R.
-
- * term.c (costs_set): Declare static, non-initialized for pcc.
-
-2002-07-01 Richard M. Stallman <[email protected]>
-
- * keyboard.c (timer_last_idleness_start_time): New variable.
- (timer_start_idle): Set that.
- (read_key_sequence): Use that to reset timer_idleness_start_time
- to previous value.
-
- * window.c (Frecenter): With arg, set optional_new_start.
-
- * xdisp.c (redisplay_internal): Make optional_new_start really work.
-
- * minibuf.c (Fminibuffer_complete_and_exit): Move to end of
- buffer for completion.
-
-2002-06-29 Ken Raeburn <[email protected]>
-
- * xdisp.c (store_mode_line_string): Lisp_Object/int mixup.
-
-2002-06-28 Jan Dj,Ad(Brv <[email protected]>
-
- * keyboard.c (readable_filtered_events): New function that filters
- FOCUS_IN_EVENT depending on parameter.
- (readable_events): Calls readable_filtered_events, not filtering
- FOCUS_IN_EVENT.
- (get_filtered_input_pending): New function, filtering parameter passed
- to readable_filtered_events.
- (get_input_pending): Calls get_filtered_input_pending, not filtering
- FOCUS_IN_EVENT.
- (Finput_pending_p): Calls get_filtered_input_pending, DO filter
- FOCUS_IN_EVENT.
-
- * xterm.h (struct x_output): Add focus_state.
-
- * xterm.c (x_focus_changed): New function.
- (x_detect_focus_change): New function.
- (XTread_socket): Call x_detect_focus_change for FocusIn/FocusOut
- EnterNotify and LeaveNotify to track X focus changes.
-
-2002-06-28 Andreas Schwab <[email protected]>
-
- * lisp.h: Remove duplicate declaration of code_convert_string_norecord.
-
-2002-06-27 Kim F. Storm <[email protected]>
-
- * xdisp.c (mode_line_string_list, mode_line_string_face)
- (mode_line_string_face_prop): New variables.
- (store_mode_line_string): New function.
- (display_mode_element): Use store_mode_line_string to
- add mode-line string elements to mode_line_string_list
- when mode_line_string_list is non-nil.
- (Fformat_mode_line): Now returns propertized string by
- default. New arg NO-PROPS to ignore properties.
- (decode_mode_spec): Only add two dashes for %- in propertized
- mode-line string.
- (syms_of_xdisp): Init and staticpro mode_line_string_list.
-
-2002-06-27 Stefan Monnier <[email protected]>
-
- * minibuf.c (minibuffer_completion_contents): Add return type.
-
-2002-06-27 Juanma Barranquero <[email protected]>
-
- * charset.c (Fchar_bytes): Remove obsolescence info from docstring.
-
-2002-06-26 Juanma Barranquero <[email protected]>
-
- * fileio.c (read_file_name_cleanup): Add missing return.
-
-2002-06-26 Richard M. Stallman <[email protected]>
-
- * window.c (Frecenter): Don't set force_start flag.
-
- * minibuf.c (do_completion, Fminibuffer_complete_word)
- (Fminibuffer_completion_help): Complete just the text before point.
- (minibuffer_completion_contents): New function.
-
- * buffer.c (Fbury_buffer): Use frames_discard_buffer.
-
- * frame.c (frames_bury_buffer): Function deleted.
-
-2002-06-25 Miles Bader <[email protected]>
-
- * callint.c (Fcall_interactively): When checking to see if doprnt hit
- the end of callint_message, allow for a terminating '\0'.
-
-2002-06-24 Juanma Barranquero <[email protected]>
-
- * w32select.c: Include composite.h.
-
- * w16select.c: Likewise.
-
-2002-06-24 Kenichi Handa <[email protected]>
-
- * callproc.c (Fcall_process): If code detection is necessary,
- call detect_coding directly here.
-
- * coding.c (detect_eol): Preserve coding->cmp_data.
-
- * w16select.c (Fw16_get_clipboard_data):
- * w32fns.c (w32_to_x_font):
- * w32select.c (Fw32_get_clipboard_data):
- * xselect.c (selection_data_to_lisp_data):
- * xterm.c (XTread_socket): Disable composition handling.
-
-2002-06-24 Stefan Monnier <[email protected]>
-
- * print.c (temp_output_buffer_setup): Kill all local variables.
-
-2002-06-22 Stefan Monnier <[email protected]>
-
- * lread.c (Fread): Remove redundant and imprecise declaration.
-
- * xfns.c (check_x_display_info): Use check_x_frame.
-
- * .gdbinit (xprintsym): Use the new `xname' field.
- (xsymbol): Use it.
-
-2002-06-22 Jason Rumney <[email protected]>
-
- * w32fns.c (file_dialog_callback): New function.
- (Fx_file_dialog): Allow selecting directories as well as files.
-
-2002-06-21 Pavel Jan,Am(Bk <[email protected]>
-
- * m/pmax.h (START_FILES): Define START_FILES for NetBSD and
- OpenBSD. Add support for mipseb-*-netbsd* machines.
-
-2002-06-17 Andrew Choi <[email protected]>
-
- * macterm.c (mac_scroll_area): Set foreground and backcolor to
- black and white before scrolling. Restore frame background and
- foreground color after scrolling.
- (do_window_update): Call XClearWindow before calling expose_frame.
- (make_mac_frame): Don't set FRAME_BACKGROUND_PIXEL and
- FRAME_FOREGROUND_PIXEL of frame.
-
- * macterm.c (XTread_socket): If Vmac_command_key_is_meta is nil,
- test Mac command key as <ALT> key.
-
-2002-06-17 Stefan Monnier <[email protected]>
-
- * window.c (Fset_window_configuration): Lisp_Object/int mixup.
-
- * keyboard.c (read_key_sequence): Be more careful with first_unbound.
- Lookup keys in function-key-map immediately so that key-translation-map
- can be applied earlier.
- Remove function_key_possible and key_translation_possible, replaced
- by checking `keytran_start < t'.
-
- * .gdbinit (xsymbol): Use the new `xname' field.
-
-2002-06-17 Andrew Choi <[email protected]>
-
- * macterm.c (XTread_socket): If Vmac_command_key_is_meta is nil,
- test Mac command key as <ALT> key.
-
- * mac.c (do_applescript): Call initialize_applescript if necessary
- when first called. Dispose of result_desc only when there is no error.
- (Fdo_applescript): Use %d format specifier instead of %ld.
-
-2002-06-16 Andrew Choi <[email protected]>
-
- * macterm.c (XTread_socket): Call FrontNonFloatingWindow instead
- of FrontWindow for cases keyDown and autoKey.
-
- * fontset.c (syms_of_fontset) [MAC_OS]: Set ASCII font of
- Vdefault_fontset to Monaco with mac-roman coding.
-
- * mac.c, macfns.c, macmenu.c, macterm.c: Undefine and redefine
- init_process before and after inclusion of Carbon/Carbon.h, resp.
-
- * macterm.c (x_new_font): Set font for normal_gc, reverse_gc, and
- cursor_gc.
- (add_font_name_table_entry): New function.
- (init_font_name_table): Use add_font_name_table_entry; add italic,
- bold, and bold-italic entries for truetype fonts.
-
- * xfaces.c (init_frame_faces) [MAC_OS]: Call realize_basic_faces
- for Mac too.
- (try_font_list) [MAC_OS]: If no font matches given registry, try
- fonts with any registry matching face_family.
- (realize_x_face) [MAC_OS]: Remove old ad-hoc fix to load font here.
-
- * s/darwin.h: If autoconf detects the Ncurses library, define
- LIBS_TERMCAP to -lncurses to use it.
-
-2002-06-16 Eli Zaretskii <[email protected]>
-
- * strftime.c [__hpux]: Include sys/_mbstate_t.h.
-
-2002-06-15 Richard M. Stallman <[email protected]>
-
- * window.c (Fset_window_configuration): Explicitly preserve
- the point value that new_current_buffer had at the start.
-
-2002-06-14 Juanma Barranquero <[email protected]>
-
- * composite.c (Fcompose_region_internal, Fcompose_string_internal):
- Fix typos.
-
-2002-06-14 Kim F. Storm <[email protected]>
-
- * insdel.c (insert_1_both, insert_from_string_1)
- (insert_from_buffer_1): Recalculate END_UNCHANGED in case the
- insert happened in the end_unchanged region. Otherwise, the
- redisplay may be confused and duplicate the last line in the
- buffer [seen after save-buffer when require-final-newline==t].
-
-2002-06-13 Jason Rumney <[email protected]>
-
- * w32.c (init_environment): Remove EMACSLOCKDIR.
- (stat): Swap _S_IFDIR and _S_IFREG.
-
-2002-06-13 Pavel Jan,Am(Bk <[email protected]>
-
- * keyboard.c, macterm.c, macmenu.c, msdos.c, sysdep.c
- * termhooks.h, xmenu.c, xsmfns.c, xterm.h, xterm.c, w32term.c,
- * w32menu.c, w32inevt.c: Rename enum event_kind as follows:
- ascii_keystroke to ASCII_KEYSTROKE_EVENT, multibyte_char_keystroke
- to MULTIBYTE_CHAR_KEYSTROKE_EVENT, non_ascii_keystroke to
- NON_ASCII_KEYSTROKE_EVENT, timer_event to TIMER_EVENT, mouse_click
- to MOUSE_CLICK_EVENT, mouse_wheel to MOUSE_WHEEL_EVENT,
- language_change_event to LANGUAGE_CHANGE_EVENT, scroll_bar_click
- to SCROLL_BAR_CLICK_EVENT, w32_scroll_bar_click to
- W32_SCROLL_BAR_CLICK_EVENT, selection_request_event to
- SELECTION_REQUEST_EVENT, selection_clear_event to
- SELECTION_CLEAR_EVENT, buffer_switch_event to BUFFER_SWITCH_EVENT,
- delete_window_event to DELETE_WINDOW_EVENT, iconify_event to
- ICONIFY_EVENT, deiconify_event to DEICONIFY_EVENT,
- menu_bar_activate_event to MENU_BAR_ACTIVATE_EVENT, drag_n_drop to
- DRAG_N_DROP_EVENT, save_session_event to SAVE_SESSION_EVENT and
- no_event to NO_EVENT.
-
-2002-06-12 Pavel Jan,Am(Bk <[email protected]>
-
- * macmenu.c: Remove declaration of Qmouse_click and Qevent_kind.
-
-2002-06-12 Stefan Monnier <[email protected]>
-
- * intervals.c (textget): Don't forget to `return'.
- (lookup_char_property): Use XCAR/XCDR.
-
-2002-06-12 Juanma Barranquero <[email protected]>
-
- * xdisp.c (Fformat_mode_line): Fix typo.
-
-2002-06-12 Kim F. Storm <[email protected]>
-
- * xdisp.c (Fformat_mode_line): New function.
- (frame_title_buf, frame_title_buf_end, frame_title_ptr)
- (store_frame_title_char, store_frame_title): Use unconditionally.
- (init_xdisp): Defsubr Fformat_mode_line.
- Initialize frame_title_buf etc. unconditionally.
-
-2002-06-11 Stefan Monnier <[email protected]>
-
- * keyboard.c (read_key_sequence):
- Remove prev_(fkey|keytran}_(map|start|end) since we don't want to pass
- things through those maps after downcasing events.
- Enforce that keytran_end <= fkey_start, i.e. that key-translation-map
- applies after function-key-map.
- Make sure that keytran can be done in the middle in the sequence.
- Be careful not to throw away events past the one we downcase.
-
- * lread.c (read_integer): Remove unused var `tem'.
- (read1): Fix int/Lisp_Object mixup.
-
- * xfaces.c (tty_lookup_color): Type bool/Lisp_Object mismatch fixed.
-
-2002-06-11 Richard M. Stallman <[email protected]>
-
- * keyboard.c (readable_events): Ignore any number of
- FOCUS_IN_EVENT events and return 0 if nothing else in buffer.
-
-2002-06-09 Miles Bader <[email protected]>
-
- * xfaces.c (Ftty_supports_face_attributes_p): New function.
- (parse_rgb_list, tty_lookup_color): New functions.
- (tty_defined_color): Use `tty_lookup_color' to do all the work.
- (color_distance, Fcolor_distance): New functions.
- (TTY_SAME_COLOR_THRESHOLD): New macro.
- (Qtty_color_standard_values): New variable.
- (syms_of_xfaces): Initialize new vars & functions.
-
-2002-06-08 Colin Walters <[email protected]>
-
- * textprop.c (Vchar_property_alias_alist): New variable.
- (syms_of_textprop) <Vchar_property_alias_alist>: DEFVAR_LISP.
-
- * intervals.c (lookup_char_property): New function for looking up
- overlay and text properties, created from textget.
- (textget): Use it.
-
- * intervals.h (lookup_char_property): Declare.
- (Vchar_property_alias_alist): Declare.
-
- * buffer.c (Foverlay_get): Use lookup_char_property.
-
-2002-06-07 Sam Steingold <[email protected]>
-
- * xselect.c (lisp_data_to_selection_data): Fix last change:
- *data_ret is not a Lisp string, while unibyte_string is.
-
-2002-06-07 Eli Zaretskii <[email protected]>
-
- * xselect.c (lisp_data_to_selection_data): Fix last change:
- set size_ret.
-
-2002-06-07 Andreas Schwab <[email protected]>
-
- * m/amdx86-64.h: New file.
-
-2002-06-05 Eli Zaretskii <[email protected]>
-
- * fns.c (Fstring_make_unibyte): Doc fix.
-
- * xselect.c (lisp_data_to_selection_data): If the requested type
- is STRING, call string_make_unibyte to encode the selected text
- as a string.
-
- * window.c (Fset_window_hscroll): Doc fix.
-
-2002-06-05 Pavel Jan,Am(Bk <[email protected]>
-
- * fileio.c (choose_write_coding_system):
- Call select-safe-coding-system properly.
-
-2002-06-03 Richard M. Stallman <[email protected]>
-
- * xdisp.c (message_with_string): Error if STRING is not a string.
-
- * fns.c (md5): Pass FILE arg to Vselect_safe_coding_system_function.
-
- * fileio.c (choose_write_coding_system): Pass FILE arg to
- Vselect_safe_coding_system_function.
-
-2002-06-03 Ken Raeburn <[email protected]>
-
- * buffer.c (fix_overlays_before): Fix list-walking bug in 05-19 change.
-
-2002-06-02 Thien-Thi Nguyen <[email protected]>
-
- * bytecode.c (Fbyte_code): Cast `current_column' return value to int.
- * cmds.c (Fdelete_backward_char, internal_self_insert): Likewise.
- * keymap.c (describe_command): Likewise.
- * minibuf.c (read_minibuf): Likewise.
-
- * xdisp.c (redisplay_internal, redisplay_window, decode_mode_spec):
- Cast `current_column' return value to int.
- (back_to_previous_visible_line_start)
- (reseat_at_next_visible_line_start, next_element_from_buffer):
- Cast `indented_beyond_p' 3rd arg to float.
-
- * indent.c (last_known_column): Now a float.
- (current_column_1, position_indentation, current_column)
- (string_display_width): Return float.
- (Fcurrent_column): Cast `current_column' return value to int.
- (Fcurrent_indentation): Cast `position_indentation' retval to int.
- (indented_beyond_p): Third arg now a float.
- (compute_motion, vmotion): Cast `indented_beyond_p' 3rd arg to float.
-
- * lisp.h (current_column): Now returns float.
- (indented_beyond_p): 3rd arg now a float.
-
-2002-05-31 Eli Zaretskii <[email protected]>
-
- * xfns.c (x_encode_text): Return stringp non-NULL if coding_system
- is Qcompound_text_with_extensions.
-
- * xselect.c (lisp_data_to_selection_data): Always set selection
- type as string if x_encode_text returns streingp non-NULL.
-
- * s/netbsd.h: Include /usr/pkg in the run time shared library path.
-
-2002-05-30 Richard M. Stallman <[email protected]>
-
- * window.c (Fset_window_configuration): Correct the handling
- of point in current buffer, to work with multiple windows.
-
-2002-05-29 Colin Walters <[email protected]>
-
- * lread.c (Fread_from_string): Don't depend on order of evaluation
- for C function parameters.
-
-2002-05-28 Richard M. Stallman <[email protected]>
-
- * xterm.c (x_display_and_set_cursor): Change the cursor in the same
- way for blinked-off state and for a nonselected window.
-
- * window.c (window_scroll_pixel_based): Don't call Fbolp;
- instead, see if the new start pos is at beginning of line.
-
- * fileio.c (Fwrite_region): If START is a string, don't
- make any annotations.
-
- * eval.c (syms_of_eval): Doc fix.
-
-2002-05-28 Colin Walters <[email protected]>
-
- * emacs.c (USAGE1): Add --no-splash.
- (standard_args): Ditto.
-
-2002-05-28 Colin Walters <[email protected]>
-
- * lread.c (readchar_count): New variable.
- (readchar): Increment it.
- (unreadchar): Decrement it.
- (read_multibyte): Decrement it.
- (Vread_with_symbol_positions): New variable.
- (Vread_symbol_positions_list): New variable.
- (read_internal_start): New function, created from Fread and
- Fread_from_string. Handle Vread_symbol_positions_list and
- Vread_with_symbol_positions.
- (readevalloop, Fread, Fread_from_string): Use it.
- (read1): Use readchar_count to add symbol positions to
- Vread_symbol_positions_list if Vread_with_symbol_positions is non-nil.
- (syms_of_lread): DEFVAR_LISP and initialize them.
-
- * lread.c (read0, read1, read_list, read_vector, read_multibyte)
- (substitute_object_recurse, substitute_object_in_subtree)
- (substitute_in_interval): Prototype.
- (read_multibyte): Return c if it's less than zero.
-
-2002-05-28 Kim F. Storm <[email protected]>
-
- * fileio.c (Fread_file_name_internal): Added brute-force
- speed up for using predicate file-directory-p.
-
-2002-05-28 Kim F. Storm <[email protected]>
-
- * fileio.c (Vread_file_name_function, Vread_file_name_predicate):
- New variables.
- (syms_of_fileio): DEFVAR_LISP them.
- (read_file_name_cleanup): New unwind function.
- (Fread_file_name_internal): Only return completions satifying
- Vread_file_name_predicate. Temporarily unwind protect and rebind
- default-directory while checking completions against the predicate.
- (Fread_file_name): Added PREDICATE argument. Specbind it to
- Vread_file_name_predicate during completion.
- Call Vread_file_name_function to read the file name if non-nil.
-
- * lisp.h (Fread_file_name): Now has 6 args.
-
- * callint.c (Fcall_interactively) <"D">: Supply Qfile_directory_p
- predicate for Fread_file_name when reading directory name.
- Supply Qnil for predicate in other calls to Fread_file_name.
-
-2002-05-26 Miles Bader <[email protected]>
-
- * term.c (tty_capable_p): New function.
- * dispextern.h (tty_capable_p): New function declaration.
- (TTY_CAP_INVERSE, TTY_CAP_UNDERLINE, TTY_CAP_BOLD, TTY_CAP_DIM)
- (TTY_CAP_BLINK, TTY_CAP_ALT_CHARSET): New macros.
-
-2002-05-23 Stefan Monnier <[email protected]>
-
- * fileio.c (read_non_regular, Finsert_file_contents): Use BEG_BYTE.
- (Finsert_file_contents, build_annotations): Use XCAR, XCDR.
- (Vwrite_region_annotate_functions): Docstring fix.
-
-2002-05-23 Kim F. Storm <[email protected]>
-
- * xterm.c (x_write_glyphs): Clear phys_cursor_on_p if current
- phys_cursor's hpos is overwritten. This is still not completely
- correct, as it doesn't really make sense to use hpos at all to
- get the cursor glyph (as that is relative to the width of the
- characters on the line, which may have changed during the update).
-
-2002-05-22 Jason Rumney <[email protected]>
-
- * w32fns.c (enumfont_t): Remove tail, make pattern a normal
- Lisp_Object.
- (enum_font_cb2, enum_font_maybe_add_to_list, w32_list_fonts):
- Use modified enumfont_t struct.
-
- * w32term.h (text_cursor_kinds): New enumeration member HBAR_CURSOR.
-
- * w32term.c (x_draw_bar_cursor): New argument KIND; callers changed.
- Handle the `hbar' cursor type.
- (x_display_and_set_cursor): Handle the HBAR_CURSOR case.
-
- * w32fns.c (Qhbar): New variable.
- (x_specified_cursor_type): Use it.
-
-2002-05-21 Ken Raeburn <[email protected]>
-
- * w32fns.c (enum_font_maybe_add_to_list): Use XCDR_AS_LVALUE for
- now, when the address is needed.
-
-2002-05-21 Colin Walters <[email protected]>
-
- * Makefile.in (shortlisp): Add font-core.el.
-
-2002-05-20 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer) <cursor-type>: Doc fix.
-
- * keyboard.c (read_char_minibuf_menu_prompt): Don't list
- equivalent key bindings here.
-
-2002-05-20 Ken Raeburn <[email protected]>
-
- Change symbol structure to contain a lisp object for the symbol
- name:
- * lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
- object field named "xname".
- (SYMBOL_NAME): New macro.
- * abbrev.c (write_abbrev): Use SYMBOL_NAME instead of XSYMBOL and
- name field.
- * alloc.c (Fmake_symbol): Set symbol xname field instead of name.
- (mark_object, gc_sweep): Use symbol xname field and XSTRING
- instead of name field.
- * buffer.c (buffer_slot_type_mismatch): Use XSTRING and
- SYMBOL_NAME instead of XSYMBOL and name field.
- * callint.c (Fcall_interactively): Use XSTRING and SYMBOL_NAME
- instead of XSYMBOL and name field.
- * charset.c (Fdefine_charset, Fdeclare_equiv_charset): Use XSTRING
- and SYMBOL_NAME instead of XSYMBOL and name field.
- * coding.c (Fread_coding_system, code_convert_region1)
- (code_convert_string1, code_convert_string_norecord)
- (Ffind_operation_coding_system): Use SYMBOL_NAME instead of
- XSYMBOL and name field.
- * data.c (Fkeywordp, Fsymbol_name, store_symval_forwarding)
- (Fmake_variable_buffer_local, Fmake_local_variable)
- (Fmake_variable_frame_local): Use SYMBOL_NAME and XSTRING instead
- of XSYMBOL and name field.
- * editfns.c (Fformat): Use SYMBOL_NAME and XSTRING instead of
- XSYMBOL and name field.
- * emacs.c (shut_down_emacs) [#if 0]: Use SYMBOL_NAME and XSTRING
- instead of XSYMBOL and name field.
- * eval.c (do_autoload): Use SYMBOL_NAME and XSTRING instead of
- XSYMBOL and name field.
- * fns.c (Fstring_equal, Fstring_lessp, Frequire, sxhash):
- Use SYMBOL_NAME and XSTRING instead of XSYMBOL and name field.
- * fontset.c (Fset_fontset_font): Use SYMBOL_NAME and XSTRING
- instead of XSYMBOL and name field.
- * keyboard.c (echo_char, record_char, parse_modifiers_uncached)
- (parse_modifiers, apply_modifiers, Fevent_convert_list)
- (parse_solitary_modifier, Fexecute_extended_command):
- Use SYMBOL_NAME and XSTRING instead of XSYMBOL and name field.
- * keymap.c (silly_event_symbol_error, Fsingle_key_description)
- (Fdescribe_buffer_bindings): Use SYMBOL_NAME and XSTRING instead
- of XSYMBOL and name field.
- (describe_command, describe_translation): Use SYMBOL_NAME and
- assignment instead of XSYMBOL and name field and XSETSTRING.
- * lread.c (Fintern_soft, oblookup): Use SYMBOL_NAME and XSTRING
- instead of XSYMBOL and name field.
- (Funintern): Use SYMBOL_NAME and assignment instead of XSYMBOL and
- name field and XSETSTRING.
- * macfns.c (parse_image_spec): Use SYMBOL_NAME and XSTRING instead
- of XSYMBOL and name field.
- * minibuf.c (Fread_command, Fread_variable): Use SYMBOL_NAME and
- assignment instead of XSYMBOL and name field and XSETSTRING.
- * print.c (print_error_message, print_object): Use SYMBOL_NAME and
- XSTRING instead of XSYMBOL and name field.
- * process.c (set_socket_options, Fsignal_process): Use SYMBOL_NAME
- and XSTRING instead of XSYMBOL and name field.
- * w32fns.c (parse_image_spec, w32_parse_hot_key): Use SYMBOL_NAME
- and XSTRING instead of XSYMBOL and name field.
- * xfaces.c (merge_face_vector_with_property): Use SYMBOL_NAME and
- XSTRING instead of XSYMBOL and name field.
- * xfns.c (parse_image_spec): Use SYMBOL_NAME and XSTRING instead
- of XSYMBOL and name field.
- * xselect.c (symbol_to_x_atom, x_get_foreign_selection):
- Use SYMBOL_NAME and XSTRING instead of XSYMBOL and name field.
-
-2002-05-19 Ken Raeburn <[email protected]>
-
- * lisp.h (LISP_MAKE_RVALUE): Delete disabled version, making XCAR
- and XCDR real rvalues in most configurations.
-
- * buffer.c (fix_overlays_in_range, fix_overlays_before):
- Don't take the address of the cdr part of a cons cell; instead, track
- the parent cell and call XSETCDR, or set the variable for the head
- of the list if we haven't started down the list yet.
-
-2002-05-19 Richard M. Stallman <[email protected]>
-
- * doc.c (reread_doc_file): Don't ask for confirmation.
-
-2002-05-18 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_create_pixmap_from_bitmap_data): New function.
- (xbm_load_image): Use it.
- (xbm_load): Ditto.
- (xbm_read_bitmap_data): Reverted to xfns.c version.
- From David Ponce <[email protected]>.
-
-2002-05-17 Eli Zaretskii <[email protected]>
-
- * msdos.c (sig_suspender, sigprocmask): Don't define for DJGPP
- 2.02 and later.
-
-2002-05-16 Juanma Barranquero <[email protected]>
-
- * keyboard.c (Fthis_command_keys, Fthis_command_keys_vector): Fix typo.
-
-2002-05-15 Stefan Monnier <[email protected]>
-
- * keyboard.c (read_char_x_menu_prompt): Use an equivalent but more
- meaningful test.
- (read_char_minibuf_menu_prompt): Fix typo.
-
-2002-05-15 Eli Zaretskii <[email protected]>
-
- * eval.c (Fcommandp): Doc fix.
-
-2002-05-13 Stefan Monnier <[email protected]>
-
- * keymap.c (keymap_parent): New fun, extracted from Fkeymap_parent.
- (Fkeymap_parent, keymap_memberp, fix_submap_inheritance): Use it.
- (Fset_keymap_parent): Gcpro a bit more.
- (access_keymap): Gcpro around meta_map call and around the main loop.
- (get_keyelt): Gcpro when following indirect references.
- (copy_keymap_item): New fun, extracted from Fcopy_keymap.
- (copy_keymap_1, Fcopy_keymap): Use it. Don't copy the parent map.
- (Fdefine_key, Flookup_key): Gcpro before calling get_keymap.
- Remove useless ad-hoc remap code.
-
-2002-05-13 Richard M. Stallman <[email protected]>
-
- * search.c (search_buffer): Give up boyer moore search if inverse
- translation change charset_base.
-
-2002-05-12 Eli Zaretskii <[email protected]>
-
- * coding.c (decode_coding) <coding_type_ccl>: If a lone CR
- characters is carried over from the previous block of text, adjust
- coding->produced to account for the extra character.
-
-2002-05-11 Andreas Schwab <[email protected]>
-
- * coding.c (intersection): Keep the elements of the returned list
- in the same order as in the first list.
-
-2002-05-11 Kim F. Storm <[email protected]>
-
- * keymap.c (current_minor_maps): Fix resizing of cmm_maps;
- only update cmm_size if realloc actually succeeds.
- Testing with initial size of 2 elements revealed that using
- realloc on GNU/Linux would cause a random trap in xmalloc
- later on, so I rewrote the code to use malloc/bcopy/free instead
- of realloc.
-
-2002-05-10 Jason Rumney <[email protected]>
-
- * w32fns.c (enum_font_cb2): Avoid DBCS raster fonts.
-
-2002-05-10 Eli Zaretskii <[email protected]>
-
- * coding.c (encode_coding_sjis_big5): Enclose bitwise AND in
- parens, to ensure correct evaluation order.
-
-2002-05-10 Kim F. Storm <[email protected]>
-
- * keymap.c (Vemulation_mode_map_alists): New variable.
- (syms_of_keymap): DEFVAR_LISP it.
- (current_minor_maps): Process keymap alists in that list before
- minor-mode-overriding-map-alist and minor-mode-map-alist.
-
-2002-05-09 Richard M. Stallman <[email protected]>
-
- * search.c (Freplace_match): Doc fix.
-
-2002-05-09 Kim F. Storm <[email protected]>
-
- * macterm.c (x_draw_image_foreground, x_draw_image_foreground_1):
- Enlarge cursor rectangle drawn around image with non-zero relief.
-
- * w32term.c (x_draw_image_foreground, w32_draw_image_foreground_1):
- Enlarge cursor rectangle drawn around image with non-zero relief.
-
- * xterm.c (x_draw_image_foreground, x_draw_image_foreground_1):
- Enlarge cursor rectangle drawn around image with non-zero relief.
-
-2002-05-07 Eli Zaretskii <[email protected]>
-
- * xselect.c (lisp_data_to_selection_data): Don't set selection
- type if comes from the Lisp object's car. If the selection
- contains a pure ASCII text, always return QSTRING as its type.
-
-2002-05-06 Pavel Jan,Am(Bk <[email protected]>
-
- * mac.c (mac-cut-function): Doc fix.
-
-2002-05-05 Richard M. Stallman <[email protected]>
-
- * s/gnu.h [DOUG_LEA_MALLOC] (REL_ALLOC): Undefine it.
-
-2002-05-04 Jason Rumney <[email protected]>
-
- * keyboard.c (make_lispy_event) <mouse-wheel>: Set count to 1
- for event-click-count.
-
- * process.c (init_process): Only add server subfeature if we can
- use non-blocking I/O.
-
-2002-05-04 Andrew Choi <[email protected]>
-
- * macterm.c (XTread_socket): Call WaitNextEvent once instead of
- repeatedly.
-
-2002-05-03 Jason Rumney <[email protected]>
-
- * process.c (Fmake_network_process): Only support server sockets
- when we can make them non-blocking.
-
- * s/ms-w32.h (HAVE_SELECT): Define.
-
- * w32.h (FILE_NDELAY): New flag.
-
- * w32.c (sys_getpeername, fcntl): New functions.
- (_sys_read_ahead): Temporarily block on non-blocking sockets.
-
- * w32proc.c: Include sys/file.h.
-
-2002-05-03 Colin Walters <[email protected]>
-
- * callproc.c (Vgame_score_directory): Renamed to
- Vshared_game_score_directory.
-
-2002-04-30 Richard M. Stallman <[email protected]>
-
- * s/gnu.h [emacs]: Include stdio.h.
- (GNU_LIBRARY_PENDING_OUTPUT_COUNT): New definition, conditional.
-
- * eval.c (do_autoload): Error if called while preparing to dump.
-
- * fns.c (Frequire): Error if need to load while preparing to dump.
-
-2002-04-28 Colin Walters <[email protected]>
-
- * callproc.c (Vgame_score_directory) [!HAVE_SHARED_GAME_DIR]:
- Default to "~/.emacs.d/games".
-
-2002-04-29 Stefan Monnier <[email protected]>
-
- * lread.c (openp): Change arg exec_only to predicate.
- (build_load_history): Use XCAR/XCDR.
- (Flocate_file_internal): New fun.
- (syms_of_lread): Defsubr it.
- (Fload): Update call to openp.
-
- * lisp.h (openp): Update prototype.
-
- * xfns.c (x_create_bitmap_from_file, x_find_image_file):
- * w32proc.c (sys_spawnve):
- * w32fns.c (x_create_bitmap_from_file, x_find_image_file):
- * w32.c (check_windows_init_file):
- * sound.c (Fplay_sound_internal):
- * process.c (Fstart_process):
- * macfns.c (x_create_bitmap_from_file, x_find_image_file):
- * mac.c (run_mac_command):
- * emacs.c (init_cmdargs):
- * callproc.c (Fcall_process): Update call to openp.
-
- * textprop.c (remove_properties): Don't use XCAR without CONSP.
-
- * xterm.c (XTread_socket): Disable the Xutf8LookupString code.
-
-2002-04-29 Pavel Jan,Am(Bk <[email protected]>
-
- * dispextern.h (DEFAULT_TOOL_BAR_BUTTON_MARGIN)
- (DEFAULT_TOOL_BAR_BUTTON_RELIEF): Change default values.
-
-2002-04-28 Richard M. Stallman <[email protected]>
-
- * minibuf.c (Fall_completions, Ftry_completion): New arg to Fcommandp.
-
- * eval.c (Fcommandp): New arg for_call_interactively.
- * lisp.h (Fcommandp): Declare new arg.
-
-2002-04-28 Jason Rumney <[email protected]>
-
- * w32proc.c (syms_of_w32proc): Get true file attributes by default.
-
- * w32.c (stat, fstat): Use file index information to generate
- inodes for directories where available.
-
-2002-04-26 Andrew Choi <[email protected]>
-
- * Makefile.in (C_SWITCH_SYSTEM_TEMACS): Add.
- [HAVE_CARBON]: Include Mac object files.
-
- * alloc.c, callproc.c, dispextern.h, dispnew.c, emacs.c,
- fontset.c, frame.c, frame.h, keyboard.c, sysdep.c, term.c,
- termcap.c, window.c, xdisp.c, xfaces.c: Use macros MAC_OS8,
- MAC_OSX, and MAC_OS instead of macintosh.
-
- * editfns.c [MAC_OS8]: Include stdio.h.
-
- * emacs.c [MAC_OS8]: Call mac_initialize instead of x_term_init.
-
- * fontset.c [MAC_OS]: Set Vdefault_fontset to ETL Fixed instead of
- Apple Monaco.
-
- * process.c (QCfamily, QCfilte): Declare extern.
- (wait_reading_process_input) [MAC_OSX]: Clear bit for stdin before
- calling select.
-
- * termcap.c [MAC_OSX]: Don't define tgetnum, PC, tputs, and tgetent.
-
- * tparam.c [MAC_OSX]: Don't define BC and UP.
-
- * config.in [HAVE_CARBON]: Add.
-
- * mac.c, macgui.h, macfns.c, macmenu.c, macterm.c, macterm.h:
- Move here from mac/src and mac/inc.
-
- * s/darwin.h, m/powermac.h, unexmacosx.c: New files.
-
-2002-04-26 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_draw_phys_cursor_glyph): Undo last change.
- Compute phys_cursor_width from the x position returned
- by x_draw_glyhs, which is cheaper.
- (x_display_and_set_cursor): Compute the buffer-local value
- of `cursor-in-non-selected-windows' only when needed.
-
-2002-04-25 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_draw_phys_cursor_glyph): Take into account that a box
- cursor on a stretch glyph has a width that depends on
- x_stretch_cursor_p.
-
-2002-04-25 Pavel Jan,Am(Bk <[email protected]>
-
- * abbrev.c (abbrev-start-location): Doc fix.
-
- * indent.c (Fvertical_motion): Fix last change.
-
-2002-04-25 Gerd Moellmann <[email protected]>
-
- * indent.c (Fvertical_motion): Move to the start of the line
- containing PT before moving up or down.
-
-2002-04-24 Gerd Moellmann <[email protected]>
-
- * dispnew.c (update_text_area): Set phys_cursor_on_p to 0 in the
- case of writing a whole row, more or less analogous to the case of
- writing only parts of a row.
-
- * xterm.c (x_display_and_set_cursor): Set phys_cursor_width to
- 0 for NO_CURSOR.
-
- * xterm.c (notice_overwritten_cursor): Fix an off by 1 error.
-
-2002-04-23 Colin Walters <[email protected]>
-
- * buffer.c (syms_of_buffer): Doc fix.
-
-2002-04-23 Gerd Moellmann <[email protected]>
-
- * xterm.c (notice_overwritten_cursor): Handle the special case
- of the cursor being in the first blank non-text line at the
- end of a window.
-
- * xterm.c (x_draw_hollow_cursor, x_draw_bar_cursor)
- (x_draw_phys_cursor_glyph): Set phys_cursor_width here.
- (x_display_and_set_cursor): Don't set phys_cursor_width here, for
- bar cursors only, to make phys_cursor_width contain what its name
- suggests.
- (notice_overwritten_cursor): Consider the cursor image erased if
- the output area intersects the cursor image in y-direction.
-
-2002-04-23 Simon Marshall <[email protected]>
-
- * xfns.c (x_set_mouse_color): Change default for cross_cursor
- to XC_hand2.
-
-2002-04-23 Pavel Jan,Am(Bk <[email protected]>
-
- * xdisp.c: Remove unused global variable `minibuf_prompt_pixel_width'.
-
-2002-04-22 Kim F. Storm <[email protected]>
-
- * textprop.c (remove_properties): Fixed trap for malformed plist.
-
-2002-04-22 Richard M. Stallman <[email protected]>
-
- * cmds.c (Fend_of_line): Handle intangible text in mid line.
-
- * window.c (make_window): Initialize height_fixed_p,
- last_cursor_off_p, and p->cursor_off_p slots.
-
-2002-04-20 Pavel Jan,Am(Bk <[email protected]>
-
- * fns.c (use-dialog-box): Doc fix.
-
-2002-04-19 Pavel Jan,Am(Bk <[email protected]>
-
- * xterm.c (note_mode_line_or_margin_highlight): Remove unused
- variables `row', `i' and `area'.
- (XTread_socket) <KeyPress>: Pass KeyPress events when in menu to
- toolkit library.
-
-2002-04-19 Stefan Monnier <[email protected]>
-
- * xfaces.c (clear_font_table): Don't free the default font of
- a frame even if it's on another display.
- (Finternal_set_lisp_face_attribute): Don't use XFRAME on something
- that could be Qt.
-
-2002-04-19 Juanma Barranquero <[email protected]>
-
- * indent.c (Fmove_to_column): Remove unused local variable
- `next_boundary_byte'.
- (current_column_1): Likewise.
-
-2002-04-19 Eli Zaretskii <[email protected]>
-
- * msdos.c (Qhbar): New variable.
- (syms_of_msdos): Intern and staticpro it.
- (IT_set_cursor_type, IT_set_frame_parameters): Handle the `hbar'
- cursor type.
-
-2002-04-19 Dave Lambert <[email protected]>
-
- Theses change implement an underscore-like (`hbar') cursor.
-
- * xterm.h (text_cursor_kinds): New enumeration member HBAR_CURSOR.
-
- * xterm.c (x_draw_bar_cursor): New argument KIND; callers changed.
- Handle the `hbar' cursor type.
- (x_display_and_set_cursor): Handle the HBAR_CURSOR case.
-
- * xfns.c (Qhbar): New variable.
- (syms_of_xfns): Intern and staticpro it.
- (x_specified_cursor_type): Handle `hbar' cursor.
-
- * s/sol2-5.h (bcopy, bzero, bcmp): Define only if HAVE_BCOPY is
- not defined.
-
-2002-04-18 Richard M. Stallman <[email protected]>
-
- * textprop.c (remove_properties): New arg LIST allows scanning
- either a list or a plist.
- (interval_has_some_properties_list): New function, like
- interval_has_some_properties using list instead of plist.
- All callers changed.
- (Fremove_list_of_text_properties): New function.
- (syms_of_textprop): Defsubr it.
-
-2002-04-17 Eli Zaretskii <[email protected]>
-
- * s/sol2.h (HAVE_LIBKSTAT): Define only if not already defined.
-
-2002-04-17 Juanma Barranquero <[email protected]>
-
- * indent.c (Fmove_to_column): Remove unused local variable `end_byte'.
-
-2002-04-17 Eli Zaretskii <[email protected]>
-
- * window.c (coordinates_in_window): Don't report on margin area
- if its width is zero.
-
-2002-04-16 Jason Rumney <[email protected]>
-
- * w32fns.c (Fx_file_dialog): Decode file name before using.
-
- * w32term.c (construct_drag_n_drop): Likewise.
-
-2002-04-16 Eli Zaretskii <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 830000, since we now
- store load-history in pure space.
-
- * s/msdos.h (SYSTEM_PURESIZE_EXTRA): Reduce to 50000.
-
-2002-04-16 Stefan Monnier <[email protected]>
-
- * xterm.c (Qlatin_1, Qutf_8): New vars.
- (syms_of_xterm): Initialize them.
- (XTread_socket): Eliminate incorrect optimization that tried to avoid
- decoding the output of X*LookupString.
- Always use latin-1 to decode the output of XLookupString.
- Try Xutf8LookupString if XmbLookupString failed.
-
- * region-cache.c (new_region_cache): Use BEG.
-
-2002-04-16 Gerd Moellmann <[email protected]>
-
- * buffer.c (MMAP_ALLOCATED_P): New macro to be set from system
- configuration files.
- (mmap_enlarge): Enlarge mapped regions only if MMAP_ALLOCATED_P
- returns 0.
-
-2002-04-15 Andreas Schwab <[email protected]>
-
- * config.in: Regenerated using autoheader.
-
- * m/7300.h, m/acorn.h, m/alliant-2800.h, m/alliant.h, m/alpha.h,
- m/altos.h, m/amdahl.h, m/apollo.h, m/arm.h, m/att3b.h, m/aviion.h,
- m/celerity.h, m/clipper.h, m/cnvrgnt.h, m/convex.h, m/cydra5.h,
- m/delta.h, m/delta88k.h, m/dpx2.h, m/elxsi.h, m/gec63.h,
- m/gould.h, m/hp800.h, m/hp9000s300.h, m/i860.h, m/ia64.h,
- m/ibmps2-aix.h, m/ibmrs6000.h, m/ibmrt-aix.h, m/ibmrt.h,
- m/ibms390.h, m/intel386.h, m/iris4d.h, m/irist.h, m/isi-ov.h,
- m/m68k.h, m/macppc.h, m/masscomp.h, m/mg1.h, m/mips-siemens.h,
- m/mips.h, m/news-r6.h, m/news.h, m/next.h, m/nh3000.h, m/nh4000.h
- m/ns32000.h, m/orion.h, m/pfa50.h, m/plexus.h, m/pmax.h,
- m/powerpcle.h, m/pyrmips.h, m/sequent-ptx.h, m/sequent.h,
- m/sparc.h, m/sr2k.h, m/symmetry.h, m/tad68k.h, m/tahoe.h,
- m/targon31.h, m/tek4300.h, m/tekxd88.h, m/template.h, m/tower32.h,
- m/tower32v3.h, m/ustation.h, m/vax.h, m/wicat.h, m/windowsnt.h,
- m/xps100.h, s/aix3-2.h, s/aix4-2.h, s/irix4-0.h, s/irix5-0.h,
- s/sco5.h, s/unixware.h: Don't set HAVE_ALLOCA, C_ALLOCA and
- STACK_DIRECTION, now set by autoconf.
-
-2002-04-14 Pavel Jan,Am(Bk <[email protected]>
-
- * dispnew.c (marginal_area_string): Sort arguments.
-
- * dispextern.h (marginal_area_string): Add prototype.
-
-2002-04-13 Richard M. Stallman <[email protected]>
-
- * fileio.c (Finsert_file_contents):
- Don't call temp_output_buffer_setup--do just part, by hand.
-
- * coding.c (run_pre_post_conversion_on_str):
- Don't call temp_output_buffer_setup--do just part, by hand.
-
- * keyboard.c (command_loop_1): Don't call start_hourglass
- or cancel_hourglass when executing a macro.
-
- * marker.c (count_markers): New function.
-
- * xdisp.c (display_mode_element): Don't let mode_line_proptrans_alist
- grow without limit. Move recently used elements to the front.
-
-2002-04-13 Eli Zaretskii <[email protected]>
-
- * unexelf.c (unexec) [__sgi]: Undo the change from 2002-01-20.
-
-2002-04-12 Gerd Moellmann <[email protected]>
-
- * xdisp.c (sync_frame_with_window_matrix_rows): Don't give frame
- rows marginal areas.
- (Fdump_frame_glyph_matrix) [GLYPH_DEBUG]: New function.
- (syms_of_xdisp) [GLYPH_DEBUG]: Defsubr it.
-
- * dispnew.c (marginal_area_string): Check that glyph row is enabled.
-
-2002-04-12 Dave Love <[email protected]>
-
- * dispnew.c (marginal_area_string): New.
-
- * window.c (window_part): Add ON_LEFT_MARGIN, ON_RIGHT_MARGIN.
- (Qleft_margin, Qright_margin): Declare.
- (coordinates_in_window, (Fcoordinates_in_window_p): Deal with margins.
-
- * xterm.c (note_mode_line_or_margin_highlight): Renamed from
- note_mode_line_highlight and extended.
-
- * keyboard.c (Qleft_margin, Qright_margin): Declare.
- (make_lispy_event): Deal with mouse events in margins.
-
-2002-04-12 Stefan Monnier <[email protected]>
-
- * msdos.c (dos_rawgetc): Use a single event for HELP_EVENT.
-
- * keyboard.c (command_loop_1): Turn off transient-mark-mode rather
- than deactivating the mark if tmm is set to `lambda'.
- (gen_help_event, kbd_buffer_store_help_event, kbd_buffer_get_event):
- Use a single event for HELP_EVENT.
- (Fexecute_extended_command): Save last_point_position.
-
-2002-04-12 Pavel Jan,Am(Bk <[email protected]>
-
- * lisp.h (Fpropertize): Add prototype.
-
- * fns.c (Fy_or_n_p): Use `minibuffer-prompt' face for prompt.
-
-2002-04-10 Colin Walters <[email protected]>
-
- * config.in: Add HAVE_SHARED_GAME_DIR.
-
- * callproc.c (Vgame_score_directory): New variable.
- (syms_of_callproc) <Vgame_score_directory>: DEFVAR_LISP.
-
-2002-04-10 Richard M. Stallman <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Reduce again to avoid big excess.
-
-2002-04-09 Stefan Monnier <[email protected]>
-
- * minibuf.c (read_minibuf): Use empty_string.
- (Ftry_completion): Allow lambda forms and lists of strings for `alist'.
- Short-circuit the search as soon as it "failed".
- (Fall_completions): Allow lambda forms and lists of strings for alist.
- (Fcompleting_read): Set Qminibuffer_completion_confirm to nil
- when require_match is nil.
- (Ftest_completion): Rename from `test_completion' and export to elisp.
- Call the predicate also when alist is a list.
- Obey Vcompletion_regexp_list.
- (do_completion, Fminibuffer_complete_and_exit): Use it.
- (Fassoc_string): Rename from `assoc_for_completion'.
- Allow list of strings as well and export to elisp.
-
-2002-04-08 Stefan Monnier <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 900KB.
-
-2002-04-08 Juanma Barranquero <[email protected]>
-
- * w32.c (sys_accept): Don't hide variable `s'.
-
-2002-04-05 Gerd Moellmann <[email protected]>
-
- * callint.c (Fcall_interactively): Use INTEGERP instead of
- NUMBERP for checking Vhistory_length.
-
-2002-04-05 Pavel Jan,Am(Bk <[email protected]>
-
- * sound.c (Fplay_sound_internal): Renamed from Fplay_sound.
- Doc fix to reflect it.
-
-2002-04-04 Richard M. Stallman <[email protected]>
-
- * xdisp.c (display_mode_element): New arg RISKY.
- Disregard text props found or specified within a variable
- that isn't marked risky-local-variable.
- (Qrisky_local_variable): New variable.
- (syms_of_xdisp): Init and staticpro it.
-
-2002-04-04 Stefan Monnier <[email protected]>
-
- * undo.c (record_point): New fun.
- (record_delete, record_insert): Use it.
-
-2002-04-03 Juanma Barranquero <[email protected]>
-
- * doc.c (Fdocumentation): Add missing parentheses.
- (Fdocumentation_property): Likewise.
-
-2002-04-03 Stefan Monnier <[email protected]>
-
- * doc.c (Fdocumentation, Fdocumentation_property): When the doc
- data is 0, just return nil.
-
-2002-04-03 Eli Zaretskii <[email protected]>
-
- * msdos.c (syms_of_msdos): Fix last change with
- mouse_autoselect_window.
-
-2002-04-03 Pavel Jan,Am(Bk <[email protected]>
-
- * w32term.c, xterm.c, msdos.c: Rename autoselect_window_p to
- mouse_autoselect_window.
-
-2002-04-02 Stefan Monnier <[email protected]>
-
- * keyboard.c (make_lispy_event): Handle unknown keysyms together
- with system-specific keysyms. Use it also for unknown function keys.
-
- * doc.c (reread_doc_file): Return whether reload was attempted.
- (Fdocumentation, Fdocumentation_property): Don't try to reload
- if the doc is 0 and only ask once.
-
- * Makefile.in (lisp, shortlisp): Add ucs-tables.elc.
-
-2002-04-02 Eli Zaretskii <[email protected]>
-
- * keyboard.c (read_char): If the event was Qselect_window,
- restore timer_idleness_start_time to its previous value.
-
- * msdos.c (dos_rawgetc): Generate SELECT_WINDOW_EVENTs when required.
-
-2002-04-01 Stefan Monnier <[email protected]>
-
- * region-cache.c (new_region_cache): Use BEG.
-
- * marker.c (buf_charpos_to_bytepos, buf_bytepos_to_charpos):
- Use BEG and BEG_BYTE.
-
- * doc.c (get_doc_string): Return nil if the location is wrong.
- (reread_doc_file): New fun.
- (Fdocumentation, Fdocumentation_property):
- Call it if get_doc_string fails.
- (Fsnarf_documentation): Make it work for a dumped Emacs.
-
- * charset.h (DEC_POS, BUF_DEC_POS): Use BEG_BYTE.
- Bound the search with MAX_MULTIBYTE_LENGTH to avoid pathological case.
-
- * charset.c (Fstring): Allow 0 arguments.
-
- * xterm.c (XTread_socket): Fix int/Lisp_Object confusion.
-
- * process.c (DATAGRAM_CONN_P, list_processes_1)
- (Fprocess_datagram_address, Fset_process_datagram_address)
- (Fset_network_process_options, server_accept_connection):
- Fix some int/Lisp_Object confusions (thank you union types).
-
-2002-04-01 Pavel Jan,Am(Bk <[email protected]>
-
- * msdos.c: Rename x_autoselect_window_p to autoselect_window_p.
-
- * w32term.c: Likewise.
- (note_mouse_movement): Put code for x_autoselect_window_p in #if 0.
-
- * keyboard.c (Qselect_window): New symbol.
- (head_table): Use it.
- (keys_of_keyboard): Bound select-window event to handle-select-window.
- (kbd_buffer_get_event): Make a Lisp event from SELECT_WINDOW_EVENT.
-
- * xterm.c: Rename x_autoselect_window_p to autoselect_window_p.
- (last_window): New variable.
- (XTread_socket): Generate SELECT_WINDOW_EVENTs.
- (note_mouse_movement): Remove reimplemented code in #if 0.
- (XTread_socket): Generate SELECT_WINDOW_EVENTs only for
- Emacs windows.
-
- * termhooks.h (enum event_kind): New event type `SELECT_WINDOW_EVENT'.
-
-2002-03-31 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_get_char_face_and_encoding): Add parameter DISPLAY_P.
- Callers changed.
-
-2002-03-30 Richard M. Stallman <[email protected]>
-
- * window.c (window_scroll_pixel_based): Exit the move_it_by_lines
- loop whenever it stops making progress.
-
- * widget.c (set_frame_size): Don't call change_frame_size.
-
-2002-03-30 Gerd Moellmann <[email protected]>
-
- * dispnew.c (direct_output_for_insert):
- Call mark_window_display_accurate.
-
-2002-03-29 Jason Rumney <[email protected]>
-
- * w32term.c (w32_draw_relief_rect): Fix calculations of line lengths.
-
-2002-03-29 Eli Zaretskii <[email protected]>
-
- * Makefile.in (lread.o): Depend on coding.h.
-
- * lread.c (openp, Fload): Encode the file name before passing it
- to `stat', `access', and `emacs_open'.
- (openp): GCPRO the encoded file name. Don't recompute Lisp
- strings unnecessarily.
-
-2002-03-29 Kim F. Storm <[email protected]>
-
- * fns.c (Flax_plist_put): Doc fix.
-
-2002-03-28 Miles Bader <[email protected]>
-
- * process.c (DATAGRAM_CONN_P): Make sure PROC is really a process.
-
-2002-03-27 Pavel Jan,Am(Bk <[email protected]>
-
- * process.c (set-network-process-options): Add usage.
- (make-network-process): Doc fix.
-
-2002-03-26 Eli Zaretskii <[email protected]>
-
- * emacs.c (Fdump_emacs): Fix a typo in "command-line-processed".
-
-2002-03-26 Richard M. Stallman <[email protected]>
-
- * fns.c (Fsubstring_no_properties): New function.
- (Flax_plist_get, Flax_plist_put): New functions.
- (syms_of_fns): defsubr them.
-
- * xdisp.c (update_menu_bar): Test only update_mode_lines;
- don't test or alter w->update_mode_line.
-
- * window.c (Fdisplay_buffer): Doc fix.
-
-2002-03-24 Richard M. Stallman <[email protected]>
-
- * regex.c (GET_UNSIGNED_NUMBER): Give proper error for spaces.
-
-2002-03-24 Gerd Moellmann <[email protected]>
-
- * eval.c (Qdeclare, Vmacro_declaration_function): New variables.
- (Fdefmacro): Handle `(declare ...)'.
- (syms_of_eval) <Qdeclare>: Initialize and staticpro.
- (syms_of_eval) <Vmacro_declaration_function>: DEFVAR_LISP.
-
-2002-03-24 Jason Rumney <[email protected]>
-
- * w32fns.c (xbm_scan, xbm_load_image, xbm_read_bitmap_data)
- (xbm_file_p): Add prototypes.
- (xbm_format, xbm_image_p): Sync with xfns.c.
- (reflect_byte): New function.
- (xbm_read_bitmap_data): Sync with xfns.c, adapt for Windows.
- (xbm_load_image): Create bitmaps with a depth of 1.
- (init_xfns): Enable XBM images.
-
-2002-03-23 Jason Rumney <[email protected]>
-
- * w32term.c (w32_handle_tool_bar_click): Detect up and down events
- correctly. Do not pass up_modifier to keyboard buffer.
-
- * w32fns.c [HAVE_IMAGES, HAVE_PBM]: Remove conditionals.
-
-2002-03-22 Stefan Monnier <[email protected]>
-
- * Makefile.in (bootstrapclean): New target.
- (bootstrap-temacs, bootstrap-doc): Remove.
- (bootstrap-emacs): Use a bog-standard `temacs'.
- Don't bother to build a DOC file.
-
- * sysdep.c (wait_for_termination): Use sigsuspend rather than sigpause.
-
- * emacs.c (main): Handle --unibyte, --multibyte, and --no-loadup
- in temacs even if !CANNOT_DUMP.
- (standard_args): Keep --no-loadup even if !CANNOT_DUMP.
-
- * alloc.c (check_pure_size): Only output a warning.
-
-2002-03-22 Jason Rumney <[email protected]>
-
- * w32fns.c (Fx_create_frame): Enable tool-bar when images are
- supported.
-
- * w32term.c (zv_bits): Declare as short, for word alignment.
- (w32_read_socket) <WM_XBUTTONUP>: Fix last change.
- (syms_of_w32term): Define x-use-underline-position-properties.
-
- * w32fns.c (x_set_cursor_color): Set cursor_gc as well.
- (clear_image_cache): Block input, fix logic, clear matrices in
- all frames that share this cache.
-
-2002-03-22 Eli Zaretskii <[email protected]>
-
- * emacs.c (main): Update the Copyright year in the blurb printed
- by "emacs --version".
-
- * xdisp.c (message_with_string): Fix syntax of a call to GCPRO2.
-
- * xterm.c (XTread_socket): If XK_ISO_Lock and
- XK_ISO_Last_Group_Lock are defined, handle keysyms between
- XK_ISO_Lock and XK_ISO_Last_Group_Lock similarly to Mode_switch.
-
-2002-03-21 Kim F. Storm <[email protected]>
-
- * keyboard.c (menu_bar_items): Mostly undo 2002-02-20 patch, so
- menu-bar bindings in keymap and local-map properties _are_ used.
- But try keymap property first in accordance with 2002-01-03 patch.
- Added comment describing why this is not always reliable.
- (tool_bar_items): Ditto for tool-bar.
-
-2002-03-21 Jason Rumney <[email protected]>
-
- * w32fns.c (x_clear_image_1): Disable color table code.
-
-2002-03-21 Kim F. Storm <[email protected]>
-
- * lisp.h (DEFUN) [USE_NONANSI_DEFUN]: The 2001-10-17 patch
- removed the wrong version of the DEFUN macro; fixed it.
-
- * fns.c (Ffeaturep): Allow subfeature to be a list (test using
- Fmember rather than Fmemq).
- (Fprovide): Check that subfeatures is a list.
-
- * process.c (QCfeature, QCdatagram): Removed variables.
- (QCtype, Qdatagram): New variables.
- (network_process_featurep): Removed function.
- (Fmake_network_process): Removed :feature check.
- Use :type 'datagram instead of :datagram t to create a datagram
- socket. This allows us to add other connection types (e.g. raw
- sockets) later in a consistent manner.
- (init_process) [subprocess, HAVE_SOCKETS]: Provide list of
- supported subfeatures for feature make-network-process.
- (syms_of_process) [subprocess]: Remove QCfeature and QCdatagram.
- Intern and staticpro QCtype and Qdatagram.
- (syms_of_process) [!subprocess]: Intern and staticpro QCtype.
-
- * xfns.c (QCtype): Remove duplicate declaration and
- initialization (is now declared in process.c).
-
- * w32fns.c (QCtype): Remove duplicate declaration and
- initialization (is now declared in process.c).
-
-2002-03-21 Richard M. Stallman <[email protected]>
-
- * regex.c (DISCARD_FAILURE_REG_OR_COUNT): New macro.
- (CHECK_INFINITE_LOOP): Use DISCARD_FAILURE_REG_OR_COUNT
- when jumping to `fail' to avoid undoing reg changes in the
- last iteration of the loop.
- (GET_UNSIGNED_NUMBER): Skip spaces around the number.
-
- * Makefile.in (dispnew.o, sysdep.o, xdisp.o, xselect.o, alloc.o):
- Depend on process.h.
-
-2002-03-20 Jason Rumney <[email protected]>
-
- Most of the following changes are still conditional on HAVE_IMAGES
- which is not set by default on Windows.
-
- * emacs.c (main) [WINDOWSNT]: Call init_xfns.
-
- * w32fns.c (x_set_cursor_color): Set foreground of cursor, not frame.
- (Fimage_size, Fimage_mask_p, XPutPixel): New functions.
- (four_corners_best, x_clear_image_1, x_clear_image)
- (x_alloc_image_color, postprocess_image)
- (x_create_x_image_and_pixmap, x_destroy_x_image, xbm_load_image)
- (x_from_x_colors, x_disable_image, pbm_load): Adapt for Windows.
- (init_xfns, syms_of_w32fns): Initialize image functions and constants.
-
- * w32gui.h (struct XImage): Define.
-
- * w32term.c (w32_read_socket) <WM_XBUTTONUP>: Use XFASTINT to
- extract mouse co-ordinates.
-
-2002-03-20 Jason Rumney <[email protected]>
-
- * w32.c (init_winsock): Dynamically load new server and UDP
- socket functions.
- (socket_to_fd): New function.
- (sys_socket): Use it.
- (sys_setsockopt, sys_listen, sys_getsockname, sys_accept)
- (sys_recvfrom, sys_sendto): New wrapper functions.
-
- * process.c (QCfamily, QCfilter): Remove duplicate declaration
- and initialization.
-
- * makefile.w32-in (LIBS): Remove $(WSOCK32).
-
-2002-03-20 Eli Zaretskii <[email protected]>
-
- * process.c (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr):
- Don't use "sun" as a variable, it's a predefined constant on Sun
- machines.
-
-2002-03-20 Pavel Jan,Am(Bk <[email protected]>
-
- * bytecode.c (Fbyte_code): Revert last change.
-
-2002-03-19 Kim F. Storm <[email protected]>
-
- * makefile.w32-in (LIBS): Add $(WSOCK32).
- From David Ponce <[email protected]>.
-
-2002-03-18 Pavel Jan,Am(Bk <[email protected]>
-
- * process.c (wait_reading_process_input): Move variables `pname'
- and `pnamelen' down where they are used.
-
- * bytecode.c (Fbyte_code): Discard unused computed value to
- prevent gcc warning.
-
- * lisp.h (Fplist_member): Add prototype.
-
-2002-03-18 Kim F. Storm <[email protected]>
-
- * config.in: Add HAVE_SENDTO, HAVE_RECVFROM, HAVE_SETSOCKOPT,
- HAVE_GETSOCKOPT, HAVE_GETPEERNAME, HAVE_GETSOCKNAME, and HAVE_SYS_UN_H.
-
- * process.c: Define HAVE_LOCAL_SOCKETS based on HAVE_SYS_UN_H.
- Remove explicit GNU_LINUX settings for datagram support.
-
-2002-03-18 Pavel Jan,Am(Bk <[email protected]>
-
- * process.c (Fmake_network_process): Remove unused variable `sa'.
- Doc fix. Add usage:.
- (set_socket_options): Remove unused variables `optnum' and `opttype'.
-
-2002-03-17 Richard M. Stallman <[email protected]>
-
- * xdisp.c (cursor_type_changed): New variable.
- (redisplay_internal): Redisplay all windows if cursor_type_changed.
- Clear it when clearing windows_or_buffers_changed.
- (try_cursor_movement, redisplay_window, try_window_id)
- (try_window_reusing_current_matrix): Test cursor_type_changed
- along with windows_or_buffers_changed.
-
- * window.h (cursor_type_changed): New variable.
-
- * xfns.c (x_set_cursor_type): Set cursor_type_changed,
- not update_mode_lines, and always set it to 1.
-
- * xdisp.c (clear_garbaged_frames): Don't set windows_or_buffers_changed
- if no frames needed redrawing.
-
-2002-03-17 Kim F. Storm <[email protected]>
-
- The following changes add support for network server processes,
- datagram connections, and local (unix) sockets.
-
- * process.h (struct Lisp_Process): New member log.
- Doc fix: Member command used to indicate stopped network process.
- Doc fix: Member childp contains plist for network process.
- Doc fix: Member kill_without_query is inverse of query-on-exit flag.
-
- * process.c (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
- (QClocal, QCremote, QCserver, QCdatagram, QCnowait, QCnoquery, QCstop)
- (QCcoding, QCoptions, QCfilter, QCsentinel, QClog, QCfeature): New
- variables.
- (NETCONN1_P): New macro.
- (DATAGRAM_SOCKETS): New conditional symbol.
- (datagram_address): New array.
- (DATAGRAM_CONN_P, DATAGRAM_CHAN_P): New macros.
- (status_message): Use concat3.
- (Fprocess_status): Add `listen' status to doc string. Return
- `stop' for a stopped network process.
- (Fset_process_buffer): Update contact plist for network process.
- (Fset_process_filter): Ditto. Don't enable input for stopped
- network processes. Server must listen, even if filter is t.
- (Fset_process_query_on_exit_flag, Fprocess_query_on_exit_flag):
- New functions.
- (Fprocess_kill_without_query): Removed. Now defined in simple.el.
- (Fprocess_contact): Added KEY argument. Handle datagrams.
- (list_processes_1): Optionally show only processes with the query
- on exit flag set. Dynamically adjust column widths. Omit tty
- column if not needed. Report stopped network processes. Identify
- server and datagram network processes.
- (Flist_processes): New optional arg `query-only'.
- (conv_sockaddr_to_lisp, get_lisp_to_sockaddr_size)
- (conv_lisp_to_sockaddr, set_socket_options)
- (network_process_featurep, unwind_request_sigio): New helper
- functions.
- (Fprocess_datagram_address, Fset_process_datagram_address):
- (Fset_network_process_options): New lisp functions.
- (Fopen_network_stream): Removed. Now defined in simple.el.
- (Fmake_network_process): New lisp function. Code is based on
- previous Fopen_network_stream, but heavily reworked with new
- property list based argument list, support for datagrams, server
- processes, and local sockets in addition to old client-only
- functionality.
- (server_accept_connection): New function.
- (wait_reading_process_input): Use it to handle incoming connects.
- Do not enable input on a new connection if process is stopped.
- (read_process_output): Handle datagram sockets. Use 2k buffer for
- them.
- (send_process): Handle datagram sockets.
- (Fstop_process, Fcontinue_process): Apply to network processes. A
- stopped network process is indicated by setting command field to t.
- (Fprocess_send_eof): No-op if datagram connection.
- (Fstatus_notify): Don't read input for a stream server socket or a
- stopped network process.
- (init_process): Initialize datagram_address array.
- (syms_of_process): Intern and staticpro new variables, defsubr new
- functions.
-
-2002-03-16 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_to_all_x_charsets): Return correct type in
- startup case.
-
-2002-03-16 Richard M. Stallman <[email protected]>
-
- * xdisp.c (redisplay_internal, redisplay_windows):
- Use list_of_error to call internal_condition_case_1.
- (safe_eval, safe_call): Pass Qt to internal_condition_case_{1,2}
- so as to catch all errors with no possibility of debugger redisplay.
- (list_of_error): New variable.
- (syms_of_xdisp): Init and staticpro it.
-
- * print.c (print_object): Delete `\ ' from printed rep of frame.
-
-2002-03-15 Eli Zaretskii <[email protected]>
-
- * msdos.c (dos_rawgetc): Disable the x-autoselect-window feature,
- until its implementation is fixed.
-
-2002-03-14 Pavel Jan,Am(Bk <[email protected]>
-
- * xfns.c (png_load): Remove unused variable `gamma_str'.
-
-2002-03-14 Richard M. Stallman <[email protected]>
-
- * xfns.c (x_real_positions): Handle failure in XQueryTree.
-
-2002-03-14 Miles Bader <[email protected]>
-
- * intervals.c (adjust_for_invis_intang): New function.
- (set_point_both): Use `adjust_for_invis_intang' to do most of the
- work for dealing with invisible+intangible regions. Do so before
- and after both forward and backward movements, to handle both
- front-sticky and rear-sticky cases.
- * textprop.c (text_property_stickiness): Function moved here from
- `editfns.c'.
- * intervals.h (text_property_stickiness): New declaration.
- * editfns.c (char_property_eq): Function removed.
- (text_property_stickiness): Function moved to `textprop.c'.
-
-2002-03-13 Jason Rumney <[email protected]>
-
- * config.in: Add STRFTIME_NO_POSIX2.
-
- * strftime.c (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
- and %OX when underlying strftime does not.
-
-2002-03-13 Stefan Monnier <[email protected]>
-
- * xterm.c (x_set_toolkit_scroll_bar_thumb) <USE_MOTIF>:
- Use a fixed-size thumb (based on an ad-hoc estimate of 30 chars per
- line) to avoid annoying flicker.
- (xm_scroll_callback): Get rid of the now unnecessary kludge.
- (XTread_socket): Mark it static.
-
- * xdisp.c (display_mode_element): Fix int/Lisp_Object mixup.
-
-2002-03-13 Kim F. Storm <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 775000.
-
-2002-03-12 Juanma Barranquero <[email protected]>
-
- * editfns.c (syms_of_editfns): Fix typo.
-
-2002-03-12 Gerd Moellmann <[email protected]>
-
- * xsmfns.c: Include stdio.h because termhooks.h needs it.
- Include termopt.h for interrupt_input.
-
-2002-03-11 Andreas Schwab <[email protected]>
-
- * coding.c (syms_of_coding) <file-coding-system-alist>: Doc fix.
-
-2002-03-11 Gerd Moellmann <[email protected]>
-
- * xterm.c (note_mouse_movement): Put code for
- x_autoselect_window_p in #if 0.
-
- * lread.c (Fload): Don't assume that message_with_string uses the
- string it is given like a C string.
-
-2002-03-10 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h (x_session_check_input, x_session_initialize): Declare.
-
- * xterm.c (XTread_socket): Add call to x_session_check_input and
- x_session_have_connection.
- (x_initialize): Add call to x_session_initialize.
-
- * termhooks.h (enum event_kind): Add save_session_event.
-
- * keyboard.c: Add Emacs event save_session_event.
-
- * emacs.c (main): Add call to syms_of_xsmfns.
-
- * lisp.h (syms_of_xsmfns): Declare extern.
-
- * config.in: Add HAVE_X_SM.
-
- * Makefile.in (LIBXT): Add -lSM -lICE
- if HAVE_X_SM and not USE_X_TOOLKIT.
- (XOBJ): New file xsmfns.c added.
-
- * xsmfns.c: New file for X session management.
-
-2002-03-09 Jason Rumney <[email protected]>
-
- * fileio.c (Fcopy_file) [WINDOWS_NT]: Ensure file is not
- read-only when setting modified time.
-
-2002-03-08 Gerd Moellmann <[email protected]>
-
- * xdisp.c (move_it_vertically_backward): At the end of the function,
- when moving forward by lines, treat terminal frames specially.
-
- * keyboard.c (echo_char): Make sure to add a separator between
- keys even if echo_dash hasn't been called.
-
- * xdisp.c: Use new string macros.
- (update_echo_area): Pass number of bytes to message3 instead of
- number of chars.
- (set_message_1): Don't access a string's size_byte directly.
- (decode_mode_spec_coding): Use number of bytes of eoltype string
- instead number of chars.
-
- * lisp.h (SREF, SDATA, SCHARS, SBYTES, SMBP): New macros.
-
-2002-03-08 Juanma Barranquero <[email protected]>
-
- * w32fns.c (Fx_display_color_cells): Force 24+ bit color depths to
- 24-bit.
-
-2002-03-06 Jason Rumney <[email protected]>
-
- * w32term.c (x_draw_hollow_cursor): Draw same size as block cursor.
-
-2002-03-06 Gerd Moellmann <[email protected]>
-
- * keyboard.c (echo_prompt, echo_char, echo_dash, echo_now)
- (cancel_echoing, echo_length, echo_truncate): Changed to
- work with new kboard definition.
- (echo_now): Use message3_nolog instead of message2_nolog.
-
- * alloc.c (mark_kboards): Mark echo_string.
-
- * keyboard.h (ECHOBUFSIZE): Removed.
- (struct kboard): Member echoptr removed, member echobuf renamed
- to echo_string.
-
- * xdisp.c (message_with_string): Use Fformat instead of doprnt and
- message3 instead of message2 to display the message using STRING's
- text properties.
-
-2002-03-05 Andreas Schwab <[email protected]>
-
- * xdisp.c (hscroll_margin): Change to EMACS_INT.
-
-2002-03-05 Per Abrahamsen <[email protected]>
-
- * frame.c (default-frame-alist): Explain that setting it doesn't
- affect existing frames.
-
-2002-03-05 Stefan Monnier <[email protected]>
-
- * indent.c (skip_invisible): Fix my brain fart.
-
- * dispnew.c (sit_for): Don't wait if executing a kbd macro.
-
-2002-03-04 Stefan Monnier <[email protected]>
-
- * dosfns.c, dosfns.h, dispnew.c, dispextern.h, commands.h, charset.c,
- * alloc.c, abbrev.c, emacs.c, eval.c, keyboard.c, keyboard.h,
- * lisp.h, lread.c, sysdep.c, termcap.c, termchar.h, w32term.c,
- * window.c, xdisp.c, xselect.c, xterm.c: Change defvar_int definition
- and variables to use EMACS_INT instead of just int.
-
- * buffer.c (syms_of_buffer): Allow non-string `mode-name'.
-
-2002-03-04 Eli Zaretskii <[email protected]>
-
- * sysdep.c (sys_subshell) [MSDOS]: If PWD is set in the
- environment, pass it down with corrected value.
-
-2002-03-04 Pavel Jan,Am(Bk <[email protected]>
-
- * lread.c (read_filtered_event): Do not call start_hourglass
- before returning.
-
-2002-03-04 Juanma Barranquero <[email protected]>
-
- * w32term.c (x_display_and_set_cursor): Fix typo.
-
-2002-03-03 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fmake_temp_name): Doc fix.
-
-2002-03-03 Gary Wong <[email protected]>
-
- * termcap.c [!emacs]: Replace ospeed for building standalone
- libtermcap, for binary compatibility.
-
- * tparam.c [!emacs]: Move #define of bcopy to after string.h.
-
-2002-03-03 Richard M. Stallman <[email protected]>
-
- * xrdb.c (file_p): Rename arg `path' to `filename'.
-
- * abbrev.c (Fexpand_abbrev): Increment plist as use count
- only if it is an integer.
-
- * xfns.c (png_load): Set screen_gamma based on f->gamma.
- If png_get_sRGB gives an answer, call png_set_gamma
- using the default image gamma value.
-
- * lread.c (read1): When reading from a file, default string to
- multibyte only if it has some multibyte characters.
-
- * print.c (print_object): Output multibyte chars 128...255
- using \x even if ! print_escape_multibyte.
-
- * xdisp.c (display_mode_element): Move the places where
- bytepos, charpos, this, and lisp_string are set.
- Use lisp_string to set bytepos.
-
- * xdisp.c (redisplay_internal):
- Call clear_image_cache only if HAVE_WINDOW_SYSTEM.
-
- * xdisp.c (display_mode_element): Merge properties specified with
- :propertize onto those that come with the string.
-
-2002-03-03 Eli Zaretskii <[email protected]>
-
- * xdisp.c (syms_of_xdisp) <auto-hscroll-mode>: Renamed from
- automatic-hscrolling. Users changed.
- <hscroll-margin>: Renamed from automatic-hscroll-margin.
- Users changed.
- <hscroll-step>: Renamed from automatic-hscroll-step. Users changed.
-
-2002-03-02 Eli Zaretskii <[email protected]>
-
- * buffer.c (syms_of_buffer) <buffer-file-coding-system>: Doc fix.
-
-2002-03-02 Kim F. Storm <[email protected]>
-
- * window.c (Fminibuffer_selected_window): New function.
- (syms_of_window): Defsubr it.
-
-2002-03-01 Kim F. Storm <[email protected]>
-
- * window.h (struct window): New member phys_cursor_width.
-
- * window.c (make_window, replace_window): Init phys_cursor_width.
-
- * xterm.c (x_display_and_set_cursor): Blink box cursor using
- hollow box cursor. Blink bar cursor using 1 pixel wide bar.
-
- * w32term.c (x_display_and_set_cursor): Blink box cursor using
- hollow box cursor. Blink bar cursor using 1 pixel wide bar.
-
- * lisp.h (GCPRO6): New macro.
-
- * process.c (Fopen_network_stream): Use GCPRO6.
-
-2002-03-01 Kim F. Storm <[email protected]>
-
- * process.c (Qconnect, Qfailed): New variables.
- (syms_of_process): Intern and staticpro them.
- (Fprocess_status): Document connect and failed return values.
- [NON_BLOCKING_CONNECT]: New conditional.
- (connect_wait_mask, num_pending_connects): New variables.
- (status_message): Convert Qfailed status.
- (Fopen_network_stream): Added support for non-blocking connect.
- New optional args: filter, sentinel, non_blocking. Doc updated.
- [HAVE_GETADDRINFO, !HAVE_GETADDRINFO]: Merged common code.
- (deactivate_process): Handle pending non-blocking connect.
- (wait_reading_process_input): Poll for status of non-blocking
- connects. Exec sentinel directly when connect succeeds.
- (status_notify): Don't read process output if not yet connected.
-
-2002-02-28 Kim F. Storm <[email protected]>
-
- * window.c (minibuf_selected_window): Renamed from
- Vminibuf_selected_window. Users changed.
- (syms_of_window): Staticpro it.
-
-2002-02-26 Kim F. Storm <[email protected]>
-
- The following changes add a new Vminibuf_selected_window variable
- which is similar to Vminibuf_scroll_window, but which is only set
- on entry to the minibuffer (from a non-minibuffer window):
-
- * window.c (Vminibuf_selected_window): New variable.
- (struct save_window_data): New member minibuf_selected_window.
- (Fset_window_configuration): Restore Vminibuf_selected_window.
- (Fcurrent_window_configuration): Save Vminibuf_selected_window.
- Set minibuf_scroll_window member to nil if minibuf_level is 0.
- (compare_window_configurations): Compare minibuf_selected_window.
-
- * window.h (Vminibuf_selected_window): Declare extern.
-
- * minibuf.c (read_minibuf): Set Vminibuf_selected_window on first
- entry to minibuffer or on entry from a non-minibuffer window.
-
- * dispextern.h (CURRENT_MODE_LINE_FACE_ID_3): Compare with
- Vminibuf_selected_window instead of Vminibuf_scroll_window.
-
- * xdisp.c (init_iterator): Compare with Vminibuf_selected_window
- instead of Vminibuf_scroll_window when deciding in which window
- the region should be highlighted. Consequently, the region remains
- highlighteded even when a completion buffer is also displayed.
-
-2002-02-26 Eli Zaretskii <[email protected]>
-
- * fileio.c (Fsubstitute_in_file_name): Fix the change from 2002-02-08.
-
- * xselect.c (Qcompound_text_with_extensions): Renamed from
- Qcompound_text_no_extensions.
- (lisp_data_to_selection_data, syms_of_xselect): Use the new name.
-
-2002-02-26 Juanma Barranquero <[email protected]>
-
- * w32proc.c (syms_of_ntproc): Doc fix.
-
-2002-02-24 Pavel Jan,Am(Bk <[email protected]>
-
- * intervals.h: Include "dispextern.h" unconditionally.
-
-2002-02-24 Jason Rumney <[email protected]>
-
- * Makefile.in (WINNT_SUPPORT) [WINDOWSNT]: Add w32-vars.elc
- and disp-table.elc.
- (lisp): Add emacs-lisp/backquote.elc.
-
-2002-02-24 Kim F. Storm <[email protected]>
-
- * keymap.c (Flookup_key): Fix problem in 2001-12-28 patch:
- The validation of the event type was too strict as it didn't
- allow string events; buffer names are used in bindings for
- menu-bar-select-buffer (see `menu-bar-update-buffers').
-
-2002-02-23 Kim F. Storm <[email protected]>
-
- The following changes rework my patch of 2002-02-06 which
- added command remapping by entering the commands directly into
- the keymaps. Now, command remapping uses an explicit `remap'
- prefix in the keymaps, i.e. [remap COMMAND].
-
- * keymap.c (Qremap, remap_command_vector): New variables.
- (is_command_symbol): Remove function.
- (Fdefine_key): No longer accept a symbol for KEY.
- Added validation of [remap COMMAND] argument for KEY.
- The DEF is no longer required to be a symbol when remapping a command.
- (Fremap_command): New function to remap command through keymaps.
- (Flookup_key): Perform command remapping initiated by
- Fremap_command directly for speed.
- (Fkey_binding): Use Fremap_command for command remapping.
- (where_is_internal): Handle new command remapping representation.
- (syms_of_keymap): Intern Qremap, initialize remap_command_vector,
- staticpro them. Defsubr Fremap_command.
-
- * keymap.h (Fremap_command): Declare extern.
- (is_command_symbol): Remove extern.
-
- * keyboard.c (command_loop_1): Use Fremap_command for command
- remapping; now try command remapping for all symbols.
-
-2002-02-23 Eli Zaretskii <[email protected]>
-
- * coding.h (run_pre_post_conversion_on_str): Add prototype.
-
-2002-02-23 Jason Rumney <[email protected]>
-
- * w32select.c (Fw32_set_clipboard_data): Run pre-write-conversion
- on the string before encoding it.
- (Fw32_get_clipboard_data): Run post-read-conversion on the string
- after decoding it.
-
- * w32fns.c (w32_wnd_proc) <WM_TIMER>: Fix last change.
-
-2002-02-23 Pavel Jan,Am(Bk <[email protected]>
-
- * w32term.c (enter_timestamp): Remove unused static variable to
- prevent warning.
-
- * xterm.c (enter_timestamp): Put in #if 0 to prevent warning.
-
-2002-02-23 Eli Zaretskii <[email protected]>
-
- * w16select.c (Fw16_get_clipboard_data): Fix last change.
-
- * xselect.c (selection_data_to_lisp_data): Fix last change.
-
-2002-02-22 Jason Rumney <[email protected]>
-
- * w32term.h (struct w32_output): New member menu_command_in_progress.
-
- * w32menu.c (menubar_selection_callback): Free the menu and
- clear the menu_command_in_progress flag.
-
- * w32fns.c (mouse_move_timer, mouse_button_timer): Initialize.
- (menu_free_timer): New variable.
- (MENU_FREE_ID, MENU_FREE_DELAY): New constants.
- (w32_wnd_proc) <WM_TIMER>: Handle menu_free_timer.
- <WM_EXITMENULOOP>: Delay before freeing menu. Do nothing if a
- menu command is in progress.
- <WM_COMMAND>: Set the menu_command_in_progress flag.
- Kill any menu_free_timer that is running.
-
- * w32term.c (w32_text_out): Renamed from W32_TEXTOUT.
- Call ExtTextOutA rather than ExtTextOut.
-
-2002-02-22 Eli Zaretskii <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 755000.
-
-2002-02-22 Eli Zaretskii <[email protected]>
-
- * w16select.c (Fw16_set_clipboard_data): Run pre-write-conversion
- on the string before encoding it.
- (Fw16_get_clipboard_data): Run post-read-conversion on the string
- after decoding it.
-
-2002-02-22 Eli Zaretskii <[email protected]>
-
- Support for ICCCM Extended Segments in X selections:
-
- * xselect.c <Qcompound_text_no_extensions>: New variable.
- (syms_of_xselect): Intern and staticpro it.
- (selection_data_to_lisp_data): Run post-read-conversion on decoded
- selection text.
- (lisp_data_to_selection_data): If next-selection-coding-system is
- compound-text-no-extensions, set the type of selection to be
- compound-text.
-
- * xterm.h (x_encode_text): Update prototype.
-
- * xfns.c (x_encode_text): Accept additional arg SELECTIONP; all
- callers changed. If SELECTIONP is non-zero, run the
- pre-write-conversion function before encoding the selection text.
-
-2002-02-21 Kim F. Storm <[email protected]>
-
- * frame.c (syms_of_frame): Change mouse-highlight default to t.
-
- * keyboard.c (kbd_buffer_get_event) [WINDOWSNT]:
- Correct composing of language-change event.
-
-2002-02-20 Kim F. Storm <[email protected]>
-
- * keyboard.c (menu_bar_items): Don't include keymap or local-map
- bindings at PT when building menu (the menu is not updated often
- enough for this to work reliable).
- (tool_bar_items): Likewise.
- (current_active_maps): Removed unused (and buggy) function.
-
-2002-02-20 Pavel Jan,Am(Bk <[email protected]>
-
- * xfns.c (gif_load): Use correct width and height for GIF images.
-
-2002-02-19 Eli Zaretskii <[email protected]>
-
- * floatfns.c (Fatan): Accept an optional second arg and call
- atan2 if passed 2 args.
-
-2002-02-18 Jason Rumney <[email protected]>
-
- * w32term.c (glyph_rect): Determine the row and glyph more precisely.
-
-2002-02-17 Jason Rumney <[email protected]>
-
- * w32term.c (x_autoselect_window_p): New variable.
- (syms_of_w32term): DEFVAR_BOOL and initialize it.
- (note_mouse_movement): Use it.
-
- * w32fns.c (w32_load_system_font): Never set fonts_changed_p to zero.
-
- * w32bdf.c (w32_load_bdf_font): Maybe set fonts_changed_p.
-
- * w32fns.c (Qfullscreen, Qfullwidth, Qfullheight, Qfullboth):
- New variables.
- (syms_of_w32fns): Intern and staticpro them.
- (x_frame_parms) <"fullscreen">: New parameter.
- (x_fullscreen_move, x_set_fullscreen): New functions.
- (x_set_frame_parameters): Support Qfullscreen.
- (x_real_positions): Save x/y_pixels_diff frame params.
- (x_figure_window_size): Support full-screen frames.
- (Fx_create_frame): Default the fullscreen parameter.
-
- * w32term.c (x_check_fullscreen, x_check_fullscreen_move)
- (x_fullscreen_adjust): New functions.
- (w32_read_socket) <WM_WINDOWPOSCHANGED>: Don't resize to
- fullscreen. Call x_check_fullscreen_move, and set the
- want_fullscreen member of output_data.w32
- <WM_ACTIVATE, WM_ACTIVATEAPP>: Call x_check_fullscreen.
-
- * w32term.h: New enum for FULLSCREEN_* constants.
- (struct w32_output): New members want_fullscreen, x_pixels_diff,
- y_pixels_diff, x_pixels_outer_diff, and y_pixels_outer_diff.
- (x-fullscreen-adjust): New prototype.
-
-2002-02-17 Kim F. Storm <[email protected]>
-
- * frame.c (Vmouse_highlight): New variable.
- (syms_of_frame): DEFVAR_LISP it.
-
- * frame.h (Vmouse_highlight): Declare extern.
-
- * xterm.h (struct x_display_info): Add mouse_face_hidden.
-
- * xterm.c (disable_mouse_highlight): Removed variable.
- (note_mouse_highlight): Don't highlight if Vmouse_highlight is nil.
- (show_mouse_face): Don't show highlight if mouse_face_hidden is set.
- (XTread_socket): Turn mouse_face_hidden off after mouse movement,
- and on after keyboard input.
- (x_term_init): Initialize mouse_face_hidden.
-
- * msdos.h (struct display_info): Add mouse_face_hidden.
-
- * msdos.c (disable_mouse_highlight): Removed variable.
- (show_mouse_face): Don't show highlight if mouse_face_hidden is set.
- (IT_note_mouse_highlight): Don't highlight if Vmouse_highlight is nil.
- (internal_terminal_init): Initialize mouse_face_hidden.
- (dos_rawgetc): Turn mouse_face_hidden off after mouse movement,
- and on after keyboard input.
-
- * w32term.h (struct w32_display_info): Add mouse_face_hidden.
-
- * w32term.c (disable_mouse_highlight): Removed variable.
- (note_mouse_highlight): Disable highlight if Vmouse_highlight is nil.
- (show_mouse_face): Don't show highlight if mouse_face_hidden is set.
- (w32_read_socket): Turn mouse_face_hidden off after mouse movement,
- and on after keyboard input.
- (w32_initialize_display_info): Initialize mouse_face_hidden.
-
-2002-02-16 Eli Zaretskii <[email protected]>
-
- * msdos.c (last_mouse_window): New variable.
- (dos_rawgetc): Fix last change--if the mouse is in the same window
- as recorded in last_mouse_window, don't select this window.
-
- * Makefile.in (lisp, shortlisp): Use cus-start.elc, not cus-start.el.
-
- * msdos.c (x_autoselect_window_p): New variable.
- (syms_of_msdos): Defvar it.
- (dos_rawgetc): If x_autoselect_window_p is set, select the window in
- which the last mouse movement occured, unless it is already selected.
-
- * xdisp.c (automatic_hscroll_margin, Vautomatic_hscroll_step):
- New variables.
- (syms_of_xdisp): DEVFAR them.
- (hscroll_window_tree): Use automatic_hscroll_margin and
- Vautomatic_hscroll_step to compute the amount of window scrolling.
-
-2002-02-16 Pavel Jan,Am(Bk <[email protected]>
-
- * xterm.c (x-autoselect-window): New variable.
- (note_mouse_movement): Use it.
-
- * keyboard.c: Do not include "systime.h" twice.
-
-2002-02-15 Andreas Schwab <[email protected]>
-
- * puresize.h (PURESIZE_RATIO): Increase to 9/5.
-
- * alloc.c (NSTATICS): Increase to 1280.
-
-2002-02-15 Kai Gro,A_(Bjohann <[email protected]>
-
- * alloc.c (NSTATICS): Bump to 1026.
-
- * xterm.c (Vx_alt_keysym, Vx_hyper_keysym, Vx_meta_keysym)
- (Vx_super_keysym): New variables.
- (syms_of_xterm): DEFVAR_LISP them.
- (x_x_to_emacs_modifiers, x_emacs_to_x_modifiers): Use the
- variables to determine which keys to use for the various modifiers.
-
-2002-02-13 Kim F. Storm <[email protected]>
-
- * window.c (Vmode_line_in_non_selected_windows): Removed.
- (mode_line_in_non_selected_windows): New variable.
- (syms_of_window): DEFVAR_BOOL it.
-
- * dispextern.h (CURRENT_MODE_LINE_FACE_ID_3):
- Use mode_line_in_non_selected_windows.
- (mode_line_in_non_selected_windows): Declare extern.
- (Vmode_line_in_non_selected_windows): Removed extern.
-
-2002-02-13 Richard M. Stallman <[email protected]>
-
- * keyboard.c (Fthis_command_keys, Fthis_command_keys_vector)
- (Fthis_single_command_keys, Fthis_single_command_raw_keys)
- (Fclear_this_command_keys): Doc fixes.
-
- * xfaces.c (Finternal_make_lisp_face, Finternal_copy_lisp_face)
- (update_face_from_frame_parameter): Increment face_change_count
- and windows_or_buffers_changed to force redisplay using changed faces.
-
- * xdisp.c (QCpropertize): New variable.
- (mode_line_proptrans_alist): New variable.
- (display_mode_element): New arg PROPS; all calls changed.
- Implement this, for strings.
- Handle literal output of strings by sharing the
- main-line code for strings, using local var `literal'.
- Handle :propertize feature.
- (syms_of_xdisp): Initialze and staticpro QCpropertize and
- mode_line_proptrans_alist.
-
-2002-02-11 Kim F. Storm <[email protected]>
-
- * window.c (Vmode_line_in_non_selected_windows): New variable.
- (syms_of_window): DEFVAR_LISP it.
-
- * dispextern.h (CURRENT_MODE_LINE_FACE_ID_3): New macro.
- (CURRENT_MODE_LINE_FACE_ID): Use it.
- (Vmode_line_in_non_selected_windows): Declare extern.
-
- * xdisp.c (display_mode_lines): Use CURRENT_MODE_LINE_FACE_ID_3
- to get mode line face.
-
-2002-02-11 Eli Zaretskii <[email protected]>
-
- * msdos.c (Vx_bitmap_file_path, x_stretch_cursor_p): Remove these
- variables; cus-start.el doesn't need them anymore.
-
-2002-02-09 Kim F. Storm <[email protected]>
-
- * insdel.c (make_gap_smaller): Preserve BEG_UNCHANGED during gap
- reduction. This fixes a display problem where stray newlines were
- inserted in the window (corrected by C-l). Clarified code (IMHO).
-
-2002-02-09 Eli Zaretskii <[email protected]>
-
- * dispextern.h (CURRENT_MODE_LINE_FACE_ID): Fix last change.
-
- * xdisp.c (display_mode_lines): Fix last change.
-
-2002-02-09 Jason Rumney <[email protected]>
-
- * w32fns.c (enum_font_cb2): Don't let charsets unknown to Windows
- match each other.
- (w32_load_system_font): Prevent Cleartype fonts from loading.
- (Fx_show_tip): Ensure tip frames are above other topmost windows.
-
-2002-02-09 Kim F. Storm <[email protected]>
-
- * dispextern.h (CURRENT_MODE_LINE_FACE_ID): New macro.
- (CURRENT_MODE_LINE_HEIGHT): Use it.
- (enum face_id): Add MODE_LINE_INACTIVE_FACE_ID.
-
- * xdisp.c (window_box_height): Use CURRENT_MODE_LINE_FACE_ID.
- (pos_visible_p, handle_face_prop): Likewise.
- (display_mode_lines): Likewise, but for the real selected window.
- (init_iterator) [row == NULL]: Handle MODE_LINE_INACTIVE_FACE_ID.
-
- * xfaces.c (Qmode_line_inactive): New face variable for mode-line
- in non-selected windows.
- (realize_basic_faces): Realize it.
- (syms_of_term): Intern and staticpro it.
-
-2002-02-08 Kim F. Storm <[email protected]>
-
- * alloc.c (SETJMP_WILL_LIKELY_WORK, SETJMP_WILL_NOT_WORK):
- Changed mail addresses to [email protected].
-
-2002-02-08 Eli Zaretskii <[email protected]>
-
- * fileio.c (Fsubstitute_in_file_name): If the file name includes
- ~user, and there's no such user, don't discard everything before ~user.
-
- * floatfns.c (Fround): Doc fix.
-
-2002-02-08 Pavel Jan,Am(Bk <[email protected]>
-
- * sysdep.c (init_system_name): Put unused variable `p' in #if 0.
-
-2002-02-07 Stefan Monnier <[email protected]>
-
- * lisp.h (Fx_file_dialog): Add extern decl (used in fileio.c).
-
-2002-02-07 Kim F. Storm <[email protected]>
-
- * keymap.c (where_is_internal): Only check whether definition is
- remapped if it fulfills is_command_symbol.
-
-2002-02-07 Andreas Schwab <[email protected]>
-
- * s/gnu-linux.h (GC_LISP_OBJECT_ALIGNMENT): Define to 2 for m68k.
-
- * alloc.c (mark_stack): Don't assume sizeof (Lisp_Object) is 4.
-
-2002-02-06 Kim F. Storm <[email protected]>
-
- * keymap.c (Fdefine_key): Allow symbol as KEY argument for
- defining command remapping. Doc updated.
- (Flookup_key): Remap command through keymap if KEY is a symbol.
- (is_command_symbol): New function.
- (Fkey_binding): Use it. New optional argument NO-REMAP.
- Doc updated. Callers changed. Perform command remapping via
- recursive call unless that arg is non-nil.
- (where_is_internal): New argument no_remap. Callers changed.
- Call recursively to find original key bindings for a remapped
- comand unless that arg is non-nil.
- (Fwhere_is_internal): New optional argument NO-REMAP.
- Doc updated. Callers changed. Pass arg to where_is_internal.
-
- * keymap.h (Fkey_binding, Fwhere_is_internal): Update prototype.
- (is_command_symbol): Add prototype.
-
- * keyboard.c (Vthis_original_command): New variable.
- (syms_of_keyboard): DEFVAR_LISP it.
- (command_loop_1): Set it, and perform command remapping.
-
-2002-02-06 Pavel Jan,Am(Bk <[email protected]>
-
- * keyboard.c (recursive_edit_1): Call cancel_hourglass unconditionally.
-
-2002-02-06 Jason Rumney <[email protected]>
-
- * w32term.c (w32_native_per_char_metric): Disable 2002-01-20 change.
-
-2002-02-06 Eli Zaretskii <[email protected]>
-
- * charset.c (get_charset_id): Use if-else instead of ?:.
-
-2002-02-06 Richard M. Stallman <[email protected]>
-
- * filelock.c (S_ISLNK): Define if not defined.
-
-2002-02-03 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fdo_auto_save): Improve "auto save disabled" msg.
-
- * lread.c (read1): Redesign strategy for force_multibyte and
- force_singlebyte. Now is_multibyte records whether read_buffer
- is multibyte. Encountering any multibyte character makes it so.
-
-2002-02-02 Stefan Monnier <[email protected]>
-
- * term.c (term_get_fkeys_1): If `k0' and `k;' are both specified and
- with the same sequence, map that sequence to f10 rather than f0.
-
-2002-02-03 Andreas Schwab <[email protected]>
-
- * s/gnu-linux.h: Check for __mc68000__ instead of __m68k__, the
- latter never being defined on GNU/Linux.
-
-2002-02-02 Eli Zaretskii <[email protected]>
-
- * xfaces.c (realize_default_face): Don't set the weight and slant of
- the default face to Qnormal, unless these attributes are unspecified.
-
-2002-02-02 Pavel Jan,Am(Bk <[email protected]>
-
- * keyboard.c (command_loop_1) [HAVE_X_WINDOWS]:
- Call cancel_hourglass unconditionally.
-
- * eval.c (Fsignal): Remove duplicated declaration of
- the variable `display_hourglass_p'.
-
-2002-01-31 Richard M. Stallman <[email protected]>
-
- * editfns.c (region_limit): Nicer error message.
-
- * coding.c (decode_composition_emacs_mule):
- Give up if NCOMPONENT gets too large to index `component'.
-
- * callint.c (check_mark): New arg to specify clearer error message.
- Callers changed.
-
-2002-01-27 Richard M. Stallman <[email protected]>
-
- * minibuf.c (Fcompleting_read): Doc fix.
-
-2002-01-27 Pavel Jan,Am(Bk <[email protected]>
-
- * minibuf.c (Fread_from_minibuffer, Fread_command, Fread_function)
- (Fread_variable, Fread_buffer, minibuffer-completion-confirm):
- Fix doc-strings.
-
-2002-01-26 Richard M. Stallman <[email protected]>
-
- * buffer.c (syms_of_buffer): Doc fixes for scroll-...-aggressively.
-
- * xdisp.c (try_scrolling): Exchange uses of scroll_down_aggressively
- and scroll_up_aggressively.
-
-2002-01-26 Pavel Jan,Am(Bk <[email protected]>
-
- * keyboard.c (parse_tool_bar_item): Remove duplicated prototypes.
-
-2002-01-25 Stefan Monnier <[email protected]>
-
- * textprop.c (Fnext_property_change, Fnext_single_property_change)
- (Fprevious_property_change, Fprevious_single_property_change):
- Stay within the narrowed-buffer boundaries.
-
-2002-01-25 Eli Zaretskii <[email protected]>
-
- * term.c (Ftty_display_color_cells): New function.
- (syms_of_term): Defsubr it.
- (Ftty_display_color_cells, Ftty_display_color_p): Change the
- argument name to DISPLAY. Doc fix.
-
- * dispextern.h: Add prototype for set_tty_color_mode and
- tty_setup_colors.
-
-2002-01-24 Jason Rumney <[email protected]>
-
- * w32term.c (x_scroll_run): Use ScrollWindowEx in place of BitBlt.
- If region left to draw is not what was expected, mark the frame as
- garbaged.
-
- * w32fns.c (w32_wnd_proc) <WM_PAINT>: Initialize update_rect.
- Combine the regions returned by BeginPaint and GetUpdateRect.
-
-2002-01-23 Jason Rumney <[email protected]>
-
- * w32term.c (x_update_window_begin): Only hide caret if
- w32_use_visible_system_caret is set.
- (x_update_window_end): Only show caret if
- w32_use_visible_system_caret is set.
- (syms_of_w32term): Handle SystemParametersInfo call failing.
-
- * w32fns.c (syms_of_w32fns): Initialize w32_visible_system_caret_hwnd.
-
-2002-01-22 Richard M. Stallman <[email protected]>
-
- * unexelf.c (unexec): Define n so as to cause compilation error
- for the code where people have often written n instead of nn.
-
- * .gdbinit (hookpost-run): Defined.
-
-2002-01-22 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_set_frame_parameters): Typo in previous fix corrected.
-
-2002-01-21 Jan Dj,Ad(Brv <[email protected]>
-
- * xfns.c (x_set_frame_parameters): Just call x_fullscreen_adjust
- if fullscreen is being set.
-
-2002-01-21 Pavel Jan,Am(Bk <[email protected]>
-
- * minibuf.c (Fminibuffer_contents)
- (Fminibuffer_contents_no_properties, Fread_from_minibuffer)
- (Fread_string, Fread_no_blanks_input, Fcompleting_read): Doc fixes.
-
-2002-01-21 Richard M. Stallman <[email protected]>
-
- * window.c (check_frame_size): Fix minimum height calculation.
-
-2002-01-20 Ken Raeburn <[email protected]>
-
- * dispextern.h (WINDOW_WANTS_MODELINE_P): Use XFASTINT on window
- height before comparison.
- (WINDOW_WANTS_HEADER_LINE_P): Likewise.
-
-2002-01-20 Jason Rumney <[email protected]>
-
- * w32term.c (w32_system_caret_width): Remove.
- (w32_use_visible_system_caret): New user flag.
- (syms_of_w32term): DEFVAR_BOOL it. Initialize based on whether
- Windows reports a screen reader running.
- (x_update_window_begin): Hide the system caret.
- (x_update_window_end): Show the system caret.
- (x_display_and_set_cursor): Don't draw a cursor when
- w32_use_visible_system_caret is set. Do not adjust width.
-
- * w32fns.c (w32_visible_system_caret_hwnd): New static variable.
- (w32_wnd_proc) <WM_KILL_FOCUS, WM_EMACS_DESTROY_CARET>: Set it.
- <WM_EMACS_TRACK_CARET>: Arrange for system caret to be visible if
- the user requests it. Use system default width when creating.
- <WM_EMACS_HIDE_CARET, WM_EMACS_SHOW_CARET>: Handle new messages.
-
- * w32term.h (WM_EMACS_SHOW_CARET, WM_EMACS_HIDE_CARET):
- New window messages.
-
-2002-01-20 Richard M. Stallman <[email protected]>
-
- * window.c (MIN_SAFE_WINDOW_HEIGHT): Value now 1.
-
-2002-01-20 Pavel Jan,Am(Bk <[email protected]>
-
- * doprnt.c (doprnt1): Fix typos in error call.
-
-2002-01-20 Eli Zaretskii <[email protected]>
-
- * unexelf.c (unexec) [__sgi]: Support the .got sections.
-
-2002-01-20 Jason Rumney <[email protected]>
-
- * w32term.c (w32_native_per_char_metric): Don't trust the metrics
- that Windows returns. If a double check fails, try to guess how
- ExtTextOut is going to act.
-
- * w32fns.c (w32_load_system_font, w32_to_x_charset): Use strnicmp
- in place of stricmp.
- (w32_list_synthesized_fonts): Removed.
- (w32_to_all_x_charsets, enum_font_maybe_add_to_list): New functions.
- (struct enumfont_t): New element; list.
- (enum_font_cb2): List all style and charset variations of a font.
- (Fw32_select_font): New optional argument; include_proportional.
- Exclude vertical fonts. Exclude proportional fonts unless
- include_proportional is non-nil.
- (w32_enable_synthesized_fonts): Change to a boolean.
- (Fw32_send_sys_command): Doc fix.
-
-2002-01-19 Pavel Jan,Am(Bk <[email protected]>
-
- * dispnew.c (update_frame): Move the variable `tem' to the block
- where it is used.
-
-2002-01-19 Jason Rumney <[email protected]>
-
- * w32fns.c (Fx_create_frame): Bind redisplay-dont-pause around
- call to face-set-after-frame-default.
-
-2002-01-18 Richard M. Stallman <[email protected]>
-
- * dispextern.h (WINDOW_WANTS_MODELINE_P): Check window height > 1.
- (WINDOW_WANTS_HEADER_LINE_P): Check window height provides room.
-
-2002-01-17 Richard M. Stallman <[email protected]>
-
- * window.c (enlarge_window): When exceeding size of parent,
- directly delete all the siblings instead of trying to resize it.
-
-2002-01-17 Pavel Jan,Am(Bk <[email protected]>
-
- * term.c (set_tty_color_mode): Remove unused variable `tem'.
-
-2002-01-16 Henrik Enberg <[email protected]>
-
- * lread.c (init_lread): Move the installed-lisp dirs later in the path.
-
-2002-01-16 Kim F. Storm <[email protected]>
-
- * xterm.c (x_erase_phys_cursor): Don't erase cursor if cursor row
- is invisible. This can happen if cursor is on top line of a
- window, and we switch to a buffer with a header line.
-
- * w32term.c (x_erase_phys_cursor): Ditto.
-
-2002-01-16 Pavel Jan,Am(Bk <[email protected]>
-
- * xterm.c (XTread_socket) [!USE_X_TOOLKIT]: Compute the value of
- `dont_resize' only when used.
-
- * xdisp.c: Remove forgotten extern declaration of `Qimage'.
-
-2002-01-15 Eli Zaretskii <[email protected]>
-
- * xdisp.c (display_mode_element): When computing charpos, depend
- on multibyteness of elt, not the text in field.
-
-2002-01-15 Pavel Jan,Am(Bk <[email protected]>
-
- * buffer.c (Fkill_all_local_variables):
- Increment `update_mode_lines' only once.
-
-2002-01-14 Pavel Jan,Am(Bk <[email protected]>
-
- * lisp.h (adjust_after_replace_noundo)
- (Fupdate_coding_systems_internal): Add prototypes.
-
- * sound.c (Fplay_sound): Initialize header_size also for :data case.
-
-2002-01-14 Eli Zaretskii <[email protected]>
-
- Support for the --color command-line argument and tty-color-mode
- frame parameter:
-
- * term.c (tty_default_color_capabilities, tty_setup_colors)
- (set_tty_color_mode): New functions.
- (term_init): Call tty_default_color_capabilities.
- (Qtty_color_mode_alist): New variable.
- (syms_of_term): Intern and staticpro it.
-
- * frame.c (store_frame_param): Call set_tty_color_mode for termcap
- frames.
- (do_switch_frame): For termcap frames, switch the tty
- color mode as specified by the frame's parameters.
- (Qtty_color_mode): New variable.
- (syms_of_frame): Intern and staticpro it.
-
- * emacs.c (USAGE2): Add the --color option.
- (standard_args): Ditto.
-
-2002-01-13 Jan Dj,Ad(Brv <[email protected]>
-
- * xterm.h (struct x_output): New members want_fullscreen,
- x_pixels_diff, y_pixels_diff, x_pixels_outer_diff, and
- y_pixels_outer_diff.
- New enum for FULLSCREEN_* constants.
- (FRAME_OUTER_WINDOW): Handle the case where output_data.x->widget
- is NULL.
- (x_fullscreen_adjust): Add prototype.
-
- * emacs.c (USAGE2): Add the new full-screen arguments.
- (standard_args): Ditto.
-
- * xfns.c (Qfullscreen, Qfullwidth, Qfullheight, Qfullboth):
- New variables.
- (syms_of_xfns): Intern and staticpro them.
- (x_frame_parms) <"fullscreen">: New parameter.
- (x_fullscreen_move, x_set_fullscreen): New functions.
- (x_set_frame_parameters): Support for Qfullscreen.
- (x_real_positions): More accurate computation of the frame position.
- (x_figure_window_size): Support full-screen frames.
- (Fx_create_frame): Default the fullscreen parameter.
-
- * xterm.c (x_check_fullscreen, x_fullscreen_adjust): New functions.
- (XTread_socket) <Expose>: Call x_check_fullscreen.
- <ConfigureNotify>: Don't resize to fullscreen.
- Call x_check_fullscreen_move, and set the want_fullscreen member of
- output_data.x.
-
-2002-01-13 Jason Rumney <[email protected]>
-
- * w32term.h (WM_XBUTTONDOWN, WM_XBUTTONUP): New window messages
- for mice with more than 3 buttons.
-
- * w32term.c (parse_button): New parameter xbutton. Callers changed.
- (w32_read_socket): Handle new "XBUTTON" messages.
-
- * w32fns.c (w32_pass_extra_mouse_buttons_to_system): New user option.
- (syms_of_w32fns): DEFVAR_BOOL it.
- (w32_wnd_proc): Handle new "XBUTTON" messages.
-
-2002-01-13 Pavel Jan,Am(Bk <[email protected]>
-
- * keyboard.c (read_key_sequence): Remove unused variable `extra_maps'.
-
-2002-01-13 Andreas Schwab <[email protected]>
-
- * xterm.c (x_load_font): Never set fonts_changed_p to zero.
-
-2002-01-12 Andreas Schwab <[email protected]>
-
- * .gdbinit (xbuffer): Remove address operator since data is now a
- pointer.
-
-2002-01-11 Richard M. Stallman <[email protected]>
-
- * insdel.c (adjust_after_replace_noundo): New function.
-
- * coding.c (code_convert_region): Don't copy old text if undo disabled.
-
-2002-01-09 Jason Rumney <[email protected]>
-
- * xdisp.c (x_consider_frame_title): Don't count the tooltip frame
- when checking for multiple frames.
-
-2002-01-08 Richard M. Stallman <[email protected]>
-
- * window.c (delete_window): Rewrite the code for changing the
- selected window to handle the case where WINDOW is not a leaf.
-
-2002-01-07 Eli Zaretskii <[email protected]>
-
- * process.c (send_process): Set src_multibyte to 1 after the call
- top setup_coding_system, not before the call.
-
-2002-01-07 Jason Rumney <[email protected]>
-
- * xmenu.c (set_frame_menubar, xmenu_show):
- (xdialog_show): Initialize wv->help to Qnil.
-
- * w32menu.c (single_submenu, set_frame_menubar, w32_menu_show):
- (w32_dialog_show): Initialize wv->help to Qnil.
-
-2002-01-06 Jason Rumney <[email protected]>
-
- * xmenu.c (single_submenu): Initialize wv->help to Qnil.
-
- * w32menu.c (w32_menu_display_help): Revert last change.
-
- * xmenu.c (menu_highlight_callback): Revert last change.
-
-2002-01-06 Andreas Schwab <[email protected]>
-
- * insdel.c (make_gap_larger): Make sure buffer size does not
- overflow range of int.
-
-2002-01-05 Jason Rumney <[email protected]>
-
- * w32term.c (x_draw_glyphs): Don't call notice_overwritten_cursor if
- OVERLAPS_P.
-
- * w32menu.c (w32_menu_display_help): Hide any tooltip window.
-
- * w32fns.c (compute_tip_xy): If tooltip won't fit on the screen
- to the left or to the right of the pointer, put it against
- the left screen edge.
- (x_frame_parms): Add missing braces around initializer.
-
- * w32term.c (x_setup_relief_colors): Don't compute an image's
- background color if it doesn't have a Pixmap.
- (notice_overwritten_cursor): Don't depend on
- output_cursor and updated_area. Compare pixel coordinates with
- window's cursor pixel coordinates.
- (x_draw_glyphs, x_clear_end_of_line, show_mouse_face):
- Call notice_overwritten_cursor with new arg list.
- (show_mouse_face): Fix bug setting a row's mouse_face_p flag
- unconditionally.
- (x_draw_image_relief): Use predefined macro instead of
- constant when the value of `tool_bar_button_relief' is negative.
-
- * w32term.c (x_display_and_set_cursor): Fix PostMessage arg types.
-
-2002-01-04 Richard M. Stallman <[email protected]>
-
- * xmenu.c (menu_highlight_callback): Hide any tooltip window.
-
-2002-01-03 Richard M. Stallman <[email protected]>
-
- * keymap.c (Fcurrent_active_maps): Put the `keymap' property map first.
- (Fkey_binding): Try the `keymap' property map first.
- (Fdescribe_buffer_bindings): Show `keymap' property bindings before
- minor mode bindings.
-
-2002-01-03 Kim F. Storm <[email protected]>
-
- * keyboard.c (read_key_sequence): Fix cast of submaps arg to bcopy.
-
-2002-01-02 Richard M. Stallman <[email protected]>
-
- * keyboard.c (read_key_sequence): Handle the keymap property
- before minor mode maps.
-
- * editfns.c (Fformat): Update thissize from field_width
- based on the actual width, in the string case.
-
-2002-01-01 Pavel Jan,Am(Bk <[email protected]>
-
- * charset.h (UNIBYTE_STR_AS_MULTIBYTE_P): Parenthesize assignment
- when used as truth value to prevent gcc warnings.
-
- * sysdep.c, unexapollo.c, w32.c, w32bdf.c, w32heap.c, w32inevt.c,
- * w32proc.c: Include <config.h>.
-
-2002-01-01 Andreas Schwab <[email protected]>
-
- * eval.c (max_specpdl_size, max_lisp_eval_depth): Define as int,
- not EMACS_INT, to make them compatible with DEFVAR_INT.
- * lisp.h (max_specpdl_size): Adjust declaration.
-
-2002-01-01 Richard M. Stallman <[email protected]>
-
- * print.c (print_object): Test print_escape_nonascii only for
- unibyte strings.
- (PRINTPREPARE): Once again bind Qprint_escape_nonascii
- when outputting to a multibyte buffer.
-
-2001-12-29 Richard M. Stallman <[email protected]>
-
- * print.c (print_object): In multibyte string, use hex escapes.
- Use octal only for unibyte strings.
- (PRINTPREPARE): Don't ever set Qprint_escape_nonascii.
-
- * lread.c (read_escape): New arg BYTEREP for reporting whether
- escape forces unibyte or multibyte.
- (read1): When reading a string, take note of that info.
-
-2001-12-29 Ken Raeburn <[email protected]>
-
- * abbrev.c (Fexpand_abbrev): Use NILP instead of implicit zero
- comparison to test lisp value returned by Fget.
-
-2001-12-29 Richard M. Stallman <[email protected]>
-
- * lisp.h (max_specpdl_size): Add declaration.
-
- * fileio.c (Fdo_auto_save): If NO_MESSAGE, don't call push_message.
-
- * keymap.c (silly_event_symbol_error): New subrtn, from Fdefine_key.
- Handle modifier bits. Correct typo in error message.
-
-2001-12-28 Richard M. Stallman <[email protected]>
-
- * abbrev.c: Use the plist of an abbrev for multiple params if nec.
- (Fdefine_abbrev): New arg SYSTEM-FLAG for a system abbrev.
- (Fdefine_global_abbrev, Fdefine_mode_abbrev):
- Update calls to Fdefine_abbrev.
- (write_abbrev): Update for changed data format.
- Don't list "system" abbrevs.
- (Fexpand_abbrev): Update use count with new data format.
- (describe_abbrev): Update for changed data format.
- (Fdefine_abbrev_table): Handle the new SYSTEM-FLAG.
-
- * config.in (HAVE_MBSINIT): Add #undef.
-
- * strftime.c (mbsinit): Define as no-op if not available.
-
- * s/sco5.h (LIBX11_SYSTEM) [MOTIF]: Add -lgen.
- (sigprocmask_set): Conditionalize decl on ! NOT_C_CODE.
-
- * keymap.c (Flookup_key): Error message if key has wrong data type.
- (Fdefine_key): Add error message for trying to bind [DEL], [RET], etc.
- (exclude_key): New variable.
-
-2001-12-28 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_setup_relief_colors): Don't compute an image's
- background color if it doesn't have a Pixmap.
-
- * xterm.c (notice_overwritten_cursor): Don't depend on
- output_cursor and updated_area. Compare pixel coordinates with
- window's cursor pixel coordinates.
- (x_draw_glyphs, x_clear_end_of_line, show_mouse_face):
- Call notice_overwritten_cursor with new arg list.
- (show_mouse_face): Fix bug setting a row's mouse_face_p flag
- unconditionally.
-
- * xdisp.c (try_scrolling) <PT below scroll margin>: Add the
- height of the cursor line to the amount to scroll.
-
-2001-12-27 Richard M. Stallman <[email protected]>
-
- * intervals.c (set_point_both): The position after an invisible,
- intangible character is not an acceptable stopping point.
-
-2001-12-27 Ken Raeburn <[email protected]>
-
- * window.c (enlarge_window): In new preserve_before code, convert
- CURBEG from lisp object to integer before doing arithmetic.
-
-2001-12-27 Richard M. Stallman <[email protected]>
-
- * bytecode.c (Fbyte_code): Undo previous change.
-
-2001-12-26 Kim F. Storm <[email protected]>
-
- * keyboard.c (record_char): Ignore duplicate help-echo events only
- separated by mouse-movement. When tracking mouse, only record
- first and last mouse-movement event in same window.
- Don't record mouse-movement events in keyboard macros.
-
-2001-12-25 Richard M. Stallman <[email protected]>
-
- * window.c (enlarge_window): New arg PRESERVE_BEFORE. Callers changed.
- (Fenlarge_window): New arg PRESERVE_BEFORE.
-
- * bytecode.c (Fbyte_code): Use Fstring_make_unibyte
- instead of Fstring_as_unibyte.
-
-2001-12-22 Pavel Jan,Am(Bk <[email protected]>
-
- The following changes remove mocklisp support:
-
- * mocklisp.h, mocklisp.c: Files removed.
-
- * lisp.h: Remove declarations of variables `Vmocklisp_arguments',
- `Qmocklisp' and `Qmocklisp_arguments'.
- Remove prototype of syms_of_mocklisp.
-
- * makefile.nt, makefile.w32-in, Makefile.in: Remove mocklisp files.
-
- * callint.c: Do not include mocklisp.h.
- (Fcall_interactively): Do not test for mocklisp case.
-
- * eval.c: Remove variables `Qmocklisp_arguments',
- `Vmocklisp_arguments' and `Qmocklisp'. Remove prototype of ml_apply.
- (Fprogn, Fwhile, Fcommandp, Feval, Ffuncall, funcall_lambda):
- Do not test for mocklisp case.
- (Fwhile): Remove unused variable `tem'.
- (syms_of_eval): Remove variable `moclisp-arguments'.
-
- * data.c (wrong_type_argument): Remove mocklisp case.
-
- * doc.c (Fdocumentation): Remove mocklisp case.
-
- * emacs.c (main): Do not call syms_of_mocklisp.
-
-2001-12-21 Richard M. Stallman <[email protected]>
-
- * xfns.c (compute_tip_xy): If tooltip won't fit on the screen
- to the left or to the right of the pointer, put it against
- the left screen edge.
-
-2001-12-21 Eli Zaretskii <[email protected]>
-
- * Makefile.in (distclean): Remove .gdbinit if we are building
- outside the source tree.
-
-2001-12-19 Eli Zaretskii <[email protected]>
-
- * w32.c (emacs_root_dir): New function.
-
- * msdos.c (emacs_root_dir): New function.
-
- * fileio.c (Fexpand_file_name) [DOS_NT]: Use the root directory
- of the current drive as the fallback for default_directory.
-
- * dired.c (file_name_completion): Run the elements of
- completion-ignored-extensions through ENCODE_FILE.
-
- * lisp.h (scmp): Remove prototype, since it's now a static
- function private to dired.c.
-
-2001-12-18 Richard M. Stallman <[email protected]>
-
- * dired.c (scmp): Function moved from minibuf.c.
- Delete multibyte handling--used only on encoded strings.
-
- * minibuf.c (scmp): Function moved to dired.c.
-
- * fns.c (merge): Add QUIT call.
-
-2001-12-18 Dave Love <[email protected]>
-
- * Makefile.in (lisp, shortlisp): Add language/utf-8-lang.el,
- language/georgian.el.
-
-2001-12-18 Eli Zaretskii <[email protected]>
-
- * Makefile.in (lisp, shortlisp): Synchronize with changes to
- lisp/Makefile.in:DONTCOMPILE.
-
-2001-12-18 Pavel Jan,Am(Bk <[email protected]>
-
- * xdisp.c (window_box_height): Do not return negative values.
- From Gerd Moellmann <[email protected]>.
-
- * keyboard.c (head_table): Add missing braces around initializer.
-
- * term.c (keys): Likewise.
-
- * xfns.c (x_frame_parms, visual_classes): Likewise.
-
-2001-12-17 Sam Steingold <[email protected]>
-
- * coding.c (DECODE_COMPOSITION_END): Fixed a typo in the last
- patch (COMPOSING_P, not COMPOSING).
-
-2001-12-17 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fcompare_buffer_substrings): Add QUIT to main loop.
-
- * coding.c (code_convert_region): Update coding->cmp_data->char_offset
- before calling decode_coding.
-
- * charset.c (Fdefine_charset): Call Fupdate_coding_systems_internal.
-
- * coding.c (DECODE_COMPOSITION_END): Check for ! COMPOSING_P (coding)
- instead of only for COMPOSITION_DISABLED.
-
-2001-12-16 Richard M. Stallman <[email protected]>
-
- * alloc.c (pure_alloc): After overflow, allocate just a small block.
-
- * Makefile.in (xmenu.o, xterm.o, fontset.o): Depend on buffer.h.
-
- * buffer.h (struct buffer): New field `display_error_modiff'.
- * buffer.c (reset_buffer): Initialize `display_error_modiff'.
-
- * window.c (Frecenter): Clear display_error_modiff field.
-
- * xdisp.c (redisplay_window_0, redisplay_window_1): New functions.
- Call redisplay_window, but not if display_error_modiff field says no.
- (redisplay_window_error): New function.
- (displayed_buffer): New variable.
- (redisplay_internal, redisplay_windows): Call the new functions
- instead of redisplay_window directly.
-
-2001-12-15 Richard M. Stallman <[email protected]>
-
- * keyboard.c (syms_of_keyboard) <double-click-fuzz>: Doc fix.
-
-2001-12-14 Andrew Innes <[email protected]>
-
- * makefile.w32-in (EMACSLOADPATH): Define.
- ($(EMACS)): Run `list-load-path-shadows' after dumping Emacs.
- (bootstrap-temacs): Remove dependency on bootstrap-clean.
-
-2001-12-13 Eli Zaretskii <[email protected]>
-
- * xfns.c (x_report_frame_params): Make the scroll-bar-width frame
- parameter have a numeric value all the time.
-
- * w32fns.c (x_report_frame_params): Likewise.
-
-2001-12-12 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fwrite_region): Doc fix.
-
- * xdisp.c (CLEAR_FACE_CACHE_COUNT): Redefine as 500.
- (redisplay_internal): Call clear_image_cache only for window terminals.
-
-2001-12-12 Gerd Moellmann <[email protected]>
-
- * xdisp.c (move_it_vertically_backward): Change heuristic
- for the case that we didn't move far enough initially.
-
- * window.c (Frecenter): Simplify computation in the case of window
- system frames and ARG < 0; use window_box_height.
-
-2001-12-11 Richard M. Stallman <[email protected]>
-
- * Makefile.in, mem-limits.h, dispnew.c, emacs.c, fileio.c:
- * process.c, sysdep.c, unexec.c: Test GNU_LINUX, not LINUX.
-
-2001-12-11 Andrew Innes <[email protected]>
-
- * insdel.c (make_gap) [DOUG_LEA_MALLOC]: Call make_gap_smaller if
- arg is negative.
-
-2001-12-11 Richard M. Stallman <[email protected]>
-
- * m/hp800.h: Split the __hpux conditional into the parts
- that are right for GNU/Linux too and the parts that are not.
- Use the former if GNU_LINUX.
- (HAVE_ALLOCA, LOAD_AVE_TYPE, LOAD_AVE_CVT): New defs for GNU/Linux.
-
- * s/gnu-linux.h (GNU_LINUX): Defined.
-
-2001-12-11 Pavel Jan,Am(Bk <[email protected]>
-
- * macros.c, msdos.c, w16select.c: Change doc-string comments to
- `new style' [w/`doc:' keyword].
-
-2001-12-10 Jason Rumney <[email protected]>
-
- * w32menu.c (w32_free_submenu_strings): Clear menu item struct
- before using.
-
-2001-12-09 Pavel Jan,Am(Bk <[email protected]>
-
- * dosfns.c: Change doc-string comments to `new style' [w/`doc:'
- keyword].
-
-2001-12-09 Eli Zaretskii <[email protected]>
-
- * dosfns.c (dos-display-scancodes, dos-decimal): Doc fix.
-
- * s/hpux10.h (srand48): Don't undefine.
-
-2001-12-09 Jason Rumney <[email protected]>
-
- * w32menu.c (_widget_value): Make `help' field a Lisp_Object.
- Add comment to explain where the struct came from.
- (single_submenu, w32_menu_show): Set `help' field as Lisp_Object.
- (add_menu_item): Process pop-up menus first to avoid memory leak.
- (add_menu_item, w32_menu_display_help): Use `help' field as
- Lisp_Object.
- (w32_free_submenu_strings): Only free owner-drawn strings.
-
-2001-12-09 Pavel Jan,Am(Bk <[email protected]>
-
- * COPYING: Moved back.
-
- * charset.c (char_to_string_1, translate_char, Fdefine_charset):
- Add parentheses around && within ||.
-
- * indent.c (compute_motion): Likewise.
-
- * intervals.c (merge_properties_sticky): Likewise.
-
- * coding.c (setup_coding_system, shrink_encoding_region)
- (Fdecode_sjis_char): Likewise.
-
-2001-12-07 Andreas Schwab <[email protected]>
-
- * xdisp.c (display_mode_element): Don't read past end of string if
- it ends with '%'.
-
- * alloc.c (inhibit_garbage_collection): Don't exceed value an int
- can hold.
-
- * data.c (Vmost_positive_fixnum, Vmost_negative_fixnum):
- Rename from most_positive_fixnum and most_negative_fixnum, resp., and
- type changed to Lisp_Object.
- (syms_of_data): DEFVAR_LISP them.
-
-2001-12-07 Richard M. Stallman <[email protected]>
-
- * callproc.c (init_callproc): Set Vdata_directory based on the source
- location whenever Emacs was run uninstalled.
-
-2001-12-06 Paul Eggert <[email protected]>
-
- * config.in (HAVE_WORKING_VFORK): New #undefs.
- * process.c (create_process):
- Use HAVE_WORKING_VFORK, not HAVE_VFORK.
- * m/cnvrgnt.h (HAVE_VFORK): Remove #define.
- * m/ibm370aix.h (HAVE_VFORK): Remove #undef.
- * m/ibmps2-aix.h (HAVE_VFORK): Remove #define.
- * m/intel386.h (HAVE_VFORK): Likewise.
- * m/mips-siemens.h (HAVE_VFORK): Likewise.
- * m/mips.h (HAVE_VFORK): Likewise.
- * s/freebsd.h (vfork): Remove #define.
- * s/lynxos.h (HAVE_VFORK): Remove #undef.
- * s/usg5-4-2.h: Fix comment about vfork.
-
-2001-12-06 Richard M. Stallman <[email protected]>
-
- * s/hpux10.h (random): Add undef.
- (HAVE_RANDOM): Define it just once.
-
-2001-12-06 Stefan Monnier <[email protected]>
-
- * eval.c: Undo last change: the standard syntax is not wanted.
-
-2001-12-06 Eli Zaretskii <[email protected]>
-
- * xterm.c (x_free_frame_resources) [USE_X_TOOLKIT]: Remove all the
- scroll bars of the frame before deleting the frame itself. If the
- frame has a widget, delete the frame with XtDestroyWidget, and do
- not call XDestroyWindow before that.
-
-2001-12-06 Kim F. Storm <[email protected]>
-
- * xfns.c (x_report_frame_params): Return actual fringe widths.
-
- * w32fns.c (x_report_frame_params): Return actual fringe widths.
-
-2001-12-05 Andrew Innes <[email protected]>
-
- * alloc.c (Fgarbage_collect): Shrink buffer gaps that are
- excessively large.
-
- * insdel.c (make_gap_larger): New function.
- (make_gap_smaller): New function.
- (make_gap) [USE_MMAP_FOR_BUFFERS || REL_ALLOC]:
- Call make_gap_smaller if arg is negative.
-
-2001-12-04 Stefan Monnier <[email protected]>
-
- * keyboard.c (kbd_buffer_store_event): Fix interrupt_signal prototype.
- Pass a dummy argument when calling interrupt_signal.
- (parse_menu_item): Mark disabled items before checking for empty def.
- (read_char_minibuf_menu_prompt): Make safety more visible.
- (read_key_sequence): Add a `first_unbound' variable.
- Use it to detect C-c ESC ESC ESC ESC ... cases and drop the
- unbound prefix as soon as we can detect it.
-
- * doc.c (Fsnarf_documentation): Add prototype.
- (get_doc_string): Handle negative arguments.
- (Fdocumentation): Use AREF and ASIZE.
- Move the calls to get_doc_string to a single place.
- Don't confuse an interactive-spec for a docstring reference.
- (Fdocumentation_property): Take advantage of the fact that
- get_doc_string now ignores the sign of the docstring position.
-
- * eval.c: Use standard syntax for usage in docstrings.
-
-2001-12-03 Pavel Jan,Am(Bk <[email protected]>
-
- * xdisp.c (syms_of_xdisp): Make `tool-bar-button-relief' an option.
-
-2001-12-02 Pavel Jan,Am(Bk <[email protected]>
-
- * xterm.c (x_draw_image_relief): Use predefined macro instead of
- constant when the value of `tool_bar_button_relief' is negative.
-
-2001-12-02 Richard M. Stallman <[email protected]>
-
- * xmenu.c (menu_highlight_callback): Use `help' field as Lisp_Object.
- (single_submenu, xmenu_show): Set `help' field as Lisp_Object.
-
- * fileio.c (read_non_regular): Delete Fsignal call.
-
-2001-12-01 Stefan Monnier <[email protected]>
-
- * lisp.h (run_hook_list_with_args): Undo last change.
-
-2001-12-01 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_draw_fringe_bitmap): Always undo clipping.
-
-2001-12-01 Jason Rumney <[email protected]>
-
- * window.c (Qleft_fringe, Qright_fringe): Remove. Now in frame.c.
-
- * w32term.h (WM_MOUSELEAVE, TME_LEAVE, TRACKMOUSEEVENT)
- [!WM_MOUSELEAVE]: Define.
-
- * w32menu.c (current_popup_menu, get_menu_item_info):
- (set_menu_item_info): New vars.
- (set_frame_menubar): Doc fix clarifying GC interaction with menus.
- (w32_menu_show): Set current_popup_menu.
- (add_menu_item): Allocate new strings for owner-drawn menu items
- and help strings.
- Use owner-draw for disabled menu items again.
- (w32_menu_display_help): Ignore owner-drawn items and popup menus.
- (w32_free_submenu_strings, w32_free_menu_strings): New functions.
-
- * w32fns.c (trackmouse_window, track_mouse_event_fn): New vars.
- (w32_wnd_proc) <WM_MOUSEMOVE>: Notice when mouse enters frame.
- <WM_EXITMENULOOP>: Free menu strings.
- <WM_MOUSELEAVE>: Stop tracking mouse.
- (x_create_tip_frame): Specify no minibuffer, modeline or fringes.
-
- * w32term.c (w32_read_socket) <WM_MOUSELEAVE>: Cancel help echo
- and mouse face.
-
-2001-12-01 Kim F. Storm <[email protected]>
-
- The following changes add left-fringe and right-fringe
- frame parameters to adjust fringe widths, or remove one or
- both fringes.
-
- * frame.h (struct frame): Remove trunc_area_pixel_width and
- trunc_area_cols fields.
- (Qleft_fringe, Qright_fringe): Declare.
- (FRAME_RIGHT_FRINGE_WIDTH): New macro.
-
- * frame.c (Qleft_fringe, Qright_fringe): New vars.
- (syms_of_frame): Initialize them.
-
- * window.c (coordinates_in_window): Handle separate left and right
- fringe widths.
-
- * xterm.h (struct x_output): Add left_fringe_width, right_fringe_width,
- and fringe_cols fields.
- (FRAME_FRINGE_BITMAP_WIDTH, FRAME_FRINGE_BITMAP_HEIGHT): Remove macros.
- (FRAME_X_FRINGE_COLS): Use fringe_cols field.
- (FRAME_X_FRINGE_WIDTH): Use fringes_extra field.
- (FRAME_X_LEFT_FRINGE_WIDTH): Use left_fringe_width field.
- (FRAME_X_RIGHT_FRINGE_WIDTH): Use right_fringe_width field.
- (x_compute_fringe_widths): Add prototype.
-
- * xterm.c (zv_height, zv_bits, zv_period): Changed zv bitmap to
- fill fringe evenly with small dashes.
- (x_draw_fringe_bitmap): Clear background if necessary. Align and
- clip the new ZV bitmap to avoid jitter between rows.
- (x_draw_row_fringe_bitmaps): Rely on x_draw_fringe_bitmap to clear
- background. Don't draw fringe bitmaps if fringe width is zero.
- (x_compute_fringe_widths): New function.
- (x_new_font, x_set_window_size_1): Use it.
-
- * xfns.c (x_frame_parms): Add `left-fringe' and `right-fringe' parms.
- (x_set_frame_parameters): Process `font' parameter before other
- parameters as fringe widths depend on it.
- (x_set_fringe_width): New function.
- (x_figure_window_size): Use x_compute_fringe_widths.
- (Fx_create_frame): Process `left-fringe' and `right-fringe' frame
- parameters.
-
- * widget.c (set_frame_size): Use x_compute_fringe_widths.
- (EmacsFrameSetCharSize): Ditto.
-
- * w32term.h: Merged changes from xterm.h.
- * w32term.c: Merged changes from xterm.c.
- * w32fns.c: Merged changes from xfns.c.
-
-2001-11-29 Pavel Jan,Am(Bk <[email protected]>
-
- * COPYING: Removed.
-
-2001-11-29 Dave Love <[email protected]>
-
- * coding.c (syms_of_coding) <Qchar_coding_system>: Give it an
- extra extra slot.
- (detect_coding_mask): Fix call of detect_coding_iso2022.
-
-2001-11-29 Pavel Jan,Am(Bk <[email protected]>
-
- * fileio.c (file-name-coding-system)
- (default-file-name-coding-system): Doc fix (links to referenced
- variables added).
-
-2001-11-28 Stefan Monnier <[email protected]>
-
- * lisp.h (GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
- Add dummy uses of gcproN variables.
-
- * category.c (describe_category, describe_category_1)
- (Fdescribe_categories): Remove. (Moved to lisp/help-fns.el.)
- (syms_of_category): Don't defsubr Sdescribe_categories.
-
-2001-11-28 Richard M. Stallman <[email protected]>
-
- * fileio.c (Ffind_file_name_handler): Avoid initializer for `result'.
-
- * Makefile.in (lispdir): New variable, referring to build dir.
- (TAGS-LISP): Find Makefile in $(lispdir), not $(lispsource).
-
-2001-11-28 Andrew Innes <[email protected]>
-
- * w32menu.c (w32_menu_display_help): Actually add the new argument
- OWNER.
-
-2001-11-28 Jason Rumney <[email protected]>
-
- * w32menu.c (add_menu_item): Do not use owner-draw for disabled
- menu items. From David Ponce <[email protected]>.
- (w32_dialog_show) [HAVE_DIALOGS]: Compile whole function
- conditionally.
- (w32_menu_display_help): New argument OWNER. Rewritten to store a
- help event in the owner frame's keyboard buffer.
-
- * w32fns.c (w32_wnd_proc) <WM_MENUSELECT>: Display help directly.
- (Fx_show_tip): Don't subtract last width from row width.
-
- * w32term.c (w32_read_socket) <WM_MENUSELECT>: Remove.
- (w32_read_socket): Use EQ to compare frames.
-
-2001-11-28 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_draw_glyphs): Don't call notice_overwritten_cursor if
- OVERLAPS_P.
-
-2001-11-28 Pavel Jan,Am(Bk <[email protected]>
-
- * xdisp.c (message_dolog): Remove unused variables `gcpro2',
- `gcpro3' and `gcpro4'.
-
- * coding.c (decode_coding_string): Remove unused variable `gcpro1'.
-
-2001-11-28 Stefan Monnier <[email protected]>
-
- * ccl.c: Use AREF and ASIZE.
-
-2001-11-27 Stefan Monnier <[email protected]>
-
- * lisp.h (run_hook_list_with_args): Remove.
- (LIST_END_P): Fix call to wrong_type_argument.
- (make_fixnum_or_float): Use EMACS_INT rather than int.
-
-2001-11-26 Stefan Monnier <[email protected]>
-
- * syntax.c (syms_of_syntax): Remove defsubr of Sdescribe_syntax.
- (describe_syntax, describe_syntax_1, Fdescribe_syntax): Remove.
-
- * eval.c: Use AREF and ASIZE.
- (Ffetch_bytecode): Add the file name to the error message.
-
- * fileio.c (Ffind_file_name_handler): Give precedence to handlers
- which match the end of the file-name.
- (Fsubstitute_in_file_name): Don't signal an error if $ENVVAR
- is not a valid env var, but leave it as is instead.
-
- * keymap.c (access_keymap): Handle t bindings like nil bindings.
- Make nil bindings in char-tables transparent.
- (store_in_keymap): Turn a nil binding into a t binding for char-tables.
-
-2001-11-26 Richard M. Stallman <[email protected]>
-
- * textprop.c (set_text_properties_1): Allow START, END in either order.
- Do nothing if range is empty.
-
- * Makefile.in (mallocobj): Simplify logic using auxiliary vars.
-
- * Makefile.in (mostlyclean): Delete bootstrap-emacs here.
- (clean): Not here.
-
-2001-11-25 Stefan Monnier <[email protected]>
-
- * textprop.c (set_text_properties_1): Clearly mark that the
- interval should not be empty.
-
- * intervals.c (graft_intervals_into_buffer):
- Don't call set_text_properties_1 on an empty interval.
-
-2001-11-25 Richard M. Stallman <[email protected]>
-
- * unexelf.c (unexec): Index by n, not nn, when checking for ".sbss".
-
- * callproc.c (Fcall_process): When we make a bigger buffer for bufptr,
- don't lose the data in it.
-
-2001-11-25 Juanma Barranquero <[email protected]>
-
- * abbrev.c (Fexpand_abbrev): Use Frun_hooks instead of Vrun_hooks.
-
- * buffer.c (Fkill_buffer): Likewise.
-
- * print.c (temp_output_buffer_setup): Likewise.
-
-2001-11-25 Stefan Monnier <[email protected]>
-
- * xfaces.c (merge_face_heights): Coerce back to int explicitly.
-
-2001-11-25 Eli Zaretskii <[email protected]>
-
- * window.c (Fset_window_vscroll): Doc fix. From Kalle Olavi
- Niemitalo <[email protected]>.
-
-2001-11-25 Jason Rumney <[email protected]>
-
- * w32term.h (FRAME_X_FRINGE_COLS): No fringe on tip frames.
-
- * w32fns.c (x_create_tip_frame): Set frame's fringes_extra to 0.
- (Fx_show_tip): Block input during frame creation.
- (Fx_show_tip, Fx_hide_tip): Enable.
-
-2001-11-24 Richard M. Stallman <[email protected]>
-
- * lread.c (Fload): Detect recursive load error for more than 3
- nestings of the same file.
- (Vrecursive_load_depth_limit): Variable deleted.
- (syms_of_lread) <recursive-load-depth-limit>: Variable deleted.
-
-2001-11-24 Jason Rumney <[email protected]>
-
- * xfns.c (compute_tip_xy): Initialize root_x and root_y from
- mouse position if either left or top is not specified.
-
- * w32fns.c (w32_wnd_proc) <WM_MENUSELECT>: Revert last change.
- <WM_WINDOWPOSCHANGING>: Let tip frames resize without restriction.
- (my_create_tip_window, Fx_show_tip): Adjust size for external border.
- (my_create_tip_window): Assign tip_window.
- (x_create_tip_frame): Use same defaults as X.
- (compute_tip_xy): Remove unused variable. Use full screen width.
- (Fx_show_tip): Do not double height. Call ShowWindow directly.
-
- * w32term.c (x_after_update_window_line): Doc fix.
- (w32_read_socket): Doc fix. Avoid SET_FRAME_GARBAGED for tip
- frames.
- <WM_SHOWWINDOW>: Redo mouse highlight when hiding tip frame.
-
- * xdisp.c (prepare_menu_bars) [HAVE_WINDOW_SYSTEM]: Use tip_frame
- for all Windowed systems.
-
-2001-11-23 Eli Zaretskii <[email protected]>
-
- * msdos.c (IT_clear_screen): If the frame's faces are not yet
- realized, use the initial screen colors to clear the screen.
-
-2001-11-23 Pavel Jan,Am(Bk <[email protected]>
-
- * textprop.c (Fset_text_properties): Remove unused variables
- `unchanged', `prev_changed', `s' and `len'.
-
- * search.c (Freplace_match): Remove unused variable `inslen'.
-
- * keymap.c (access_keymap): Remove unused variables `c1' and `c2'.
-
-2001-11-22 Jason Rumney <[email protected]>
-
- * w32fns.c (x_window_to_frame): Remove irrelevant TODO comment.
- (w32_wnd_proc) <WM_MENUSELECT>: Show help echo directly.
- (my_create_tip_window): New function.
- (x_create_tip_frame, compute_tip_xy): Adapt for Windows.
- (Fx_show_tip, Fx_hide_tip) [TEST_TOOLTIPS]: Adapt for Windows.
-
-2001-11-20 Jason Rumney <[email protected]>
-
- * coding.h (Vw32_system_coding_system) [WINDOWSNT]: Remove.
- (ENCODE_SYSTEM, DECODE_SYSTEM) [WINDOWSNT]: Use Vlocale_coding_system.
-
- * w32fns.c (Vw32_system_coding_system): Remove.
- (w32_to_x_font, x_to_w32_font): Use Vlocale_coding_system.
-
-2001-11-19 Stefan Monnier <[email protected]>
-
- * fileio.c (Fwrite_region): Move choose_write_coding_system to
- after build_annotations.
-
- * syntax.c (describe_syntax): Add dummy arg.
- (describe_syntax_1): Update call to describe_vector.
-
- * category.c (describe_category): Add dummy arg.
- (describe_category_1): Update call to describe_vector.
-
- * keymap.c (Fdescribe_vector): Add `describer' parameter.
- (describe_command, describe_translation): Add dummy second param.
- (describe_map): Call elt_describer with two arguments.
- (describe_vector_princ): Add `fun' parameter.
- Call it instead of the hardcoded `princ'.
- (describe_vector): Add arg `args'.
- Pass it as a new second argument to elt_describer.
-
- * keymap.h (describe_vector): Update prototype.
-
- * frame.c: Don't include keymap.h any more.
- (keys_of_frame): Remove.
-
- * lisp.h (keys_of_frame): Remove declaration.
-
- * emacs.c (main): Don't call `keys_of_frame' any more.
-
-2001-11-14 Andreas Schwab <[email protected]>
-
- * unexelf.c [!defined MAP_ANON]: Define MAP_ANON to MAP_ANONYMOUS
- if defined, 0 otherwise.
- (MAP_FAILED): Define if not defined and use it to test mmap failure.
- (unexec) [!MAP_ANON]: Use /dev/zero as file to map.
-
-2001-11-19 Richard M. Stallman <[email protected]>
-
- * indent.c (current_column_1): Fix handling of scan_bytes for mb chars.
-
-2001-11-18 Jason Rumney <[email protected]>
-
- * w32term.c (note_mouse_highlight): Fix type of variable `ignore'.
- (x_draw_bar_cursor): If the background color of the glyph under
- the cursor equals the frame's cursor color, use the glyph's
- foreground color for drawing the bar cursor.
- (x_after_update_window_line): Clear internal border in different
- circumstances.
- (w32_set_vertical_scroll_bar): Check for width and height > 0.
- (w32_draw_relief_rect): Correct relief by 1 pixel.
- (x_set_glyph_string_background_width):
- Set extends_to_end_of_line_p if the row's fill_line_p is set and
- drawing the last glyph with DRAW_IMAGE_{RAISED,SUNKEN}.
- (x_display_and_set_cursor): If cursor_in_echo_area, use NO_CURSOR
- if cursor_in_non_selected_windows is false.
- (show_mouse_face): Clean up. Recognize overwritten cursor differently.
- (x_draw_glyphs): Remove parameters REAL_START and REAL_END.
- Notice if cursor gets overwritten.
- (notice_overwritten_cursor): Renamed from
- note_overwritten_text_cursor. Rewritten to take glyph widths
- into account, and to take X positions as parameters.
- (x_draw_phys_cursor_glyph): Save state of w->phys_cursor_on_p
- around call to x_draw_glyphs.
- (x_setup_relief_colors): Use `IMAGE_BACKGROUND' and
- `IMAGE_BACKGROUND_TRANSPARENT' to calculate the correct background
- color to use for image glyph reliefs.
- (x_draw_image_relief): Accept zero tool_bar_button_relief.
- (glyph_rect): Remove unused variable `area'.
-
- * w32fns.c (x_set_frame_parameters): Avoid infinite recursion for
- some items.
- (x_set_internal_border_width): Set frame garbaged when window
- doesn't exist yet.
- (Fx_create_frame): Accept zero tool_bar_button_relief.
- (x_clear_image_1, four_corners_best, image_background)
- (image_background_transparent): New functions.
- (xpm_format, png_format, jpeg_format, tiff_format, gif_format)
- (gs_format): Add `:background' entry.
- (lookup_image): Set IMG's background color if specified.
- (pbm_load, xbm_load_image, png_load): Set IMG's background field
- when appropriate.
- (x_clear_image_1): Reset `background_valid' and
- `background_transparent_valid' fields.
- (x_build_heuristic_mask): Use IMAGE_BACKGROUND instead of
- calculating it here. Set IMG's background_transparent field.
- (enum xpm_keyword_index): Add XPM_BACKGROUND.
- (enum png_keyword_index): Add PNG_BACKGROUND.
- (enum jpeg_keyword_index): Add JPEG_BACKGROUND.
- (enum tiff_keyword_index): Add TIFF_BACKGROUND.
- (enum gif_keyword_index): Add GIF_BACKGROUND.
- (enum gs_keyword_index): Add GS_BACKGROUND.
- (pbm_load, png_load, jpeg_load, tiff_load, gif_load):
- Pre-calculate image background color where necessary.
- (x_create_x_image_and_pixmap, xbm_load, gs_load):
- Use display info's n_cbits entry for screen depth.
- (Fx_show_tip): Remove unused variables `buffer', `top',
- `left', `max_width' and `max_height'.
-
- * w32menu.c (w32_menu_show, push_menu_pane): Doc fixes.
-
-2001-11-18 Gerd Moellmann <[email protected]>
-
- * puresize.h (BASE_PURESIZE): Increase to 750000.
-
-2001-11-18 Pavel Jan,Am(Bk <[email protected]>
-
- * frame.c (Fframe_live_p): Doc fix.
-
-2001-11-18 Richard M. Stallman <[email protected]>
-
- * xdisp.c (message_dolog_marker1, message_dolog_marker2)
- (message_dolog_marker3): New static variables hold three markers.
- (syms_of_xdisp): Initialize and staticpro them.
- (message_dolog): Use message_dolog_marker1..3 instead of
- allocating markers each time. Unchain them when done.
-
-2001-11-17 Richard M. Stallman <[email protected]>
-
- * doc.c (Fsnarf_documentation): Doc fix.
-
-2001-11-17 Andreas Schwab <[email protected]>
-
- * xterm.c (note_mouse_highlight): Fix type of variable `ignore'.
-
-2001-11-17 Richard M. Stallman <[email protected]>
-
- * fileio.c (Fwrite_region): Avoid initializer for Lisp_Object.
-
-2001-11-17 Jason Rumney <[email protected]>
-
- * xterm.c (notice_overwritten_cursor): Take care of end < 0 case.
-
-2001-11-17 Gerd Moellmann <[email protected]>
-
- * xdisp.c (tool_bar_item_info): Avoid calling Fget_text_property
- with invalid position.
-
-2001-11-16 Richard M. Stallman <[email protected]>
-
- * syswait.h: Delete conditionals for HPUX7, ISC 4.1, and convex.
-
- * s/isc4-1.h (HAVE_SYS_WAIT_H): Add #undef.
- * s/hpux.h (HAVE_SYS_WAIT_H): Add #undef.
- * s/hpux8.h (HAVE_SYS_WAIT_H): Define it.
-
- * m/convex.h (HAVE_SYS_WAIT_H): Add #undef.
-
-2001-11-16 Stefan Monnier <[email protected]>
-
- * fileio.c (build_annotations): Split off the tail.
- (build_annotations_2): New fun. Extracted from build_annotations.
- (Fwrite_region): Split the call to build_annotations into two
- calls to build_annotations and build_annotations_2.
-
-2001-11-16 Pavel Jan,Am(Bk <[email protected]>
-
- * sysdep.c (wait_for_kbd_input) [VMS]: Do not call
- clear_waiting_for_input with argument.
-
- * xterm.h (x_update_cursor): Remove duplicated prototype.
-
- * keyboard.h (clear_waiting_for_input): Remove duplicated prototype.
-
- * xterm.c (waiting_for_input): Remove unnecessary declaration.
-
- * data.c (Ftimes, Fquo, Frem, Fmod): Doc fix.
-
-2001-11-16 Stefan Monnier <[email protected]>
-
- * fileio.c (choose_write_coding_system): New fun, extracted
- from Fwrite_region.
- (Fwrite_region): Use it.
-
- * eval.c (max_specpdl_size, max_lisp_eval_depth): Use EMACS_INT.
- (funcall_lambda, run_hook_with_args): Make static and add prototype.
- (ml_apply, find_handler_clause): Add prototype.
-
-2001-11-16 Eli Zaretskii <[email protected]>
-
- * config.in: Add #undef HAVE_COFF_H.
-
- * unexec.c (coff.h): Don't include unless HAVE_COFF_H is defined.
- Required for ISC 4.1.
-
-2001-11-16 Eli Zaretskii <[email protected]>
-
- * syswait.h (HAVE_SYS_WAIT_H): Undef for ISC 4.1. Reported by
- Andrew Wiseman <[email protected]>.
-
-2001-11-16 Kim F. Storm <[email protected]>
-
- The following changes are made to clean up the various internal
- references to the fringes to actually use the term `fringe' for
- them. Previously, they were called `flags areas', `bitmap areas',
- `left/right side of windows', or implicitly as `flags' or
- `bitmaps':
-
- * dispextern.h (FRINGE_FACE_ID): Renamed from BITMAP_AREA_FACE_ID.
- Comments fixed. Use renamed symbols.
-
- * dispnew.c: Comment fix. Use renamed symbols.
-
- * frame.h (FRAME_FRINGE_COLS): Renamed from FRAME_FLAGS_AREA_COLS.
- (FRAME_FRINGE_WIDTH): Renamed from FRAME_FLAGS_AREA_WIDTH.
- (FRAME_LEFT_FRINGE_WIDTH): Renamed from FRAME_LEFT_FLAGS_AREA_WIDTH.
-
- * msdos.c: Comment fix.
-
- * w32fns.c: Use renamed symbols.
-
- * w32term.c: Comment fixes. Use renamed symbols.
- (fringe_bitmap_type): Renamed from bitmap_type.
- (NO_FRINGE_BITMAP): Renamed from NO_BITMAP.
- (w32_draw_fringe_bitmap): Renamed from w32_draw_bitmap.
- (x_draw_row_fringe_bitmaps): Renamed from x_draw_row_bitmaps.
-
- * w32term.h: Comment fixes. Use renamed symbols.
- (fringes_extra): Renamed from flags_areas_extra.
- (FRAME_FRINGE_BITMAP_WIDTH): Renamed from FRAME_FLAGS_BITMAP_WIDTH.
- (FRAME_FRINGE_BITMAP_HEIGHT): Renamed from FRAME_FLAGS_BITMAP_HEIGHT.
- (FRAME_X_FRINGE_COLS): Renamed from FRAME_X_FLAGS_AREA_COLS.
- (FRAME_X_FRINGE_WIDTH): Renamed from FRAME_X_FLAGS_AREA_WIDTH.
- (FRAME_X_LEFT_FRINGE_WIDTH):
- Renamed from FRAME_X_LEFT_FLAGS_AREA_WIDTH.
- (FRAME_X_RIGHT_FRINGE_WIDTH):
- Renamed from FRAME_X_RIGHT_FLAGS_AREA_WIDTH.
-
- * widget.c: Use renamed symbols.
-
- * window.c: Comment fixes. Use renamed symbols.
- (coordinates-in-window-p): Doc fix.
-
- * xdisp.c: Comment fixes. Use renamed symbols.
-
- * xfaces.c (realize_basic_faces): Use FRINGE_FACE_ID.
-
- * xfns.c: Use renamed symbols.
-
- * xterm.c: Comment fixes. Use renamed symbols.
- (fringe_bitmap_type): Renamed from bitmap_type.
- (NO_FRINGE_BITMAP): Renamed from NO_BITMAP.
- (x_draw_fringe_bitmap): Renamed from x_draw_bitmap.
- (x_draw_row_fringe_bitmaps): Renamed from x_draw_row_bitmaps.
-
- * xterm.h: Comment fixes. Use renamed symbols.
- (fringes_extra): Renamed from flags_areas_extra.
- (FRAME_FRINGE_BITMAP_WIDTH): Renamed from FRAME_FLAGS_BITMAP_WIDTH.
- (FRAME_FRINGE_BITMAP_HEIGHT): Renamed from FRAME_FLAGS_BITMAP_HEIGHT.
- (FRAME_X_FRINGE_COLS): Renamed from FRAME_X_FLAGS_AREA_COLS.
- (FRAME_X_FRINGE_WIDTH): Renamed from FRAME_X_FLAGS_AREA_WIDTH.
- (FRAME_X_LEFT_FRINGE_WIDTH):
- Renamed from FRAME_X_LEFT_FLAGS_AREA_WIDTH.
- (FRAME_X_RIGHT_FRINGE_WIDTH):
- Renamed from FRAME_X_RIGHT_FLAGS_AREA_WIDTH.
-
-2001-11-15 Jason Rumney <[email protected]>
-
- * w32menu.c (add-menu-item): Make help_echo and radio buttons
- work for most menu items. From David Ponce
-
-2001-11-15 Gerd Moellmann <[email protected]>
-
- * xfns.c (x_set_frame_parameters): Revert change of 2001-11-07.
- Some x_set_* function expect to be called even if old and new
- value are equal.
-
- * xdisp.c (build_desired_tool_bar_string): Accept zero
- tool_bar_button_relief.
-
- * xfns.c (Fx_create_frame): Accept zero tool_bar_button_relief.
-
- * xterm.c (x_draw_image_relief): Accept zero tool_bar_button_relief.
-
- * xterm.c (x_draw_bar_cursor): If the background color of the
- glyph under the cursor equals the frame's cursor color, use
- the glyph's foreground color for drawing the bar cursor.
-
- * dispnew.c (direct_output_forward_char): Fix character/byte
- position comparison.
-
-2001-11-15 Miles Bader <[email protected]>
-
- * editfns.c (find_field): Add BEG_LIMIT and END_LIMIT parameters.
- (Fdelete_field, Ffield_string, Ffield_string_no_properties):
- Update arguments to find_field.
- (Ffield_beginning, Ffield_end): Add LIMIT param, pass to find_field.
- (Fconstrain_to_field): Use LIMIT arg to shorten search time.
- * lisp.h (Ffield_beginning, Ffield_end): Update EXFUN decl.
- * minibuf.c (Fminibuffer_prompt_end): Update args to Ffield_end.
-
-2001-11-14 Richard M. Stallman <[email protected]>
-
- * editfns.c (Fpropertize): Allow call with 1 arg.
-
- * dispextern.h (image_background, image_background_transparent):
- Conditionalize on HAVE_X_WINDOWS.
-
-2001-11-13 Richard M. Stallman <[email protected]>
-
- * print.c (Fprin1_to_string): Doc fix.
-
- * sunfns.c (Fsun_change_cursor_icon): Doc fix.
-
- * floatfns.c (Fceiling, Ffloor): Doc fixes.
-
- * filelock.c (Funlock_buffer, Ffile_locked_p): Doc fixes.
-
- * fileio.c (Ffile_accessible_directory_p): Doc fix.
-
- * eval.c (syms_of_eval): Doc fix.
-
- * coding.c (syms_of_coding): Doc fix.
-
- * doc.c (Fsnarf_documentation): Doc fix.
-
- * dispnew.c (syms_of_display): Doc fix.
-
- * category.c (Fget_unused_category): Doc fix.
-
- * buffer.c (syms_of_buffer): Doc fixes.
-
-2001-11-14 Eli Zaretskii <[email protected]>
-
- * print.c (prin1, print): Doc fix.
-
-2001-11-14 Pavel Jan,Am(Bk <[email protected]>
-
- * fontset.h: Remove declarations of variables
- `Vhighlight_wrong_size_font' and `Vclip_large_size_font'.
-
- * fontset.c: Remove variables `Vhighlight_wrong_size_font' and
- `Vclip_large_size_font'.
-
-2001-11-13 Jason Rumney <[email protected]>
-
- * w32fns.c: Doc fix.
-
-2001-11-13 Pavel Jan,Am(Bk <[email protected]>
-
- * xfaces.c (Fface_attributes_as_vector): Doc fix.
-
- * fns.c: Doc fix.
-
- * emacs.c: Doc fix.
-
- * coding.c: Doc fix.
-
- * cmds.c, composite.c, dired.c, doc.c, filelock.c, floatfns.c,
- * fontset.c, insdel.c, keymap.c: Change doc-string comments to
- `new style' [w/`doc:' keyword].
-
-2001-11-12 Richard M. Stallman <[email protected]>
-
- * xterm.c (XTread_socket): Don't update focus for EnterNotify or
- LeaveNotify events. Only FocusIn and FocusOut do that now.
- (x_display_and_set_cursor): Do display hollow cursors in active
- minibuffer windows when they are not selected.
-
-2001-11-12 Jason Rumney <[email protected]>
-
- * w32console.c, w32fns.c, w32menu.c, w32proc.c, w32select.c,
- * w32term.c: Change doc-string comments to `new style'
- [w/`doc:' keyword]. Doc fixes.
-
- * w32fns.c: Don't define max.
- (Fx_open_connection): Only execute once.
-
-2001-11-12 Pavel Jan,Am(Bk <[email protected]>
-
- * ccl.c: Change macros to use do-while block instead of if-else.
- Use braces to follow GNU Coding Standards.
-
-2001-11-11 Richard M. Stallman <[email protected]>
-
- * sysdep.c (child_setup_tty): Don't clear ICRNL or INLCR.
-
- * lread.c (read_escape): Use end_of_file_error for reporting eof.
-
- * insdel.c (replace_range): Use adjust_markers_for_replace
- instead of adjust_markers_for_delete and adjust_markers_for_insert.
-
- * intervals.h (set_text_properties, set_text_properties_1): Declare.
-
- * textprop.c (set_text_properties_1): New subroutine
- broken out of set_text_properties.
- (set_text_properties): Use set_text_properties_1.
-
- * intervals.c (graft_intervals_into_buffer):
- Use set_text_properties_1 to clear out properties.
-
- * search.c (Freplace_match): Use replace_range to insert
- and delete. Don't request property inheritance from
- surrounding text.
-
-2001-11-10 Jason Rumney <[email protected]>
-
- * w32fns.c (enum_font_cb2): Use leading @ on face name to detect
- vertical fonts. Allow them if face name is explicitly specified.
- Do not give up if we find a font that cannot be converted to an xlfd.
-
-2001-11-10 Gerd Moellmann <[email protected]>
-
- * unexelf.c (unexec): Use mmap/munmap to allocate buffers
- instead of malloc/free.
-
-2001-11-09 Pavel Jan,Am(Bk <[email protected]>
-
- * xfaces.c (merge_face_vectors): Use braces to follow GNU
- Coding Standards.
- (Finternal_set_lisp_face_attribute): Likewise.
-
- * buffer.c (Fbury_buffer): Likewise.
-
- * indent.c (current_column_1): Remove unused variable `prev_col'.
-
- * coding.c (encode_coding): Use precomputed value of `src'.
- (encode_coding): Remove unused variable `src_end'.
- (code_convert_region): Remove unused variables `count'.
-
-2001-11-07 Jason Rumney <[email protected]>
-
- * w32term.c (x_display_and_set_cursor): Do not move system caret
- if cursor_glyph is NULL.
-
-2001-11-07 Pavel Jan,Am(Bk <[email protected]>
-
- * keymap.c (access_keymap): Fix compilation error.
-
-2001-11-07 Miles Bader <[email protected]>
-
- * xfns.c (x_set_frame_parameters): Avoid infinite recursion.
-
-2001-11-07 Pavel Jan,Am(Bk <[email protected]>
-
- * intervals.c (graft_intervals_into_buffer):
- Remove #ifdef'd-out code.
- (graft_intervals_into_buffer): Remove unused variable `middle'.
-
- * lread.c (Feval_region): Remove obsolete #ifdef'd-out
- code (eval-current-buffer).
- Change doc-string comments to `new style' [w/`doc:' keyword].
-
-2001-11-06 Richard M. Stallman <[email protected]>
-
- * keymap.c (access_keymap): Don't use initializers on Lisp_Object.
-
-2001-11-06 Stefan Monnier <[email protected]>
-
- * lread.c (read1): Fix behavior with nested backquoting.
-
- * keyboard.c (make_lispy_event): Check integerness and fix
- Lisp_Object/int mixup.
-
-2001-11-06 Pavel Jan,Am(Bk <[email protected]>
-
- * fns.c (copy_hash_table): Remove unused variable `v'.
-
- * fontset.c (fontset_font_pattern): Remove unused variable
- `family_registry'.
-
- * indent.c (current_column_1): Remove unused variable `prev_col'.
-
-2001-11-05 Richard M. Stallman <[email protected]>
-
- * m/news-risc.h (BROKEN_PROTOTYPES): Defined.
-
- * buffer.c (Fkill_buffer): Don't delete auto save file
- if buffer is modified.
-
-2001-11-05 Andrew Innes <[email protected]>
-
- * w32proc.c (Fw32_set_keyboard_layout): Use CHECK_NUMBER_CAR and
- CHECK_NUMBER_CDR.
-
-2001-11-05 Richard M. Stallman <[email protected]>
-
- * unexelf.c (unexec): Minor changes; clean up comments.
-
-2001-11-05 Sam Steingold <[email protected]>
-
- * w32term.c (x_display_and_set_cursor): Fix w32 compilation error.
-
-2001-11-05 Andreas Schwab <[email protected]>
-
- * sound.c (sound_perror): Save errno from being clobbered.
-
-2001-11-05 Dale Hagglund <[email protected]>
-
- * unexelf.c (unexec): Don't use `mmap'. Instead, read and write
- the program image directly.
-
-2001-11-05 Pavel Jan,Am(Bk <[email protected]>
-
- * buffer.h (Fbuffer_local_value): Add prototype.
-
-2001-11-04 Richard M. Stallman <[email protected]>
-
- * buffer.c (Fbuffer_local_value): Remove extra args from CHECK_SYMBOL
- and CHECK_BUFFER.
-
- * keyboard.c (read_char): Use Fcar and Fcdr, not Fnth.
- (record_char): Likewise.
-
- * keyboard.c (make_lispy_event): Don't insist a drag event must
- move to a different buffer position. Instead, check for moving at
- least double_click_fuzz.
-
- * fns.c (Fmake_hash_table): Use XCAR and XCDR, not Fnth and Flength.
-
- * keyboard.c (echo-area-clear-hook): Undo Oct 29 change.
-
- * indent.c (current_column_1, Fmove_to_column): Separate the code
- for display-table glyphs from the code for buffer text, to fix
- bugs in the former.
-
-2001-11-04 Michael Welsh Duggan <[email protected]>
-
- * buffer.c (Fbuffer_local_value): New function.
- (syms_of_buffer): Defsubr it.
-
- * xterm.c, w32term.c (x_display_and_set_cursor): Use buffer-local
- value of `cursor-in-non-selected-windows'.
-
- * lisp.h (Qcursor_in_non_selected_windows): New declaration.
- * xdisp.c (Qcursor_in_non_selected_windows): New variable.
- (syms_of_xdisp): Initialize it.
-
-2001-11-04 Pavel Jan,Am(Bk <[email protected]>
-
- * xfns.c (Fx_create_frame): Doc fix.
-
- * coding.c: Change doc-string comments to `new style' [w/`doc:'
- keyword].
-
- * eval.c (top_level_value, top_level_set): Remove commented and
- #ifdef'd-out code.
- (Fdefvar): Fix usage in doc-string.
-
-2001-11-03 Richard M. Stallman <[email protected]>
-
- * xfns.c: Include unistd.h, if it exists.
-
- * editfns.c: Move the include of ctype.h after unistd.h.
-
- * gmalloc.c: Test BROKEN_PROTOTYPES.
-
-2001-11-03 Ken Raeburn <[email protected]>
-
- * lisp.h (CHECK_STRING_CAR): New macro.
- * lread.c (Fload): Use XSETCARFASTINT, XSETCDRFASTINT instead of
- treating XCAR and XCDR as lvalues.
- (openp): Use CHECK_STRING_CAR.
- (read_list): Use XSETCDR instead of treating XCDR as lvalue.
-
-2001-11-03 Eli Zaretskii <[email protected]>
-
- * s/sco5.h (sigprocmask_set): Declare as extern SIGMASKTYPE.
- (SIGMASKTYPE): Define.
-
- * syssignal.h (sigunblock): Don't define if already defined.
-
-2001-11-02 Pavel Jan,Am(Bk <[email protected]>
-
- * eval.c (debugger_may_continue, Vdebug_ignored_errors)
- (call_debugger, Fcondition_case, skip_debugger, unbind_to):
- Fix typos in comments.
-
- * mocklisp.c (Fml_defun, Fml_while, Fml_substr): Remove commented
- and #ifdef'd-out code.
- Fix and reindent comments.
-
- * mocklisp.h: Remove comment which is a copy of comment in mocklisp.c.
-
- * category.h (CHECK_CATEGORY, CHECK_CATEGORY_SET): Remove unused
- argument `i' in macros.
-
- * frame.h (CHECK_FRAME, CHECK_LIVE_FRAME): Remove unused argument
- `i' in macros.
-
- * lisp.h (CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST)
- (CHECK_STRING, CHECK_CONS, CHECK_SYMBOL, CHECK_CHAR_TABLE)
- (CHECK_VECTOR, CHECK_VECTOR_OR_CHAR_TABLE, CHECK_BUFFER)
- (CHECK_WINDOW, CHECK_LIVE_WINDOW, CHECK_PROCESS, CHECK_NUMBER)
- (CHECK_NATNUM, CHECK_MARKER, CHECK_NUMBER_COERCE_MARKER)
- (CHECK_FLOAT, CHECK_NUMBER_OR_FLOAT)
- (CHECK_NUMBER_OR_FLOAT_COERCE_MARKER, CHECK_OVERLAY)
- (CHECK_NUMBER_CAR, CHECK_NUMBER_CDR): Remove unused argument `i'
- in macros.
-
- * abbrev.c, alloc.c, buffer.c, bytecode.c, callint.c, callproc.c,
- * casefiddle.c, category.c, ccl.c, charset.c, cmds.c, coding.c,
- * composite.c, data.c, dired.c, dispnew.c, doc.c, dosfns.c, emacs.c,
- * eval.c, fileio.c, filelock.c, fns.c, fontset.c, frame.c, frame.h,
- * indent.c, keyboard.c, keymap.c, lread.c, macros.c, marker.c,
- * minibuf.c, mocklisp.c, msdos.c, print.c, process.c, search.c,
- * sunfns.c, syntax.c, textprop.c, undo.c, w16select.c, w32console.c,
- * w32fns.c, w32menu.c, w32proc.c, w32select.c, window.c, xdisp.c,
- * xfaces.c, xmenu.c, xselect.c: Update usage of CHECK_ macros
- (remove unused second argument).
-
-2001-11-02 Stefan Monnier <[email protected]>
-
- * syntax.c (describe_syntax): New wrapper.
- (Finternal_describe_syntax_value): Rename from describe_syntax.
- Don't insert space at front and \n at the end.
- (syms_of_syntax): Defsubr Sinternal_describe_syntax_value.
-
- * regex.c (re_wctype): Try to fix some warnings.
- (regcomp, regexec): Don't forget the __restrict.
-
-2001-11-02 Richard M. Stallman <[email protected]>
-
- * textprop.c (Fget_char_property): Doc fix.
-
-2001-11-02 Pavel Jan,Am(Bk <[email protected]>
-
- * process.c (Fstart_process): Add usage to doc-string.
-
- * data.c (Fsetq_default): Ditto.
-
- * callint.c (Finteractive): Ditto.
-
-2001-11-01 Stefan Monnier <[email protected]>
-
- * macros.c: Don't include keymap.h any more.
-
-2001-11-01 Richard M. Stallman <[email protected]>
-
- * data.c (Fmake_local_variable): Doc fix.
-
- * eval.c (Frun_hooks, Frun_hook_with_args_until_failure): Doc fix.
- (Frun_hook_with_args_until_success, Frun_hook_with_args): Doc fix.
-
- * keymap.c (Fdescribe_buffer_bindings): Print character property
- bindings along with or instead of the buffer local map.
- Make the overriding maps override what they should.
-
-2001-11-01 Pavel Jan,Am(Bk <[email protected]>
-
- * window.c (grow_mini_window): Fix typo in comment.
-
-2001-11-01 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_scroll_bar_create): Check for width and height > 0.
- (XTset_vertical_scroll_bar): Likewise.
-
- * xfns.c (x_build_heuristic_mask): Use four_corners_best
- instead of IMAGE_BACKGROUND.
-
- * xfns.c (four_corners_best): Reindent.
-
- * xfaces.c (Finternal_set_lisp_face_attribute_from_resource):
- Handle :box so that it is possible to specify sexprs.
-
-2001-10-31 Eli Zaretskii <[email protected]>
-
- * s/hpux11.h: New file.
-
-2001-10-31 Pavel Jan,Am(Bk <[email protected]>
-
- * emacs.c (USAGE1): Show command line option --no-window-system
- instead of --no-windows in usage.
- (standard_args): Rename --no-windows to --no-window-system.
- (bug_reporting_address): Follow Emacs coding conventions.
-
- * eval.c (Fcommandp): Doc fix.
- Change doc-string comments to `new style' [w/`doc:' keyword].
-
- * frame.c (Fframe_live_p): Doc fix.
-
- * buffer.c (selective-display-ellipses): Doc fix.
-
-2001-10-31 Gerd Moellmann <[email protected]>
-
- * lread.c (to_multibyte): Fix computation of new read_buffer_size.
-
- * xfaces.c (realize_x_face): If C is not a single-byte character,
- set the face's colors_copied_bitwise_p instead of the defaulted_p
- members which have a different meaning.
- (free_face_colors): Do nothing for a face whose colors have been
- copied bitwise.
-
- * dispextern.h (struct face) <colors_copied_bitwise_p>: New member.
-
-2001-10-31 Pavel Jan,Am(Bk <[email protected]>
-
- * marker.c, mocklisp.c: Change doc-string comments to `new style'
- [w/`doc:' keyword].
-
-2001-10-31 Gerd Moellmann <[email protected]>
-
- * fns.c (require_unwind): Return Lisp_Object.
-
-2001-10-31 Pavel Jan,Am(Bk <[email protected]>
-
- * keyboard.c (lucid-menu-bar-dirty-flag): Doc fix.
- (last-input-char): Revert doc-string to be the same as the
- doc-string of `last-input-event'.
-
- * xdisp.c: Fix typos in comments.
-
-2001-10-31 Gerd Moellmann <[email protected]>
-
- * window.c (grow_mini_window): Handle case that the root
- window is already smaller than the nominal mininum height.
-
-2001-10-30 Stefan Monnier <[email protected]>
-
- * emacs.c (main): Don't call keys_of_macros any more.
-
- * lisp.h (keys_of_macros): Remove.
-
- * macros.c (keys_of_macros): Remove.
-
- * xfaces.c (Fface_attribute_relative_p): Declare args.
-
-2001-10-30 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_to_x_charset): Increase size of XLFD charset buffer.
- (enum_font_cb2): Ignore fonts with vertical orientation.
-
-2001-10-30 Richard M. Stallman <[email protected]>
-
- * keyboard.c (Finput_pending_p): Doc fix.
-
-2001-10-30 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_after_update_window_line): Don't run the code
- clearing in borders for rows whose visible height is 0.
-
- * xdisp.c (clear_garbaged_frames): Redraw the frame only if its
- resized_p flag is set. If not set, use the much less flickering
- method previously used.
-
- * dispnew.c (change_frame_size_1): Set frame's resized_p.
-
- * frame.h (struct frame) <resized_p>: New member.
-
- * lread.c (to_multibyte): Ensure read_buffer is at least twice
- as large as the number of bytes to convert.
-
- * lread.c (to_multibyte): New function.
- (read1): Use it.
-
-2001-10-30 Eli Zaretskii <[email protected]>
-
- * msdos.h (FRAME_LINE_HEIGHT): Define (it's used by xmenu.c).
-
-2001-10-30 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_draw_relief_rect): Correct bottom relief by 1 pixel.
- (x_set_glyph_string_background_width): Set extends_to_end_of_line_p
- if the row's fill_line_p is set and drawing the last glyph with
- DRAW_IMAGE_{RAISED,SUNKEN}.
-
- * xdisp.c (clear_garbaged_frames): Call Fredraw_frame.
-
-2001-10-29 Stefan Monnier <[email protected]>
-
- * xmenu.c: Include coding.h and charset.h.
- (Fx_popup_menu): Use FRAME_PTR and FRAME_FONT and FRAME_LINE_HEIGHT.
- (Fx_popup_dialog): Use FRAME_PTR and enum scroll_bar_part.
- (single_submenu, xmenu_show): Use ENCODE_SYSTEM.
- Explicitly set wv->help. Use `TRUE' rather than `True'.
- (menu_help_callback): Use empty_string.
-
- * w32menu.c (Fx_popup_menu): Explicitly init f, xpos, and ypos.
- (Fx_popup_dialog): Explicitly init f.
- (w32_menu_display_help): Use empty_string.
-
-2001-10-29 Richard M. Stallman <[email protected]>
-
- * fns.c (Frequire): Detect recursive try to require the same
- feature 3 or more levels deep, and get error.
- (require_unwind): New subroutine.
- (require_nesting_list): New variable.
- (syms_of_fns): Init and staticpro it.
-
- * print.c (print_object): Clarify indication of insertion type.
-
-2001-10-29 Eli Zaretskii <[email protected]>
-
- * coding.c (syms_of_coding): Document that locale-coding-system is
- used for decoding input on X.
-
- * window.c (Fscroll_left, Fscroll_right): Doc fix.
-
-2001-10-29 Pavel Jan,Am(Bk <[email protected]>
-
- * keyboard.c (Finput_pending_p): Fix typo in doc-string.
- (echo-area-clear-hook): Properly DEFVAR_LISP and staticpro it.
-
-2001-10-29 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_display_and_set_cursor): If cursor_in_echo_area,
- use NO_CURSOR if cursor_in_non_selected_windows is false.
-
- * xfaces.c (Fface_font): Use UNSPECIFIEDP instead of NILP for
- the slant attribute if FRAME is t.
-
- * xfns.c (x_set_internal_border_width): Set frame garbaged
- when X window doesn't exist yet.
-
- * xterm.c (x_after_update_window_line): Clear internal border
- in different circumstances.
-
- * xterm.c (XTread_socket) <KeyPress>: Don't use
- STRING_CHAR_AND_LENGTH if nchars == nbytes. From Kenichi Handa
-
-2001-10-28 Eli Zaretskii <[email protected]>
-
- * m/ibms390.h: New file. From Adam Thornton
-
-2001-10-28 Gerd Moellmann <[email protected]>
-
- * xfns.c (x_build_heuristic_mask): Use x_alloc_image_color.
-
- * xfns.c (x_build_heuristic_mask): Fix a bug not incrementing
- a loop counter.
-
-2001-10-28 Pavel Jan,Am(Bk <[email protected]>
-
- * emacs.c: Use argv[0] instead of "emacs" when -t was specified.
-
- * keyboard.c: Change doc-string comments to `new style' [w/`doc:'
- keyword].
- Fix typos in comments.
-
- * emacs.c (bug_reporting_address): New function.
- Use it when displaying usage message.
-
- * minibuf.c (read_minibuf): Remove unused external declaration of
- variable `Qread_only'.
-
- * keymap.c (access_keymap): Remove unused variable `charset'.
-
-2001-10-28 Miles Bader <[email protected]>
-
- * xfaces.c (merge_face_heights): Handle TO being relative as well.
- Remove #ifdef'd-out code.
- (Fface_attribute_relative_p, Fmerge_face_attribute): New functions.
- (syms_of_xfaces): Initialize them.
-
-2001-10-27 Jason Rumney <[email protected]>
-
- * w32fns.c (w32_wnd_proc) <WM_KILLFOCUS>: Destroy the system caret.
- <WM_EMACS_DESTROY_CARET, WM_EMACS_TRACK_CARET>: Track cursor
- position using the system caret.
-
- * w32term.c (w32_system_caret_hwnd, w32_system_caret_width)
- (w32_system_caret_height, w32_system_caret_x)
- (w32_system_caret_y): New variables for tracking system caret.
- (w32_initialize): Initialize them.
- (x_display_and_set_cursor): Make system caret follow the active cursor.
-
- * w32term.h (WM_EMACS_TRACK_CARET, WM_EMACS_DESTROY_CARET):
- New messages types.
-
- * w32term.c (note_mouse_highlight): Clear old help_echo.
-
-2001-10-27 Pavel Jan,Am(Bk <[email protected]>
-
- * xterm.c: Fix typo in a comment.
-
- * emacs.c: Fix typos in comments.
- Remove unnecessary spaces.
- Change doc-string comments to `new style' [w/`doc:' keyword].
- (USAGE2): Fix typos in usage string.
-
- * xterm.c: Fix typo in a comment.
-
- * lisp.h (gdb_lisp_params): Remove code in #if 0 which is now in
- emacs.c.
-
-2001-10-27 Gerd Moellmann <[email protected]>
-
- * xdisp.c (move_it_vertically_backward): Use 2/3 line_height
- instead of 1/2 line_height in the heuristic for skipping
- farther backward when target_y was not reached.
-
- * sound.c (sound_perror): Unblock SIGIO, turn on atimers.
- Display errno only if non-zero.
- (sound_warning): New function.
- (vox_configure): Don't treat failing to set sample rate as error.
- (various places): Improve error messages.
-
-2001-10-26 Eli Zaretskii <[email protected]>
-
- * fileio.c (Faccess_file): Run the argument filename through
- Fexpand_file_name, before using it.
-
- * dispnew.c (syms_of_display) <visible-bell>: Add a reference to
- ring-bell-function. Suggested by Alf-Ivar Holm <[email protected]>
-
-2001-10-26 Gerd Moellmann <[email protected]>
-
- * insdel.c (insert_1_both): Do nothing if NCHARS == 0.
-
- * xterm.c (XTset_vertical_scroll_bar) [!USE_TOOLKIT_SCROLL_BARS]:
- Fix clearing in the case of scroll bars on the right.
-
-2001-10-26 Juanma Barranquero <[email protected]>
-
- * w32gui.h (XImage): Add a dummy typedef.
-
-2001-10-26 Gerd Moellmann <[email protected]>
-
- * xfns.c (XScreenNumberOfScreen): Fix struct to pointer comparison.
-
-2001-10-25 Eli Zaretskii <[email protected]>
-
- * frame.c (Fframe_parameter): Fix last change.
-
- * fileio.c: Revert last change (which removed old commented-out
- version of expand-file-name). Add a comment that explains why
- this old version should not be removed.
-
-2001-10-25 Gerd Moellmann <[email protected]>
-
- * frame.c (Fframe_parameter): Fix a bug whereby some
- ``artificial'' frame parameters, like `minibuffer' were not
- obtained by calling Fframe_parameters.
-
- * xterm.c (show_mouse_face): Clean up. Recognize overwritten
- cursor differently.
-
- * xdisp.c (move_it_vertically_backward): Compute line height
- differently. Add heuristic to try to be more compatible to 20.x.
-
-2001-10-25 Stefan Monnier <[email protected]>
-
- * lisp.h (make_fixnum_or_float): Coerce double to int explicitly.
-
- * editfns.c (text_property_stickiness): Fix Lisp_Object used as
- boolean.
-
-2001-10-25 Miles Bader <[email protected]>
-
- * xfns.c (png_load): Make sure SPECIFIED_BG is a string.
- BG is a pointer to a structure, not a structure.
- (gif_format, png_format): Add missing commas.
-
-2001-10-24 Richard M. Stallman <[email protected]>
-
- * xfaces.c (Fface_attributes_as_vector): New function.
- (syms_of_xfaces): Defsubr it.
-
-2001-10-24 Pavel Jan,Am(Bk <[email protected]>
-
- * dispnew.c (sync_window_with_frame_matrix_rows): Remove unused
- variable `area'.
-
-2001-10-25 Pavel Jan,Am(Bk <[email protected]>
-
- * search.c (scan_newline): Remove unused variable `selective_display'.
-
-2001-10-25 Miles Bader <[email protected]>
-
- * dispextern.h (struct image): Add `background',
- `background_valid', and `background_transparent' fields.
- (image_background, image_background_transparent): New declarations.
- (IMAGE_BACKGROUND, IMAGE_BACKGROUND_TRANSPARENT): New macros.
- * xfns.c (image_background, image_background_transparent)
- (four_corners_best): New functions.
- (xpm_format, png_format, jpeg_format, tiff_format, gif_format)
- (gs_format): Add `:background' entry.
- (lookup_image): Set IMG's background color if specified.
- (pbm_load, xbm_load_image, png_load): Set IMG's background field
- when appropriate.
- (x_clear_image_1): Reset `background_valid' and
- `background_transparent_valid' fields.
- (x_build_heuristic_mask): Use IMAGE_BACKGROUND instead of
- calculating it here. Set IMG's background_transparent field.
- (enum xpm_keyword_index): Add XPM_BACKGROUND.
- (enum png_keyword_index): Add PNG_BACKGROUND.
- (enum jpeg_keyword_index): Add JPEG_BACKGROUND.
- (enum tiff_keyword_index): Add TIFF_BACKGROUND.
- (enum gif_keyword_index): Add GIF_BACKGROUND.
- (enum gs_keyword_index): Add GS_BACKGROUND.
- (pbm_load, png_load, jpeg_load, tiff_load, gif_load):
- Pre-calculate image background color where necessary.
- * xterm.c (x_setup_relief_colors): Use `IMAGE_BACKGROUND' and
- `IMAGE_BACKGROUND_TRANSPARENT' to calculate the correct background
- color to use for image glyph reliefs.
-
-2001-10-24 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_draw_glyphs): Don't check for cursor overwriting
- in full-width rows.
-
- * xterm.c (XTset_vertical_scroll_bar) [!USE_TOOLKIT_SCROLL_BARS]:
- Fix clearing of area not covered by scroll bar.
-
-2001-10-24 Pavel Jan,Am(Bk <[email protected]>
-
- * xterm.c (x_insert_glyphs): Remove unused variables `real_end'
- and `real_start'.
- (x_draw_image_foreground): Remove unused variables `mask' and `xgcv'.
- (glyph_rect): Remove unused variable `area'.
-
-2001-10-24 Gerd Moellmann <[email protected]>
-
- * xdisp.c: Change #ifdef GLYPH_DEBUG to #if.
-
- * xdisp.c (try_window_reusing_current_matrix): Use row_containing_pos.
- (row_containing_pos): Take additional argument DY.
- Treat rows ending in middle of char differently.
- (display_line): Handle tabs on window systems differently.
-
- * xterm.c, w32term.c (fast_find_position): Call row_containing_pos
- with additional argument.
-
- * dispextern.h (row_containing_pos): Adjust prototype.
-
- * xdisp.c (inhibit_try_window_id, inhibit_try_window_reusing)
- (inhibit_try_cursor_movement) [GLYPH_DEBUG]: New variables.
- (try_window_id, try_window_reusing_current_matrix)
- (try_cursor_movement) [GLYPH_DEBUG]: Don't run if inhibited.
- (syms_of_xdisp) [GLYPH_DEBUG]: DEFVAR_BOOL the variables.
-
-2001-10-24 Pavel Jan,Am(Bk <[email protected]>
-
- * xmenu.c: Spell the name of Emacs properly (GNU Emacs instead of
- gnuemacs).
- (HAVE_BOXES): Fix typo in comment.
- (push_menu_pane): Fix typo in comment.
-
- * xdisp.c (display_prop_string_p): Remove unused local declaration
- of `Qwhen'.
- (single_display_prop_string_p): Remove unused local declarations
- of `Qwhen' and `Qmargin'.
- (string_buffer_position): Remove unused variable `around'.
- (store_frame_title): Remove unused variable `width'.
-
- * window.c: Don't define max.
- (coordinates_in_window): Remove unused variable `uy'.
-
- * widget.c: Don't define max.
-
- * process.c: Don't define max.
- (create_process): Remove unused variable `buffer'.
-
-2001-10-23 Gerd Moellmann <[email protected]>
-
- * xfaces.c (Finternal_set_lisp_face_attribute): Fix compilation error.
-
-2001-10-23 Eli Zaretskii <[email protected]>
-
- * xfaces.c (Finternal_set_lisp_face_attribute)
- [HAVE_WINDOW_SYSTEM]: Don't do anything for QCfont unless the
- frame is on a windowed display.
-
-2001-10-23 Gerd Moellmann <[email protected]>
-
- * dispnew.c (sync_window_with_frame_matrix_rows):
- Fix handling of windows which aren't full-width, fix handling
- of marginal areas.
-
- * lread.c (syms_of_lread) <recursive-load-depth-limit>: Raise to 50.
-
-2001-10-23 Andreas Schwab <[email protected]>
-
- * m/macppc.h [LINUX]: Undef LD_SWITCH_SYSTEM_TEMACS and override
- LD_SWITCH_MACHINE_TEMACS with "-Xlinker -znocombreloc".
-
-2001-10-23 Gerd Moellmann <[email protected]>
-
- * xterm.c (x_draw_glyphs): Remove parameters READ_START and
- REAL_END. Notice if cursor gets overwritten.
- (notice_overwritten_cursor): Take X positions as parameters.
- (x_draw_phys_cursor_glyph): Save state of w->phys_cursor_on_p
- around call to x_draw_glyphs.
-
-2001-10-23 Pavel Jan,Am(Bk <[email protected]>
-
- * syntax.c (modify-syntax-entry): Fix argument names (use CHAR
- instead of C) and usage.
-
- * editfns.c (char-to-string): Fix argument names (use CHAR instead
- of C) and usage.
-
- * xfns.c (Fx_show_tip): Remove unused variables `buffer', `top',
- `left', `max_width' and `max_height'.
-
-2001-10-23 Gerd Moellmann <[email protected]>
-
- * xdisp.c (display_line): For a tab continued to the next line,
- set row's ends_in_middle_of_char_p.
-
-2001-10-22 Gerd Moellmann <[email protected]>
-
- * xdisp.c (display_line): Fix computation of continuation lines
- width for TABs.
-
-2001-10-22 Pavel Jan,Am(Bk <[email protected]>
-
- * xdisp.c (build_desired_tool_bar_string): Remove unused variable
- `Qlaplace'.
-
- * fileio.c: Remove unused code.
-
-2001-10-22 Miles Bader <[email protected]>
-
- * lisp.h (DEFVAR_LISP, DEFVAR_LISP_NOPRO, DEFVAR_BOOL)
- (DEFVAR_INT, DEFVAR_PER_BUFFER, DEFVAR_KBOARD):
- Remove `DOC_STRINGS_IN_COMMENTS' cases.
-
-2001-10-21 Jason Rumney <[email protected]>
-
- * w32term.c (x_erase_phys_cursor): Remove inverse_p again.
-
-2001-10-21 Eli Zaretskii <[email protected]>
-
- * mocklisp.c (Fml_if, Fml_provide_prefix_argument)
- (Finsert_string): Avoid the multi-line string literals warning.
-
-2001-10-22 Miles Bader <[email protected]>
-
- * doc.c (Vhelp_manyarg_func_alist): Variable removed.
- (Fdocumentation): Don't use it.
- (syms_of_doc): Don't initialize it.
-
- * keyboard.c (Ftrack_mouse): Add usage: string to doc string.
- * print.c (Fwith_output_to_temp_buffer): Likewise.
- * window.c (Fsave_window_excursion): Likewise.
- * editfns.c (Fsave_excursion, Fsave_current_buffer)
- (Fsave_restriction): Likewise.
- * eval.c (Frun_hooks, Frun_hook_with_args)
- (Frun_hook_with_args_until_failure)
- (Frun_hook_with_args_until_success, Ffuncall, For, Fand, Fif)
- (Fcond, Fprogn, Fprog1, Fprog2, Fsetq, Fquote, Ffunction, Fdefun)
- (Fdefmacro, Fdefvar, Fdefconst, FletX, Flet, Fwhile, Fcatch)
- (Funwind_protect, Fcondition_case): Likewise.
- * coding.c (Ffind_operation_coding_system): Likewise.
- * keyboard.c (Ftrack_mouse): Likewise.
-
-2001-10-21 Miles Bader <[email protected]>
-
- * fns.c (Fappend, Fconcat, Fvconcat, Fnconc, Fwidget_apply)
- (Fmake_hash_table): Add usage: string to doc string.
- * editfns.c (Finsert, Finsert_and_inherit, Finsert_before_markers)
- (Fmessage, Fmessage_box, Fmessage_or_box, Fpropertize, Fformat)
- (Fencode_time, Finsert_and_inherit_before_markers): Likewise.
- * mocklisp.c (Finsert_string, Fml_if, Fml_provide_prefix_argument)
- (Fml_prefix_argument_loop): Likewise.
-
-2001-10-21 Pavel Jan,Am(Bk <[email protected]>
-
- * fileio.c (Finsert_file_contents): Remove unused variable `gap_size'.
-
- * sysdep.c (init_sys_modes): Change doc-string comments to `new
- style' [w/`doc:' keyword].
-
- * data.c, fileio.c, indent.c, print.c, search.c, sound.c,
- * sunfns.c, textprop.c, undo.c, xselect.c: Change doc-string
- comments to `new style' [w/`doc:' keyword].
-
-2001-10-21 Jason Rumney <[email protected]>
-
- * w32fns.c (Fx_file_dialog): Pass a filter to GetOpenFileName.
-
- * w32term.c (remember_mouse_glyph): New function.
- (w32_mouse_position): Use it.
- (note_mouse_movement): If the mouse moved off the glyph, remember
- its new position.
-
- * w32term.h (struct w32_output): Correct spelling of x_compatible.
- (w32_display_info): Add mouse_face_overlay.
-
- * w32term.c (notice_overwritten_cursor): Renamed from
- note_overwritten_text_cursor. Rewritten to take glyph widths into
- account.
- (x_y_to_hpos_vpos): Add parameter BUFFER_ONLY_P.
- (fast_find_string_pos): New function.
- (fast_find_position): Return the correct vpos. Add parameter
- STOP. In the final row, stop before glyphs having STOP as object.
- Don't consider glyphs that are not from a buffer.
- (fast_find_position) [0]: Add a presumably more correct version
- for after 21.1.
- (expose_window_tree, expose_frame): Don't compute intersections here.
- (expose_window): Do it here instead.
- (expose_window_tree, expose_window, expose_line): Return 1 when
- overwriting mouse-face.
- (expose_window): If W is the window currently being updated, mark
- the frame garbaged.
- (expose_frame): If mouse-face was overwritten, redo it.
- (x_use_underline_position_properties): New variable.
- (syms_of_xterm): DEFVAR_BOOL it.
- (x_draw_glyph_string): Add comment to use it in future.
- (x_draw_glyph_string): Restore clipping after drawing box.
- Fix a computation of the underline position.
- (w32_get_glyph_string_clip_rect): Minor cleanup.
- (x_fill_stretch_glyph_string): Remove an assertion.
- (x_produce_glyphs): Don't convert multibyte characters
- to unibyte characters in unibyte buffers.
- (cursor_in_mouse_face_p): New function.
- (x_draw_stretch_glyph_string): Use it to choose a different GC
- when drawing a cursor within highlighted text. Don't draw
- background again if it has already been drawn.
- (x_draw_glyph_string_box): Don't draw a full-width
- box just because the glyph row's full_width_p flag is set.
- (x_draw_glyphs): Fix computation of rightmost x for
- full-width rows.
- (x_dump_glyph_string): Put in #if GLYPH_DEBUG.
- (w32_draw_relief_rect): Extend left shadow to the bottom and left;
- change bottom shadow accordingly. Some cleanup.
- (x_update_window_end): Handle overwritten mouse face
- also for tool bar windows.
- (show_mouse_face): Set the glyph row's mouse_face_p flag also when
- DRAW is DRAW_IMAGE_RAISED.
- (clear_mouse_face): Return 1 if text with mouse face was
- actually redrawn. Make the function static.
- Reset dpyinfo->mouse_face_overlay otherwise note_mouse_highlight might
- optimize away highlighting if we pass over that same overlay again.
- (note_mouse_highlight): Call mouse_face_overlay_overlaps
- to detect a case where we have to highlight a different region
- despite not having left the currently highlighted region.
- Set mouse_face_overlay in the x_display_info. Avoid changing the
- mouse pointer shape when show_mouse_face has already done it, or
- there is no need. Handle mouse-face and help-echo in strings.
- (glyph_rect): New function.
- (w32_mouse_position): Use it to raise the threshold for mouse
- movement event generation.
- (w32_initialize_display_info): Initialize the x_display_info's
- mouse_face_overlay.
- (w32_set_vertical_scroll_bar): Don't clear a zero height
- or width area.
- (w32_set_vertical_scroll_bar, x_scroll_bar_create): Don't configure
- a widget to zero height.
-
- * w32menu.c (single_submenu, w32_menu_show) [!HAVE_MULTILINGUAL_MENU]:
- Protect unibyte strings created by replacing their multibyte
- equivalents in menu_items.
- (w32_menu_show): Don't overwrite an item's name with its key
- description in case the description is a multibyte string.
- (single_submenu): Some cleanup.
-
- * w32fns.c (x_laplace_read_row, x_laplace_write_row): Removed.
- (postprocess_image): New function.
- (lookup_image): Call it for all image types except PostScript.
- (x_kill_gs_process): Call postprocess_image.
- (tiff_error_handler, tiff_warning_handler): New functions.
- (tiff_load): Install them as handlers.
- (x_kill_gs_process): Recognize if someone has cleared the image
- cache under us.
- (valid_image_p): Protect better against invalid image
- specifications. Previous code could signal an error.
- (Fx_hide_tip, Fshow_tip): Doc fix.
- (Fv_max_tooltip_size): New variable.
- (syns_of_xfns): DEFVAR_LISP it.
- (Fx_show_tip): Add parameter TEXT. Set the tip frame's root
- window buffer to *tip* right after creating the frame. Set frame's
- window_width. Use a maximum tooltip size specified by
- Vx_max_tooltip_size, if that has valid contents.
- (compute_tip_xy): Add parameters WIDTH and HEIGHT.
- Make sure the tooltip is completely visible.
- (x_create_tip_frame): Set tooltip buffer's truncate-lines to nil.
- (Fx_create_frame): Adjust the frame's height for presence
- of the tool bar before calling x_figure_window_size.
- (x_set_tool_bar_lines): Clear the tool bar window's current matrix
- when the window gets smaller.
- (x_set_foreground_color): Set frame's cursor_pixel.
- (x_set_foreground_color, x_set_background_color): Cleaned up.
- (x_set_font): Handle case of x_new_fontset returning the same name
- as before, although there was a change in fontsets.
-
-2001-10-21 Miles Bader <[email protected]>
-
- * data.c (Fplus, Fminus, Fmax, Ftimes, Fquo, Flogand, Flogior)
- (Flogxor): Add usage: string to doc string.
- * charset.c (Fstring): Likewise.
- * callproc.c (Fcall_process_region, Fcall_process): Likewise.
- * alloc.c (Fmake_byte_code, Fvector, Flist): Likewise.
-
-2001-10-21 Pavel Jan,Am(Bk <[email protected]>
-
- * buffer.c: Reindent DEFUNs and DEFVARs with doc: keywords.
-
- * alloc.c: Reindent DEFUNs with doc: keywords.
-
- * abbrev.c (Finsert_abbrev_table_description): Reindent.
-
- * frame.c: Change doc-string comments to `new style' [w/`doc:'
- keyword].
-
-See ChangeLog.9 for earlier changes.
+See ChangeLog.10 for earlier changes.
;; Local Variables:
;; coding: iso-2022-7bit
;; add-log-time-zone-rule: t
;; End:
- Copyright (C) 2001, 2002, 2003, 2004, 2005,
- 2006, 2007 Free Software Foundation, Inc.
+ Copyright (C) 2007 Free Software Foundation, Inc.
This file is part of GNU Emacs.
@@ -29074,4 +2448,4 @@ See ChangeLog.9 for earlier changes.
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
-;;; arch-tag: 5dcc435f-4038-4141-b3bf-5be51cd76bd4
+;; arch-tag: dfb6ad96-1550-4905-9e53-d2059ee84c40
diff --git a/src/ChangeLog.10 b/src/ChangeLog.10
new file mode 100644
index 0000000000..f0e0f191b9
--- /dev/null
+++ b/src/ChangeLog.10
@@ -0,0 +1,27934 @@
+2007-04-24 Chong Yidong <[email protected]>
+
+ * Branch for 22.1.
+
+2007-04-24 Chong Yidong <[email protected]>
+
+ * xdisp.c (redisplay_window): Use BEG_UNCHANGED and END_UNCHANGED
+ values of the actual window.
+
+2007-04-23 Richard Stallman <[email protected]>
+
+ * process.c (Fstart_process): Doc fix.
+
+2007-04-23 Eli Zaretskii <[email protected]>
+
+ * process.c (Fstart_process): Doc fix.
+
+2007-04-22 Richard Stallman <[email protected]>
+
+ * abbrev.c (Fdefine_abbrev): Doc fix.
+
+ * keymap.c (Fdefine_key): Minor doc fix.
+
+2007-04-21 Glenn Morris <[email protected]>
+
+ * keymap.c (Fdefine_key): Fix info ref in doc string.
+
+2007-04-20 Glenn Morris <[email protected]>
+
+ * sysdep.c (init_system_name): Don't accept localhost.localdomain.
+
+2007-04-19 Juanma Barranquero <[email protected]>
+
+ * minibuf.c (Fminibuffer_contents, Fminibuffer_contents_no_properties)
+ (Fminibuffer_completion_contents, Fdelete_minibuffer_contents):
+ Doc fixes.
+
+2007-04-16 Chong Yidong <[email protected]>
+
+ * dispnew.c (adjust_frame_glyphs_for_frame_redisplay):
+ Set garbaged flag in presence of window margins.
+ (showing_window_margins_p): New function.
+
+ * xdisp.c (cursor_row_p): Only end row on newline if it's a
+ display string. Suggested by Lennart Borgman.
+
+2007-04-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * alloc.c (mem_insert): Set min_heap_address and max_heap_address
+ if they are not yet initialized.
+
+2007-04-15 Chong Yidong <[email protected]>
+
+ * xdisp.c (redisplay_window): When deciding whether or not to
+ recenter, don't use the reset values of BEG_UNCHANGED and
+ END_UNCHANGED.
+
+2007-04-13 Kim F. Storm <[email protected]>
+
+ * buffer.c (Fkill_buffer): gcpro BUF during kill_buffer_processes
+ and check that buffer is still alive upon return.
+
+2007-04-13 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c [!TARGET_API_MAC_CARBON]: Include Displays.h.
+ (mac_screen_config_changed): New variable.
+ (mac_handle_dm_notification, init_dm_notification_handler)
+ (mac_get_screen_info): New functions.
+ [MAC_OS8] (main): Call init_dm_notification_handler.
+ (mac_initialize) [MAC_OSX]: Likewise.
+ (XTread_socket): Call mac_get_screen_info if screen config changed.
+ (mac_initialized): Make static.
+ (mac_initialize_display_info): Remove function.
+ (mac_term_init): Call mac_get_screen_info. Add partial contents of
+ mac_initialize_display_info.
+
+2007-04-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (xrm_get_preference_database, Fmac_get_preference)
+ [TARGET_API_MAC_CARBON]: Use CFPreferencesAppSynchronize.
+
+ * macterm.c [TARGET_API_MAC_CARBON] (mac_post_mouse_moved_event):
+ Use GetGlobalMouse instead of GetMouse and LocalToGlobal.
+ (mac_initialize_display_info) [MAC_OSX]: Use CGRectZero.
+ (mac_initialize_display_info) [!MAC_OSX]: dpyinfo->height and
+ dpyinfo->width are those of whole screen.
+
+2007-04-10 Chong Yidong <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Don't decrement
+ glyph pointer before start of glyph row.
+
+2007-04-09 YAMAMOTO Mitsuharu <[email protected]>
+
+ * s/darwin.h (__restrict, struct kboard): Remove outdated workarounds.
+ (C_SWITCH_SYSTEM): Remove `-I../mac/src'.
+
+2007-04-09 Martin Rudalics <[email protected]>
+
+ * indent.c (Fmove_to_column): Set next_boundary with correct start pt.
+
+2007-04-08 Richard Stallman <[email protected]>
+
+ * xdisp.c (syms_of_xdisp) <message-log-max>: Default 100.
+
+2007-04-07 Chong Yidong <[email protected]>
+
+ * editfns.c (Ftranspose_regions): Validate interval before setting
+ text properties.
+
+2007-04-03 Eli Zaretskii <[email protected]>
+
+ * emacs.c (main): Fix instructions for building Emacs for profiling.
+
+2007-04-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_update_menubar): Call g_list_next after moving
+ menu bar item.
+
+2007-04-02 Juanma Barranquero <[email protected]>
+
+ * print.c (Fprin1_to_string): Use macro SPECPDL_INDEX.
+
+2007-04-01 Chong Yidong <[email protected]>
+
+ * keymap.c (Fcommand_remapping): New optional argument.
+ (where_is_internal): Use new keymaps argument.
+ (Fkey_binding): Caller changed.
+
+ * keyboard.c (command_loop_1): Caller changed.
+
+2007-03-31 Eli Zaretskii <[email protected]>
+
+ * window.c (Fget_lru_window): Doc fix.
+
+2007-03-30 Chong Yidong <[email protected]>
+
+ * undo.c (Fprimitive_undo): Give clearer error message when trying
+ to change text properties outside accessible part of buffer.
+
+2007-03-29 Kim F. Storm <[email protected]>
+
+ * process.c (wait_reading_process_output) [HAVE_PTYS]:
+ When EIO happens, clear channel from descriptor masks before raising
+ SIGCHLD signal to avoid busy loop between read and sigchld_handler.
+ (sigchld_handler): Remove sleep (2007-03-11 & 2007-03-26 changes).
+
+2007-03-29 Juanma Barranquero <[email protected]>
+
+ * buffer.c (Fset_buffer_major_mode): Check that BUFFER is valid.
+
+ * process.c (Fformat_network_address): Return nil when the
+ argument vector contains invalid values.
+
+2007-03-28 YAMAMOTO Mitsuharu <[email protected]>
+
+ * gmalloc.c [HAVE_GTK_AND_PTHREAD]: Define USE_PTHREAD.
+ [USE_PTHREAD]: Include pthread.h.
+ (malloc_init_once_control, _malloc_mutex) [USE_PTHREAD]: New variables.
+ (malloc_initialize_1): New function created from __malloc_initialize.
+ (__malloc_initialize): Use it.
+ (LOCK, UNLOCK): New macros to make malloc etc. thread safe.
+ (_malloc_internal, _free_internal, _realloc_internal): Use them.
+
+ * lread.c (readchar): Extend BLOCK_INPUT block to ferror/clearerr.
+
+2007-03-27 Juanma Barranquero <[email protected]>
+
+ * process.c (Fformat_network_address): Make args array big enough
+ to format IPv6 addresses.
+
+2007-03-27 Glenn Morris <[email protected]>
+
+ * m/hp800.h: Restore HP-UX support (removed 2007-01-29).
+
+2007-03-26 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (Fx_display_mm_height, Fx_display_mm_width): Scale whole
+ screen size in pixels by millimeters per pixel of main display.
+
+ * macselect.c (get_scrap_target_type_list, x_own_selection):
+ Move assignments outside predicate macros.
+ (Vselection_converter_alist): Doc fix.
+
+ * macterm.c (create_text_encoding_info_alist): Move assignments
+ outside predicate macros.
+ (mac_initialize_display_info) [MAC_OSX]: dpyinfo->height and
+ dpyinfo->width are those of whole screen.
+
+2007-03-26 Sam Steingold <[email protected]>
+
+ * process.c (sigchld_handler): Delay by 1ms instead of 1s to
+ alleviate sluggishness (the original problem is still fixed).
+
+2007-03-25 Kim F. Storm <[email protected]>
+
+ * intervals.c (merge_properties): Use explicit loop instead of
+ Fplist_member to avoid QUIT. Don't use Fcdr.
+ (intervals_equal): Likewise. Rewrite loop to perform length check
+ on the fly rather than calling Flength. Don't use Fcar.
+
+2007-03-24 Eli Zaretskii <[email protected]>
+
+ * editfns.c (Fgoto_char): Doc fix.
+
+ * indent.c (Findent_to): Doc fix.
+
+2007-03-24 Chong Yidong <[email protected]>
+
+ * editfns.c (Ftranspose_regions): Use set_text_properties_1
+ instead of Fset_text_properties to avoid GC. Signal after change.
+
+2007-03-24 Eli Zaretskii <[email protected]>
+
+ * xfns.c (Fx_show_tip): Doc fix.
+
+ * macfns.c (Fx_show_tip): Doc fix.
+
+ * w32fns.c (Fx_show_tip): Doc fix.
+
+2007-03-23 Kim F. Storm <[email protected]>
+
+ * intervals.c (merge_properties, intervals_equal):
+ Use Fplist_member instead of Fmemq to find properties.
+
+2007-03-23 Glenn Morris <[email protected]>
+
+ * unexhp9k800.c: Restore file with clarified legal status.
+ * m/sr2k.h: Restore since dependency unexhp9k800.c is restored.
+
+2007-03-22 Chong Yidong <[email protected]>
+
+ * widget.c (EmacsFrameSetCharSize): Catch X errors.
+
+2007-03-22 Kenichi Handa <[email protected]>
+
+ * fileio.c (Fcopy_file): Call barf_or_query_if_file_exists with
+ non-encoded file name.
+ (Frename_file): Likewise.
+ (Fadd_name_to_file): Likewise.
+ (Fmake_symbolic_link): Likewise.
+
+2007-03-20 YAMAMOTO Mitsuharu <[email protected]>
+
+ * Makefile.in (alloca.o, gtkutil.o): Depend on systime.h.
+ (dired.o, editfns.o, fileio.o, msdos.o): Depend on atimer.h.
+ (dosfns.o, window.o, fns.o, macselect.o): Depend on atimer.h and
+ systime.h.
+ (term.o, print.o, lread.o): Depend on blockinput.h, atimer.h, and
+ systime.h.
+ (macfns.o): Remove duplicate dependency on systime.h.
+
+ * dispnew.c (Fopen_termscript): Add BLOCK_INPUT around fclose.
+ (Fsend_string_to_terminal): Add BLOCK_INPUT around fwrite.
+
+ * fileio.c (do_auto_save_unwind): Add BLOCK_INPUT around fclose.
+ (Fdo_auto_save): Add BLOCK_INPUT around fwrite.
+
+ * keyboard.c (record_char): Add BLOCK_INPUT around fwrite.
+ (Fopen_dribble_file): Add BLOCK_INPUT around fclose.
+
+ * lread.c: Include blockinput.h.
+ (readchar, Fget_file_char): Add BLOCK_INPUT around getc.
+ (unreadchar): Add BLOCK_INPUT around ungetc.
+ (load_unwind): Add BLOCK_INPUT around fclose.
+
+ * print.c: Include blockinput.h.
+ (Fredirect_debugging_output): Add BLOCK_INPUT around fclose.
+
+ * process.c (Fmake_network_process) [HAVE_GETADDRINFO]:
+ Clear immediate_quit before calling freeaddrinfo.
+ Add BLOCK_INPUT around freeaddrinfo.
+
+ * term.c: Include blockinput.h.
+ (write_glyphs, insert_glyphs): Add BLOCK_INPUT around fwrite.
+
+2007-03-19 Richard Stallman <[email protected]>
+
+ * keyboard.c (NUM_RECENT_KEYS): Bump up to 300.
+
+ * buffer.c (syms_of_buffer): Doc fix.
+
+2007-03-18 Chong Yidong <[email protected]>
+
+ * image.c (pbm_load): Signal error for invalid image size.
+
+2007-03-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (note_mouse_movement): Don't return immediately for
+ LeaveNotify case.
+
+ * macmenu.c (popup_activated_flag): New variable.
+ (x_activate_menubar, mac_menu_show): Set it during menu tracking.
+ (popup_activated): New function.
+
+ * xdisp.c (redisplay_internal, note_mouse_highlight):
+ Check popup_activated for MAC_OS.
+
+2007-03-17 Juanma Barranquero <[email protected]>
+
+ * buffer.c (syms_of_buffer) <buffer-display-table>: Doc fix.
+ Reported by Nikolaj Schumacher <[email protected]>.
+
+2007-03-17 Richard Stallman <[email protected]>
+
+ * dired.c (file_name_completion): gcpro NAME.
+
+2007-03-17 Chong Yidong <[email protected]>
+
+ * xdisp.c (try_window_id): Increment matrix positions if the
+ buffer's byte count has increased, but not the character count.
+
+2007-03-12 Andreas Schwab <[email protected]>
+
+ * lisp.h: Declare check_obarray.
+
+ * process.c (Fdelete_process): Properly handle deletion of first
+ element of deleted_pid_list.
+ (create_process): Declare pid as pid_t.
+
+2007-03-12 Kim F. Storm <[email protected]>
+
+ * process.c (sigchld_handler): Change type of pid to pid_t.
+ Scan deleted_pid_list explicitly to avoid using Fmember which don't
+ know about mark bits and make_fixnum_or_float which may malloc.
+ Reported by Andreas Schwab.
+
+ * keyboard.c (read_key_sequence): Store original event into keybuf
+ when replaying sequence with local keymap(s) from string.
+
+2007-03-12 Glenn Morris <[email protected]>
+
+ * editfns.c (Fdecode_time, Fencode_time): Doc fix ("daylight
+ savings" to "daylight saving").
+
+2007-03-11 Sam Steingold <[email protected]>
+
+ * process.c (sigchld_handler): Sleep before wait3 to avoid a busyloop.
+
+2007-03-11 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (Fx_server_vendor): Change vendor string to "Apple Inc.".
+
+2007-03-10 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c [USE_CARBON_EVENTS] (mac_handle_mouse_event):
+ Ignore mouse wheel movement on title bar or tool bar.
+
+2007-03-10 Chong Yidong <[email protected]>
+
+ * keyboard.c (help_form_saved_window_configs): New var.
+ (read_char_help_form_unwind): New function.
+ (read_char): Don't restore window configuration if a mouse click
+ arrives while the help form is being displayed.
+
+2007-03-10 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Don't automatically select a new window
+ start for a contination line during mouse-click.
+
+2007-03-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): Ignore buttons > 3 for the tool bar.
+
+2007-03-09 Juanma Barranquero <[email protected]>
+
+ * keymap.c (Fdescribe_buffer_bindings): Check that BUFFER is valid.
+
+2007-03-08 Richard Stallman <[email protected]>
+
+ * keyboard.c (syms_of_keyboard): Doc fix.
+
+2007-03-08 Chong Yidong <[email protected]>
+
+ * minibuf.c (Ftry_completion): Don't short circuit if
+ completion-ignore-case is non-nil.
+
+2007-03-07 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (mac_set_scroll_bar_width, mac_frame_parm_handlers):
+ Undo 2006-03-06 changes.
+
+ * macterm.c (XTset_vertical_scroll_bar) [MAC_OSX]: Don't show scroll
+ bar if its width is smaller than that of Aqua small scroll bar.
+
+2007-03-07 Stefan Monnier <[email protected]>
+
+ * minibuf.c (read_minibuf): Bind inhibit-read-only a bit longer so as
+ to handle correctly prompts with read-only property.
+
+2007-03-06 Jan Dj,Ad(Brv <[email protected]>
+
+ * sound.c (wav_play): Check header->data_length to see how much we
+ shall read.
+ (alsa_period_size): Convert ALSA period size in frames to bytes.
+ (alsa_write): Return if frames is zero.
+
+2007-03-06 Kenichi Handa <[email protected]>
+
+ * xselect.c (Vselection_coding_system): Documentation improved.
+
+2007-03-05 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (x_scroll_bar_create, XTread_socket): Replace #if
+ USE_TOOLKIT_SCROLL_BARS with #ifdef USE_TOOLKIT_SCROLL_BARS.
+ (x_set_window_size): Call SET_FRAME_GARBAGED. Clear window if
+ internal border width has changed.
+
+ * macterm.h (struct mac_output): New member `internal_border_width'.
+
+2007-03-04 Richard Stallman <[email protected]>
+
+ * window.c (Fdisplay_buffer): Doc fix.
+
+2007-03-03 Glenn Morris <[email protected]>
+
+ * Makefile.in: Don't clear out LIB_X11_LIB, since XFT_LIBS does
+ not include -lX11 on Solaris.
+
+2007-03-02 Stuart D. Herring <[email protected]>
+
+ * keymap.c (Fkey_binding): Don't consider one-element lists as events.
+
+2007-03-01 Kenichi Handa <[email protected]>
+
+ * process.c (send_process_object): Check the process status and
+ signal an error if something is wrong.
+
+2007-02-28 Chong Yidong <[email protected]>
+
+ * insdel.c (Fcombine_after_change_execute): Return nil if
+ combine_after_change_buffer has been invalidated.
+
+2007-02-25 Dan Nicolaescu <[email protected]>
+
+ * m/xtensa.h: New file.
+
+2007-02-24 Nick Roberts <[email protected]>
+
+ * .gdbinit (xprintstr): Ensure GDB (> 6.6) prints symbol name
+ as strings and not character arrays.
+
+2007-02-24 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_drag)
+ (x_set_toolkit_scroll_bar_thumb): Add bar->min_handle as margin to
+ scroll bar handle size in order to avoid `scroll backward' problem.
+ (x_scroll_bar_create, XTset_vertical_scroll_bar)
+ [USE_TOOLKIT_SCROLL_BARS]: Initialize bar->min_handle.
+
+ * macterm.h (struct scroll_bar) [USE_TOOLKIT_SCROLL_BARS]:
+ New member `min_handle'.
+
+2007-02-23 Kim F. Storm <[email protected]>
+
+ * print.c (print): Reset print_number_index if Vprint_number_table
+ is nil.
+
+2007-02-23 Eli Zaretskii <[email protected]>
+
+ * w32.c (stat, get_long_basename, is_unc_volume): Use _mbspbrk
+ instead of strpbrk.
+
+2007-02-23 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (mac_menu_show): Call unbind_to early. Use variable
+ `menu_item_selection' as in W32 version.
+ [TARGET_API_MAC_CARBON] (mac_handle_dialog_event): Add explicit
+ braces to avoid ambiguous `else'.
+
+ * macterm.c (mac_display_info_for_display): Remove function.
+ (mac_flush_display_optional) [USE_CG_DRAWING]: New function.
+ (x_redisplay_interface) [USE_CG_DRAWING]: Set it as handler for
+ flush_display_optional.
+ [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_press):
+ New argument MOUSE_POS. All uses changed. Set bar->dragging to
+ negative integer if scroll bar handle is pressed.
+ [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_release):
+ Negative bar->dragging means scroll bar handle is not dragged.
+ [USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_handle_drag): Get initial
+ offset of scroll bar handle from negative bar->dragging.
+ (XTread_socket) [USE_TOOLKIT_SCROLL_BARS]: Modifiers for scroll
+ bar click is compared against mapped one. Set down/up_modifier
+ for scroll bar click event with control key.
+
+ * macterm.h (x_display_info_for_display): Remove extern.
+ (SCROLL_BAR_UNPACK, SET_SCROLL_BAR_CONTROL_HANDLE): Don't limit
+ value to be unpacked to 32-bit on LP64 model.
+
+2007-02-23 Kenichi Handa <[email protected]>
+
+ * process.c (send_process_object_unwind): New function.
+ (send_process_object): New function.
+ (Fprocess_send_region): Call send_process_object.
+ (Fprocess_send_string): Likewise.
+
+2007-02-22 Jason Rumney <[email protected]>
+
+ * w32menu.c (w32_menu_show): Mark the frame's menu as inactive
+ when popup menu finishes.
+
+ * w32fns.c (menubar_in_use): New flag.
+ (w32_wnd_proc) <WM_INITMENU, WM_EXITMENULOOP, WM_TIMER, WM_COMMAND>:
+ Use it.
+
+ * w32menu.c (Fx_popup_menu): Don't free menu strings here.
+ (w32_menu_show): Do it here instead.
+
+ * w32fns.c (w32_wnd_proc) <WM_INITMENU>: Set menubar_active frame
+ parameter.
+
+ * w32menu.c (current_popup_menu): Make available globally.
+ (menubar_selection_callback): Free menu strings before pushing the
+ menu event into the keyboard buffer. Remove menu_command_in_progress.
+
+ * w32fns.c (current_popup_menu): Use from w32menu.c.
+ (w32_wnd_proc) <WM_EXITMENULOOP, WM_TIMER>: Use menubar_active
+ and current_popup_menu to determine whether a menubar menu has
+ been cancelled.
+
+ * w32term.h (w32_output): Remove menu_command_in_progress.
+
+2007-02-22 Kim F. Storm <[email protected]>
+
+ * dispnew.c (update_frame, update_single_window): Set force_p here if
+ redisplay_dont_pause is set or Vredisplay_preemption_period is nil...
+ (update_window, update_frame_1): ... instead of here.
+ (update_text_area): Clear mouse face on header lines.
+
+2007-02-21 Kim F. Storm <[email protected]>
+
+ * minibuf.c (Fassoc_string): Doc fix. Allow symbol for KEY too.
+
+2007-02-21 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (WINDOW_RESOURCE, TERM_WINDOW_RESOURCE): Remove macros.
+ [USE_MAC_TSM] (mac_handle_text_input_event): Remove unused variable
+ `mapped_modifiers'.
+ (XTread_socket) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1020]: Use Keyboard
+ Layout Services routines to get current Unicode keyboard layout.
+
+2007-02-20 Chong Yidong <[email protected]>
+
+ * frame.c (x_set_screen_gamma): Apply gamma value to the frame's
+ bgcolor.
+
+2007-02-19 Kim F. Storm <[email protected]>
+
+ * minibuf.c (Fassoc_string): Allow symbols as keys.
+
+ * w32term.c (w32_set_scroll_bar_thumb): Don't resize scroll-bar
+ handle while dragging, except when we get close to eob.
+ Fix position and size calculations so we don't scroll backwards
+ just by clicking on the handle.
+
+2007-02-17 YAMAMOTO Mitsuharu <[email protected]>
+
+ * Makefile.in (${emacsapp}Contents/Resources/Emacs.rsrc)
+ [HAVE_CARBON]: Remove target.
+ (macosx-app) [HAVE_CARBON]: Don't depend on it.
+
+2007-02-17 Juanma Barranquero <[email protected]>
+
+ * callproc.c (syms_of_callproc) <doc-directory>:
+ <configure-info-directory>:
+ (Fgetenv_internal): Fix typos in docstrings.
+
+ * doc.c (Fsubstitute_command_keys): Fix typo in docstring.
+
+2007-02-16 Andreas Schwab <[email protected]>
+
+ * frame.c (Fmodify_frame_parameters): Return a value.
+
+ * editfns.c (Fformat): Add support for '+' flag.
+ * doprnt.c (doprnt1): Likewise. Fix overflow checking.
+
+2007-02-14 Chong Yidong <[email protected]>
+
+ * s/umips.h: Unused file removed.
+
+2007-02-14 Juanma Barranquero <[email protected]>
+
+ * xfaces.c (Fcolor_distance): Don't continue checking a color for
+ errors after it has been correctly parsed as an RGB list.
+
+2007-02-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (do_ewmh_fullscreen): Also check for _NET_WM_STATE_FULLSCREEN.
+
+2007-02-13 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (Fx_focus_frame): Move current process to foreground if
+ it is not.
+ [TARGET_API_MAC_CARBON] (Fx_file_dialog): Replace #if MAC_OSX with
+ #ifdef MAC_OSX.
+ (Fmac_set_font_panel_visible_p) [USE_MAC_FONT_PANEL]: Rename from
+ Fmac_set_font_panel_visibility. All uses changed. Rename argument
+ VISIBLE to FLAG.
+
+ * macterm.c (MakeMeTheFrontProcess) [MAC_OSX]: Remove function.
+ (mac_initialize) [MAC_OSX]: Call SetFrontProcess instead of
+ MakeMeTheFrontProcess.
+
+2007-02-12 Chong Yidong <[email protected]>
+
+ * frame.c (x_set_screen_gamma): Clear face cache.
+
+2007-02-11 Juanma Barranquero <[email protected]>
+
+ * buffer.c (Fgenerate_new_buffer_name, Fbuffer_modified_tick):
+ Reflow docstrings.
+
+2007-02-10 Eli Zaretskii <[email protected]>
+
+ * window.c (Fwindow_height, Fwindow_hscroll)
+ (Fwindow_redisplay_end_trigger, Fwindow_point, Fwindow_start)
+ (Fwindow_end, Fwindow_display_table, Fwindow_text_height):
+ Document the effect of WINDOW arg being nil.
+
+2007-02-08 Kim F. Storm <[email protected]>
+
+ * minibuf.c (read_minibuf): Fix 2007-01-30 change.
+ Use Qlambda as interim value of Vminibuffer_completing_file_name.
+ (Fcompleting_read): Use non-filename maps if value is Qlambda (or Qnil).
+ (syms_of_minibuf) <minibuffer-completing-file-name>: Document lambda.
+
+2007-02-07 Juanma Barranquero <[email protected]>
+
+ * makefile.w32-in ($(TRES)): Use literal "../nt/emacs.rc" instead
+ of $(ALL_DEPS).
+
+2007-02-07 Eli Zaretskii <[email protected]>
+
+ * makefile.w32-in ($(TRES)): Depend on stamp_BLD, since $(TRES) is
+ put into $(BLD).
+
+2007-02-06 Chong Yidong <[email protected]>
+
+ * frame.c (Fmodify_frame_parameters): Don't bind
+ Qinhibit_default_face_x_resources, which has no effect.
+ (Qinhibit_default_face_x_resources): Symbol deleted.
+
+2007-02-03 Eli Zaretskii <[email protected]>
+
+ * indent.c (Fmove_to_column): Document that the argument COLUMN is
+ taken from prefix numeric argument.
+
+2007-02-03 Juanma Barranquero <[email protected]>
+
+ * lread.c (syms_of_lread) <load-history>: Doc fix.
+
+2007-01-29 Andreas Seltenreich <[email protected]> (tiny change)
+
+ * xterm.c [!USE_TOOLKIT_SCROLL_BARS] (x_scroll_bar_expose):
+ Use the foreground color of the scroll-bar face when drawing
+ the scroll-bar's border.
+
+2007-02-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (do_ewmh_fullscreen): Check that what != NULL before
+ calling wm_supports.
+
+2007-02-01 Juanma Barranquero <[email protected]>
+
+ * lread.c (syms_of_lread) <user-init-file>: Doc fix.
+ Wording by Eli Zaretskii.
+
+2007-01-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Initialize h/vmargin to 0.
+
+2007-01-30 Richard Stallman <[email protected]>
+
+ * minibuf.c (read_minibuf):
+ Save and clear Vminibuffer_completing_file_name.
+ (read_minibuf_unwind): Restore it.
+ (Vminibuffer_completion_table, Qminibuffer_completion_table)
+ (Vminibuffer_completion_predicate, Qminibuffer_completion_predicate)
+ (Vminibuffer_completion_confirm, Qminibuffer_completion_confirm)
+ (Vminibuffer_completing_file_name): Definitions moved up.
+
+2007-01-29 Chong Yidong <[email protected]>
+
+ * m/hp800.h: Restore, removing HP-UX support.
+
+2007-01-29 Jan Dj,Ad(Brv <[email protected]>
+
+ * Makefile.in: Use a variable, XFT_LIBS, instead #define LIB_X11_LIB.
+
+2007-01-28 Richard Stallman <[email protected]>
+
+ * minibuf.c (Ftry_completion, Fall_completions)
+ (Fcompleting_read, Ftest_completion):
+ Rename arg ALIST or TABLE to COLLECTION.
+
+2007-01-27 Chong Yidong <[email protected]>
+
+ * unexhp9k800.c: Remove due to lack of legal papers.
+
+ * m/sr2k.h, m/hp800.h: Remove due to dependence on above.
+
+2007-01-27 Eli Zaretskii <[email protected]>
+
+ * keyboard.c (Fthis_command_keys, Fthis_command_keys_vector): Doc fix.
+
+ * minibuf.c (Fcompleting_read): Doc fix.
+
+2007-01-26 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_initialize): Call XftInit if HAVE_XFT.
+
+ * Makefile.in: Use XFT_LIBS if defined.
+
+2007-01-26 YAMAMOTO Mitsuharu <[email protected]>
+
+ * alloc.c (BLOCK_INPUT_ALLOC, UNBLOCK_INPUT_ALLOC): Use
+ BLOCK_INPUT/UNBLOCK_INPUT.
+
+ * blockinput.h (interrupt_input_blocked): Declare volatile.
+
+ * keyboard.c (interrupt_input_blocked): Declare volatile.
+
+ * syssignal.h (SIGNAL_THREAD_CHECK): Use pthread_equal.
+
+2007-01-24 Kim F. Storm <[email protected]>
+
+ * keymap.c (describe_map): Don't consider prefix keys to be shadowed.
+
+2007-01-23 Juanma Barranquero <[email protected]>
+
+ * editfns.c (Finsert_char): Doc fix.
+ (Fget_internal_run_time, Fdecode_time): Fix typos in docstrings.
+
+2007-01-22 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macselect.c [TARGET_API_MAC_CARBON] (mac_do_receive_drag):
+ Don't pass keyboard modifiers to mac_store_drag_event, but put
+ them as kEventParamKeyModifiers Apple event parameter.
+
+2007-01-21 Chong Yidong <[email protected]>
+
+ * xdisp.c (try_window): Revert previous change.
+
+ * dispnew.c (update_text_area): Revert 2006-09-17 change.
+ Always redraw non-mode-line rows with mouse-face.
+
+2007-01-20 Chong Yidong <[email protected]>
+
+ * xdisp.c (try_window): Clear mouse-face highlights first.
+
+ * window.c (set_window_buffer): Revert 2006-11-22 change.
+
+2007-01-20 Eli Zaretskii <[email protected]>
+
+ * .gdbinit (ppt, xtype, xmisctype, xint, xptr, xmarker, xframe)
+ (xbuffer, xcons, xcar, xcdr): Fix doc strings.
+
+2007-01-20 Chong Yidong <[email protected]>
+
+ * keyboard.c (read_key_sequence): Extract local map only if the
+ given position is in an accessible buffer region.
+
+2007-01-19 Nick Roberts <[email protected]>
+
+ * .gdbinit: Reformat documentation so that first sentence
+ displays properly with "help user-defined" (like apropos).
+
+2007-01-18 Bruno Haible <[email protected]> (tiny change)
+
+ * epaths.in: Move PATH_DOC from local/info to local/share/info.
+
+2007-01-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (create_and_show_dialog) [TARGET_API_MAC_CARBON]:
+ Create movable modal window instead of movable alert window.
+ (create_and_show_dialog) [!MAC_OSX]: Use DeactivateControl instead
+ of DisableControl.
+
+ * macselect.c (Fmac_resume_apple_event): Set error number when
+ descriptor type of reply is non-null.
+
+2007-01-14 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (create_and_show_dialog) [TARGET_API_MAC_CARBON]:
+ Use DisableControl for disabled items. Set default button to first
+ enabled one. Use icon of application in execution.
+
+2007-01-13 Eli Zaretskii <[email protected]>
+
+ * process.c (Fdelete_process, Fprocess_id, sigchld_handler):
+ Copy PID into EMACS_INT to avoid GCC warnings.
+
+ * fns.c (maybe_resize_hash_table): Copy new size of hash table
+ into EMACS_INT to avoid GCC warnings.
+
+ * editfns.c (Fuser_uid, Fuser_real_uid): Copy values returned by
+ geteuid and getuid into EMACS_INT to avoid GCC warnings.
+
+ * dired.c (Ffile_attributes): Fix last change.
+
+2007-01-12 Eli Zaretskii <[email protected]>
+
+ * dired.c (Ffile_attributes): Copy some members of `struct stat'
+ into int's to avoid GCC warnings about limited range of short in
+ arguments to FIXNUM_OVERFLOW_P.
+
+2007-01-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (HAVE_DIALOGS): Define if TARGET_API_MAC_CARBON.
+ (mac_handle_dialog_event, install_dialog_event_handler)
+ (create_and_show_dialog) [TARGET_API_MAC_CARBON]: New functions.
+ (DIALOG_LEFT_MARGIN, DIALOG_TOP_MARGIN, DIALOG_RIGHT_MARGIN)
+ (DIALOG_BOTTOM_MARGIN, DIALOG_MIN_INNER_WIDTH)
+ (DIALOG_MAX_INNER_WIDTH, DIALOG_BUTTON_BUTTON_HORIZONTAL_SPACE)
+ (DIALOG_BUTTON_BUTTON_VERTICAL_SPACE, DIALOG_BUTTON_MIN_WIDTH)
+ (DIALOG_TEXT_MIN_HEIGHT, DIALOG_TEXT_BUTTONS_VERTICAL_SPACE)
+ (DIALOG_ICON_WIDTH, DIALOG_ICON_HEIGHT, DIALOG_ICON_LEFT_MARGIN)
+ (DIALOG_ICON_TOP_MARGIN) [TARGET_API_MAC_CARBON]: New macros.
+ (mac_dialog) [TARGET_API_MAC_CARBON]: Remove function.
+ (mac_dialog_show) [TARGET_API_MAC_CARBON]: Use create_and_show_dialog.
+
+ * macterm.c (x_free_frame_resources) [USE_CG_DRAWING]:
+ Call mac_prepare_for_quickdraw.
+ (quit_char, make_ctrl_char) [TARGET_API_MAC_CARBON]: Move externs
+ outside #ifdef MAC_OSX.
+ (mac_quit_char_key_p) [TARGET_API_MAC_CARBON]: Move function
+ outside #ifdef MAC_OSX.
+ (mac_check_bundle) [MAC_OSX]: Remove unused function.
+
+ * macterm.h (mac_quit_char_key_p): Move extern outside #ifdef MAC_OSX.
+ (HOURGLASS_WIDTH, HOURGLASS_HEIGHT): Parenthesize definitions.
+
+2007-01-11 Jan Dj,Ad(Brv <[email protected]>
+
+ * alloc.c (BLOCK_INPUT_ALLOC, UNBLOCK_INPUT_ALLOC): Use pthread_equal,
+ block/unblock SIGIO.
+
+2007-01-10 Stefan Monnier <[email protected]>
+
+ * editfns.c (Fformat): Allow integer-format to work with floats of size
+ larger than most-positive-fixnum (but still smaller than MAXINT).
+
+ * dired.c (Ffile_attributes): Use floats for large uids/gids.
+
+2007-01-09 Eli Zaretskii <[email protected]>
+
+ * emacs.c (syms_of_emacs) <path-separator>: Doc fix.
+
+2007-01-09 YAMAMOTO Mitsuharu <[email protected]>
+
+ * callproc.c (Fcall_process_region) [HAVE_MKSTEMP]: Add BLOCK_INPUT
+ around mkstemp.
+
+ * image.c (XDrawLine) [MAC_OS]: Remove macro.
+ (XCreateGC_pixmap) [!HAVE_NTGUI]: Likewise.
+ (x_disable_image) [!HAVE_NTGUI]: Use XCreateGC instead of
+ XCreateGC_pixmap.
+
+ * macgui.h (Display): Typedef to opaque type.
+
+ * macmenu.c (mac_dialog_modal_filter) [MAC_OSX]: New function.
+ (Fx_popup_dialog) [MAC_OSX]: Use standard alert if called from
+ Fmessage_box, Fyes_or_no_p, or Fy_or_n_p.
+ [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030] (menu_quit_handler):
+ Use mac_quit_char_key_p.
+
+ * macterm.c (XDrawLine): Rename from mac_draw_line_to_pixmap.
+ (XCreateGC): Change type of 2nd argument to void *.
+ (XFreeGC) [USE_CG_DRAWING && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
+ Fix last change.
+ (mac_to_emacs_modifiers): Change return type to int.
+ [USE_CARBON_EVENTS] (mac_event_to_emacs_modifiers): Likewise.
+ (mac_mapped_modifiers): New function.
+ (XTread_socket): Use it.
+ [USE_TSM] (mac_handle_text_input_event): Likewise.
+ (do_window_update) [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw.
+ (mac_quit_char_modifiers, mac_quit_char_keycode) [MAC_OSX]:
+ Remove variables.
+ (mac_determine_quit_char_modifiers, init_quit_char_handler)
+ [MAC_OSX]: Remove functions.
+ (make_ctrl_char) [MAC_OSX]: Add extern.
+ (mac_quit_char_key_p) [MAC_OSX]: New function.
+ (mac_initialize) [MAC_OSX]: Don't call init_quit_char_handler.
+
+ * macterm.h (FONT_MAX_WIDTH): Remove unused macro.
+ (XCreateGC): Change type in extern.
+ (XDrawLine): Rename from mac_draw_line_to_pixmap.
+ (mac_quit_char_key_p) [MAC_OSX]: Add extern.
+
+2007-01-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c (init_keyboard): Initialize interrupt_input_blocked and
+ interrupt_input_pending.
+
+ * xterm.h (x_display_info): New: net_supported_atoms,
+ nr_net_supported_atoms and net_supported_window.
+
+ * xterm.c (last_user_time): New variable.
+ (handle_one_xevent): Set last_user_time from events that have Time.
+ Set net_supported_window to 0 when reparented.
+ (wm_supports): New function.
+ (do_ewmh_fullscreen): Use wm_supports to check for _NET_WM_STATE.
+ (x_term_init): Initialize net_supported_atoms, nr_net_supported_atoms
+ and net_supported_window.
+
+2007-01-05 Kim F. Storm <[email protected]>
+
+ * indent.c (Fvertical_motion): Fix it overshoot check for overlay
+ strings without embedded newlines immediately followed by newline.
+
+2007-01-05 YAMAMOTO Mitsuharu <[email protected]>
+
+ * editfns.c (Fformat_time_string, Fdecode_time, Fencode_time)
+ (Fcurrent_time_string, Fcurrent_time_zone): Add BLOCK_INPUT around
+ gmtime/localtime/emacs_memftimeu/mktime.
+
+ * mac.c (Fmac_set_file_creator): Use MAC_EMACS_CREATOR_CODE
+ instead of 'EMAx'.
+ [!MAC_OSX] (sys_open, sys_creat, sys_fopen): Likewise.
+
+ * macgui.h (struct _XGC) [USE_CG_DRAWING
+ && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: New members cg_fore_color
+ and cg_back_color.
+
+ * macmenu.c (Vshow_help_function) [TARGET_API_MAC_CARBON]: Add extern.
+ (restore_show_help_function, menu_target_item_handler)
+ [TARGET_API_MAC_CARBON]: New functions.
+ (install_menu_target_item_handler): New function.
+ (add_menu_item) [TARGET_API_MAC_CARBON]: Set help string as menu
+ item property.
+
+ * macterm.c (CG_SET_FILL_COLOR_MAYBE_WITH_CGCOLOR)
+ (CG_SET_FILL_COLOR_WITH_GC_FOREGROUND)
+ (CG_SET_FILL_COLOR_WITH_GC_BACKGROUND)
+ (CG_SET_STROKE_COLOR_MAYBE_WITH_CGCOLOR)
+ (CG_SET_STROKE_COLOR_WITH_GC_FOREGROUND): New macros.
+ (mac_cg_color_space_rgb) [USE_CG_DRAWING]: New variable.
+ (mac_cg_color_black) [USE_CG_DRAWING
+ && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: New variable.
+ (init_cg_color) [USE_CG_DRAWING]: New function.
+ (mac_draw_line, mac_draw_rectangle) [USE_CG_DRAWING]: Use
+ CG_SET_STROKE_COLOR_WITH_GC_FOREGROUND instead of CG_SET_STROKE_COLOR.
+ (mac_erase_rectangle, mac_clear_window, mac_draw_cg_image)
+ (mac_fill_rectangle, mac_draw_image_string_cg) [USE_CG_DRAWING]:
+ Use CG_SET_FILL_COLOR_WITH_GC_FOREGROUND or
+ CG_SET_FILL_COLOR_WITH_GC_BACKGROUND instead of CG_SET_FILL_COLOR.
+ (mac_draw_string_common) [MAC_OSX && USE_ATSUI]: Likewise.
+ (XCreateGC, XFreeGC, XSetForeground, XSetBackground) [USE_CG_DRAWING
+ && MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: Use gc->cg_fore_color and/or
+ gc->cg_back_color.
+ (install_drag_handler, remove_drag_handler): Make extern.
+ (install_menu_target_item_handler): Add extern.
+ (install_window_handler): Call install_menu_target_item_handler.
+ [MAC_OS8] (main): Use MAC_EMACS_CREATOR_CODE instead of 'EMAx'.
+ (mac_initialize) [USE_CG_DRAWING]: Call init_cg_color.
+
+ * macterm.h (MAC_EMACS_CREATOR_CODE): New enumerator.
+
+2007-01-04 Juanma Barranquero <[email protected]>
+
+ * window.c (Fwindow_end): Fix use of >= operator.
+
+2007-01-03 Richard Stallman <[email protected]>
+
+ * window.c (Fwindow_end): Check BUF_OVERLAY_MODIFF like BUF_MODIFF.
+
+2007-01-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.h (xg_menu_item_cb_data_): Remove highlight_id and
+ unhighlight_id.
+
+ * gtkutil.c (menuitem_highlight_callback): Invoked widget is the
+ parent of the menu item. Get menu item widget from event.
+ (xg_create_one_menuitem, xg_update_menu_item): highlight_id and
+ unhighlight_id has been removed.
+ (create_menus): Connect enter/leave-notify-event to the menu instead
+ of individual items.
+
+2006-12-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Connect create-menu-proxy with
+ xg_tool_bar_menu_proxy.
+ (xg_tool_bar_menu_proxy): New function.
+ (xg_tool_bar_proxy_callback): New function.
+
+2006-12-30 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_tool_bar_button_cb): Save last modifier on widget.
+ (xg_tool_bar_callback): Remove check for button.
+ (update_frame_tool_bar): Put an event box in the tool bar and a button
+ in the event box. Attach enter/leave-notify-event to the event box.
+
+2006-12-30 Richard Stallman <[email protected]>
+
+ * keymap.c (Fdefine_key): Doc fix.
+
+2006-12-29 Kim F. Storm <[email protected]>
+
+ * frame.h (struct frame): New member minimize_tool_bar_window_p.
+
+ * xdisp.c (auto_resize_tool_bars_p): Replace with ...
+ (Vauto_resize_tool_bars): ... this.
+ (syms_of_xdisp): DEFVAR_LISP and initialize it. Update doc string
+ to describe new value `grow-only', and use of C-l.
+ (display_tool_bar_line): Only use default face for border below
+ toolbar if not grow-only (to get acceptable visual appearence).
+ Explicitly set visible_height for empty toolbar lines.
+ (redisplay_tool_bar): Handle `grow-only' setting. Check and clear
+ minimize_tool_bar_window_p flag.
+
+ * window.c (Frecenter): Set minimize_tool_bar_window_p flag
+ when called without arg to redraw with minimum toolbar height.
+ Update doc string.
+
+2006-12-29 Jason Rumney <[email protected]>
+
+ * s/ms-w32.h (tzname): Do not define in msvc8.
+ (utime): Do not define in msvc8.
+
+ * regex.c (regerror): Change parameter name err_code.
+
+2006-12-26 Richard Stallman <[email protected]>
+
+ * search.c (Fsearch_forward): Doc fix.
+
+ * callint.c (Finteractive): Doc fix.
+
+2006-12-25 Kim F. Storm <[email protected]>
+
+ * s/ms-w32.h (BROKEN_DATAGRAM_SOCKETS): Define it.
+
+2006-12-23 Eli Zaretskii <[email protected]>
+
+ * keyboard.c (some_mouse_moved): Fix last change.
+
+2006-12-22 Eli Zaretskii <[email protected]>
+
+ * callproc.c (syms_of_callproc) <shell-file-name>: Doc fix.
+
+2006-12-22 Mark Davies <[email protected]>
+
+ * m/amdx86-64.h, m/hp800.h: Add support for NetBSD.
+ * m/sh3el.h: New file.
+
+2006-12-22 Eli Zaretskii <[email protected]>
+
+ * makefile.w32-in (emacs, temacs): Depend on stamp_BLD instead of
+ $(BLD).
+ ($(OBJ0) $(OBJ1) $(WIN32OBJ)): New dependency on stamp_BLD.
+ (bootstrap-temacs): Pass $(XMFLAGS) to sub-make.
+ ($(OBJ0) $(OBJ1) $(WIN32OBJ)): Add lastfile.$(O) and firstfile.$(O).
+ (clean): Delete stamp_BLD.
+
+2006-12-22 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (mac_update_title_bar) [TARGET_API_MAC_CARBON]:
+ Call mac_update_proxy_icon also when buffer modification flag changed.
+ [TARGET_API_MAC_CARBON] (mac_update_proxy_icon): Don't update alias,
+ but compare FSRef/FSSpec of resolved alias.
+
+2006-12-21 Kim F. Storm <[email protected]>
+
+ * w32.c (_sys_wait_accept): Fix handle leak.
+
+2006-12-20 Jan Dj,Ad(Brv <[email protected]>
+
+ * sound.c: Include <alsa/asoundlib.h> if ALSA_SUBDIR_INCLUDE is
+ defined.
+
+2006-12-20 Kim F. Storm <[email protected]>
+
+ * s/ms-w32.h (BROKEN_NON_BLOCKING_CONNECT): Define it.
+
+2006-12-19 Juanma Barranquero <[email protected]>
+
+ * keyboard.c (syms_of_keyboard) <double-click-time>:
+ * mac.c (Fmac_code_convert_string):
+ * search.c (Fsearch_forward): Doc fixes.
+
+2006-12-19 Kim F. Storm <[email protected]>
+
+ Rework 2006-12-04 change. A SIGUSR1 (SIGUSR2) signal now generates
+ a sigusr1 event instead of [signal usr1] sequence, and signal events
+ are now supposed to be handled via special-event-map.
+
+ * keyboard.c (kbd_buffer_store_event_hold): Undo 2006-12-04 change.
+ (make_lispy_event): Don't generate Qsignal prefix for code 0.
+ Abort if signal code is unknown.
+ (store_user_signal_events): Don't make Qsignal prefix (code 0).
+ (Qsignal): Move declaration back to process.c.
+ (syms_of_keyboard): Don't intern or staticpro it here.
+
+ * process.c (Qsignal): Declare here.
+ (syms_of_process): Intern or staticpro it.
+
+ * emacs.c (main): Rename user signals to sigusr1 and sigusr2.
+
+ * .gdbinit: Pass on SIGUSR1 and SIGUSR2 to Emacs.
+
+2006-12-19 Juanma Barranquero <[email protected]>
+
+ * buffer.c (syms_of_buffer) <buffer-display-table>:
+ <scroll-up-aggressively, scroll-down-aggressively>: Doc fixes.
+
+2006-12-17 Richard Stallman <[email protected]>
+
+ * fileio.c (Fread_file_name_internal): Pass Vread_file_name_predicate
+ to Ffile_name_completion.
+
+ * dired.c (file_name_completion): New arg PREDICATE. Some cleanup.
+ (Ffile_name_completion): New arg PREDICATE.
+
+2006-12-17 Juanma Barranquero <[email protected]>
+
+ * buffer.c (Fkill_buffer): Doc fix.
+ (syms_of_buffer) <kill-buffer-query-functions>: Doc fix.
+
+2006-12-16 Juanma Barranquero <[email protected]>
+
+ * minibuf.c (Ftry_completion): Check that obarray buckets are symbols.
+
+2006-12-16 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (w32-window-exists-p): New function.
+ (syms_of_w32fns): Defsubr it.
+
+ * prefix-args.c [STDC_HEADERS]: Include stdlib.h.
+
+2006-12-16 Juanma Barranquero <[email protected]>
+
+ * minibuf.c (Ftry_completion): Use `check_obarray' if ALIST is a vector.
+
+2006-12-15 Eli Zaretskii <[email protected]>
+
+ * emacs.c (USAGE3): Clarify documentation of --color.
+
+2006-12-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (wakeup_from_rne_enabled_p) [TARGET_API_MAC_CARBON]:
+ New variable.
+ (ENABLE_WAKEUP_FROM_RNE, DISABLE_WAKEUP_FROM_RNE): New macros.
+ [!MAC_OSX] (select): Use them.
+ [MAC_OSX] (select_and_poll_event, sys_select): Likewise.
+ (mac_wakeup_from_rne) [TARGET_API_MAC_CARBON]: New function.
+
+ * macfns.c (mac_atsu_font_face_attributes) [USE_ATSUI]: Add extern.
+ (Fmac_atsu_font_face_attributes) [USE_ATSUI]: New function.
+ (syms_of_macfns) [USE_ATSUI]: Defsubr it.
+
+ * macselect.c [TARGET_API_MAC_CARBON] (mac_do_receive_drag):
+ Use mac_wakeup_from_rne instead of mac_post_mouse_moved_event.
+
+ * macterm.c (mac_query_char_extents) [USE_ATSUI]: Don't call
+ ATSUGetGlyphBounds if not necessary.
+ (Vmac_atsu_font_table) [USE_ATSUI]: Remove variable.
+ (syms_of_macterm) [USE_ATSUI]: Don't defvar it.
+ (fm_get_style_from_font, atsu_find_font_from_family_name)
+ (atsu_find_font_family_name, mac_atsu_font_face_attributes)
+ [USE_ATSUI]: New functions.
+ (init_font_name_table) [USE_ATSUI]: Use atsu_find_font_family_name.
+ (mac_load_query_font) [USE_ATSUI]: Use atsu_find_font_from_family_name.
+ Don't get metrics for Latin-1 right half characters.
+ (mac_load_query_font): Don't load font if space width is not positive.
+ [TARGET_API_MAC_CARBON] (mac_store_event_ref_as_apple_event):
+ Use mac_wakeup_from_rne instead of mac_post_mouse_moved_event.
+ (XTread_socket): Call SelectWindow when unfocused frame is clicked.
+
+ * macterm.h (mac_wakeup_from_rne) [TARGET_API_MAC_CARBON]: Add extern.
+
+2006-12-15 Kim F. Storm <[email protected]>
+
+ * keyboard.c (ignore_mouse_drag_p): New global var.
+ (some_mouse_moved): Return 0 if it is non-zero.
+ (make_lispy_event): Generate click event on mouse up if
+ ignore_mouse_drag_p is non-zero, even if mouse moved.
+ Clear ignore_mouse_drag_p on mouse down/up.
+
+ * xdisp.c (redisplay_window): Set ignore_mouse_drag_p if tool-bar
+ is resized to avoid generating a mouse drag event.
+
+2006-12-14 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (w32_wnd_proc): Force non-tooltip frames to respect the
+ minimum tracking size. Remove non-working old hack to do the same.
+
+2006-12-14 YAMAMOTO Mitsuharu <[email protected]>
+
+ * emacs.c (handle_user_signal): Move function to keyboard.c.
+ (main): Use add_user_signal for SIGUSR1 and SIGUSR2.
+
+ * keyboard.c (make_lispy_event): Use find_user_signal_name.
+ (read_avail_input): Store pending user signal events.
+ (struct user_signal_info): New struct.
+ (user_signals): New variable.
+ (add_user_signal, store_user_signal_events)
+ (find_user_signal_name): New functions.
+ (handle_user_signal): Move function from emacs.c. Don't store
+ USER_SIGNAL_EVENT here, but increment number of pending signals.
+
+ * keyboard.h (add_user_signals): Add extern.
+
+2006-12-11 Juanma Barranquero <[email protected]>
+
+ * buffer.c (syms_of_buffer) <cursor-in-non-selected-windows>:
+ <default-scroll-up-aggressively, default-scroll-down-aggressively>:
+ <line-spacing, left-margin>: Doc fixes.
+
+ * xdisp.c (syms_of_xdisp) <mode-line-inverse-video>: Doc fix.
+
+2006-12-10 Kim F. Storm <[email protected]>
+
+ * xdisp.c (show_mouse_face): Never use text cursor in tool-bar.
+
+2006-12-10 Juanma Barranquero <[email protected]>
+
+ * abbrev.c (syms_of_abbrev) <last-abbrev-text>:
+ * buffer.c (syms_of_buffer) <default-major-mode>:
+ * keymap.c (Flookup_key):
+ * lread.c (Feval_buffer, Feval_region):
+ * macterm.c (syms_of_macterm) <x-use-underline-position-properties>:
+ <x-underline-at-descent-line, mac-emulate-three-button-mouse>:
+ * marker.c (Fmarker_insertion_type):
+ * minibuf.c (syms_of_minibuf) <minibuffer-completion-table>:
+ * msdos.c (syms_of_msdos) <delete-exited-processes>:
+ * w32term.c (syms_of_w32term) <x-use-underline-position-properties>:
+ <x-underline-at-descent-line>:
+ * xdisp.c (format-mode-line):
+ * xterm.c (syms_of_xterm) <x-use-underline-position-properties>:
+ <x-underline-at-descent-line>: Doc fixes.
+
+2006-12-10 Andreas Schwab <[email protected]>
+
+ * systime.h (EMACS_GET_TIME): Remove check for
+ HAVE_STRUCT_TIMEZONE which is never defined.
+
+2006-12-10 Alan Mackenzie <[email protected]>
+
+ * syntax.c (Fpartial_parse_sexp): Correct Docco: Elt 8 of the
+ result is now neither the last elt nor optional for OLDSTATE.
+
+2006-12-09 Eli Zaretskii <[email protected]>
+
+ * process.c (Fsignal_process): Doc fix. Use XFLOAT_DATA to
+ extract the process ID from a Lisp float.
+
+2006-12-09 Chong Yidong <[email protected]>
+
+ * xterm.c (XTframe_raise_lower): Comment out _NET_ACTIVE_WINDOW code.
+
+2006-12-08 Eli Zaretskii <[email protected]>
+
+ * frame.h (PIX_TYPE): Redefine as `unsigned long', for 64-bit
+ platforms where long is 64-bit.
+
+ * msdos.h (PIX_TYPE): Redefine as `unsigned long'.
+
+2006-12-08 NAKAJI Hiroyuki <[email protected]> (tiny change)
+
+ * m/amdx86-64.h: Add support for Solaris 10 on x86-64.
+
+2006-12-08 Kenichi Handa <[email protected]>
+
+ * xterm.c (x_query_font): Use xstricmp instead off strcasecmp.
+
+2006-12-08 Juanma Barranquero <[email protected]>
+
+ * emacs.c (syms_of_emacs) <system-type>: Doc fix.
+
+2006-12-07 Kim F. Storm <[email protected]>
+
+ * process.c (parse_signal): Use xstricmp instead of strcasecmp.
+ (Fsignal_process): Don't use strncasecmp.
+
+2006-12-05 Glenn Morris <[email protected]>
+
+ * abbrev.c (Qforce): New Lisp_Object.
+ (Fdefine_abbrev): Do not overwrite non-system abbrevs with system
+ abbrevs, unless 'force is applied.
+ (syms_of_abbrev): Add Qforce.
+
+2006-12-04 Kim F. Storm <[email protected]>
+
+ * process.c (parse_signal): Rename macro from handle_signal.
+ (Fsignal_process): Also accept lower-case variants of signal
+ names (to align with signal names generated by Emacs itself).
+
+ * emacs.c (handle_USR1_signal, handle_USR2_signal): Replace by...
+ (handle_user_signal): ... this, which generates two USER_SIGNAL_EVENTs
+ first with code == 0 [signal] and one with code == sig number.
+ (main): Use it as handler for SIGUR1 and SIGUSR2.
+
+ * keyboard.c (kbd_buffer_store_event_hold): Don't throw-on-input
+ if first event in [signal xxx] sequence.
+ (lispy_user_signals, Qusr1_signal, Qusr2_signal): Remove.
+ (syms_of_keyboard): Don't intern and staticpro them.
+ (Qsignal): Declare here.
+ (syms_of_keyboard): Intern and staticpro it.
+ (make_lispy_event): Use it. Intern symbols on the fly for other
+ USER_SIGNAL_EVENTs events.
+
+ * process.c (Qsignal): Declare extern.
+ (syms_of_process): Don't intern/staticpro it here.
+
+ * process.c (read_process_output): Abort if carryover < 0.
+
+2006-12-04 YAMAMOTO Mitsuharu <[email protected]>
+
+ * config.in: Regenerate.
+
+ * fileio.c [__NetBSD__]: Don't define `unix'.
+ (Funix_sync, syms_of_fileio): Use `#ifdef HAVE_SYNC' instead of
+ `#ifdef unix'.
+
+2006-12-04 Glenn Morris <[email protected]>
+
+ * Makefile.in (version): New variable, set by configure.
+ (bootstrapclean, mostlyclean): Also remove emacs-${version}.
+
+2006-12-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Handle modifying a toolbar item
+ without an image.
+
+2006-12-01 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (Fw32_shell_execute): Doc fix.
+
+2006-11-30 Chong Yidong <[email protected]>
+
+ * xdisp.c (move_it_to): Correctly count tab glyphs for continued
+ lines ending in tab.
+
+2006-11-30 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_raise_frame): Move setting of _NET_ACTIVE_WINDOW
+ property ...
+ (XTframe_raise_lower): ... to here.
+
+2006-11-30 Kenichi Handa <[email protected]>
+
+ * regex.c (regex_compile): Fix previous change.
+
+2006-11-29 Juanma Barranquero <[email protected]>
+
+ * sound.c (Fplay_sound_internal): Remove spurious newline in docstring.
+
+2006-11-28 Chong Yidong <[email protected]>
+
+ * config.in: Regenerate.
+
+2006-11-28 Kenichi Handa <[email protected]>
+
+ * regex.c (regex_compile): Don't call SET_LIST_BIT with a
+ multibyte character.
+
+2006-11-27 Chong Yidong <[email protected]>
+
+ * s/aix4-2.h: Undefine _NO_PROTO. Suggested by Joe Buehler.
+
+2006-11-27 Kim F. Storm <[email protected]>
+
+ * window.c (set_window_buffer): Refactor recent changes.
+
+2006-11-27 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_msg_worker): Declare correctly.
+ (w32_initialize): Don't cast w32_msg_worker.
+
+ * w32fns.c (w32_msg_worker): Define as WINAPI and arg as void pointer.
+
+2006-11-26 Chong Yidong <[email protected]>
+
+ * m/amdx86-64.h: Look for standard libs in /usr/lib64 only if that
+ directory exists.
+
+2006-11-25 Eli Zaretskii <[email protected]>
+
+ * w16select.c (Fw16_set_clipboard_data): Fix the call to sit_for
+ as per the calling sequence change on 2006-07-11.
+
+2006-11-25 Chong Yidong <[email protected]>
+
+ * window.c (set_window_buffer): Use BLOCK_INPUT.
+
+2006-11-24 Juanma Barranquero <[email protected]>
+
+ * fns.c (substring_both): Add missing address operator.
+
+2006-11-24 Stefan Monnier <[email protected]>
+
+ * fns.c: Use AREF/ASIZE macros.
+ (concat): Provide the full ANSI prototype.
+
+2006-11-24 Juanma Barranquero <[email protected]>
+
+ * buffer.c (syms_of_buffer) <buffer-undo-list>: Doc fix.
+
+2006-11-23 William Smith <[email protected]> (tiny change)
+
+ * strftime.c (HAVE_SYS__MBSTATE_T_H): Fix typo.
+
+2006-11-22 Alfred M. Szmidt <[email protected]> (tiny change)
+
+ * s/openbsd.h (LD_SWITCH_SYSTEM): Remove /usr/pkg/lib and
+ /usr/pkg/lib from the library search path.
+ (LD_SWITCH_X_DEFAULT): New macro.
+
+2006-11-22 Chong Yidong <[email protected]>
+
+ * window.c (set_window_buffer): Clear mouse highlight if it is in
+ this window.
+
+2006-11-21 Chong Yidong <[email protected]>
+
+ * xfaces.c (realize_default_face): Check if the default font name
+ exists on this display before trying to use it.
+
+2006-11-21 Richard Stallman <[email protected]>
+
+ * fileio.c: Break line before &&, not after.
+
+2006-11-20 Eli Zaretskii <[email protected]>
+
+ * fns.c (concat) [!__GNUC__]: Add prototype.
+
+2006-11-20 Kenichi Handa <[email protected]>
+
+ * fileio.c (Fread_file_name_internal): Use SBYTES (not SCHARS) to
+ check the tailing slash of a filename.
+
+2006-11-20 KOBAYASHI Yasuhiro <[email protected]> (tiny change)
+
+ * indent.c (Fvertical_motion): Include composition in the case of
+ overshoot expected.
+
+2006-11-19 Andreas Schwab <[email protected]>
+
+ * xfaces.c (Fdisplay_supports_face_attributes_p): Initialize supports.
+
+ * xmenu.c (Fx_popup_menu): Initialize selection.
+
+2006-11-18 Andreas Schwab <[email protected]>
+
+ * s/gnu-linux.h (GC_MARK_SECONDARY_STACK): Update call to mark_memory.
+
+2006-11-17 Tetsurou Okazaki <[email protected]> (tiny change)
+
+ * xterm.c (do_ewmh_fullscreen): Declare variable before XSETFRAME
+ to avoid gcc 2.96 error.
+
+2006-11-17 NIIMI Satoshi <[email protected]> (tiny change)
+
+ * search.c (simple_search): In the loop of backward searching,
+ check also the byte position against the limit.
+
+2006-11-14 Romain Francoise <[email protected]>
+
+ * minibuf.c (Fcompleting_read): Fix typo in docstring.
+
+2006-11-14 Kenichi Handa <[email protected]>
+
+ * coding.c (code_convert_region): Initialize coding->heading_ascii.
+ (decode_coding_string, code_convert_region): Likewise.
+
+2006-11-14 YAMAMOTO Mitsuharu <[email protected]>
+
+ * config.in: Regenerate.
+
+ * macfns.c (Fx_display_mm_height, Fx_display_mm_width)
+ [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
+ && MAC_OS_X_VERSION_MIN_REQUIRED == 1020]: Check if
+ CGDisplayScreenSize is available.
+
+ * macmenu.c (menu_quit_handler, install_menu_quit_handler):
+ Replace `#ifdef HAVE_CANCELMENUTRACKING' with
+ `#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1030'.
+ (install_menu_quit_handler) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
+ && MAC_OS_X_VERSION_MIN_REQUIRED == 1020]: Check if
+ CancelMenuTracking is available.
+
+ * macterm.c [USE_CG_TEXT_DRAWING] (mac_draw_image_string_cg)
+ [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
+ && MAC_OS_X_VERSION_MIN_REQUIRED == 1020]: Check if
+ CGContextShowGlyphsWithAdvances is available.
+
+2006-11-13 Jason Rumney <[email protected]>
+
+ * s/ms-w32.h: Define HAVE_INET_SOCKETS.
+
+2006-11-13 Nozomu Ando <[email protected]>
+
+ * alloc.c (mark_memory): New argument OFFSET. All uses changed.
+ Fix address calculations for case END < START.
+ (mark_stack): Impose Lisp_Object alignment on jmp_buf.
+
+2006-11-12 Juanma Barranquero <[email protected]>
+
+ * coding.c (Fencode_sjis_char, Fencode_big5_char):
+ Improve argument/docstring consistency.
+
+ * editfns.c (Fmessage): Doc fixes.
+
+ * process.c (syms_of_process) <delete-exited-processes>: Doc fix.
+
+2006-11-12 Chong Yidong <[email protected]>
+
+ * xmenu.c (popup_activated): Define outside HAVE_MENUS.
+
+2006-11-12 Romain Francoise <[email protected]>
+
+ * xselect.c (selection-coding-system): Fix docstring.
+
+2006-11-12 Juanma Barranquero <[email protected]>
+
+ * category.c (Fchar_category_set): Improve arg/docstring consistency.
+
+ * data.c (Flogxor):
+ * fns.c (Frandom, Flength, Fsafe_length, Fstring_bytes)
+ (Fstring_equal, Fcompare_strings, Fstring_lessp, Fcopy_sequence)
+ (Fstring_make_unibyte): Fix typos in docstrings.
+
+2006-11-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h (struct x_display_info): Fix indentation.
+
+ * xterm.c (do_ewmh_fullscreen, XTfullscreen_hook): New functions.
+ (x_check_fullscreen): Call do_ewmh_fullscreen.
+ (x_initialize): Set fullscreen_hook to XTfullscreen_hook.
+
+ * frame.c (x_set_fullscreen): Call fullscreen_hook if set.
+
+ * term.c: Define fullscreen_hook.
+ (syms_of_term): Initialize fullscreen_hook to NULL.
+
+ * termhooks.h: Add fullscreen_hook.
+
+2006-11-08 Juanma Barranquero <[email protected]>
+
+ * bytecode.c (Fbyte_code):
+ * data.c (Fmakunbound): Use SYMBOL_CONSTANT_P macro.
+
+2006-11-06 Juanma Barranquero <[email protected]>
+
+ * lread.c (syms_of_lread):
+ * xsmfns.c (syms_of_xsmfns): Fix typo in docstring.
+
+2006-11-06 Martin Rudalics <[email protected]>
+
+ * macmenu.c (Fmenu_or_popup_active_p): Define outside HAVE_MENUS.
+
+ * w32menu.c (Fmenu_or_popup_active_p): Define outside HAVE_MENUS.
+ Return nil if building without menus.
+
+ * xmenu.c (Fmenu_or_popup_active_p): Define outside HAVE_MENUS.
+ Return nil if building without menus.
+
+2006-11-05 Mark Davies <[email protected]> (tiny change)
+
+ * s/netbsd.h (POSIX_SIGNALS): Define.
+
+2006-11-05 Martin Rudalics <[email protected]>
+
+ * macmenu.c (Fmenu_or_popup_active_p): New function.
+ (syms_of_macmenu): Defsubr it.
+
+ * w32menu.c (Fmenu_or_popup_active_p): New function.
+ (syms_of_w32menu): Defsubr it.
+ (popup_activated_flag, popup_activated): Remove.
+
+ * xdisp.c (note_mouse_highlight) [HAVE_NTGUI]: Don't bother to
+ check popup_activated.
+
+ * xmenu.c (Fmenu_or_popup_active_p): New function.
+ (syms_of_xmenu): Defsubr it.
+
+2006-11-05 YAMAMOTO Mitsuharu <[email protected]>
+
+ * unexmacosx.c (malloc_cookie): Remove unused variable.
+ (region_list_head, region_list_tail, lca, nlc, infile_lc_highest_addr)
+ (text_seg_lowest_offset, mh, curr_header_offset, infd, outfd)
+ (emacs_zone, data_segment_old_fileoff, data_segment_scp)
+ (num_unexec_regions, unexec_regions): Make variables static.
+ (print_regions, find_emacs_zone_regions): Make static.
+ (unexec_region_info): New typedef.
+ (unexec_regions): Change type from vm_range_t[] to unexec_region_info[].
+ All uses changed.
+ (unexec_regions_recorder): Subtract size of trailing null pages from
+ filesize. Show filesize.
+ (unexec_regions_merge): Don't merge if null pages of preceding region
+ is not too small. Use long format in printf.
+ (copy_segment, copy_data_segment): Show filesize.
+ (copy_data_segment): Write filesize bytes of region data.
+ Adjust filesize in segment command accordingly.
+ (dump_it): Use long format in printf.
+
+2006-11-05 Juanma Barranquero <[email protected]>
+
+ * dosfns.c (Finsert_startup_screen):
+ * fns.c (Ffeaturep, syms_of_fns):
+ * frame.c (syms_of_frame): Fix typos in docstrings.
+
+ * unexcw.c (unexec): Fix typo in output message.
+
+2006-11-04 Ralf Angeli <[email protected]>
+
+ * w32fns.c (w32_createwindow): Remove code for handling -geometry
+ command line option and `initial-frame-alist' which is superfluous
+ after the last change to `w32_createwindow'.
+
+2006-11-04 Slawomir Nowaczyk <[email protected]> (tiny change)
+
+ * w32proc.c (sys_wait): Only wait for processes with fd<0.
+ Others should be handled by sys_select instead. Fixes problems
+ with (progn (start-process "" nil "ls") (call-process "ls")).
+
+2006-11-04 Giorgos Keramidas <[email protected]> (tiny change)
+
+ * xmenu.c (Fmenu_bar_open): Declare variable before BLOCK_INPUT to
+ avoid gcc 2.95 error.
+
+2006-11-04 Chong Yidong <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): If icon image is invalid and
+ wicon is null, insert an empty button.
+
+2006-11-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_raise_frame): Send _NET_ACTIVE_WINDOW when raising the
+ window.
+
+2006-11-02 Juanma Barranquero <[email protected]>
+
+ * emacs.c (Fkill_emacs): Fix typo in docstring.
+
+2006-11-02 Nozomu Ando <[email protected]>
+
+ * unexmacosx.c (mach_header, segment_command, vm_region, section)
+ [_LP64]: New defines.
+ (VM_REGION_BASIC_INFO_COUNT, VM_REGION_BASIC_INFO, LC_SEGMENT)
+ (MH_MAGIC) [_LP64]: Redefine.
+ (delta): Remove variable.
+ (curr_file_offset, pagesize): New variables.
+ (ROUNDUP_TO_PAGE_BOUNDARY): New macro.
+ (data_segment_old_fileoff): Initialize explicitly.
+ (print_region, unexec_regions_recorder, print_load_command_name)
+ (copy_segment, copy_data_segment): Use long format in printf.
+ (MAX_UNEXEC_REGIONS): Increase to 400.
+ (unexec_regions_recorder): Don't warn too many regions here.
+ (find_emacs_zone_regions): Warn too many regions here.
+ (print_load_command_name) [_LP64]: Show correct load command name.
+ (copy_segment, copy_data_segment): Use variable `curr_file_offset'.
+ Show starting virtual memory address. Don't show ending file offset.
+ (copy_symtab, copy_dysymtab, copy_twolevelhints): New argument DELTA.
+ (dump_it): Use new local variable `linkedit_delta' and pass to them.
+ Error if trying to handle multiple DATA segments.
+ (unexec): Initialize variable `pagesize'.
+
+2006-11-01 Juanma Barranquero <[email protected]>
+
+ * eval.c (Fcatch): Doc fix.
+
+2006-10-31 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c [MAC_OS] (image_load_qt_1, xpm_scan, xpm_make_color_table_v)
+ (xpm_put_color_table_v, xpm_get_color_table_v, xpm_make_color_table_h)
+ (xpm_put_color_table_h, xpm_get_color_table_h, xpm_str_to_color_key)
+ (xpm_load_image): Add const qualifier to arguments.
+ [MAC_OS] (xpm_color_key_strings): Make static const.
+
+ * mac.c (create_apple_event_from_event_ref)
+ (create_apple_event_from_drag_ref, skip_white_space, parse_comment)
+ (parse_include_file, parse_binding, parse_component)
+ (parse_resource_name, parse_value, parse_resource_line)
+ (xrm_merge_string_database, xrm_get_resource)
+ (xrm_get_preference_database): Add const qualifier to arguments.
+ [MAC_OSX] (sys_select): Make variable `context' static const.
+
+ * macfns.c (mac_color_map): Make static const.
+ (mac_color_map_lookup): Add const qualifier to arguments.
+
+ * macmenu.c (install_menu_quit_handler): Make variable `typesList'
+ static const.
+ (name_is_separator): Add const qualifier to arguments.
+
+ * macselect.c (init_service_handler): Make variable `specs' static
+ const.
+
+ * macterm.c (mac_create_bitmap_from_bitmap_data): Make variable
+ `swap_nibbles' static const.
+ (atsu_get_text_layout_with_text_ptr): Make variables `lengths',
+ `tags', `sizes', `values' static const.
+ (mac_draw_string_common): Make variables `context' static.
+ Make variables `tags', `sizes', and `values' static const.
+ (pcm_get_status, x_detect_focus_change, x_scroll_bar_handle_click)
+ (xlfdpat_create, xlfdpat_block_match_1, xlfdpat_match)
+ (mac_to_x_fontname, parse_x_font_name, add_mac_font_name)
+ (mac_do_list_fonts, is_fully_specified_xlfd, do_grow_window)
+ (mac_store_event_ref_as_apple_event, mac_make_rdb): Add const
+ qualifier to arguments.
+ (xlfd_scalable_fields, keycode_to_xkeysym_table)
+ (fn_keycode_to_keycode_table): Make static const.
+ (mac_load_query_font): Make variables `tags', `sizes', `values',
+ `types', and `selectors' static const.
+ (mac_handle_command_event, mac_handle_window_event):
+ Make variables `names' and `types' static const.
+ (init_command_handler, install_window_handler): Make variables
+ `specs*' static const.
+ (mac_handle_font_event, mac_handle_text_input_event)
+ (mac_store_service_event): Make variables `names' and `types'
+ const. Make variables `names_*' and `types_*' static const.
+
+ * macterm.h (create_apple_event_from_event_ref)
+ (create_apple_event_from_drag_ref, xrm_merge_string_database)
+ (xrm_get_resource, xrm_get_preference_database): Add const
+ qualifier to arguments in externs.
+
+2006-10-31 Kenichi Handa <[email protected]>
+
+ * xfns.c (xic_create_xfontset): Fix previous change.
+
+2006-10-30 Chong Yidong <[email protected]>
+
+ * s/openbsd.h (LD_SWITCH_SYSTEM): Add /usr/pkg/lib and
+ /usr/pkg/lib to library search path.
+
+2006-10-29 Mark Davies <[email protected]> (tiny change)
+
+ * ralloc.c (relinquish): Use a long for excess space counter to
+ handle 64-bit case correctly.
+
+2006-10-29 Jeramey Crawford <[email protected]>
+
+ * m/amdx86-64.h: Add defines for OpenBSD x86-64.
+
+2006-10-29 Juanma Barranquero <[email protected]>
+
+ * window.c (Fdisplay_buffer): Fix typo in docstring.
+
+2006-10-27 Ben North <[email protected]> (tiny change)
+
+ * w32term.c (x_draw_glyph_string_foreground): Set background mode
+ to TRANSPARENT before using overstrike to simulate bold faces.
+
+ * xfaces.c (best_matching_font): Fix logic to decide whether to
+ use overstriking to simulate bold-face (it was reversed).
+
+2006-10-23 Kim F. Storm <[email protected]>
+
+ * xdisp.c (remember_mouse_glyph): Do nothing if glyphs are not
+ initialized.
+
+ * keyboard.c (read_char): Make an element (t . EVENT) in
+ unread-command-events add EVENT to the current command's key sequence.
+ (syms_of_keyboard) <unread-command-events>: Update doc.
+
+2006-10-21 Richard Stallman <[email protected]>
+
+ * minibuf.c (Vread_expression_map): Define here.
+ (Qread_expression_history): New variable.
+ (syms_of_minibuf): Initialize them.
+ (Feval_minibuffer): Use Vread_expression_map and
+ Qread_expression_history.
+
+2006-10-21 Kenichi Handa <[email protected]>
+
+ * xfns.c (xic_create_fontsetname): If ADSTYLE field is not a wild
+ card, change it to "*".
+ (xic_create_xfontset): Call XCreateFontSet for each single
+ fontname in fontsetname.
+
+2006-10-19 Chong Yidong <[email protected]>
+
+ * callint.c (callint_message): Convert to a Lisp string.
+ (syms_of_callint): Initialize it.
+ (callint_message_size): Var deleted.
+ (Fcall_interactively): Use Fformat instead of doprnt to construct
+ prompt string.
+
+2006-10-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * xdisp.c (display_mode_line): Clear enabled_p flag on mode-line row.
+
+2006-10-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (Vmac_carbon_version_string) [TARGET_API_MAC_CARBON]:
+ New variable.
+ (syms_of_macfns) [TARGET_API_MAC_CARBON]: Defvar it.
+
+2006-10-19 Jan Dj,Ad(Brv <[email protected]>
+
+ * xselect.c (x_handle_selection_request): If the converted_selection
+ is nil or XCDR (converted_selection) is nil, decline the request.
+
+2006-10-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (get_utf8_string): Remove warnings with casts.
+ (xg_tool_bar_button_cb): Ditto.
+ (xg_tool_bar_callback): Ditto.
+
+2006-10-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * dispnew.c (adjust_frame_glyphs_for_frame_redisplay): Remove unused
+ variable ch_dim.
+ (adjust_frame_glyphs_for_window_redisplay): Likewise. Don't allocate
+ menu bar window matrices on non-X systems.
+
+ * mac.c (Fmac_get_preference, Fmac_code_convert_string): Add GCPROs.
+
+ * macterm.c (mac_query_char_extents): Don't return glyph ID if layout
+ adjustment is needed.
+ (mac_load_query_font): Check if width and height are positive.
+
+2006-10-14 Richard Stallman <[email protected]>
+
+ * sysdep.c (init_sys_modes): Delete DEFVAR_LISP in the wrong place.
+
+2006-10-13 Chong Yidong <[email protected]>
+
+ * xdisp.c (decode_mode_spec): Ignore %c and %l constructs in frame
+ title.
+
+2006-10-12 Chong Yidong <[email protected]>
+
+ * keymap.c (Fkey_binding): Check Lisp_Object types before doing
+ XCAR and XINT.
+
+2006-10-12 Romain Francoise <[email protected]>
+
+ * image.c (xbm_read_bitmap_data): Delete extra semicolon.
+
+2006-10-10 Stefan Monnier <[email protected]>
+
+ * eval.c: Include xterm.h for x_fully_uncatch_errors and friends.
+
+ * dispextern.h: Declare x_create_bitmap_from_xpm_data.
+
+ * xterm.c (x_check_expected_move): Remove unused var `count'.
+
+ * xmenu.c (syms_of_xmenu): Use Ffset rather than Fdefalias, since
+ Fdefalias is not declared in any *.h file.
+
+2006-10-09 Chong Yidong <[email protected]>
+
+ * dispnew.c (sit_for): Sit forever if TIMEOUT is t.
+
+ * keyboard.c (command_loop_1): Handle non-number values of
+ `minibuffer-message-timeout'.
+ (Fexecute_extended_command): Fix typo.
+
+ * minibuf.c (temp_echo_area_glyphs): Sit for
+ `minibuffer-message-timeout' seconds.
+
+2006-10-08 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_draw_image_string, mac_draw_image_string_16):
+ Add argument OVERSTRIKE_P.
+ (mac_draw_string_common, mac_draw_image_string_cg): Likewise.
+ Support overstrike.
+ (mac_draw_string, mac_draw_string_16): Remove functions.
+ (x_draw_glyph_string_foreground): Use overstrike when needed.
+ (x_draw_composite_glyph_string_foreground): Likewise.
+ Use mac_draw_image_string_16 instead of mac_draw_string_16.
+ (mac_load_query_font): Rename from XLoadQueryFont. Take argument
+ F instead of DPY. All uses changed. Don't save/restore font.
+
+2006-10-07 Ralf Angeli <[email protected]>
+
+ * w32fns.c (w32_createwindow): Honour left and top positions if
+ supplied explicitly.
+
+2006-10-06 Kim F. Storm <[email protected]>
+
+ * xdisp.c (pos_visible_p): Fix value when EOB is visible.
+
+2006-10-05 Chong Yidong <[email protected]>
+
+ * frame.c (Qinhibit_face_set_after_frame_default): New var.
+ (syms_of_frame): Initialize it.
+ (x_set_frame_parameters): Avoid resetting :font attributes to the
+ new-frame defaults.
+
+2006-10-03 Stefan Monnier <[email protected]>
+
+ * lisp.h (clear_regexp_cache): Declare.
+
+ * search.c (compile_pattern): Only check `cp->syntax_table' if needed.
+ (compile_pattern_1): Remember `used_syntax' in `cp->syntax_table'.
+ (clear_regexp_cache): Only flush those regexps which depend on
+ a syntax-table.
+
+ * regex.c (regex_compile): Set the new `used_syntax' bit.
+
+ * regex.h: Remove file local variables.
+ (struct re_pattern_buffer): New field `used_syntax'.
+
+2006-10-03 Kim F. Storm <[email protected]>
+
+ * process.c (list_processes_1): Run sentinels before removing dead
+ processes. Also remove `closed' network connections.
+
+2006-10-01 Stefan Monnier <[email protected]>
+
+ * xdisp.c (handle_fontified_prop): Don't fontify at EOB.
+
+2006-09-30 Eli Zaretskii <[email protected]>
+
+ * config.in: Regenerated.
+
+2006-09-29 Juri Linkov <[email protected]>
+
+ * buffer.c (syms_of_buffer): Reorder coding systems in the
+ docstring of %z to the real order displayed in the modeline.
+
+2006-09-28 Stefan Monnier <[email protected]>
+
+ * keymap.c (Fdefine_key): Yet another int/Lisp_Object mixup (YAILOM).
+
+2006-09-26 Chong Yidong <[email protected]>
+
+ * indent.c (Fvertical_motion): Do move back if the Lisp string
+ being displayed contains newlines.
+
+2006-09-26 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_compute_glyph_string_overhangs, XLoadQueryFont)
+ [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw before QDTextBounds.
+
+2006-09-26 Kenichi Handa <[email protected]>
+
+ * keymap.c (Fsingle_key_description): For an invalid char, return
+ "Invalid char code NNNNN".
+
+2006-09-25 Chong Yidong <[email protected]>
+
+ * callint.c (Fcall_interactively): Doc fix.
+
+2006-09-25 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (x_underline_at_descent_line): New variable.
+ (syms_of_macterm): DEFVAR_BOOL it.
+ (x_draw_glyph_string): Use it.
+ (XLoadQueryFont): Calculate min_bounds.descent and max_bounds.descent.
+
+2006-09-25 Kenichi Handa <[email protected]>
+
+ * keymap.c (Fsingle_key_description): Return unique names for
+ generic characters.
+
+2006-09-24 Richard Stallman <[email protected]>
+
+ * search.c (compile_pattern_1): Don't BLOCK_INPUT.
+
+2006-09-24 Eli Zaretskii <[email protected]>
+
+ * makefile.w32-in ($(BLD)/fns.$(O), $(BLD)/w32proc.$(O)):
+ Depend on nt/inc/langinfo.h and nt/inc/nl_types.h.
+
+ * w32proc.c (nl_langinfo): New function.
+
+ * w32fns.c (w32-pass-alt-to-system, w32-alt-is-meta)
+ (w32-pass-lwindow-to-system, w32-enable-num-lock)
+ (w32-enable-caps-lock, w32-scroll-lock-modifier)
+ (w32-lwindow-modifier, w32-rwindow-modifier)
+ (w32-apps-modifier, w32-mouse-button-tolerance): Doc fix.
+
+2006-09-23 Juanma Barranquero <[email protected]>
+
+ * minibuf.c (Finternal_complete_buffer, Fread_minibuffer)
+ (Fdisplay_completion_list): Fix typos in docstrings.
+
+2006-09-23 Romain Francoise <[email protected]>
+
+ * s/gnu-linux.h (MAIL_USE_FLOCK): Check for HAVE_LIBLOCKFILE too.
+
+2006-09-23 Kenichi Handa <[email protected]>
+
+ * keymap.c (Fmap_keymap): Docstring mentions about generic character.
+
+2006-09-22 Stefan Monnier <[email protected]>
+
+ * regex.c (analyse_first): For eight-bit-control chars, mark both the
+ char's value and its leading byte in the fastmap.
+ (re_search_2): When fast-scanning without translation, be careful to
+ check that we only match the leading byte of a multibyte char.
+
+ * charset.h (PREV_CHAR_BOUNDARY): Make it work from within a char's
+ byte sequence.
+ (AT_CHAR_BOUNDARY): New macro.
+
+2006-09-22 Kenichi Handa <[email protected]>
+
+ * fns.c (optimize_sub_char_table): Don't optimize a sub-char-table
+ whose default value is non-nil.
+
+2006-09-22 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_file_with_chooser): Only show C-l help for
+ Gtk+ versions < 2.10.
+
+ * xfns.c (syms_of_xfns): Fix typo in help text for
+ x-gtk-file-dialog-help-text.
+
+2006-09-21 Kim F. Storm <[email protected]>
+
+ * fns.c (Fmemq): Refill doc string.
+ (Fmemql): New defun, like memq but using eql.
+ (syms_of_fns): Defsubr it.
+
+2006-09-20 Kim F. Storm <[email protected]>
+
+ * xdisp.c (pos_visible_p): CHARPOS < 0 means return info for
+ last visible glyph in window.
+
+ * window.c (Fset_window_hscroll, Fwindow_line_height):
+ Doc fix. Use "off-window" instead of "off-screen".
+ (Fpos_visible_in_window_p): Likewise.
+ If POS is t, return info for last visible glyph in window.
+
+2006-09-19 Chong Yidong <[email protected]>
+
+ * search.c (struct regexp_cache): New entry syntax_table.
+ (compile_pattern_1): Set it.
+ (syms_of_search): Initialize it.
+ (compile_pattern): Require the syntax_table entry of the cache
+ element to match the current syntax table entry.
+
+2006-09-19 Stefan Monnier <[email protected]>
+
+ * window.c (Fwindow_end): Fix recent change.
+
+2006-09-19 Kim F. Storm <[email protected]>
+
+ * window.c (Fset_window_hscroll, Fpos_visible_in_window_p):
+ Doc fix. Use "off-screen" instead of "invisible".
+ (Fwindow_line_height): Make line numbers 0-based. Make line arg
+ optional; if nil, use current cursor row. Handle text terminals
+ properly. Return nil if non-interactive or pseudo-window.
+
+2006-09-19 Stefan Monnier <[email protected]>
+
+ * keymap.c: Include alloca.h if available.
+ (Fkey_binding): Only use AREF after checking it's a vector.
+ Remove unused var `window'.
+
+2006-09-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * emacs.c (shut_down_emacs) [!subprocesses]: Don't set
+ inhibit_sentinels.
+
+ * mac.c [!MAC_OSX] (select): Fix argument name.
+
+ * macmenu.c (enum mac_menu_kind, min_menu_id): New enumerator and
+ menu ID for Apple menu.
+ (menubar_selection_callback): Remove function.
+ (find_and_call_menu_selection): New function from xmenu.c.
+ (x_activate_menubar): Use it.
+ (set_frame_menubar): Don't use f->output_data.mac->menubar_active.
+
+ * macterm.c (menubar_selection_callback): Remove extern.
+ (M_APPLE): Change to 234.
+ (do_apple_menu) [!TARGET_API_MAC_CARBON]: Make non-static.
+ (do_menu_choice): Remove function.
+
+ * macterm.h (struct mac_output): Remove member menubar_active.
+ (do_menu_choice): Remove extern.
+ (do_apple_menu) [!TARGET_API_MAC_CARBON]: Add extern.
+
+2006-09-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (syms_of_xfns): Rename x_gtk_show_chooser_help_text to
+ x_gtk_file_dialog_help_text.
+
+ * gtkutil.c (xg_uses_old_file_dialog): Rename x-use-old-gtk-file-dialog
+ to x-gtk-use-old-file-dialog.
+ (xg_get_file_with_chooser): Rename x_gtk_show_chooser_help_text to
+ x_gtk_file_dialog_help_text.
+
+ * xfns.c (syms_of_xfns): Ditto.
+
+2006-09-18 Kim F. Storm <[email protected]>
+
+ * window.c (Fwindow_line_visibility): Remove.
+ (Fwindow_line_height): New defun replacing it.
+ (syms_of_window): Defsubr it.
+
+2006-09-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (SELECT_USE_CFSOCKET) [MAC_OSX]: Set default to 1.
+ [MAC_OSX] (sys_select) [SELECT_USE_CFSOCKET]: Fix pointer type.
+
+2006-09-17 Jay Belanger <[email protected]>
+
+ * gmalloc.c:
+ * md5.c:
+ * md5.h:
+ * strftime.c: Replace "GNU Library General Public License" by "GNU
+ General Public License" throughout.
+
+2006-09-17 Kim F. Storm <[email protected]>
+
+ * dispnew.c (update_text_area): Undo 2000-07-18 change.
+ Always redrawing whole row if line has mouse-face in it causes
+ excessive flickering of the mode line.
+
+2006-09-17 Chong Yidong <[email protected]>
+
+ * search.c (clear_regexp_cache): New function.
+
+ * syntax.c (Fmodify_syntax_entry): Clear regexp cache.
+
+2006-09-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_file_with_chooser):
+ Check x-gtk-show-chooser-help-text before adding the help text.
+
+ * xfns.c (syms_of_xfns): New variable: x-gtk-show-chooser-help-text.
+
+ * gtkutil.c (get_utf8_string): Try harder to convert to UTF8. Gtk+
+ will simply crash if we fail.
+
+2006-09-16 Richard Stallman <[email protected]>
+
+ * regex.c (re_compile_pattern): Set gl_state.current_syntax_table.
+
+2006-09-15 Kim F. Storm <[email protected]>
+
+ * window.c (Fwindow_line_visibility): New defun for line-move-partial.
+ (syms_of_window): Defsubr it.
+ (Fwindow_end): Use window's buffer rather than current buffer.
+
+2006-09-15 Jay Belanger <[email protected]>
+
+ * COPYING: Replace "Library Public License" by "Lesser Public
+ License" throughout.
+
+2006-09-15 David Kastrup <[email protected]>
+
+ * Makefile.in (keymap.o): Add "keymap.h" and "window.h" dependencies.
+
+ * keymap.c: include "window.h".
+ (Fcommand_remapping): New optional POSITION argument.
+ (Fkey_binding): New optional POSITION argument. Completely rework
+ handling of mouse clicks to get the same order of keymaps as
+ `read-key-sequence' and heed POSITION. Also temporarily switch
+ buffers to location of mouse click and back.
+
+ * keyboard.c (command_loop_1): Adjust call of `Fcommand_remapping'
+ for additional argument.
+ (parse_menu_item): Adjust call of `Fkey_binding' for additional
+ argument.
+ (read_key_sequence): If there are both `local-map' and `keymap'
+ text properties at some buffer position, heed both.
+
+ * keymap.h: Declare additional optional arguments of
+ `Fcommand_remapping' and `Fkey_binding'.
+
+2006-09-15 Juanma Barranquero <[email protected]>
+
+ * indent.c (Fcurrent_column, Findent_to): Fix typos in docstring.
+
+2006-09-14 Andreas Schwab <[email protected]>
+
+ * print.c: Whitespace fixup.
+
+2006-09-14 Kim F. Storm <[email protected]>
+
+ * xdisp.c (produce_image_glyph): Automatically crop wide images at
+ right window edge so we can draw the cursor on the same row to
+ avoid confusing redisplay by placing the cursor outside the visible
+ window area.
+
+2006-09-13 YAMAMOTO Mitsuharu <[email protected]>
+
+ * xterm.c (x_initialize): Don't install Xt event timer here.
+ (x_timeout_atimer_activated_flag): New var.
+ (x_activate_timeout_atimer): New function to install Xt timer.
+ (x_send_scroll_bar_event, x_process_timeouts): Use it.
+
+ * xmenu.c (x_menu_set_in_use, popup_activate_callback)
+ (create_and_show_popup_menu, create_and_show_dialog): Use it.
+
+ * xterm.h (x_activate_timeout_atimer): Add prototype.
+
+2006-09-13 Richard Stallman <[email protected]>
+
+ * print.c (print_string): When printcharfun is t,
+ copy string contents and call strout on the copy.
+
+ * keyboard.c (read_char): If end_time specified, don't put the
+ event into this_command_keys.
+ (read_key_sequence): If Voverriding_terminal_local_map is specified,
+ don't check Voverriding_local_map at all.
+
+2006-09-12 Stefan Monnier <[email protected]>
+
+ * textprop.c (Fnext_property_change, Fnext_single_property_change)
+ (Fprevious_property_change, Fprevious_single_property_change):
+ Avoid changing limit, so we can correctly catch the case where the
+ property is constant up to limit.
+
+2006-09-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (mac_window) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
+ * macterm.c (XTread_socket) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
+ Undo 2006-09-08 change.
+
+2006-09-11 Chong Yidong <[email protected]>
+
+ * keymap.c (Fkey_binding): Use string position for string objects.
+
+2006-09-11 Kim F. Storm <[email protected]>
+
+ * keymap.c (Fkey_binding): Fix last change.
+
+ * editfns.c (Fmessage): Recommend using (message "%s" ...).
+
+2006-09-10 Chong Yidong <[email protected]>
+
+ * keymap.c (Fkey_binding): Check for local keymap for mouse click
+ events.
+
+2006-09-10 Kim F. Storm <[email protected]>
+
+ * keyboard.c (Finput_pending_p): Check Vunread_input_method_events
+ and Vunread_post_input_method_events.
+
+ * dispnew.c (Fredisplay): Document return value.
+
+2006-09-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (Fx_close_connection): Call xg_display_close when USE_GTK.
+
+ * gtkutil.c (xg_display_close): Always change default display if needed,
+ check for < Gtk+ version 2.10 before calling gdk_display_close.
+
+2006-09-10 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c [MAC_OSX] (sys_select): Check argument `nfds' more rigidly.
+ Make variable `ofds' static. Remove variable `maxfd'.
+
+ * macfns.c (Fx_file_dialog): Remove unused variable `f'.
+ Call check_mac.
+
+ * macmenu.c (Vmenu_updating_frame, syms_of_macmenu):
+ * w32menu.c (Vmenu_updating_frame, syms_of_w32menu):
+ Apply 2006-09-08 change for xmenu.c.
+
+ * xfns.c (Fx_file_dialog): Call check_x.
+
+2006-09-10 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): Use hollow cursor on
+ non-transparent images.
+
+2006-09-09 Eli Zaretskii <[email protected]>
+
+ * editfns.c (Fsystem_name): Mention "host" in the doc string.
+ (syms_of_editfns) <system-name>: Likewise.
+
+2006-09-08 Martin Rudalics <[email protected]>
+
+ * xdisp.c (mouse_autoselect_window): Remove.
+ (Vmouse_autoselect_window): New variable. DEFVAR_LISP it.
+
+ * dispextern.h (mouse_autoselect_window): Remove extern.
+ (Vmouse_autoselect_window): Add extern.
+
+ * macterm.c (XTread_socket): Test Vmouse_autoselect_window
+ instead of mouse_autoselect_window.
+
+ * msdos.c (dos_rawgetc): Likewise.
+
+ * w32term.c (w32_read_socket): Likewise.
+
+ * xterm.c (handle_one_xevent): Likewise.
+
+2006-09-08 Richard Stallman <[email protected]>
+
+ * xdisp.c (Vmenu_updating_frame): Define here.
+ (syms_of_xdisp): DEFVAR it here.
+ (update_menu_bar): Always return hooks_run.
+ Set Vmenu_updating_frame.
+
+ * xdisp.c (redisplay_internal): Test Vinhibit_redisplay
+ before calculating SELECTED_FRAME.
+
+ * xmenu.c (Vmenu_updating_frame): Don't define here.
+ (syms_of_xmenu): Don't DEFVAR it here.
+
+ * xterm.c (x_error_quitter): For BadName error, just return.
+
+ * eval.c (find_handler_clause): Give up on debugger if INPUT_BLOCKED_P.
+
+ * casetab.c (init_casetab_once): Call set_case_table.
+
+ * emacs.c (shut_down_emacs): Set inhibit_sentinels.
+
+ * process.c (inhibit_sentinels): New variable.
+ (exec_sentinel): Test inhibit_sentinels.
+ (init_process): Initialize it.
+
+ * process.h (inhibit_sentinels): Add decl.
+
+ * search.c (looking_at_1, string_match_1, search_command):
+ Make syntax table's canon table point to eqv table.
+
+2006-09-08 Andreas Schwab <[email protected]>
+
+ * print.c (strout): Fix whitespace.
+
+2006-09-08 Kim F. Storm <[email protected]>
+
+ * xterm.c (x_draw_glyph_string): Fix 2006-08-24 change.
+
+2006-09-08 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c [!MAC_OSX]: Don't include keyboard.h.
+ [!MAC_OSX] (select): Try detect_input_pending before ReceiveNextEvent
+ in the same BLOCK_INPUT block, in case that some input has already
+ been read asynchronously. Pretend to be interrupted by a signal
+ if some input is available.
+ [MAC_OSX] (select_and_poll_event, sys_select): Likewise.
+ (SELECT_POLLING_PERIOD_USEC) [SELECT_USE_CFSOCKET]: Change to 100000.
+ Now used for ReceiveNextEvent timeout instead of select timeout.
+ (EVENT_CLASS_SOCK) [SELECT_USE_CFSOCKET]: Remove macro.
+ [SELECT_USE_CFSOCKET] (socket_callback): Add non-blocking connect
+ support. Quit event loop.
+ [MAC_OSX] (sys_select) [SELECT_USE_CFSOCKET]: Add non-blocking
+ connect support. Reuse previously allocated CFRunLoopSource.
+ (Fmac_process_hi_command) [TARGET_API_MAC_CARBON]: New function.
+ (syms_of_mac) [TARGET_API_MAC_CARBON]: Defsubr it.
+
+ * macfns.c (mac_window) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]:
+ Specify kWindowAsyncDragAttribute.
+
+ * macterm.c (mac_handle_origin_change, mac_handle_size_change)
+ (mac_get_ideal_size): New functions.
+ (x_set_offset, x_set_window_size, x_make_frame_visible)
+ (do_zoom_window, mac_handle_window_event, XTread_socket): Use them.
+ (install_window_handler, mac_handle_window_event)
+ [USE_CARBON_EVENTS]: Handle kEventWindowGetIdealSize and
+ kEventWindowBoundsChanged.
+ (XTread_socket) [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: Don't call
+ DragWindow.
+
+2006-09-07 Andreas Schwab <[email protected]>
+
+ * m/ibms390x.h (START_FILES, LIB_STANDARD): Override to
+ use lib64 instead of lib.
+
+2006-09-06 Stefan Monnier <[email protected]>
+
+ * Makefile.in: Avoid double quotes when possible.
+
+2006-09-06 Kenichi Handa <[email protected]>
+
+ * editfns.c (Fformat_time_string): Use make_unibyte_string to make
+ a Lisp string from the result of emacs_memftimeu call.
+
+2006-09-06 Kim F. Storm <[email protected]>
+
+ * xdisp.c (pos_visible_p): Remove exact_mode_line_heights_p arg;
+ so calculate heights even when pos-visible-in-window-p is called
+ with partially = t. Don't overshoot last_visible_y in move_it_to.
+ Return row height and row number in new rowh and vpos args.
+ (cursor_row_fully_visible_p): First line is always "fully visible".
+ (try_window): Don't clear matrix if vscrolled.
+
+ * lisp.h (pos_visible_p): Update prototype.
+
+ * window.c (Fpos_visible_in_window_p): Adapt to new pos_visible_p.
+ Return row height and row number for partially visible rows.
+ Modify return value to a 2 element list for fully visible rows and
+ 6 for partially visible row.
+ (window_scroll_pixel_based): Use pos_visible_p directly instead of
+ Fpos_visible_in_window_p. Fix auto vscrolling for partially
+ visible lines. Only vscroll backwards if already vscrolled
+ forwards. Unconditionally vscroll forwards if PT is first (and
+ only) line. Set new window start instead of scrolling at
+ start/end of tall line.
+
+2006-09-05 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (install_window_handler, mac_handle_window_event)
+ [USE_CARBON_EVENTS]: Handle kEventWindowClose.
+ [USE_MAC_TSM] (mac_handle_text_input_event): Set modifiers for
+ ASCII keystroke event.
+
+2006-09-04 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_file_with_chooser): Don't mention specific keys in
+ the file chooser message. Only call gtk_file_chooser_set_current_name
+ when action is SAVE.
+
+2006-09-04 Andreas Schwab <[email protected]>
+
+ * Makefile.in: Double all single and back quotes in C-style
+ comments to help fontifier.
+
+2006-09-03 Jason Rumney <[email protected]>
+
+ * w32.c (shutdown_handler): New function to exit cleanly on shutdown.
+ (globals_of_w32): Register it as a signal handler.
+
+2006-09-02 Juri Linkov <[email protected]>
+
+ * marker.c (Fmarker_position): Doc fix.
+
+2006-09-03 Eli Zaretskii <[email protected]>
+
+ * window.c (syms_of_window) <split-height-threshold>:
+ <window-min-height, window-min-width>: Doc fix.
+
+2006-09-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_file_with_chooser): Change file chooser message
+ for writing files. Call gtk_file_chooser_set_current_name to keep
+ default filename.
+
+ * minibuf.c (Finternal_complete_buffer): Move after DEFUN:s it calls.
+
+2006-09-02 Jindrich Makovicka <[email protected]> (tiny change)
+
+ * fns.c (concat) [__GNUC__]: Declare with
+ `__attribute__((noinline))'.
+
+ * eval.c (apply1, call2) [__GNUC__]: Declare with
+ `__attribute__((noinline))'.
+
+2006-09-02 Stuart D. Herring <[email protected]>
+
+ * minibuf.c (Finternal_complete_buffer): New function.
+ (syms_of_minibuf): Defsubr it.
+ (Fread_buffer): Use it, instead of Vbuffer_alist.
+
+2006-09-01 Martin Rudalics <[email protected]>
+
+ * buffer.h (struct buffer_text): New field chars_modiff.
+ (CHARS_MODIFF, BUF_CHARS_MODIFF): New macros.
+ * buffer.c (Fbuffer_chars_modified_tick): New function returning
+ value of BUF_CHARS_MODIFF.
+ (syms_of_buffer): Defsubr it.
+ (Fget_buffer_create): Initialize BUF_CHARS_MODIFF.
+ * insdel.c (modify_region): New argument preserve_chars_modiff.
+ Set CHARS_MODIFF to MODIFF provided preserve_chars_modiff is zero.
+ (insert_1_both, insert_from_string_1, insert_from_buffer_1)
+ (adjust_after_replace, adjust_after_replace_noundo)
+ (replace_range, replace_range_2, del_range_2): Reset CHARS_MODIFF.
+ * lisp.h (modify_region): Add fourth argument in extern.
+ * casefiddle.c (casify_region): Call modify_region with fourth
+ argument zero to assert that CHARS_MODIFF is updated.
+ * editfns.c (Fsubst_char_in_region, Ftranslate_region_internal)
+ (Ftranspose_regions): Likewise.
+ * textprop.c (Fadd_text_properties, Fset_text_properties)
+ (Fremove_text_properties, Fremove_list_of_text_properties):
+ Call modify_region with fourth argument 1 to avoid that
+ CHARS_MODIFF is updated.
+
+2006-08-31 Richard Stallman <[email protected]>
+
+ * editfns.c (Fformat): Don't sign-extend for %o or %x.
+
+2006-08-29 Chong Yidong <[email protected]>
+
+ * indent.c (Fvertical_motion): Don't move back if we were
+ displaying a Lisp string, either.
+
+2006-08-28 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_window_cursor_type) [!HAVE_WINDOW_SYSTEM]:
+ Don't attempt to replace cursor on image glyphs.
+
+2006-08-28 Kenichi Handa <[email protected]>
+
+ * coding.c (Fdetect_coding_region, Fdetect_coding_string):
+ Fix docstring about ISO-2022 control characters.
+
+2006-08-28 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): Replace BOX cursor on images
+ with a hollow box cursor if image is larger than 32x32 (or the default
+ frame font if that is bigger). Replace any other cursor on images
+ with hollow box cursor, as redisplay doesn't support bar and hbar
+ cursors on images.
+
+2006-08-27 YAMAMOTO Mitsuharu <[email protected]>
+
+ * alloc.c (BLOCK_INPUT_ALLOC, UNBLOCK_INPUT_ALLOC): Undo previous
+ change. Move mutex lock/unlock operations inside BLOCK_INPUT.
+
+ * dired.c (directory_files_internal_unwind, directory_files_internal)
+ (file_name_completion): Add BLOCK_INPUT around opendir/closedir.
+
+ * image.c [MAC_OS] (image_load_qt_1): Use ComponentResult instead
+ of OSErr.
+
+ * keyboard.c (in_sighandler): Remove variable.
+ (Fcurrent_idle_time): Add missing `doc:'.
+ (input_available_signal, init_keyboard): Undo previous change.
+
+ * keyboard.h (in_sighandler): Remove extern.
+
+ * mac.c (create_apple_event_from_event_ref, select)
+ (Fmac_get_file_creator, Fmac_get_file_type, Fmac_set_file_creator)
+ (Fmac_set_file_type, cfstring_create_normalized)
+ (mac_get_system_locale, select_and_poll_event, sys_select):
+ Use OSStatus instead of OSErr.
+
+ * macfns.c [TARGET_API_MAC_CARBON] (mac_update_proxy_icon):
+ Don't use FRAME_FILE_NAME. Use (FS)UpdateAlias.
+ (Fx_create_frame): Apply 2006-07-03 for xfns.c.
+
+ * macselect.c (get_scrap_from_symbol, clear_scrap, put_scrap_string)
+ (put_scrap_private_timestamp, scrap_has_target_type, get_scrap_string)
+ (get_scrap_private_timestamp, get_scrap_target_type_list)
+ (x_own_selection, x_get_foreign_selection)
+ (Fx_disown_selection_internal, Fx_selection_owner_p)
+ (Fx_selection_exists_p): Use OSStatus instead of OSErr.
+
+ * macterm.c (mac_draw_string_common, mac_query_char_extents)
+ (x_iconify_frame, XLoadQueryFont, install_window_handler)
+ (mac_handle_command_event, init_command_handler, init_menu_bar):
+ Use OSStatus instead of OSErr.
+ (x_free_frame_resources) [TARGET_API_MAC_CARBON]: Don't use
+ FRAME_FILE_NAME.
+ (x_query_font): Apply 2006-08-04 change for xterm.c.
+ (Qhi_command): Rename from Qhicommand. All uses changed.
+
+ * macterm.h (struct mac_output) [TARGET_API_MAC_CARBON]: Remove member
+ file_name.
+ (FRAME_FILE_NAME): Remove macro.
+ (install_window_handler, create_apple_event_from_event_ref):
+ Return OSStatus instead of OSErr.
+
+2006-08-26 Kim F. Storm <[email protected]>
+
+ * buffer.c (Fset_buffer_multibyte):
+ * editfns.c (Fcurrent_time, Fget_internal_run_time):
+ * macfns.c (Fxw_color_values):
+ * w32fns.c (Fxw_color_values):
+ * xfns.c (Fxw_color_values): Simplify; use list3.
+
+ * fileio.c (Fmake_directory_internal, Fdelete_directory)
+ (Fdelete_file): Simplify; use list1.
+ (Frename_file, Fadd_name_to_file, Fmake_symbolic_link):
+ Simplify; remove NO_ARG_ARRAY stuff, use list2.
+
+2006-08-25 Richard Stallman <[email protected]>
+
+ * buffer.c (Fswitch_to_buffer): Fix previous change.
+
+2006-08-25 Kim F. Storm <[email protected]>
+
+ * keyboard.c (Fcurrent_idle_time): Simplify.
+
+2006-08-25 Richard Stallman <[email protected]>
+
+ * fns.c (sxhash_string): Rotate properly; don't lose bits.
+
+2006-08-24 Francesc Rocher <[email protected]>
+
+ * xdisp.c (overline_margin): New variable.
+ (x_produce_glyphs): Use it.
+ (syms_of_xdisp): DEFVAR_INT it.
+
+ * xterm.c (x_underline_at_descent_line): New variable.
+ (syms_of_xterm): DEFVAR_BOOL it.
+ (x_draw_glyph_string): Use it.
+ Draw underline and overline up to the end of line if the face
+ extends to the end of line.
+
+ * macterm.c: Likewise.
+
+ * w32term.c: Likewise.
+
+2006-08-24 Nick Roberts <[email protected]>
+
+ * buffer.c (Fswitch_to_buffer): Move buffer to front of
+ buffer-alist if necessary.
+
+2006-08-22 Kim F. Storm <[email protected]>
+
+ * xdisp.c (update_tool_bar): Redisplay toolbar also when only
+ number of items changes.
+
+2006-08-22 Stefan Monnier <[email protected]>
+
+ * buffer.c (Fset_buffer_multibyte): Record proper undo entry.
+
+2006-08-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c: Clarify difference between in_sighandler and
+ handling_signal.
+
+2006-08-21 Kim F. Storm <[email protected]>
+
+ * macterm.c (x_draw_stretch_glyph_string):
+ * w32term.c (x_draw_stretch_glyph_string):
+ * xterm.c (x_draw_stretch_glyph_string): It is ok to draw a
+ stretch glyph in left marginal areas on header and mode lines.
+
+2006-08-21 Kenichi Handa <[email protected]>
+
+ * keyboard.c (syms_of_keyboard): Docstring of
+ Vunread_post_input_method_events and Vunread_input_method_events
+ fixed.
+
+2006-08-20 Chong Yidong <[email protected]>
+
+ * keyboard.c (show_help_echo): Preserve mouse movement flag if
+ tracking mouse.
+
+2006-08-20 Richard Stallman <[email protected]>
+
+ * xfaces.c (load_pixmap): Add quotes in error message.
+
+ * keyboard.c (Fcurrent_idle_time): New function.
+ (syms_of_keyboard): defsubr it.
+
+2006-08-18 Nick Roberts <[email protected]>
+
+ * window.c (Fset_window_fringes): Do nothing on a tty.
+ (Fwindow_fringes): Put ? operator after the line break.
+
+2006-08-16 Andreas Schwab <[email protected]>
+
+ * print.c (debug_output_compilation_hack): Fix return type.
+
+2006-08-16 Richard Stallman <[email protected]>
+
+ * print.c (debug_output_compilation_hack): New function.
+
+2006-08-16 Kenichi Handa <[email protected]>
+
+ * fileio.c (choose_write_coding_system): Use LF for end-of-line
+ in auto-saving.
+
+2006-08-15 Chong Yidong <[email protected]>
+
+ * keyboard.c (read_char): Don't change idle timer state at all if
+ end_time is supplied.
+
+2006-08-15 Kenichi Handa <[email protected]>
+
+ * coding.c (ONE_MORE_BYTE_CHECK_MULTIBYTE): New arg RET. If SRC
+ is exhausted, return with RET.
+ (detect_coding_emacs_mule, detect_coding_iso2022)
+ (detect_coding_sjis, detect_coding_big5, detect_coding_utf_8)
+ (detect_coding_utf_16, detect_coding_ccl): Adjusted for the above
+ change.
+
+2006-08-14 Chong Yidong <[email protected]>
+
+ * keyboard.c (read_char): Don't reset idle timers if a time limit
+ is supplied.
+
+2006-08-14 Kim F. Storm <[email protected]>
+
+ * .gdbinit (pitx): Print iterator position.
+ Limit stack dump in case iterator is not initialized.
+
+2006-08-12 Eli Zaretskii <[email protected]>
+
+ * frame.c (Fmouse_position, Fmouse_pixel_position)
+ (Fset_mouse_position, Fset_mouse_pixel_position): Doc fix.
+
+2006-08-11 Jan Dj,Ad(Brv <[email protected]>
+
+ * xselect.c (Fx_register_dnd_atom): New function.
+ (syms_of_xselect): Defsubr it.
+ (x_handle_dnd_message): Check that message_type is in
+ dpyinfo->x_dnd_atoms before generating lisp event.
+
+ * xterm.h (struct x_display_info): Add x_dnd_atoms* to keep track
+ of drag and drop Atoms.
+
+ * xterm.c (x_term_init): Initialize dpyinfo->x_dnd_atoms*.
+
+2006-08-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c: Define in_sighandler.
+ (input_available_signal): Set in_sighandler.
+ (init_keyboard): Initialize in_sighandler.
+
+ * keyboard.h: Declare in_sighandler.
+
+ * alloc.c (UNBLOCK_INPUT_ALLOC, BLOCK_INPUT_ALLOC): Use in_sighandler
+ to check if mutex should be locked or not.
+
+2006-08-09 Richard Stallman <[email protected]>
+
+ * keyboard.c (keyremap_step): No-op if fkey->parent = nil.
+ (read_key_sequence): Always start fkey.start and fkey.end at 0,
+ and likewise for keytran.
+
+2006-08-09 Kenichi Handa <[email protected]>
+
+ * coding.c (syms_of_coding): Improve the docstring
+ of file-coding-system-alist.
+
+2006-08-07 Andreas Schwab <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 1120000.
+
+2006-08-06 Chong Yidong <[email protected]>
+
+ * buffer.c (Vchange_major_mode_hook, Qchange_major_mode_hook): New vars.
+ (Fkill_all_local_variables): Use it.
+ (syms_of_buffer): Defvar it.
+
+2006-08-05 Eli Zaretskii <[email protected]>
+
+ * w32.c (w32_valid_pointer_p): New function.
+
+ * w32.h: Add prototype for w32_valid_pointer_p.
+
+ * alloc.c: Include w32.h.
+ (valid_lisp_object_p) [WINDOWSNT]: Call w32_valid_pointer_p to do
+ the job.
+
+ * keyboard.c (kbd_buffer_get_event): Return Qnil when current time
+ is exactly equal to end_time, not only when it is past that.
+
+2006-08-04 Chong Yidong <[email protected]>
+
+ * keyboard.c (read_char): Rebalance specpdl after receiving jump.
+
+ * process.c: Reapply 2006-08-01 change.
+
+2006-08-04 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (w32_query_font): Fix last change: use stricmp.
+
+2006-08-04 Stefan Monnier <[email protected]>
+
+ * editfns.c (Fsubst_char_in_region): Redo the setup work after running
+ the before-change-functions since they may have altered the buffer.
+
+2006-08-04 Ralf Angeli <[email protected]>
+
+ * w32fns.c (w32_createwindow): Handle -geometry command line option
+ and the geometry settings in the Registry.
+
+2006-08-04 Kenichi Handa <[email protected]>
+
+ * w32fns.c (w32_query_font): Compare names by ignoring case.
+
+ * xterm.c (x_query_font): Compare names by ignoring case.
+
+2006-08-03 Jason Rumney <[email protected]>
+
+ * w32menu.c (w32_menu_show, w32_dialog_show): Call Fsignal to quit
+ when no option selected.
+
+2006-08-03 Chong Yidong <[email protected]>
+
+ * process.c: Revert last change.
+
+2006-08-01 Kim F. Storm <[email protected]>
+
+ * process.c (wait_reading_process_output_unwind): New function.
+ Restores waiting_for_user_input_p to saved value.
+ (wait_reading_process_output): Unwind protect waiting_for_user_input_p
+ instead of save/restore old value on stack.
+
+2006-07-30 Thien-Thi Nguyen <[email protected]>
+
+ * editfns.c: Undo 2006-06-27 change.
+
+2006-07-29 Eli Zaretskii <[email protected]>
+
+ * coding.c (Ffind_operation_coding_system): Revert the change from
+ 2006-05-29.
+
+ * alloc.c [WINDOWSNT]: Include fcntl.h, to fix last change.
+
+2006-07-28 Richard Stallman <[email protected]>
+
+ * xfaces.c (lookup_named_face, Fdisplay_supports_face_attributes_p):
+ Add conditional aborts for clarity.
+
+ * xdisp.c (update_menu_bar): New arg HOOKS_RUN. Callers changed.
+ Used to avoid running the hooks over and over for each frame.
+ (prepare_menu_bars): Pass value from update_menu_bar
+ as HOOKS_RUN of next call.
+
+ * keyboard.c (safe_run_hooks_1): Don't crash if Vrun_hooks is nil.
+
+2006-07-28 Kim F. Storm <[email protected]>
+
+ * alloc.c (valid_pointer_p): New function (from valid_lisp_object_p).
+ (valid_lisp_object_p): Use it to check for valid SUBRP obj.
+
+2006-07-26 Chong Yidong <[email protected]>
+
+ * keyboard.c (read_char): New arg END_TIME specifying timeout.
+ All callers changed. Turn off echoing if END_TIME is non-NULL.
+ (kbd_buffer_get_event): New arg END_TIME.
+
+ * lread.c (read_filtered_event): New arg SECONDS to wait until.
+ (Fread_char, Fread_event, Fread_char_exclusive): New arg SECONDS.
+
+ * lisp.h: Update read-char, read-event, and read_filtered_event
+ prototypes.
+
+ * keyboard.h: Include systime.h. Update read_char prototype.
+
+2006-07-25 YAMAMOTO Mitsuharu <[email protected]>
+
+ * alloc.c (find_string_data_in_pure): New function.
+ (make_pure_string): Use it to reuse existing string data if possible.
+
+ * puresize.h (BASE_PURESIZE): Decrease to 1102000.
+
+2006-07-22 Stefan Monnier <[email protected]>
+
+ * keymap.c (Fdefine_key): If the key binding definition looks like an
+ XEmacs-style key sequence, convert it to Emacs's format.
+
+2006-07-22 Ralf Angeli <[email protected]>
+
+ * w32fns.c (w32_createwindow): If `left' and/or `top' frame
+ parameters are bound to some values, use that instead of
+ CW_USEDEFAULT.
+
+2006-07-21 Eli Zaretskii <[email protected]>
+
+ * w32.c (convert_time): Use explicit long double constants to
+ ensure long double arithmetics is used throughout.
+
+2006-07-20 YAMAMOTO Mitsuharu <[email protected]>
+
+ * alloc.c (pure_bytes_used_lisp, pure_bytes_used_non_lisp): New vars.
+ (init_alloc_once): Initialize them.
+ (pure_alloc): Allocate non-Lisp objects from the end of pure storage
+ without alignment.
+
+ * puresize.h (BASE_PURESIZE): Decrease to 1141000.
+
+2006-07-18 Francis Litterio <[email protected]>
+
+ * w32term.c (x_calc_absolute_position): Fix frame positioning
+ with negative X/Y coordinates.
+
+2006-07-18 Dan Nicolaescu <[email protected]>
+
+ * xterm.c (x_connection_closed, x_error_quitter): Mark as NO_RETURN.
+
+ * textprop.c (text_read_only): Likewise.
+
+ * lread.c (end_of_file_error): Likewise.
+
+ * lisp.h (circular_list_error, memory_full, buffer_memory_full):
+ Likewise.
+
+ * eval.c (unwind_to_catch): Likewise.
+
+ * buffer.h (buffer_slot_type_mismatch): Likewise.
+
+2006-07-18 Kim F. Storm <[email protected]>
+
+ Cleanup Fsignal calls that never returns; now only use it for Qquit.
+
+ * eval.c (xsignal): New func. Like Fsignal, but marked no-return.
+ (xsignal0, xsignal1, xsignal2, xsignal3): New no-return functions.
+ (signal_error): New no-return function (from xfaces.c).
+ (Fthrow): Use xsignal2 instead of Fsignal + abort.
+ (error): Use xsignal1 instead of Fsignal + abort.
+ (FletX, Flet, grow_specpdl): Use signal_error.
+ (Feval, Ffuncall, funcall_lambda): Use xsignal1, xsignal2.
+
+ * alloc.c (buffer_memory_full, memory_full): Use xsignal. Remove loop.
+ (list1): New function.
+
+ * lisp.h (list1): Add EXFUN.
+ (xsignal, xsignal0, xsignal1, xsignal2, xsignal3, signal_error):
+ Add prototypes. Mark them as no-return.
+
+ * buffer.c (Fbuffer_local_value, Fbarf_if_buffer_read_only):
+ Use xsignal1.
+
+ * callint.c (check_mark): Use xsignal0.
+
+ * casefiddle.c (casify_object): wrong_type_argument is no-return.
+
+ * cmds.c (Fforward_char, Fdelete_char): Use xsignal0.
+
+ * coding.c (Fcheck_coding_system): Use xsignal1. Remove loop.
+ (Fdefine_coding_system_internal): Use xsignal1.
+
+ * data.c (circular_list_error): Use xsignal.
+ (wrong_type_argument): Use xsignal2. Don't care about return value.
+ (args_out_of_range, args_out_of_range_3): Use xsignal2, xsignal3.
+ Remove loop around Fsignal.
+ (indirect_variable, Fsymbol_value, set_internal, Fdefault_value)
+ (indirect_function, Findirect_function, Fstring_to_number)
+ (Fmakunbound, Ffmakunbound, Fsymbol_function, Ffset): Use xsignal1.
+ (arith_driver, float_arith_driver, Frem, Fmod, arith_error):
+ Use xsignal0.
+
+ * doc.c (Fdocumentation): Use xsignal1.
+
+ * editfns.c (region_limit, Fget_internal_run_time): Use xsignal0.
+
+ * fileio.c (report_file_error): Use xsignal.
+ (barf_or_query_if_file_exists, Fcopy_file, Fdelete_file)
+ (Finsert_file_contents): Use xsignal2.
+ (syms_of_fileio): Use list2, list3.
+
+ * floatfns.c (arith_error, range_error, domain_error): Use xsignal2.
+ (range_error2, domain_error2): Use xsignal3.
+ (rounding_driver, fmod_float): Use xsignal0.
+ (float_error): Use xsignal1.
+ (matherr): Use xsignal.
+
+ * fns.c (Flength): wrong_type_argument is no-return.
+ (hashfn_user_defined, Fmake_hash_table): Use signal_error.
+ (Fmd5): Use xsignal1.
+
+ * frame.c (x_set_line_spacing, x_set_screen_gamma): Use signal_error.
+
+ * keyboard.c (recursive_edit_1): Use xsignal1.
+
+ * keymap.c (Fmap_keymap): Use xsignal1.
+
+ * lread.c (Fload): Use xsignal2, signal_error.
+ (end_of_file_error): Use xsignal0, xsignal1.
+ (read0): Use xsignal1.
+ (invalid_syntax): New error function marked no-return.
+ (read_integer, read1, read_list): Use it.
+
+ * macselect.c (x_get_local_selection): Use signal_error.
+
+ * msdos.c (Fmsdos_set_mouse_buttons): Use xsignal2.
+
+ * search.c (compile_pattern_1): Use xsignal1.
+ (signal_failure): Remove (was only called once).
+ (search_command): Use xsignal1 instead of signal_failure.
+
+ * syntax.c (scan_lists): Use xsignal3.
+
+ * textprop.c (text_read_only): Use xsignal0, xsignal1.
+
+ * unexsol.c (unexec): Use xsignal.
+
+ * window.c (window_scroll_pixel_based, window_scroll_line_based):
+ Use xsignal0.
+
+ * xfaces.c (signal_error): Move to eval.c.
+ (resolve_face_name): Use xsignal1.
+
+ * xfns.c (x_decode_color): Use signal_error.
+
+ * xselect.c (x_get_local_selection, copy_multiple_data)
+ (x_get_window_property_as_lisp_data)
+ (lisp_data_to_selection_data, CHECK_CUT_BUFFER)
+ (Fx_get_cut_buffer_internal): Use signal_error.
+
+2006-07-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (XTread_socket): Undo previous change.
+
+2006-07-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (keycode_to_xkeysym): Remove function. All uses now
+ directly lookup keycode_to_xkeysym_table.
+ [USE_MAC_TSM] (mac_handle_text_input_event): Don't construct
+ ASCII_KEYSTROKE_EVENT for non-zero keycode_to_xkeysym_table entries.
+ (XTread_socket): Use character codes to construct keypad key events.
+ (mac_initialize_display_info) [MAC_OSX]: Use CGDisplaySamplesPerPixel.
+ (x_delete_display): Apply 2006-07-04 change for xterm.c.
+
+2006-07-17 Richard Stallman <[email protected]>
+
+ * keyboard.c (Vcommand_error_function): New variable.
+ (syms_of_keyboard): Defvar it.
+ (cmd_error_internal): Simplify, and handle Vcommand_error_function.
+
+ * dispnew.c (init_display): Mention DISPLAY as well as TERM in err msg.
+
+2006-07-17 Kim F. Storm <[email protected]>
+
+ * xdisp.c (handle_single_display_spec): Ensure the right value of
+ it->position is saved by push_it.
+ (pop_it): Restore it->object for GET_FROM_BUFFER and GET_FROM_STRING.
+ (reseat_1): Don't setup it->object twice.
+ (set_iterator_to_next): No need to set it->object after pop_it.
+ (move_it_to): Explicitly check to see if last move reached to_charpos.
+
+2006-07-17 Thien-Thi Nguyen <[email protected]>
+
+ * xdisp.c (display_mode_line): Preserve match data.
+
+2006-07-14 Kim F. Storm <[email protected]>
+
+ * w32.c (pfn_WSACreateEvent, pfn_WSACloseEvent): New func ptrs.
+ (init_winsock): Load them. Use ws2_32.dll.
+ (sys_listen): Undo last change. Just set FILE_LISTEN flag.
+ (sys_accept): Undo last change. Instead, set child status to
+ STATUS_READ_ACKNOWLEDGED and reset char_avail event so next
+ sys_select will wakeup the reader thread.
+ (_sys_wait_accept): New function used by reader thread to wait for
+ an incoming connection on a server socket.
+
+ * w32.h (_sys_read_ahead, _sys_wait_accept): Add prototypes.
+
+ * w32proc.c (reader_thread): Use _sys_wait_accept to wait on a
+ server socket (FILE_LISTEN flag).
+
+2006-07-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * sound.c (alsa_init): Call snd_pcm_close after successful snd_pcm_open.
+
+2006-07-14 Kim F. Storm <[email protected]>
+
+ * w32.c: Fix high cpu load for server sockets.
+ (pfn_WSAEventSelect): New function ptr.
+ (init_winsock): Load it.
+ (sys_listen): Set FILE_LISTEN flag. Set event mask for socket's
+ char_avail event object to FD_ACCEPT.
+ (sys_accept): Check FILE_LISTEN flag. Set event mask on new
+ socket's char_avail event object to FD_READ|FD_CLOSE.
+
+ * w32.h (FILE_LISTEN): New filedesc flag value.
+
+2006-07-13 Kim F. Storm <[email protected]>
+
+ * bytecode.c (Fbyte_code): Use CAR, CDR for Bcar, Bcdr.
+ Use CAR_SAFE, CDR_SAFE for Bcar_safe, Bcdr_safe.
+ Simplify loops and use CAR for Bnth and Belt.
+
+ * data.c (Findirect_function): Optimize for no indirection.
+
+ * eval.c (Fthrow): Remove loop around Fsignal.
+ (Feval, Fapply, Ffuncall): Optimize for no function indirection.
+ Use original function name in all signaled errors.
+ Simplify Fsignal calls (no return).
+ (funcall_lambda): Simplify Fsignal calls (no return).
+
+2006-07-13 Andreas Schwab <[email protected]>
+
+ * syntax.c (scan_sexps_forward): Use EMACS_INT for out_bytepos and
+ out_charpos.
+
+2006-07-13 Kenichi Handa <[email protected]>
+
+ * editfns.c (Fformat): Fix calculation of text property positions
+ of format string.
+
+2006-07-12 Kim F. Storm <[email protected]>
+
+ * lisp.h (CHECK_TYPE): New macro for generic type checking.
+ (CAR_SAFE, CDR_SAFE): New macros.
+ (ARRAYP, CHECK_ARRAY): New macros.
+ (CHECK_VECTOR_OR_STRING, CHECK_SUBR): New macros.
+ (CHECK_WINDOW_CONFIGURATION): New macro.
+ (CHECK_LIST_CONS, CHECK_LIST_END): New checks for list traversal.
+ (CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST)
+ (CHECK_STRING, CHECK_STRING_CAR, CHECK_CONS, CHECK_SYMBOL)
+ (CHECK_CHAR_TABLE, CHECK_VECTOR, CHECK_VECTOR_OR_CHAR_TABLE)
+ (CHECK_BUFFER, CHECK_WINDOW, CHECK_LIVE_WINDOW, CHECK_PROCESS)
+ (CHECK_NUMBER, CHECK_NATNUM, CHECK_MARKER, CHECK_OVERLAY)
+ (CHECK_NUMBER_COERCE_MARKER, CHECK_FLOAT, CHECK_NUMBER_OR_FLOAT)
+ (CHECK_NUMBER_OR_FLOAT_COERCE_MARKER): Use CHECK_TYPE.
+
+ * category.h (CHECK_CATEGORY, CHECK_CATEGORY_SET):
+ * frame.h (CHECK_FRAME, CHECK_LIVE_FRAME): Use CHECK_TYPE.
+
+ * callint.c (Fcall_interactively):
+ * casefiddle.c (casify_object):
+ * editfns.c (general_insert_function):
+ * fns.c (Flength, Felt, Ffillarray):
+ * data.c (Fcar, Fcdr): Remove loop around wrong_type_argument.
+
+ * data.c (wrong_type_argument): Remove loop around Fsignal.
+ (Farrayp, Fsequencep): Use ARRAYP.
+ (Fcar): Use CAR.
+ (Fcar_safe): Use CAR_SAFE.
+ (Fcdr): Use CDR.
+ (Fcdr_safe): Use CDR_SAFE.
+ (Fsetcar, Fsetcdr): Use CHECK_CONS.
+ (Fsubr_arity, Fsubr_name): Use CHECK_SUBR.
+ (Faset): Use CHECK_ARRAY.
+
+ * fns.c (Felt): Use CHECK_ARRAY.
+ (concat): Use CHECK_NUMBER.
+ (Fsubstring, substring_both): Use CHECK_VECTOR_OR_STRING.
+ (Fmemq): Use CHECK_LIST.
+ (Fassq, Fassoc, Frassq, Frassoc): Use CAR.
+ (assq_no_quit): Use CAR_SAFE.
+ (Fnthcdr, Fmember, Fdelq, Fdelete, Fnreverse, Fnconc):
+ Use CHECK_LIST_CONS.
+ (Freverse, Fplist_get, Flax_plist_get): Use CHECK_LIST_END.
+
+ * bytecode.c (Fbyte_code): Use CHECK_VECTOR.
+
+ * casetab.c (check_case_table):
+ * category.c (check_category_table):
+ * marker.c (Fcopy_marker):
+ * syntax.c (check_syntax_table):
+ * xfaces.c (load_pixmap): Use CHECK_TYPE.
+
+ * fns.c (Fcopy_sequence, concat):
+ * fringe.c (Fdefine_fringe_bitmap):
+ * lread.c (check_obarray): Cleanup wrong_type_argument use.
+
+ * keyboard.c (access_keymap_keyremap): Use ARRAYP.
+
+ * keymap.c (Fdefine_key, Flookup_key):
+ * macros.c (Fstart_kbd_macro): Use CHECK_VECTOR_OR_STRING.
+
+ * mac.c (Fmac_get_preference): Use CHECK_LIST_END.
+
+ * search.c (Fset_match_data): Use CHECK_LIST.
+
+ * sunfns.c (sun_item_create): Use CHECK_LIST_CONS.
+
+ * window.c (Fwindow_configuration_frame, Fset_window_configuration):
+ (compare_window_configurations): Use CHECK_WINDOW_CONFIGURATION.
+
+2006-07-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * Makefile.in (dired.o, editfns.o, fileio.o): Depend on blockinput.h.
+
+ * dired.c: Include blockinput.h.
+ (Ffile_attributes): Add BLOCK_INPUT around getpwuid/getgrgid.
+
+ * editfns.c: Include blockinput.h.
+ (Fuser_login_name, Fuser_full_name): Add BLOCK_INPUT around
+ getpwuid/getpwnam.
+
+ * fileio.c: Include blockinput.h.
+ (Fexpand_file_name, search_embedded_absfilename): Add BLOCK_INPUT
+ around getpwnam.
+ (search_embedded_absfilename): Remove spurious xfree.
+
+2006-07-11 Kim F. Storm <[email protected]>
+
+ * dispnew.c (sit_for): Reduce number of args from 5 to 3.
+ Now just one TIMEOUT arg that can be a Lisp float or Lisp int.
+ Combine args DISPLAY and INITIAL_DISPLAY into one arg DO_DISPLAY.
+ Signal error if TIMEOUT is not a number.
+ Undo 2006-06-14 change for non-preemptive display if TIMEOUT < 0.
+ The rework of sit_for args also fixes several incorrect Qt args
+ which should have been 1.
+ (Fredisplay): Pass 1 instead of Qt to swallow_events and
+ detect_input_pending_run_timers.
+
+ * lisp.h (sit_for): Update prototype.
+ (Fredisplay): Add EXFUN.
+
+ * dispextern.h (sit_for): Remove prototype.
+
+ * callint.c (Fcall_interactively):
+ * minibuf.c (temp_echo_area_glyphs):
+ * keyboard.c (command_loop_1, read_char, Fexecute_extended_command):
+ * fileio.c (Fdo_auto_save): Update/simplify sit_for calls.
+
+2006-07-11 Stefan Monnier <[email protected]>
+
+ * syntax.c (forw_comment): Also use EMACS_INT for buffer positions.
+
+2006-07-11 Kim F. Storm <[email protected]>
+
+ * dispnew.c (Fredisplay): Add FORCE argument to force redisplay when
+ input is available. Fix test for redisplay_dont_pause non-nil.
+ Specbind redisplay-dont-pause to t if FORCE non-nil.
+
+2006-07-10 Chong Yidong <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment to 1211000.
+
+ * dispnew.c (Fredisplay): New function, equivalent to (sit-for 0).
+ (Fsit_for): Function deleted.
+
+ * keyboard.c (command_loop_1, Fexecute_extended_command):
+ Call sit_for instead of Fsit_for.
+
+ * minibuf.c (temp_echo_area_glyphs): Likewise.
+
+2006-07-09 Stefan Monnier <[email protected]>
+
+ * syntax.c (Fforward_comment): Revert the reversion.
+ (back_comment, scan_lists): Also use EMACS_INT for buffer positions.
+
+2006-07-09 John Paul Wallington <[email protected]>
+
+ * syntax.c (Fforward_comment): Revert previous change.
+
+2006-07-09 Kim F. Storm <[email protected]>
+
+ * window.c (Fforce_window_update): Doc fix.
+
+2006-07-08 Stephen Gildea <[email protected]>
+
+ * fileio.c (do_auto_save_make_dir): Make the auto-save-list-file
+ directory unreadable for better user privacy.
+
+2006-07-07 Stefan Monnier <[email protected]>
+
+ * syntax.c (Fforward_comment): Fix int-32 vs EMACS_INT-64 mixup.
+
+ * lread.c (read_filtered_event): Remove `register' qualifier because it
+ causes compilation problem with gcc-4.0.2-20051125 on amd64.
+ (readevalloop): Remove unused var `bpos'.
+ Yet another int/Lisp_Object mixup (YAILOM).
+
+2006-07-07 Eli Zaretskii <[email protected]>
+
+ * keyboard.c (Fexecute_extended_command): Mention the argument
+ PREFIXARG in the doc string.
+
+2006-07-07 Kim F. Storm <[email protected]>
+
+ * fringe.c (Fdefine_fringe_bitmap): Doc fix.
+
+2006-07-05 Chong Yidong <[email protected]>
+
+ * insdel.c (prepare_to_modify_buffer): For an indirect buffer, do
+ clash detection using the base buffer.
+
+ * puresize.h (BASE_PURESIZE): Increment to 1210500.
+
+2006-07-04 Kim F. Storm <[email protected]>
+
+ * xterm.c (x_delete_display): Don't free or derefence NULL pointers.
+
+2006-07-04 Kenichi Handa <[email protected]>
+
+ * fontset.c (Fset_overriding_fontspec_internal): Check if we need
+ to update Voverriding_fontspec_alist.
+
+2006-07-03 Richard Stallman <[email protected]>
+
+ * xfns.c (Fx_create_frame): Move unwind_create_frame setup down.
+
+ * xfaces.c (Fface_attribute_relative_p): Doc fix.
+
+ * textprop.c (Fget_char_property_and_overlay): Doc fix.
+
+ * eval.c (Fdefvaralias): Doc fix.
+
+2006-07-03 Kim F. Storm <[email protected]>
+
+ * dispnew.c (sit_for): Fix preempt condition.
+
+2006-07-02 Stefan Monnier <[email protected]>
+
+ * lread.c (read_filtered_event): Treat select-window just like
+ switch-frame.
+
+2006-07-02 Kim F. Storm <[email protected]>
+
+ * xdisp.c (display_tool_bar_line): Skip glyphs which are too big
+ to ever fit the tool-bar,
+ (MAX_FRAME_TOOL_BAR_HEIGHT): New macro.
+ (tool_bar_lines_needed): Use unused mode-line row as temp_row.
+ (redisplay_tool_bar): Only clear desired matrix if we actually
+ change the tool-bar window height. Only try to make the tool-bar
+ window bigger if there is actually room for it.
+
+2006-06-30 Ralf Angeli <[email protected]>
+
+ * w32term.c (x_make_frame_visible): Use SystemParametersInfo with
+ SPI_GETWORKAREA to find the dimensions of the screen work area,
+ and adjust vertical position of the frame in order to avoid being
+ covered by the task bar.
+
+ * w32fns.c (w32_createwindow): Use CW_USEDEFAULT instead of
+ f->left_pos and SH_SHOW instead of f->top_pos in the call to
+ CreateWindow. Record the actual position in f->left_pos and
+ f->top_pos.
+
+2006-06-30 John Paul Wallington <[email protected]>
+
+ * w32console.c (syms_of_ntterm) <w32-use-full-screen-buffer>:
+ Doc fix - default value has changed.
+
+2006-06-28 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c [!TARGET_API_MAC_CARBON]: Don't include FixMath.h or Scrap.h.
+
+ * macfns.c (Fx_create_frame): Apply 2006-06-24 change for xfns.c.
+
+ * macgui.h (USE_MAC_TSM) [TARGET_API_MAC_CARBON]: Set default to 1.
+
+ * macterm.c (Qeql): Add extern.
+ (x_set_mouse_pixel_position) [MAC_OSX]: Use CGWarpMouseCursorPosition.
+ (fm_style_face_attributes_alist) [USE_ATSUI]: New variable.
+ (syms_of_macterm) [USE_ATSUI]: Initialize and staticpro it.
+ Change keys of Vmac_atsu_font_table from strings to numbers.
+ (fm_style_to_face_attributes) [USE_ATSUI]: New function.
+ (init_font_name_table) [USE_ATSUI]: Use it.
+ (saved_ts_script_language_on_focus) [USE_MAC_TSM]: New variable.
+ (syms_of_macterm) [USE_MAC_TSM]: Initialize and staticpro it.
+ [USE_MAC_TSM] (mac_tsm_resume): Restore script and language codes
+ only when saved_ts_script_language_on_focus coincides with
+ Vmac_ts_script_language_on_focus.
+ [USE_MAC_TSM] (mac_tsm_suspend): Save value of
+ Vmac_ts_script_language_on_focus to saved_ts_script_language_on_focus.
+ (XTread_socket) [USE_MAC_TSM]: Add Mac OS Classic support.
+ [USE_MAC_TSM] (mac_handle_text_input_event, init_tsm): Likewise.
+
+2006-06-27 Chong Yidong <[email protected]>
+
+ * editfns.c (Fdelete_field, Ffield_string, Ffield_beginning)
+ (Ffield_string_no_properties, Ffield_end): Mention
+ args-out-of-range error condition in docstring.
+
+2006-06-27 Kim F. Storm <[email protected]>
+
+ * xdisp.c (handle_composition_prop): Set stop_charpos before push_it.
+
+2006-06-25 Kim F. Storm <[email protected]>
+
+ * s/gnu-linux.h (SIGNALS_VIA_CHARACTERS): Define for Linux kernel
+ version 2.4 and later.
+
+2006-06-24 Chong Yidong <[email protected]>
+
+ * xfns.c (Fx_create_frame): Set font parameter directly instead of
+ using x_default_parameter, since x_get_args clears the parm alist.
+
+2006-06-24 Eli Zaretskii <[email protected]>
+
+ * dired.c (directory_files_internal) [WINDOWSNT]: Find files
+ case-insensitively.
+
+2006-06-24 Aidan Kehoe <[email protected]>
+
+ * lread.c (read_escape): When an unknown Unicode code point is
+ encountered as a string or character escape, signal an error.
+
+2006-06-23 Kim F. Storm <[email protected]>
+
+ * .gdbinit (pitx): Dump iterator stack.
+
+ * xdisp.c (handle_composition_prop): Push iterator on stack.
+ (set_iterator_to_next): Pop iterator at end of composition.
+
+2006-06-23 Martin Rudalics <[email protected]>
+
+ * fileio.c (Frename_file) [DOS_NT]: Don't try to move directory to
+ itself on DOS_NT platforms, if the old and new names are identical
+ but for the letter-case.
+
+2006-06-21 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct it): Add `position' member to iterator stack.
+ Rename `pos' member to `current'. Rearrange and add comments.
+
+ * xdisp.c (handle_stop): Set it->ignore_overlay_strings_at_pos_p
+ if we get any overlays.
+ (set_cursor_from_row): Don't clobber `end' if we rescan from
+ start_string.
+ (push_it, pop_it): Save it->position.
+
+2006-06-19 Richard Stallman <[email protected]>
+
+ * window.c (size_window): New arg FIRST_ONLY. All callers changed.
+ (adjust_window_trailing_edge): Specially compute FIRST_PARALLEL
+ for the case of a top-level window and the following minibuffer.
+ Don't exit because of no `next' when there is a parent.
+ Use the FIRST_ONLY feature when resizing following windows.
+
+ * syntax.c (init_syntax_once): Give most control chars' syntax Spunct.
+
+2006-06-17 Kim F. Storm <[email protected]>
+
+ * dispnew.c (update_frame): Check for input pending on entry.
+ (update_window, update_frame_1): Break loop if input is detected.
+
+2006-06-16 Francis Litterio <[email protected]>
+
+ * xterm.c (x_check_expected_move, handle_one_xevent)
+ (x_set_offset, x_check_fullscreen): Extensive changes to make
+ frame positioning deterministic under X.
+
+ * xterm.h (x_output): Add members left_before_move and
+ top_before_move. Removed members expected_left and expected_top.
+
+2006-06-16 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct it): Add union to iterator stack to save
+ image, composition, and stretch specific paramters.
+
+ * xdisp.c (next_overlay_string): Fix assert.
+ (push_it, pop_it): Handle composition and stretch specific values.
+ Only handle it->slice in image (for now).
+ (back_to_previous_visible_line_start): Continue search if newline is
+ part of a compisition. Simplify.
+ (reseat_1): Set it->object to buffer.
+ (set_iterator_to_next): Set it->object to string or buffer, when
+ setting it->method to GET_FROM_STRING or GET_FROM_BUFFER.
+ (next_element_from_composition): Set it->object to buffer if not
+ from string.
+ (set_cursor_from_row): Only save start of string if not already
+ done to handle multiple strings in a row.
+
+ * .gdbinit (pitx): Show composition parameters.
+ (pgx, pg): New commands to print a glyph structure.
+ (pgi, pgn): New commands to print specific/next glyph.
+ (pgrowx, pgrow): New commands to print all glyphs in a row.
+
+2006-06-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (Fx_display_mm_height, Fx_display_mm_width)
+ [MAC_OS_X_VERSION_MAX_ALLOWED >= 1030]: Use CGDisplayScreenSize.
+
+ * macterm.c (do_app_resume, do_app_suspend): Remove functions.
+ (mac_tsm_resume, mac_tsm_suspend) [USE_MAC_TSM]: New functions.
+ (mac_handle_window_event, XTread_socket) [USE_MAC_TSM]: Use them.
+ (Vmac_ts_script_language_on_focus) [USE_MAC_TSM]: New variable.
+ (syms_of_macterm) [USE_MAC_TSM]: Defvar it.
+ (saved_ts_language, saved_ts_component) [USE_MAC_TSM]: New variables.
+ (mac_initialize_display_info) [MAC_OSX]: Use Quartz Display
+ Services functions to get size of main display in pixels.
+
+2006-06-14 Chong Yidong <[email protected]>
+
+ * xdisp.c (back_to_previous_visible_line_start):
+ Reset it->continuation_lines_width.
+
+2006-06-14 Richard Stallman <[email protected]>
+
+ * eval.c (Fdefconst): Mark variable as risky.
+
+ * callproc.c (Fcall_process): Doc fix.
+
+ * window.c (adjust_window_trailing_edge): Don't break out of the loop
+ because there's no next window, if there are parallel windows.
+ Do break out when WINDOW is nil.
+
+2006-06-14 Kim F. Storm <[email protected]>
+
+ * dispextern.h (IT_STACK_SIZE): New macro specifying size of
+ iterator stack (instead of hardcoded number). Increase from 2 to
+ 4 to make room for propertized overlay strings before and after a
+ display string, image or composition.
+ (struct it): Add image_id and method members to iterator stack.
+
+ * xdisp.c (init_from_display_pos): Don't set it->method and
+ overlay_string_index after pop_it. Add asserts.
+ (handle_stop): Look for overlay strings around a display string,
+ image, or composition. Handle properties on those strings.
+ (next_overlay_string): Don't set string, pos or method after pop_it.
+ (get_overlay_strings_1): Split from get_overlay_strings; don't
+ modify it if no overlay strings are found.
+ (get_overlay_strings): Use get_overlay_strings_1. Always set
+ it->string and it->method.
+ (push_it): Push it->image_id and it->method. Push it->object
+ instead of it->string if method is GET_FROM_IMAGE.
+ (pop_it): Pop it->image_id and it->method. Ppo it->object
+ instead of it->string if method is GET_FROM_IMAGE.
+ Reset it->current.string_pos if popped it->string is nil.
+ (reseat_1): Remove comment dated 19 May 2003. It expressed doubt
+ whether a given change was correct; but the change is correct.
+ Clear it->string_from_display_prop_p.
+ (set_iterator_to_next): Rely on it->method and it->image_id from
+ iterator stack, instead of setting them explicitly after pop_it.
+
+ * dispnew.c (sit_for): Undo 2006-06-01 change. Instead, a
+ negative time forces redisplay even when input is available.
+ (Fsit_for): Doc fix.
+
+2006-06-13 Kim F. Storm <[email protected]>
+
+ * dispnew.c: Modify preemptive redisplay to be based on periodic
+ checks for input.
+ (PERIODIC_PREEMPTION_CHECKING): Define to 1 iff EMACS_HAS_USECS.
+ (Vredisplay_preemption_period): New variable.
+ (syms_of_display): DEFVAR_LISP and initialize it.
+ (preemption_period, preemption_next_check): New variables.
+ (update_frame, update_single_window): Initialize them based on
+ Vredisplay_preemption_period if !force_p.
+ (update_window, update_frame_1): Use them to determine when to
+ check for input.
+
+2006-06-03 Aidan Kehoe <[email protected]>
+
+ * lread.c (read_escape): Provide a Unicode character escape
+ syntax; \u followed by exactly four or \U followed by exactly
+ eight hex digits in a comment or string is read as a Unicode
+ character with that code point.
+
+2006-06-09 Eli Zaretskii <[email protected]>
+
+ * window.c (window_scroll_pixel_based): Signal "Beginning of
+ buffer" when scroll-down at the beginning of an empty buffer.
+
+2006-06-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c [USE_MAC_TSM] (mac_handle_text_input_event):
+ Exclude 0x7f from ASCII range.
+
+2006-06-05 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_set_scroll_bar_thumb, x_scroll_bar_create)
+ (w32_set_vertical_scroll_bar, w32_scroll_bar_handle_click)
+ (x_scroll_bar_report_motion): Remove workarounds for
+ versions of Windows NT < 3.51.
+ [!SIF_ALL]: Remove.
+ (pfnSetScrollInfo, pfnGetScrollInfo): Remove.
+ (w32_initialize): Don't dynamically load Get/SetScrollInfo.
+
+2006-06-04 David Kastrup <[email protected]>
+
+ * dispnew.c: Mention `redisplay-dont-pause' in doc string of
+ `sit-for'.
+
+2006-06-03 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (x_set_icon_name): Apply 2006-06-02 change for xfns.c.
+
+ * macgui.h (USE_MAC_TSM): Set default to 1 on Mac OS X.
+
+ * macterm.c (tsm_document_id) [USE_MAC_TSM]: New variable.
+ (Qtext_input, Qupdate_active_input_area, Qunicode_for_key_event)
+ [USE_MAC_TSM]: Likewise.
+ (syms_of_macterm) [USE_MAC_TSM]: Intern and staticpro them.
+ (Qbefore_string) [USE_MAC_TSM]: Add extern.
+ (do_app_resume, do_app_suspend) [USE_MAC_TSM]: Call
+ ActivateTSMDocument/DeactivateTSMDocument.
+ (mac_store_event_ref_as_apple_event): Call mac_post_mouse_moved_event.
+ (mac_handle_window_event) [USE_MAC_TSM]: Handle
+ kEventWindowFocusAcquired/kEventWindowFocusRelinquish.
+ (mac_handle_text_input_event) [USE_MAC_TSM]: New function.
+ (install_window_handler) [USE_MAC_TSM]: Install it. Register
+ kEventWindowFocusAcquired/kEventWindowFocusRelinquish.
+ (keycode_to_xkeysym_table): Add entry for f16.
+ (XTread_socket) [USE_MAC_TSM]: Set/reset read_socket_inev
+ before/after passing keystroke event to toolbox dispatcher.
+ (init_tsm) [USE_MAC_TSM]: New function.
+ (mac_initialize) [USE_MAC_TSM]: Call it.
+ (Vmac_ts_active_input_overlay) [USE_MAC_TSM]: New defvar.
+
+ * macterm.h (EVENT_PARAM_TEXT_INPUT_SEQUENCE_NUMBER): New enumerator.
+
+2006-06-02 John Paul Wallington <[email protected]>
+
+ * xfns.c (x_set_name_internal): Set icon to `text', derived from
+ name, when frame's icon_name isn't a string rather than only when
+ it is nil.
+
+2006-06-03 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (x_set_icon_name): Don't use arg if it's not a string
+ and not nil.
+
+2006-06-02 Chong Yidong <[email protected]>
+
+ * xfns.c (x_set_icon_name): No-op if arg is non-nil and not a
+ string.
+
+2006-06-02 YAMAMOTO Mitsuharu <[email protected]>
+
+ * xdisp.c (next_element_from_composition): Set it->object to
+ it->string if composition is coming from string.
+ (set_cursor_from_row): Don't return 0 unless row displays a
+ continued line.
+ (dump_glyph): Dump composite glyph.
+
+2006-06-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (menu_nav_ended): Check that menubar_widget is not NULL.
+
+2006-06-01 Richard Stallman <[email protected]>
+
+ * window.c (Fsplit_window): Doc fix.
+
+2006-06-01 Micha,Ak(Bl Cadilhac <[email protected]>
+
+ * process.c (deleted_pid_list): New variable to store the pids
+ of deleted processes. Declare it only if SIGCHLD is defined.
+ (init_process): Initialize it.
+ (syms_of_process): Staticpro it.
+ (Fdelete_process): Add pid of the deleted process to it. Check after
+ the addition and before the kill if the process is already stopped,
+ in which case it is deleted from the list and not killed.
+ (sigchld_handler): Define it only if SIGCHLD is. Search the process
+ that signaled Emacs in `deleted_pid_list' before `Vprocess_alist'.
+ Original idea by Stefan Monnier.
+
+2006-06-01 Kim F. Storm <[email protected]>
+
+ * dispnew.c (sit_for): Perform redisplay even if input is pending
+ when redisplay-dont-pause is non-nil.
+
+2006-06-01 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_handle_visibility_change): Set buf.arg to Qnil.
+ (XTread_socket): Remove obsolete comment.
+
+2006-06-01 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (syms_of_xmenu): Make accelerate-menu an alias for
+ menu-bar-open.
+
+2006-06-01 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (Fmenu_bar_open, syms_of_xmenu): Change menu-bar-start to
+ menu-bar-open.
+
+ * gtkutil.c (menu_nav_ended): Change x-menu-bar-start to menu-bar-open.
+
+2006-05-31 Juri Linkov <[email protected]>
+
+ * minibuf.c (Vhistory_add_new_input): New variable.
+ (read_minibuf): Use it.
+ (syms_of_minibuf) <history-add-new-input>: New Lisp variable.
+ (syms_of_minibuf) <history-delete-duplicates>: Doc fix.
+
+2006-05-31 Kim F. Storm <[email protected]>
+
+ * process.c (select_wrapper): Add wrapper around select to work around
+ "incomplete backtrace" bug in gdb 5.3, when emacs is stopped inside
+ select called from wait_reading_process_output.
+
+2006-05-30 Andreas Schwab <[email protected]>
+
+ * xmenu.c (Fmenu_bar_start): Return a value.
+
+2006-05-30 Richard Stallman <[email protected]>
+
+ * coding.c (Ffind_operation_coding_system): Doc fix.
+
+2006-05-30 Eli Zaretskii <[email protected]>
+
+ * w32term.c (x_draw_hollow_cursor): Fix last change.
+
+2006-05-29 Kim F. Storm <[email protected]>
+
+ * w32term.c (x_draw_stretch_glyph_string): Fix last change.
+
+2006-05-29 Eli Zaretskii <[email protected]>
+
+ * coding.c (Ffind_operation_coding_system): Doc fix.
+
+2006-05-29 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c [USE_MAC_FONT_PANEL] (Fmac_set_font_panel_visibility):
+ Call mac_set_font_info_for_selection if font panel is made visible.
+
+ * macterm.c (font_panel_shown_p) [USE_MAC_FONT_PANEL]: New variable.
+ (mac_font_panel_visible_p, mac_show_hide_font_panel)
+ [USE_MAC_FONT_PANEL]: New functions.
+ [USE_MAC_FONT_PANEL] (mac_set_font_info_for_selection):
+ Return immediately if font panel is not visible.
+
+ * macterm.h (mac_font_panel_visible_p, mac_show_hide_font_panel):
+ Add externs.
+
+2006-05-29 Dan Nicolaescu <[email protected]>
+
+ * search.c (matcher_overflow): Mark as NO_RETURN.
+
+ * xterm.c (x_connection_closed): Likewise.
+
+ * sysdep.c (croak): Likewise.
+
+ * sound.c (sound_perror, alsa_sound_perror): Likewise.
+
+ * lisp.h (die, nsberror): Likewise.
+
+2006-05-29 Jan Dj,Ad(Brv <[email protected]>
+
+ * sound.c (alsa_open, alsa_configure, alsa_write):
+ Move assignment to err out of if-statement.
+
+ * gtkutil.c (menu_nav_ended): New function.
+ (create_menus): Connect menu_nav_ended to "selection-done" to fix
+ grabs.
+
+ * xmenu.c (Fmenu_bar_start): New function for USE_GTK and USE_X_TOOLKIT.
+
+2006-05-28 Dan Nicolaescu <[email protected]>
+
+ * charset.h (invalid_character): Mark as NO_RETURN.
+
+2006-05-29 Kenichi Handa <[email protected]>
+
+ * coding.c (Ffind_operation_coding_system): Call a function by
+ safe_call1 instead of call1.
+
+2006-05-28 Stefan Monnier <[email protected]>
+
+ * window.c (struct saved_window): Add `dedicated'.
+ (Fset_window_configuration, save_window_save): Save/restore the
+ `dedicated' flag.
+
+2006-05-28 Kim F. Storm <[email protected]>
+
+ * xdisp.c (set_cursor_from_row): If cursor cannot be set in row,
+ don't update w->cursor and return 0. Return 1 on success.
+ (try_cursor_movement): Repeat set_cursor_from_row on successive rows
+ until it succeeds.
+
+ * dispextern.h (set_cursor_from_row): Update prototype.
+
+2006-05-28 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_phys_cursor_geometry): Return computed x and y through
+ parameters. Adjust x and width in case cursor in on a partially
+ visible stretch glyph on the left edge.
+ (erase_phys_cursor): Don't erase into left fringe/margin in case
+ previous cursor glyph is a partially visible stretch glyph on left.
+
+ * dispextern.h (get_phys_cursor_geometry): Update prototype.
+
+ * xterm.c (x_draw_stretch_glyph_string): Fix problems with invisible
+ cursor and erasing cursor on partially visible stretch glyph on left.
+ (x_draw_hollow_cursor): Compute x via get_phys_cursor_geometry.
+
+ * macterm.c: Likewise.
+
+ * w32term.c: Likewise.
+
+2006-05-27 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macselect.c (mac_handle_apple_event):
+ Return errAEEventNotHandled if key binding is not found.
+
+2006-05-26 Eli Zaretskii <[email protected]>
+
+ * emacs.c (main) [PROFILING]: Enable also for __MINGW32__.
+ [__MINGW32__]: MinGW-specific declaration of `etext'.
+
+ * w32heap.c (etext, edata): Remove unused definitions.
+
+2006-05-26 Chong Yidong <[email protected]>
+
+ * fileio.c (Fcopy_file): Delete argument MUSTBENEW.
+ Incorporate the exclusive file-opening functionality into the behavior
+ when OK-IF-ALREADY-EXISTS is nil.
+ (Frename_file): Call Fcopy_file without MUSTBENEW argument.
+
+2006-05-26 Jan Dj,Ad(Brv <[email protected]>
+
+ * sound.c (alsa_configure): Move get period/buffer_size after
+ setting hwparams.
+
+2006-05-26 Kenichi Handa <[email protected]>
+
+ * coding.c (Ffind_operation_coding_system): Allow (FILENAME
+ . BUFFER) in TARGET.
+
+2006-05-25 Chong Yidong <[email protected]>
+
+ * image.c (png_load): Don't call fclose on NULL.
+
+2006-05-25 Luc Teirlinck <[email protected]>
+
+ * fns.c (Fyes_or_no_p):
+ * callint.c (Fcall_interactively): Fread_from_minibuffer now takes
+ only seven args.
+
+2006-05-25 Juri Linkov <[email protected]>
+
+ * lisp.h (Fread_from_minibuffer): Decrement number of args.
+
+ * minibuf.c (read_minibuf): Remove arg KEEP_ALL. Callers changed.
+ (Fread_from_minibuffer): Remove arg KEEP_ALL. Callers changed.
+
+ * buffer.c (mode-line-format): Fix docstring.
+
+2006-05-25 Richard Stallman <[email protected]>
+
+ * emacs.c (main, Fdump_emacs): Don't test __linux or __linux__.
+
+2006-05-24 Luc Teirlinck <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 1210000.
+
+2006-05-24 Alan Mackenzie <[email protected]>
+
+ * lread.c (Vload_history): Enhance doc-string to say that the file
+ is the absolute truename of the loaded file.
+
+ * lread.c (Vafter_load_alist): doc-string: state that an element
+ now has a regexp to match file names, not a file name as such.
+
+ * lread.c (readevalloop): Call file-truename on the name for
+ load-history, except at preloading time.
+
+ * lread.c (Fload): At preloading time, preserve the extension of
+ the filename which goes into load-history. New var hist_file_name.
+
+ * lread.c (Fload): Do eval-after-load stuff by calling the lisp
+ function do-after-load-evaluation.
+
+2006-05-24 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (ae_attr_table): New variable.
+ (syms_of_mac): Intern and staticpro its elements.
+ (mac_aelist_to_lisp): Also convert Apple event attributes.
+ (mac_ae_put_lisp): New function.
+ (create_apple_event_from_event_ref) [MAC_OSX]: Use typeUTF8Text.
+
+ * macfns.c (Fx_server_version): Use gestaltSystemVersionMajor etc.
+
+ * macselect.c (Qemacs_suspension_id): New variable.
+ (syms_of_macselect): Intern and staticpro it.
+ (struct suspended_ae_info): New struct.
+ (deferred_apple_events, defer_apple_events)
+ (Fmac_process_deferred_apple_events): Use it.
+ (suspended_apple_events): New variable.
+ (mac_handle_apple_event_1): New function.
+ (mac_handle_apple_event): Use it. Don't process previously
+ suspended events.
+ (cleanup_suspended_apple_events, get_suspension_id)
+ (cleanup_all_suspended_apple_events): New functions.
+ (init_apple_event_handler): Call cleanup_all_suspended_apple_events
+ at exit.
+ (Fmac_cleanup_expired_apple_events, Fmac_ae_set_reply_parameter)
+ (Fmac_resume_apple_event): New defuns.
+ (syms_of_macselect): Defsubr them.
+
+ * macterm.c (fn_keycode_to_keycode_table, XTread_socket) [MAC_OSX]:
+ Fix last change. Don't map `fn' modifier if pressed with F1 ... F12.
+
+ * macterm.h (TYPE_FILE_NAME): Change from macro to enumerator.
+ (KEY_EMACS_SUSPENSION_ID_ATTR): New enumerator.
+ (keyReplyRequestedAttr) [MAC_OS_X_VERSION_MAX_ALLOWED < 1030]: Likewise.
+ (gestaltSystemVersionMajor, gestaltSystemVersionMinor)
+ (gestaltSystemVersionBugFix) [MAC_OS_X_VERSION_MAX_ALLOWED < 1040]:
+ Likewise.
+ (typeUTF8Text, kEventParamWindowMouseLocation)
+ [MAC_OSX && MAC_OS_X_VERSION_MAX_ALLOWED < 1020]: Likewise.
+ (x_get_focus_frame, mac_ae_put_lisp): Add externs.
+
+2006-05-23 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (fn_keycode_to_xkeysym_table, convert_fn_keycode): Remove.
+ (fn_keycode_to_keycode_table) [MAC_OSX]: New variable.
+ (mac_set_unicode_keystroke_event) [TARGET_API_MAC_CARBON]: New function.
+ (XTread_socket) [TARGET_API_MAC_CARBON]: Use it.
+ (XTread_socket) [MAC_OSX]: Try 'uchr' Unicode keyboard-layout
+ resource to backtranslate key with modifiers.
+ (XTread_socket): Don't set read_socket_inev around AEProcessAppleEvent.
+
+2006-05-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c: Remove declarations already in xterm.h.
+
+ * xterm.h: Add extern declarations for x_clear_errors,
+ x_fully_uncatch_errors, x_catching_errors and
+ x_alloc_lighter_color_for_widget. Remove duplicated declarations.
+
+2006-05-21 Richard Stallman <[email protected]>
+
+ * xfaces.c (best_matching_font): Abort for best == NULL
+ before we start to use it.
+
+ * buffer.c (syms_of_buffer, Fmake_overlay): Doc fixes.
+
+2006-05-20 Kim F. Storm <[email protected]>
+
+ * xfaces.c (best_matching_font): Fix crash in 2006-05-17 change.
+
+2006-05-20 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (convert_fn_keycode): Fix last change.
+
+2006-05-19 Eli Zaretskii <[email protected]>
+
+ * w32.c (init_environment): Perform the processing of environment
+ variables on a copy of default variables and their values, not on
+ the original. Simplify code that calls ExpandEnvironmentStrings
+ and make buf1[] and buf2[] more visible for easier debugging.
+
+2006-05-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * frame.c (x_set_border_width): Remove #ifndef MAC_OS.
+
+ * image.c [MAC_OS] (gif_load): Allocate Lisp string first.
+
+ * macfns.c (Fx_focus_frame): Don't check dpyinfo->x_focus_frame.
+
+ * macterm.c (XTread_socket) [TARGET_API_MAC_CARBON && MAC_OSX]:
+ Forward keyUp events to toolbox_dispatcher.
+
+ * window.c (foreach_window): Check WINDOWP (FRAME_ROOT_WINDOW (f)).
+
+2006-05-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * config.in: Regenerated (HAVE_ALSA).
+
+ * sound.c (alsa_sound_perror, alsa_open, alsa_period_size)
+ (alsa_configure, alsa_close, alsa_choose_format, alsa_write)
+ (snd_error_quiet, alsa_init): New functions.
+ (vox_init): Return 0 if unable to open device.
+ (Fplay_sound_internal): Test for alsa first and use vox (oss) as
+ a fallback.
+ (struct sound_device): Add period_size.
+ (wav_play, au_play): Use period_size if set.
+
+ * Makefile.in (CFLAGS_SOUND): New flags for ALSA.
+ (ALL_CFLAGS): Add CFLAGS_SOUND.
+
+2006-05-18 Kenichi Handa <[email protected]>
+
+ * callproc.c (Fcall_process): Reject encoding arguments by
+ ascii-incompatible coding systems (e.g. utf-16).
+
+ * coding.c (Qascii_incompatible): New variable.
+ (syms_of_coding): Setup Qascii_incompatible.
+ (setup_coding_system): Be sure to initialize coding->common_flags.
+ Check `ascii-incompatible' property of the coding system.
+
+ * coding.h (CODING_ASCII_INCOMPATIBLE_MASK): New macro.
+
+2006-05-18 Kim F. Storm <[email protected]>
+
+ * xdisp.c (display_tool_bar_line): Restore entire tool-bar
+ geometry when backtracking in case last image doesn't fit on line.
+
+2006-05-18 MIYOSHI Masanori <[email protected]> (tiny change)
+
+ * xdisp.c (display_tool_bar_line): Don't adjust tool-bar height by
+ more than height of one frame default line.
+
+2006-05-17 Richard Stallman <[email protected]>
+
+ * xfaces.c (better_font_p): Any font beats no font.
+ (best_matching_font): Simplify based on above change.
+
+ * buffer.c (Fprevious_overlay_change, Fnext_overlay_change): Doc fixes.
+
+2006-05-16 Kim F. Storm <[email protected]>
+
+ * xterm.c (handle_one_xevent): Check that f is not NULL before
+ calling x_kill_gs_process.
+
+2006-05-14 Richard Stallman <[email protected]>
+
+ * textprop.c (Fnext_single_char_property_change)
+ (Fprevious_single_char_property_change): Don't allow returning
+ value beyond LIMIT in any cases.
+ (Fnext_char_property_change, Fprevious_char_property_change): Doc fix.
+
+ * intervals.c (get_local_map): Abort if POSITION outside BEGV, ZV.
+
+2006-05-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): Check that f is not NULL before
+ calling _XEditResCheckMessages.
+
+2006-05-14 Kim F. Storm <[email protected]>
+
+ * xterm.c (handle_one_xevent): Fix crash in 2006-03-24 change.
+
+2006-05-13 Eli Zaretskii <[email protected]>
+
+ * frame.c (x_set_border_width): Fix error message to say "frame",
+ not "window".
+
+ * Makefile.in (SOME_MACHINE_LISP): Add fringe.elc.
+
+2006-05-12 Chong Yidong <[email protected]>
+
+ * intervals.c (set_point_both): Fix mixup before before and after
+ in variable names.
+
+ * editfns.c (Fline_beginning_position): Inhibit point-motion hooks
+ while setting point temporarily.
+
+2006-05-11 Richard Stallman <[email protected]>
+
+ * lread.c (readevalloop): Abort if START non-nil for non-buffer input.
+
+2006-05-11 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_tool_bar): Handle large tool-bar-border values.
+
+2006-05-11 Kenichi Handa <[email protected]>
+
+ * fileio.c (Finsert_file_contents): Fix for the case of IO error
+ while handling replace operation.
+
+2006-05-10 Kenichi Handa <[email protected]>
+
+ * xfaces.c (realize_default_face) [HAVE_X_WINDOWS]: If the font
+ chosen for the default face was different from the frame font,
+ adjust the frame font.
+
+2006-05-10 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c (Qduration) [MAC_OS]: Undo previous change.
+ (syms_of_image) [MAC_OS]: Likewise.
+ [MAC_OS] (gif_load): Emulate Graphic Control Extension block.
+
+ * macfns.c (x_to_mac_color): Fix shift amount change.
+ (mac_set_font) [USE_MAC_FONT_PANEL]: Use x_get_focus_frame.
+ [USE_MAC_FONT_PANEL] (Fmac_set_font_panel_visibility): Doc fix.
+
+ * macselect.c (Vmac_service_selection) [MAC_OSX]: Rename from
+ Vmac_services_selection. All uses changed.
+ (mac_store_service_event): Rename from mac_store_services_event in
+ extern and calls.
+
+ * macterm.c (Qservice) [MAC_OSX]: Rename from Qservices. All uses
+ changed.
+ [MAC_OSX] (mac_store_service_event): Rename from
+ mac_store_services_event. All callers changed.
+ [USE_MAC_FONT_PANEL] (mac_set_font_info_for_selection): Add args
+ FACE_ID and C. All callers changed.
+ (x_free_frame_resources) [USE_MAC_FONT_PANEL]: Call
+ mac_set_font_info_for_selection when focus frame is destroyed.
+ (XTread_socket): Revert to FrontNonFloatingWindow/FrontWindow.
+
+ * macterm.h (mac_set_font_info_for_selection): Add 2nd and 3rd
+ args in extern.
+
+2006-05-09 Chong Yidong <[email protected]>
+
+ * keymap.c (describe_map): Avoid generating duplicate entries if
+ the shadowed binding has the same definition.
+
+2006-05-09 Kenichi Handa <[email protected]>
+
+ * keymap.c (push_key_description): Handle invalid character key.
+
+2006-05-08 Kenichi Handa <[email protected]>
+
+ * callproc.c (Fcall_process): Use system_eol_type for encoding
+ arguments if eol_type is not yet decided.
+
+ * coding.h (system_eol_type): Extern it.
+
+ * coding.c (setup_coding_system): For invalid coding-system, set
+ coding->eol_type to CODING_EOL_UNDECIDED.
+ (encode_coding): Cancel previous change.
+ (shrink_encoding_region): Likewise.
+ (code_convert_region1): Likewise.
+ (code_convert_string1): Likewise.
+ (code_convert_string_norecord): Likewise.
+
+ * fileio.c (choose_write_coding_system): Use system_eol_type for
+ encoding if eol_type is not yet decided.
+
+ * process.c (setup_process_coding_systems): Use system_eol_type
+ for encoding if eol_type is not yet decided.
+ (read_process_output): Likewise.
+ (send_process): Likewise.
+
+2006-05-07 Juanma Barranquero <[email protected]>
+
+ * minibuf.c (syms_of_minibuf) <history-length>: Fix typo in doc.
+
+2006-05-07 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (Fmac_clear_font_name_table): Move defun to macfns.c.
+ (syms_of_mac): Likewise for defsubr.
+
+ * macfns.c (mac_set_font): New function.
+ (mac_frame_parm_handlers, syms_of_macfns): Replace x_set_font with it.
+ (mac_window) [TARGET_API_MAC_CARBON && MAC_OSX]: Specify
+ kWindowToolbarButtonAttribute when creating window.
+ (Fmac_clear_font_name_table): Move from macfns.c.
+ (syms_of_macfns): Likewise for defsubr.
+ [USE_MAC_FONT_PANEL] (Fmac_set_font_panel_visibility): New defun.
+ (syms_of_macfns) [USE_MAC_FONT_PANEL]: Defsubr it.
+
+ * macgui.h (USE_MAC_FONT_PANEL): Define to 1 if USE_ATSUI is set
+ and build is done on Mac OS X 10.2 and later.
+
+ * macselect.c (mac_do_receive_drag): Remove unused variable `index'.
+ (mac_store_services_event): Change return type in extern.
+
+ * macterm.c (XLoadQueryFont) [USE_ATSUI]: Set font->mac_fontnum to
+ FMFontFamily value.
+ [USE_MAC_FONT_PANEL] (mac_set_font_info_for_selection): New function.
+ (x_new_focus_frame) [USE_MAC_FONT_PANEL]: Use it.
+ (QCfamily, QCweight, QCslant, Qnormal, Qbold, Qitalic): Add extern.
+ (QWindow) [MAC_OSX]: Likewise.
+ (Qfont) [USE_MAC_FONT_PANEL]: Likewise.
+ (Vmac_atsu_font_table) [USE_ATSUI]: New variable.
+ (syms_of_macterm) [USE_ATSUI]: Defvar it.
+ (Qtoolbar_switch_mode) [MAC_OSX]: New variable.
+ (Qpanel_closed, Qselection) [USE_MAC_FONT_PANEL]: Likewise.
+ (syms_of_macterm): Intern and staticpro them.
+ (init_font_name_table) [USE_ATSUI]: Add data to Vmac_atsu_font_table.
+ [TARGET_API_MAC_CARBON] (mac_store_event_ref_as_apple_event):
+ New function.
+ [USE_CARBON_EVENTS] (mac_handle_command_event): Use it.
+ [MAC_OSX] (mac_store_services_event): Likewise.
+ [USE_CARBON_EVENTS] (mac_handle_window_event) [MAC_OSX]: Handle
+ kEventWindowToolbarSwitchMode event.
+ (install_window_handler) [USE_CARBON_EVENTS && MAC_OSX]: Register it.
+ [MAC_OSX] (mac_store_services_event): Change return type to OSStatus.
+ [USE_MAC_FONT_PANEL] (mac_handle_font_event): New function.
+ (install_window_handler) [USE_MAC_FONT_PANEL]: Install it.
+ (XTread_socket): Select window on mouse click if x_focus_frame is NULL.
+
+ * macterm.h (mac_set_font_info_for_selection): Add extern.
+
+2006-05-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c (Qduration) [MAC_OS]: New variable.
+ (syms_of_image) [MAC_OS]: Intern and staticpro it.
+ [MAC_OS] (gif_load): Save image extension data in img->data.lisp_val.
+ [MAC_OSX] (image_load_quartz2d): Use cfstring_create_with_utf8_cstring
+ instead of cfstring_create_with_string.
+
+2006-05-06 Kim F. Storm <[email protected]>
+
+ * .gdbinit (xframe): Print frame name.
+ (xlist): New command to print a list (max 10 elements).
+ (xpr): Print lisp object of any type.
+ (pitx): Print it->pixel_width.
+
+2006-05-05 Kenichi Handa <[email protected]>
+
+ * xdisp.c (handle_composition_prop): Fix for the case of empty
+ composition component.
+
+2006-05-05 YAMAMOTO Mitsuharu <[email protected]>
+
+ * keyboard.c (make_lispy_event) [MAC_OS]: Get Apple event info
+ from event->arg.
+
+ * termhooks.h (enum event_kind) [MAC_OS]: Update comment for
+ MAC_APPLE_EVENT.
+
+ * macterm.h (mac_make_lispy_event_code): Remove extern.
+ (mac_post_mouse_moved_event): Add extern.
+ (mac_aelist_to_lisp, mac_aedesc_to_lisp): Change arg 1 to
+ `const AEDesc *' in externs.
+ (create_apple_event_from_drag_ref) [TARGET_API_MAC_CARBON]: New extern.
+
+ * mac.c (mac_aelist_to_lisp, mac_aedesc_to_lisp): Change arg 1 to
+ `const AEDesc *'.
+ [TARGET_API_MAC_CARBON] (create_apple_event): New function.
+ [TARGET_API_MAC_CARBON] (create_apple_event_from_event_ref): Use it.
+ Use xrealloc instead of repeated xmalloc/xfree.
+ [TARGET_API_MAC_CARBON] (create_apple_event_from_drag_ref):
+ New function.
+
+ * macmenu.c (restore_menu_items, cleanup_popup_menu): Return a value.
+
+ * macselect.c: Update copyright year.
+ (mac_store_apple_event): Change return type to void in extern.
+ (mac_handle_apple_event): Don't get return value from
+ mac_store_apple_event.
+ [TARGET_API_MAC_CARBON] (Vmac_dnd_known_types): New variable.
+ (syms_of_macselect) [TARGET_API_MAC_CARBON]: Defvar it.
+ [TARGET_API_MAC_CARBON] (mac_do_track_drag): Move function from
+ macterm.c. Use Vmac_dnd_known_types as acceptable flavors.
+ [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Likewise. New
+ implementation using create_apple_event_from_drag_ref.
+ [TARGET_API_MAC_CARBON] (mac_do_track_dragUPP)
+ (mac_do_receive_dragUPP): Move variables from macterm.c.
+ (install_drag_handler, remove_drag_handler): New functions.
+
+ * macterm.c (XTread_socket) [TARGET_API_MAC_CARBON]: Try window
+ path select also for proxy icon click.
+ [TARGET_API_MAC_CARBON] (mac_post_mouse_moved_event): New function.
+ [USE_TOOLKIT_SCROLL_BARS] (scroll_bar_timer_callback): Use it.
+ (xlfdpat_create): Remove unused label `error' and trailing sentences.
+ (mac_do_track_drag, mac_do_receive_drag): Move functions to macselect.c.
+ (mac_do_track_dragUPP, mac_do_receive_dragUPP): Move variables to
+ macselect.c.
+ (install_drag_handler, remove_drag_handler): Add extern.
+ (mac_store_apple_event): Change return type to void. All uses changed.
+ Create Lisp object from Apple event and store it into input event.
+ (mac_make_lispy_event_code): Remove function.
+ [TARGET_API_MAC_CARBON] (mac_store_drag_event): New function.
+ (install_window_handler): Call install_drag_handler.
+ (remove_window_handler): Call remove_drag_handler.
+
+2006-05-03 Richard Stallman <[email protected]>
+
+ * sound.c (Fplay_sound_internal): Dynamically allocate
+ current_sound_device and current_sound.
+ (sound_cleanup): Free them.
+
+ * minibuf.c (read_minibuf): Don't use read_minibuf_noninteractive
+ when inside a keyboard macro.
+
+2006-05-02 Andreas Schwab <[email protected]>
+
+ * xmenu.c (restore_menu_items): Return a value.
+
+2006-05-01 Martin Rudalics <[email protected]>
+
+ * syntax.c (Fforward_comment): Detect generic comment at beginning of
+ buffer when moving backwards.
+
+2006-05-01 YAMAMOTO Mitsuharu <[email protected]>
+
+ * dispnew.c (update_window): Don't set changed_p when mode/header
+ line is updated.
+
+ * xdisp.c (prepare_menu_bars) [MAC_OS]: Call mac_update_title_bar.
+ (get_glyph_face_and_encoding, get_char_face_and_encoding):
+ Don't distinguish known faces from others.
+
+ * mac.c (mac_coerce_file_name_ptr): Try typeFSRef if coercion
+ through typeFileURL failed.
+
+ * macfns.c (mac_update_title_bar): New function.
+ [TARGET_API_MAC_CARBON] (mac_update_proxy_icon): New function.
+ (show_hourglass, hide_hourglass) [USE_CG_DRAWING]:
+ Call mac_prepare_for_quickdraw.
+
+ * macgui.h (USE_ATSUI): Set default to 1 if MAC_OSX is defined.
+ (USE_CG_DRAWING): Don't define if compiled on Mac OS X 10.1.
+ (enum pcm_status): New enum.
+ (XCHARSTRUCTROW_CHAR_VALID_P, XCHARSTRUCTROW_SET_CHAR_VALID)
+ (XCharStructRow): Remove. Now validity is represented by
+ non-negativeness of sum of ascent and descent.
+ (struct MacFontStruct): Change type of member `rows'.
+ (struct _XGC) [USE_CG_DRAWING]: Add member `clip_rects'.
+
+ * macterm.c (mac_draw_line, mac_draw_line_to_pixmap):
+ Adjust endpoints of strictly horizontal/vertical lines.
+ (mac_set_clip_rectangles) [USE_CG_DRAWING]: Set clip_rects.
+ (pcm_init, pcm_get_status): New functions.
+ (x_per_char_metric, XLoadQueryFont): Use them instead of
+ XCharStructRow and related macros.
+ (x_draw_relief_rect): Don't adjust arguments of mac_draw_line.
+ (x_free_frame_resources) [TARGET_API_MAC_CARBON]: Free FRAME_FILE_NAME.
+ (XTread_socket) [TARGET_API_MAC_CARBON]: Handle proxy icon drag
+ and window path pop-up menu on title bar.
+ (mac_use_core_graphics) [USE_CG_DRAWING]: Set default to 1.
+
+ * macterm.h (mac_update_title_bar): Add extern.
+ (struct mac_output) [TARGET_API_MAC_CARBON]: New member `file_name'.
+ (FRAME_FILE_NAME): New macro.
+
+ * unexmacosx.c (unexec): Error if trying unexec from dumped executable.
+
+2006-04-30 Richard Stallman <[email protected]>
+
+ * keymap.c (Fdefine_key): Improve error message
+ when KEY begins with a non-prefix key.
+
+2006-04-30 Martin Rudalics <[email protected]>
+
+ * syntax.c (Fforward_comment): Don't forget to break out of the loop
+ when we skipped backward over a generic comment.
+
+2006-04-27 Nick Roberts <[email protected]>
+
+ * .gdbinit (pp1, pv1): Only print value as expression is now
+ printed out by gud-print.
+ (pv1): Correct doc string.
+
+2006-04-26 Stefan Monnier <[email protected]>
+
+ * keymap.c (store_in_keymap): Change `def' arg to not be `register'.
+ Seems to trigger a bug in gcc-amd64 4.0.2 20051125 (Red Hat 4.0.2-8):
+ keymap.c:895: error: address of register variable `def' requested.
+
+2006-04-26 Jason Rumney <[email protected]>
+
+ * w32term.c (construct_mouse_wheel): Handle negative coordinates.
+
+ * w32fns.c (w32_wnd_proc) <WM_LBUTTONDOWN, WM_RBUTTONDOWN>:
+ <WM_LBUTTONUP, WM_RBUTTONUP>: Call signal_user_input in the cases
+ where we preempt mouse_button_timer.
+
+2006-04-25 Miles Bader <[email protected]>
+
+ * editfns.c (Ffield_beginning, find_field): Undo change of 2006-04-23.
+
+2006-04-24 Stefan Monnier <[email protected]>
+
+ * process.h: Include headers for pid_t.
+
+2006-04-24 Kim F. Storm <[email protected]>
+
+ * xdisp.c (fill_stretch_glyph_string): Set s->nchars = 1 for code which
+ does last_glyph=s->first_glyph+s->nchars-1, e.g. if stretch has relief.
+ (produce_stretch_glyph): Assume that face box height and width is
+ already included in stretch glyph size so caller doesn't have to
+ consider the extra space otherwise added (fixes problem in ses.el).
+
+ * frame.c (x_set_font): Clear f->n_tool_bar_rows and current frame
+ matrices to force recalculation of tool-bar height after font change.
+
+ * xdisp.c (tool_bar_lines_needed): New local `temp_row' for clarity.
+ Clear it when done, so we don't accidentally draw a second copy of
+ the tool-bar after resetting f->n_tool_bar_rows.
+ (redisplay_tool_bar): Update tool-bar-lines frame parameter whenever
+ we recalculate f->n_tool_bar_rows.
+
+2006-04-23 Lars Hansen <[email protected]>
+
+ * editfns.c (find_field): Fix comment.
+ (Ffield_beginning): Fix bug when POS is at field beginning.
+
+2006-04-22 Eli Zaretskii <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 1205000.
+
+2006-04-21 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Fix last change. Don't recenter if
+ window start is at BEGV.
+
+ * dispextern.h (struct image): New member `corners'.
+ (TOP_CORNER, LEFT_CORNER, BOT_CORNER, RIGHT_CORNER): New macros.
+
+ * image.c (four_corners_best): New arg CORNERS specifies what pixels
+ to look at in case image has margin.
+ (x_create_bitmap_mask): Pass NULL for CORNERS to four_corners_best.
+ (image_background, image_background_transparent)
+ (x_build_heuristic_mask): Pass img->corners to four_corners_best.
+ (gif_load): Set img->corners according to image's margin spec.
+ Use img->corners values directly where applicable.
+ Save image extension data in img->data.lisp_val.
+ (gif_clear_image): New function to free img->data.lisp_val.
+ (gif_type): Use it instead of generic x_clear_image.
+ (Fimage_extension_data): New defun.
+ (syms_of_image): Defsubr it.
+
+2006-04-21 John Sullivan <[email protected]> (tiny change)
+
+ * window.c (Fdisplay_buffer): Doc fix.
+
+2006-04-21 Eli Zaretskii <[email protected]>
+
+ * s/ms-w32.h (SYSTEM_PURESIZE_EXTRA): Increase to 25000.
+
+2006-04-21 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c [MAC_OS] (xpm_load_image): Fill in background field
+ while we have ximg handy.
+
+ * macmenu.c (restore_menu_items, save_menu_items): New functions
+ from xmenu.c.
+ (set_frame_menubar, digest_single_submenu): Apply 2006-04-18
+ changes for xmenu.c.
+
+ * macterm.c (x_per_char_metric): Return NULL if glyph width is 0.
+ (add_mac_font_name): New function.
+ (init_font_name_table): Use it. Adopt the first found font from
+ those having the same family name.
+
+2006-04-21 Nick Roberts <[email protected]>
+
+ * xdisp.c (note_mouse_highlight): Use build_string.
+
+2006-04-20 Lars Hansen <[email protected]>
+
+ * textprop.c (Fremove_list_of_text_properties):
+ Ensure modify_region is called only when buffer is modified and that
+ signal_after_change is allways called in that case.
+
+ * print.c (PRINTFINISH): Call signal_after_change.
+
+2006-04-20 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Fix last change.
+
+ * xdisp.c (redisplay_window): If current window start is not at the
+ beginning of a line, select a new window start if buffer is modified
+ and window start is in the modified region, but the first change is
+ before window start.
+
+2006-04-18 Richard Stallman <[email protected]>
+
+ * xmenu.c (restore_menu_items, save_menu_items): New fns.
+ (set_frame_menubar): Use save_menu_items. Save updated vector in
+ the frame before unwinding it. Don't use unuse_menu_items.
+ Don't use discard_menu_items.
+ (digest_single_submenu): Abort if an item is not in a pane.
+ (init_menu_items): Put the error check at the top.
+
+ * keymap.c (describe_map): Make "shadowed" warning more verbose.
+
+ * window.c (adjust_window_trailing_edge): Correctly distinguish
+ series vs parallel cases, even when window has no parent.
+
+ * abbrev.c (record_symbol): New function.
+ (Finsert_abbrev_table_description): Sort the abbrevs alphabetically.
+
+2006-04-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c (x_create_bitmap_from_data) [MAC_OS]: Don't check return
+ value of xmalloc.
+
+ * mac.c (mac_coerce_file_name_ptr, mac_coerce_file_name_desc)
+ (create_apple_event_from_event_ref, xrm_get_preference_database)
+ (cfstring_create_normalized): Don't check return value of xmalloc.
+
+ * macselect.c (get_scrap_target_type_list, defer_apple_events)
+ (copy_scrap_flavor_data, mac_handle_service_event): Don't check
+ return value of xmalloc/xrealloc.
+
+ * macterm.c (XCreateGC, x_per_char_metric, xlfdpat_create)
+ (init_font_name_table, init_font_name_table, mac_do_list_fonts)
+ (XLoadQueryFont, mac_store_apple_event): Don't check return value
+ of xmalloc.
+
+2006-04-17 Kim F. Storm <[email protected]>
+
+ * window.c (coordinates_in_window): On the vertical border,
+ calculate the row number measured from the top of the window, not
+ the top of the frame.
+ (window_loop): Test w->dedicated with !NILP instead of EQ Qt.
+ (window_scroll_pixel_based): Fix off-by-one bug in 2002-12-23 change.
+
+2006-04-16 Eli Zaretskii <[email protected]>
+
+ * s/ms-w32.h (SYSTEM_PURESIZE_EXTRA): Reduce to 24000.
+
+2006-04-16 Romain Francoise <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Decrement back to 1200000.
+
+2006-04-16 Andreas Schwab <[email protected]>
+
+ * puresize.h (PURESIZE_RATIO): Reduce to 10/6.
+
+2006-04-15 Romain Francoise <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment to 1210000.
+
+2006-04-13 Micha,Ak(Bl Cadilhac <[email protected]>
+
+ * print.c (Fprin1_to_string): Mention in the `doc' that the
+ behavior is modified by `print-level' and `print-length'.
+
+2006-04-13 Kenichi Handa <[email protected]>
+
+ * coding.c (setup_coding_system): If eol-type is not yet decided
+ and system_eol_type is not LF, set CODING_REQUIRE_ENCODING_MASK.
+ If coding_system is nil, return 0.
+ (code_convert_region1): Even if coding_system is nil, don't skip
+ conversion if system_eol_type is not LF.
+ (code_convert_string1): Likewise.
+ (code_convert_string_norecord): Likewise.
+
+2006-04-13 Kenichi Handa <[email protected]>
+
+ * coding.c (setup_coding_system): Fix previous change.
+ (encode_coding): If eol_type is not yet decided, use system_eol_type.
+ (shrink_encoding_region): If eol_type is not yet decided and
+ system_eol_type is not LF, don't shrink.
+
+2006-04-13 Nick Roberts <[email protected]>
+
+ * xdisp.c (note_mouse_highlight): Add help echo for dragging vertical
+ line.
+
+2006-04-12 Richard Stallman <[email protected]>
+
+ * keyboard.c (read_key_sequence): Explicitly avoid keybuf[-1].
+
+ * process.c (conv_lisp_to_sockaddr): If FAMILY unknown, just return.
+ (Fprocess_send_eof): Abort if fail to open null device.
+
+2006-04-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * fns.c [HAVE_MENUS && MAC_OS]: Include macterm.h.
+
+ * image.c [MAC_OS] (xpm_load_image): Add parentheses around
+ assignment used as truth value. Add explicit braces to avoid
+ ambiguous `else'.
+ [MAC_OS] (gif_load): Remove unused variable `gcpro1'.
+
+ * lisp.h (syms_of_fontset, Fset_fontset_font): Put extern and
+ EXFUN in #ifdef HAVE_WINDOW_SYSTEM.
+ (syms_of_xfns, syms_of_xsmfns, syms_of_xselect, syms_of_xterm):
+ Put externs in #ifdef HAVE_X_WINDOWS.
+ (syms_of_macfns, syms_of_macselect, syms_of_macterm)
+ (syms_of_macmenu, syms_of_mac) [MAC_OS]: Add externs.
+ (init_mac_osx_environment) [MAC_OSX]: Add extern.
+
+ * mac.c (init_process): Remove undef.
+ (select) [MAC_OSX]: Undefine before including sysselect.h.
+ (posix_pathname_to_fsspec, fsspec_to_posix_pathname) [MAC_OSX]:
+ Remove functions and prototypes.
+ (parse_value): Add parentheses around + inside shift.
+ (path_from_vol_dir_name): Make static.
+ (get_temp_dir_name): Remove unused variables `cpb' and `dir_name'.
+ [!MAC_OSX] (get_path_to_system_folder): Likewise.
+ (Fmac_get_file_creator, Fmac_get_file_type): Remove unused
+ variable `cCode'.
+ (Fmac_coerce_ae_data): Remove unused variables `fref' and `fs'.
+ (Fmac_get_preference): Add explicit braces to avoid ambiguous `else'.
+
+ * macfns.c (x_to_mac_color): Remove unused variable `tail'.
+ (x_set_mouse_color): Remove unused variable `dpy'.
+ (Fx_create_frame): Remove unused variable `x_frame_count'.
+ (Fx_server_version): Add explicit braces to avoid ambiguous `else'.
+ (x_sync): Move from macterm.c.
+ (Fx_file_dialog): Remove unused variable `default_filter_index'.
+
+ * macmenu.c (min_menu_id): Make element type explicit.
+
+ * macselect.c (get_flavor_type_from_symbol): Remove unused
+ variable `val'.
+ (get_scrap_private_timestamp, x_get_foreign_selection)
+ (copy_scrap_flavor_data): Add explicit braces to avoid ambiguous `else'.
+ (Fmac_process_deferred_apple_events): Remove unused variables
+ `keyword', `reply', `apple_event', `count', and `err'.
+
+ * macterm.c: Don't include gnu.h.
+ (x_io_error_quitter, x_draw_image_foreground_1): Remove prototypes.
+ (x_sync): Move to macfns.c.
+ [USE_CG_DRAWING] (mac_define_fringe_bitmap): Remove unused
+ variable `mask_bits'.
+ (mac_compute_glyph_string_overhangs): Avoid ambiguous `else'.
+ (x_draw_image_glyph_string): Remove unused variable `pixmap'.
+ (x_mac_to_emacs_modifiers): Remove function.
+ (XTset_vertical_scroll_bar, mac_handle_visibility_change)
+ (x_make_frame_visible, xlfdpat_create, mac_handle_command_event):
+ Add explicit braces to avoid ambiguous `else'.
+ (x_make_frame_visible): Remove unused variables `type',
+ `original_top', and `original_left'.
+ (mac_do_list_fonts, XTread_socket): Add parentheses around && within ||.
+ (x_load_font): Remove unused variables `full_name', and `value'.
+ (do_get_menus, do_init_managers, do_check_ram_size) [!MAC_OS8]:
+ Remove functions.
+ (do_zoom_window): Reorganize variables with respect to conditionals.
+ (init_command_handler): Remove unused variable `err'.
+ [MAC_OSX] (mac_check_bundle): Remove unused variable `child'.
+
+ * macterm.h (x_set_mouse_position, x_set_mouse_pixel_position)
+ (x_make_frame_invisible, x_iconify_frame, x_free_frame_resources)
+ (x_destroy_window, x_wm_set_size_hint, x_delete_display, XFreeGC)
+ (do_menu_choice, have_menus_p, x_real_positions)
+ (x_set_menu_bar_lines, x_pixel_width, x_pixel_height, x_char_width)
+ (x_char_height, x_sync, x_set_tool_bar_lines, x_activate_menubar)
+ (free_frame_menubar): Add externs.
+
+ * unexmacosx.c: Include config.h before using HAVE_MALLOC_MALLOC_H.
+ (malloc, realloc, free): Add undefs.
+ (read_load_commands): Remove unused variable `n' and `j'.
+ (copy_data_segment): Remove unused variable `r'.
+
+ * xdisp.c (get_glyph_string_clip_rects): Add parentheses around &&
+ within ||. Add explicit braces to avoid ambiguous `else'.
+ (dump_glyph_row): Remove label for `inverse_p' from legend.
+
+ * xfaces.c (Finternal_merge_in_global_face, try_font_list):
+ Add explicit braces to avoid ambiguous `else'.
+
+2006-04-11 Micha,Ak(Bl Cadilhac <[email protected]>
+
+ * dispnew.c (init_display): Don't init X display if the user asked
+ for a non-X display.
+
+2006-04-12 Kenichi Handa <[email protected]>
+
+ * coding.c (setup_coding_system): Use system_eol_type for default
+ coding->eol_type.
+
+2006-04-11 Dan Nicolaescu <[email protected]>
+
+ * lisp.h (wrong_type_argument): Mark as NO_RETURN.
+
+ * data.c (wrong_type_argument): Try to avoid compiler warnings due
+ to the fact the function is now marked as NO_RETURN.
+
+2006-04-10 Eli Zaretskii <[email protected]>
+
+ * s/ms-w32.h (pid_t) [_MSC_VER]: New typedef.
+
+2006-04-10 Romain Francoise <[email protected]>
+
+ * xrdb.c (gethomedir): Use xstrdup.
+
+2006-04-10 Andreas Schwab <[email protected]>
+
+ * xrdb.c (gethomedir): Make sure to always return a pointer that
+ can be passed to free.
+
+2006-04-09 Richard Stallman <[email protected]>
+
+ * lisp.h (Fkill_emacs): Undo previous change.
+
+2006-04-08 Richard Stallman <[email protected]>
+
+ * search.c (boyer_moore): Test ch >= 0400, not >.
+
+2006-04-09 Dan Nicolaescu <[email protected]>
+
+ * puresize.h (pure_write_error): Mark as NO_RETURN.
+
+ * lisp.h (args_out_of_range, args_out_of_range_3, Fkill_emacs):
+ Likewise.
+
+2006-04-08 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (w32_wnd_proc) <WM_MOUSEMOVE>: Ignore mouse movements
+ if a menu is active on this frame.
+
+2006-04-08 Dan Nicolaescu <[email protected]>
+
+ * lisp.h (report_file_error): Mark as NO_RETURN.
+
+2006-04-08 Eli Zaretskii <[email protected]>
+
+ * alloc.c [STDC_HEADERS]: Include stddef.h.
+
+ * lisp.h (PSEUDOVECSIZE): Fix last change.
+
+2006-04-08 Stefan Monnier <[email protected]>
+
+ * process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
+ `raw_status_high', and `raw_status_low' with plain integers, and move
+ them to the end of the structure.
+
+ * alloc.c (allocate_process): Use PSEUDOVECSIZE to initialize the
+ pseudovector's size field so only the Lisp_Object fields get GC'd.
+
+ * process.c (update_status, make_process, Fdelete_process)
+ (Fprocess_status, list_processes_1, start_process_unwind)
+ (create_process, Fmake_network_process, server_accept_connection)
+ (wait_reading_process_output, send_process, Fprocess_running_child_p)
+ (process_send_signal, proc_encode_coding_system, Fprocess_send_eof)
+ (sigchld_handler, status_notify): Adjust to new non-Lisp fields for
+ `pid' and `raw_status'.
+ (Fprocess_id, Fsignal_process): Same, and additionally use floats when
+ representing PIDs that are larger than most-positive-fixnum.
+
+ * keymap.c (describe_map): Only use XINT if we checked INTEGERP.
+
+ * lisp.h (OFFSETOF, PSEUDOVECSIZE): New macros.
+
+2006-04-08 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (Fx_show_tip): Add 3 to the 5th arg of SetWindowPos.
+
+2006-04-03 Paul Eggert <[email protected]>
+
+ * editfns.c (TM_YEAR_IN_ASCTIME_RANGE): New macro, identical to
+ ../lib-src/b2m.c and ../lib-src/editfns.c.
+ (Fcurrent_time_string): Use it.
+ Document that the year might not consume 4 columns if it's outside
+ the range 1000-9999.
+ Check for asctime failure.
+ Don't assume that the output string length is always exactly 24.
+
+2006-04-03 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (XTread_socket): Initialize variable `f' before its use.
+
+2006-04-03 Kenichi Handa <[email protected]>
+
+ * image.c: Include "charset.h" and "coding.h".
+ (x_find_image_file): Return an encoded file name.
+
+2006-04-01 Eli Zaretskii <[email protected]>
+
+ * configure: Regenerated.
+
+2006-03-31 Kenichi Handa <[email protected]>
+
+ * xfns.c (xg_set_icon): Delete superfluous UNGCPRO.
+
+2006-03-30 Dan Nicolaescu <[email protected]>
+
+ * xdisp.c (syms_of_xdisp): Fix variable name.
+
+2006-03-30 Kenichi Handa <[email protected]>
+
+ * xterm.c (x_term_init): Delete superfluous UNGCPRO.
+
+2006-03-29 Juanma Barranquero <[email protected]>
+
+ * keyboard.c (process_tool_bar_item): Reorder dummy args.
+
+2006-03-29 Stefan Monnier <[email protected]>
+
+ * keyboard.c (tool_bar_items): Use map_keymap.
+ (process_tool_bar_item): Add dummy args to fit the required interface.
+
+2006-03-25 Eli Zaretskii <[email protected]>
+
+ * .gdbinit (pr, pp, pp1, pv, pv1): Force print_output_debug_flag
+ to zero before calling debug_print or safe_debug_print.
+
+ * print.c (print_output_debug_flag): New global variable.
+ (Fexternal_debugging_output) [WINDOWSNT]: Don't call
+ OutputDebugString if print_output_debug_flag is zero.
+
+2006-03-24 Paul Eggert <[email protected]>
+
+ * editfns.c (TM_YEAR_BASE): Move up, so the changes below can use it.
+ (Fdecode_time, Fencode_time): Use TM_YEAR_BASE instead of 1900.
+ (Fdecode_time): Cast tm_year to EMACS_INT.
+ (Fcurrent_time_string): Report an invalid time specification if
+ the argument is invalid. Also, check for out-of-range time stamps.
+
+2006-03-24 Kim F. Storm <[email protected]>
+
+ * xterm.c (handle_one_xevent):
+ * w32term.c (w32_read_socket):
+ * macterm.c (XTread_socket): Don't let key-press clear mouse face
+ on in toolbar window if mouse-highlight is an integer.
+
+ * fns.c (sxhash_list): Include last non-nil CDR in hash.
+
+2006-03-24 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (enum mac_menu_kind): New enum.
+ (min_menu_id): New variable.
+ (POPUP_SUBMENU_ID, MIN_POPUP_SUBMENU_ID, MIN_MENU_ID)
+ (MIN_SUBMENU_ID): Remove defines. All uses are replaced with
+ min_menu_id and enumerators in enum mac_menu_kind.
+ (fill_menu, dispose_menus, install_menu_quit_handler): New arg KIND.
+ All uses changed. Add range check for menu ID.
+ (fill_menubar): Add range check for menu ID.
+ [HAVE_CANCELMENUTRACKING] (menu_quit_handler): Check error code of
+ GetEventParameter.
+ (set_frame_menubar, mac_menu_show): Call install_menu_quit_handler
+ for each menu kind.
+
+2006-03-22 Kim F. Storm <[email protected]>
+
+ * xdisp.c: Undo 2006-03-21 change.
+
+ * term.c: Define aliases for append_glyph and produce_stretch_glyph
+ when `static' is defined to avoid name clash with those in xdisp.c.
+
+ * process.c (Faccept_process_output): Fix to comply with lisp
+ reference. Change arg "timeout" to "seconds" and allow both
+ integer and float value. Change arg "timeout-msec" to "millisec"
+ and interpret" as milliseconds rather than microseconds. Fix doc
+ string accordingly.
+
+2006-03-21 Ken Raeburn <[email protected]>
+
+ * xdisp.c (store_next_glyph): Rename from append_glyph.
+ (generate_stretch_glyph): Rename from produce_stretch_glyph.
+ All callers changed accordingly.
+
+2006-03-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c: x_session_initialized new variable.
+ (x_term_init): Use x_session_initialized to check if
+ x_session_initialize should be called.
+ (x_initialize): Initialize x_session_initialized.
+
+2006-03-21 Kim F. Storm <[email protected]>
+
+ * fringe.c (draw_fringe_bitmap): Don't calculate default overlay arrow
+ bitmap here, but ...
+ (update_window_fringes): ... here, so we can test if it has changed.
+
+2006-03-20 Andreas Schwab <[email protected]>
+
+ * dispnew.c (init_display): Check DISPLAY here.
+
+ * emacs.c (main): Don't check here.
+
+ * xterm.c (x_display_ok): Don't use DISPLAY env var.
+
+2006-03-20 Stefan Monnier <[email protected]>
+
+ * window.c (window_scroll_pixel_based): Yet another int/Lisp_Object
+ mixup (YAILOM).
+
+2006-03-20 Eli Zaretskii <[email protected]>
+
+ * emacs.c (main): Fix last change.
+
+2006-03-20 Kenichi Handa <[email protected]>
+
+ * fileio.c (Fwrite_region): Set visit_file to Qnil before GCPRO it.
+
+ * keymap.c (map_keymap): Set tail to Qnil before GCPRO it.
+
+ * xfns.c (xg_set_icon): Remove unnecessary GCPRO.
+
+ * xterm.c (x_term_init): Remove unnecessary GCPRO.
+
+2006-03-19 Kim F. Storm <[email protected]>
+
+ * xdisp.c (set_cursor_from_row): Fix cursor property on overlay string,
+ so it doesn't associate overlay string with following glyph by default.
+ Allow integer property value to specify explicit number of buffer
+ positions associate with overlay string.
+
+2006-03-18 Chong Yidong <[email protected]>
+
+ * xterm.c (x_display_ok): Fix minor bug and compilation warnings.
+
+2006-03-18 Nozomu Ando <[email protected]>
+
+ * m/pmax.h (BROKEN_NOCOMBRELOC) [__NetBSD__]: Define.
+ (LIB_STANDARD, START_FILES) [__NetBSD__]: Don't define.
+ (START_FILES, RUN_TIME_REMAP, UNEXEC) [__NetBSD__, __OpenBSD__]:
+ Don't redefine.
+
+ * m/mips.h: Don't use unexmips on NetBSD.
+ (LIBS_MACHINE): Move definition lower, so it doesn't use
+ LD_SWITCH_MACHINE, START_FILES, LIB_STANDARD, LIBS_TERMCAP,
+ C_SWITCH_MACHINE, and C_DEBUG_SWITCH.
+
+ * unexelf.c [BROKEN_NOCOMBRELOC]: Include assert.h.
+ (unexec) [BROKEN_NOCOMBRELOC]: Handle platforms whose nocombreloc
+ option is broken (e.g., MIPS/NetBSD).
+
+2006-03-18 Craig McDaniel <[email protected]> (tiny change)
+
+ * sheap.c (STATIC_HEAP_SIZE): Enlarge STATIC_HEAP_SIZE to 12MB.
+ Remove the HAVE_X_WINDOWS conditional.
+
+2006-03-18 Vivek Dasmohapatra <[email protected]> (tiny change)
+
+ * emacs.c (main): If user asks for a display that is unavailable,
+ simulate -nw.
+
+ * xterm.c (x_display_ok): New function.
+
+ * xterm.h: Add prototype for x_display_ok.
+
+2006-03-18 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (Fw32_select_font): Doc fix.
+
+2006-03-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c [MAC_OS] (XPutPixel, XGetPixel)
+ [!WORDS_BIG_ENDIAN && USE_CG_DRAWING]: Don't use specialized
+ version when depth is 32.
+ (mac_create_cg_image_from_image) [MAC_OS && USE_CG_DRAWING]:
+ New function.
+ (prepare_image_for_display) [MAC_OS && USE_CG_DRAWING]: Use it.
+ (x_clear_image_1) [MAC_OS && USE_CG_DRAWING]: Release CGImage.
+
+ * macterm.c (XCreatePixmap) [!WORDS_BIG_ENDIAN && USE_CG_DRAWING]:
+ Create GWorld in ARGB pixel format.
+ (mac_copy_area, mac_copy_area_with_mask) [USE_CG_DRAWING]:
+ Remove functions.
+ (x_draw_image_foreground) [USE_CG_DRAWING]: Use mac_draw_cg_image
+ instead of mac_copy_area/mac_copy_area_with_mask.
+
+2006-03-15 Kim F. Storm <[email protected]>
+
+ * xdisp.c (extend_face_to_end_of_line): Always add space glyph to
+ empty row. Fixes memory corruption revealed by 2006-03-02 change.
+ (display_tool_bar_line): Skip empty tool-bar line if HEIGHT < 0.
+ (tool_bar_lines_needed): Fix tool-bar display in case the tool-bar
+ width is exactly the same as the window width. Don't count a final
+ empty tool-bar line (pass HEIGHT = -1 to display_tool_bar_line).
+
+2006-03-15 Juanma Barranquero <[email protected]>
+
+ * fringe.c (w32_init_fringe, w32_reset_fringes): Revert to being
+ conditional on HAVE_NTGUI, not WINDOWS_NT.
+
+2006-03-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * dispextern.h (mac_init_fringe) [MAC_OS]: Add prototype.
+
+ * fringe.c (mac_init_fringe) [MAC_OS]: New function.
+
+ * macterm.c (mac_initialize) [USE_CG_DRAWING]: Call mac_init_fringe.
+ (max_fringe_bmp, fringe_bmp) [USE_CG_DRAWING]: New variables.
+ (mac_define_fringe_bitmap, mac_destroy_fringe_bitmap)
+ (mac_draw_cg_image) [USE_CG_DRAWING]: New functions.
+ (mac_draw_bitmap) [USE_CG_DRAWING]: Remove function.
+ (x_draw_fringe_bitmap) [USE_CG_DRAWING]: Use mac_draw_cg_image
+ instead of mac_draw_bitmap.
+ (x_redisplay_interface) [USE_CG_DRAWING]: Set handlers for
+ define_fringe_bitmap and destroy_fringe_bitmap.
+
+2006-03-14 Chong Yidong <[email protected]>
+
+ * xterm.c (x_uncatch_errors): Block input for entire function.
+
+2006-03-12 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fx_create_frame): Remove call to
+ Qface_set_after_frame_default (from xfns.c 2003-05-26).
+
+ * w32menu.c (Fx_popup_menu): Call w32_free_menu_strings when
+ finished with the menu.
+
+ * w32term.c: Sync 2005-10-24 xterm.c changes.
+ (last_mouse_glyph_frame): New var.
+ (note_mouse_movement): Say mouse moved if current frame differs
+ from last_mouse_glyph_frame, and update last_mouse_glyph_frame.
+ (w32_mouse_position): Set last_mouse_glyph_frame.
+ Remove OLD_REDISPLAY_CODE block.
+
+2006-03-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macgui.h [USE_ATSUI && MAC_OSX]: Define USE_CG_TEXT_DRAWING to 1.
+
+ * macterm.h (struct mac_output) [USE_CG_DRAWING]: New member cg_context.
+ (mac_prepare_for_quickdraw) [USE_CG_DRAWING]: Add prototype.
+
+ * mac.c (sys_select) [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw.
+
+ * macfns.c (x_create_tip_frame): Apply 2006-03-11 change for xfns.c.
+
+ * macterm.c (mac_draw_rectangle, x_draw_glyph_string_foreground)
+ (x_draw_composite_glyph_string_foreground)
+ (x_draw_image_foreground): Undo previous changes.
+ (x_draw_hollow_cursor): Likewise. Subtract 1 from the last
+ argument of mac_draw_rectangle.
+ (CG_SET_FILL_COLOR, CG_SET_STROKE_COLOR): New macros.
+ (mac_draw_string_common, mac_draw_image_string_cg): Use them.
+ (FRAME_CG_CONTEXT) [USE_CG_DRAWING]: New macro.
+ (mac_begin_cg_clip, mac_end_cg_clip, mac_prepare_for_quickdraw)
+ [USE_CG_DRAWING]: New functions.
+ (mac_draw_line, mac_erase_rectangle, mac_clear_window)
+ (mac_fill_rectangle, mac_draw_rectangle, mac_draw_string_common)
+ (mac_draw_image_string_cg) [USE_CG_DRAWING]: Add Quartz 2D drawing part.
+ (mac_draw_bitmap, mac_invert_rectangle, mac_draw_string_common)
+ (mac_copy_area, mac_scroll_area, x_scroll_bar_create)
+ (x_scroll_bar_remove, XTset_vertical_scroll_bar, x_set_window_size)
+ (XTread_socket) [USE_CG_DRAWING]: Call mac_prepare_for_quickdraw.
+
+2006-03-12 L$,1 q(Brentey K,Aa(Broly <[email protected]>
+
+ * xfns.c (x_icon): Disable redundant call to `x_wm_set_window_state'.
+
+2006-03-11 Jason Rumney <[email protected]>
+
+ * w32fns.c (signal_user_input): New function.
+ (post_character_message): Use it for keyboard input.
+ (w32_msg_pump): Use it for mouse input.
+
+2006-03-11 Luc Teirlinck <[email protected]>
+
+ * window.c: Rename preserve_y to window_scroll_pixel_based_preserve_y.
+ (window_scroll_pixel_based, syms_of_window): Adapt to above change.
+
+2006-03-11 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (w32_wnd_proc): Ignore middle and extra button events
+ if a menu is already active (the menubar_active flag is on).
+
+2006-03-11 David Ponce <[email protected]>
+
+ * xfns.c (x_create_tip_frame): Preserve received parms by copying them.
+
+2006-03-11 Eli Zaretskii <[email protected]>
+
+ * w32term.c: Add x_fully_uncatch_errors and x_catching_errors to
+ the list of unused display error handling functions.
+
+ * eval.c (unwind_to_catch): Call x_fully_uncatch_errors only if
+ HAVE_X_WINDOWS.
+ (internal_condition_case, internal_condition_case_1)
+ (internal_condition_case_2): Call x_catching_errors only if
+ HAVE_X_WINDOWS.
+
+ * vm-limit.c [HAVE_GETRLIMIT]: Don't define unconditionally.
+ Don't include sys/resource.h unless defined.
+
+2006-03-11 Richard Stallman <[email protected]>
+
+ * keymap.c (describe_map): Shorten string to indicate shadowed binding.
+
+ * vm-limit.c (get_lim_data, lim_data, data_space_start):
+ Move from mem-limits.h.
+ (enum warnlevel): New data type.
+ (check_memory_limits): Rewrite the logic about warnings.
+ Use standard `struct rlimit'. Check return values for nonsense.
+ (memory_warnings): Always clear lim_data.
+
+ * mem-limits.h (get_lim_data, lim_data, data_space_start):
+ Move to vm-limit.c.
+
+ * xterm.c (x_fully_uncatch_errors, x_catching_errors): New functions.
+
+ * eval.c (unwind_to_catch): Call x_fully_uncatch_errors.
+ (internal_condition_case_1, internal_condition_case_2):
+ Abort if within unclosed x_catch_errors.
+
+2006-03-11 Romain Francoise <[email protected]>
+
+ * process.c (Vprocess_adaptive_read_buffering): Doc fix.
+
+2006-03-11 Giorgos Keramidas <[email protected]> (tiny change)
+
+ * lisp.h: Remove duplicate prototypes. Make the prototype of
+ getloadavg be conditioned on HAVE_GETLOADAVG being undefined.
+
+2006-03-11 Eli Zaretskii <[email protected]>
+
+ * xterm.c (x_draw_hollow_cursor): Subtract 1 from the last
+ argument of XDrawRectangle.
+
+ * xdisp.c (get_phys_cursor_geometry): Don't decrease height by 1.
+
+ * macterm.c (mac_draw_rectangle): Don't add 1 to width and height.
+ (x_draw_glyph_string_foreground)
+ (x_draw_composite_glyph_string_foreground)
+ (x_draw_image_foreground): Don't subtract 1 from width and height
+ arguments to mac_draw_rectangle.
+ (x_draw_hollow_cursor): Add 1 to w->phys_cursor_width.
+
+2006-03-10 Kim F. Storm <[email protected]>
+
+ * alloc.c (USE_POSIX_MEMALIGN): Fix last change.
+
+2006-03-09 Stefan Monnier <[email protected]>
+
+ * alloc.c (USE_POSIX_MEMALIGN): New macro.
+ (ABLOCKS_BASE, lisp_align_malloc, lisp_align_free): Use it.
+
+2006-03-09 Kenichi Handa <[email protected]>
+
+ * coding.c (DECODE_EMACS_MULE_COMPOSITION_CHAR): Fix decoding
+ ASCII component of a composition.
+
+2006-03-08 Luc Teirlinck <[email protected]>
+
+ * window.c: Declare preserve_y as a static global variable.
+ (window_scroll_pixel_based): No longer declare preserve_y;
+ it is global now.
+ (syms_of_window): Set preserve_y to -1.
+
+2006-03-08 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c [MAC_OS] (XPutPixel): Set alpha channel bits if pixmap
+ depth is 32.
+ [MAC_OS] (XGetPixel): Strip off alpha channel bits if pixmap
+ depth is 32.
+
+2006-03-06 Chong Yidong <[email protected]>
+
+ * xdisp.c (handle_invisible_prop): Don't update it->position with
+ a buffer position if we're in a display string.
+
+2006-03-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.h (MAC_AQUA_VERTICAL_SCROLL_BAR_WIDTH)
+ (MAC_AQUA_SMALL_VERTICAL_SCROLL_BAR_WIDTH): New defines.
+
+ * macfns.c (x_default_scroll_bar_color_parameter)
+ (x_set_scroll_bar_foreground, x_set_scroll_bar_background):
+ Remove unnecessary prototypes.
+ (x_set_scroll_bar_default_width):
+ Use MAC_AQUA_VERTICAL_SCROLL_BAR_WIDTH.
+ (mac_set_scroll_bar_width): New function.
+ (mac_frame_parm_handlers): Set it as handler for scroll-bar-width.
+
+ * macterm.c (get_control_part_bounds): Fix type of return value.
+ (x_set_toolkit_scroll_bar_thumb, x_scroll_bar_create)
+ (XTset_vertical_scroll_bar) [USE_TOOLKIT_SCROLL_BARS]: Don't show
+ scroll bar if it is not tall enough to display scroll bar thumb.
+ [USE_CARBON_EVENTS] (mac_convert_event_ref)
+ (mac_handle_command_event, mac_handle_window_event)
+ (mac_handle_mouse_event): Check error code of GetEventParameter.
+ (convert_fn_keycode) [MAC_OSX]: Likewise.
+
+2006-03-05 Andreas Schwab <[email protected]>
+
+ * xselect.c (x_catch_errors_unwind): Fix missing return value.
+
+2006-03-02 Kim F. Storm <[email protected]>
+
+ * frame.h (struct frame): New member n_tool_bar_rows.
+
+ * xdisp.c: Minimize the unpleasent visual impact of the requirement
+ that non-toolkit tool-bars must occupy an integral number of screen
+ lines, by distributing the rows evenly over the tool-bar screen area.
+ (Vtool_bar_border): New variable.
+ (syms_of_xdisp): DEFVAR_LISP it.
+ (display_tool_bar_line): Add HEIGHT arg for desired row height.
+ Make tool-bar row the desired height. Use default face for border
+ below tool-bar.
+ (tool_bar_lines_needed): Add N_ROWS arg. Use it to return number of
+ actual tool-bar rows.
+ (redisplay_tool_bar): Calculate f->n_tool_bar_rows initially.
+ Adjust the height of the tool-bar rows to fill tool-bar screen area.
+ (redisplay_tool_bar): Calculate f->n_tool_bar_rows when tool-bar area
+ is resized.
+
+2006-03-01 Luc Teirlinck <[email protected]>
+
+ * search.c (Fregexp_quote): Do not precede a literal `]' with two
+ backslashes to try to make clear that it has a literal meaning; it
+ does not do that. (It could close a character alternative
+ containing a backslash.)
+
+2006-02-28 Chong Yidong <[email protected]>
+
+ * xselect.c (x_catch_errors_unwind): New function.
+ (x_reply_selection_request): Put x_uncatch_errors in an unwind.
+ (Fx_get_atom_name): Call x_uncatch_errors earlier.
+
+ * window.c (Qscroll_up, Qscroll_down): New syms.
+ (window_scroll_pixel_based): Make preserve_y static to avoid
+ getting point stuck when scrolling 1 line.
+
+2006-02-26 Chong Yidong <[email protected]>
+
+ * xterm.h, xterm.c (x_uncatch_errors): Delete unneccessary argument.
+
+ * xterm.c (x_load_font, x_term_init, XTmouse_position)
+ (handle_one_xevent, x_connection_closed, x_list_fonts):
+ No arg for x_uncatch_errors.
+
+ * xselect.c (x_own_selection, x_decline_selection_request)
+ (x_reply_selection_request, x_get_foreign_selection)
+ (Fx_get_atom_name, Fx_send_client_event): Likewise.
+
+ * xfns.c (x_real_positions, x_set_mouse_color, Fx_focus_frame):
+ Likewise.
+
+2006-02-26 Luc Teirlinck <[email protected]>
+
+ * lread.c: Declare Vload_file_rep_suffixes instead of
+ deleted variable default_suffixes.
+ (Fget_load_suffixes): New function.
+ (Fload): Use Fget_load_suffixes and Vload_file_rep_suffixes.
+ No longer use deleted variable default_suffixes. Update docstring.
+ (syms_of_lread): defsubr Sget_load_suffixes.
+ Expand `load-suffixes' docstring.
+ Delete default_suffixes and DEFVAR_LISP the new variable
+ `load-file-rep-suffixes'.
+
+ * w32.c (check_windows_init_file): Use Fget_load_suffixes instead
+ of Vload_suffixes.
+
+ * lisp.h: EXFUN Fget_load_suffixes.
+ Extern Vload_file_rep_suffixes.
+
+ * eval.c (specpdl_ptr): Remove volatile qualifier for consistency
+ with lisp.h.
+
+2006-02-26 Stefan Monnier <[email protected]>
+
+ * lisp.h (struct specbinding, specpdl_ptr): Remove the volatile
+ qualifier which was trying to avoid the bug that was fixed by
+ yesterday's changes to xterm.c.
+
+2006-02-25 Chong Yidong <[email protected]>
+
+ * xterm.h (x_catch_errors) Return value changed to void.
+ (x_uncatch_errors): Delete unused count argument.
+
+ * xterm.c (x_catch_errors): Don't use record_unwind_protect, since
+ it can be called in a signal handler.
+ (x_catch_errors_unwind): Function deleted.
+ (x_uncatch_errors): Deallocate last x_error_message_stack struct.
+ (x_check_errors): Call x_uncatch_errors before signalling error.
+
+ (x_load_font, x_term_init, XTmouse_position, handle_one_xevent)
+ (x_connection_closed, x_list_fonts): Use new versions of
+ x_catch_errors and x_uncatch_errors.
+
+ * xselect.c (x_own_selection, x_decline_selection_request)
+ (x_reply_selection_request, x_get_foreign_selection)
+ (Fx_get_atom_name, Fx_send_client_event): Likewise.
+
+ * xfns.c (x_real_positions, x_set_mouse_color, Fx_focus_frame):
+ Likewise.
+
+ * eval.c (record_unwind_protect): Add an assertion.
+
+2006-02-25 Stefan Monnier <[email protected]>
+
+ * process.c (Fmake_network_process): Init the process's mark.
+
+2006-02-25 Kim F. Storm <[email protected]>
+
+ * buffer.c (modify_overlay): Force redisplay if we modify an
+ overlay at the end of the buffer.
+
+2006-02-24 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_image_for_pixmap): If x_find_image_file returns
+ nil the image file has been removed, in that case use the (cached)
+ pixmap.
+
+2006-02-24 Kenichi Handa <[email protected]>
+
+ * fileio.c (Finsert_file_contents): When a text is replaced
+ partially, be sure to set point before the inserted characters.
+
+2006-02-23 Zhang Wei <[email protected]> (tiny change)
+
+ * xfns.c (Fx_file_dialog): Return a decoded file name.
+
+2006-02-23 YAMAMOTO Mitsuharu <[email protected]>
+
+ * dispnew.c (update_text_area): Avoid needless redraw of rightmost
+ glyph whose face is extended to the text area end.
+
+ * macterm.c (x_set_toolkit_scroll_bar_thumb): Don't set control
+ values if control is not visible or values are not changed.
+
+2006-02-22 Stefan Monnier <[email protected]>
+
+ * window.c (Fwindow_list): Check `window' before doing XWINDOW.
+ The default `window' should not be "on a different frame".
+
+2006-02-22 Kim F. Storm <[email protected]>
+
+ * indent.c (Fvertical_motion): Only try to move back if we can.
+
+2006-02-22 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macgui.h (struct _XGC) [!MAC_OSX || !USE_ATSUI]: New member
+ n_clip_rects.
+
+ * macmenu.c (digest_single_submenu): Apply 2006-02-19 change for
+ xmenu.c.
+
+ * macterm.c (GC_CLIP_REGION): Remove macro.
+ (mac_begin_clip, mac_end_clip): Take arg GC instead of REGION.
+ All uses changed. Don't do clipping if n_clip_rects is zero.
+ (mac_set_clip_rectangles): Use xassert instead of abort.
+ Set n_clip_rects. Don't make clip_region empty when number of
+ clipping rectangles is zero.
+ (mac_reset_clip_rectangles): Set n_clip_rects directly instead of
+ calling mac_set_clip_rectangles.
+ (x_set_toolkit_scroll_bar_thumb): Temporarily hide scroll bar to
+ avoid multiple redraws.
+
+2006-02-22 Kim F. Storm <[email protected]>
+
+ * fringe.c (draw_fringe_bitmap): Fix overlay-arrow display.
+
+2006-02-21 Kim F. Storm <[email protected]>
+
+ * fringe.c (syms_of_fringe) <fringe-bitmaps>: Doc fix.
+
+2006-02-21 Zhang Wei <[email protected]>
+
+ * xfns.c (Fx_file_dialog, Motif and GTK): DECODE_FILE before
+ returning it.
+
+2006-02-21 Giorgos Keramidas <[email protected]> (tiny change)
+
+ * fringe.c (horizontal_bar_bits): Rename from `horisontal_bar_bits'.
+ (standard_bitmaps): Use it.
+
+2006-02-21 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_draw_string_common): Remove arg MODE. New arg
+ BG_WIDTH. All uses changed. Draw background if BG_WIDTH is not zero.
+ (mac_draw_image_string, mac_draw_image_string_16): New arg BG_WIDTH.
+ [USE_CG_TEXT_DRAWING] (mac_draw_image_string_cg): Rename from
+ mac_draw_string_cg. New arg BG_WIDTH. All uses changed.
+ Draw background if BG_WIDTH is not zero. Use float constants as
+ divisors instead of double. Use alloca instead of xmalloc/xfree.
+ (x_draw_glyph_string_background, x_draw_glyph_string_foreground)
+ [!MAC_OS8 || USE_ATSUI]: Background may be drawn using
+ mac_draw_image_string* functions.
+ (XLoadQueryFont) [MAC_OS8 && USE_ATSUI]: Don't adjust heights of
+ some fonts when srcCopy text transfer mode might be used.
+ (mac_begin_clip, mac_end_clip): Check if region is empty.
+ (mac_set_clip_rectangles): When resetting clip region, make it
+ empty instead of disposing of it.
+
+2006-02-20 Kim F. Storm <[email protected]>
+
+ * Makefile.in: Add fringe.elc to WINDOW_SUPPORT.
+
+ * buffer.h (struct buffer): New members fringe_indicator_alist and
+ fringe_cursor_alist.
+
+ * buffer.c (init_buffer_once): Set dummy default values for
+ fringe-indicator-alist and fringe-cursor-alist. The proper
+ default values are set by pre-loading fringe.el.
+ (syms_of_buffer): defvar_per_buffer new fringe-indicator-alist and
+ fringe-cursor-alist buffer-local variables and defvar_lisp_nopro
+ corresponding default- variables.
+
+ * fringe.c (enum fringe_bitmap_type): Remove. Change all uses
+ to use `int'.
+ (NO_FRINGE_BITMAP, UNDEF_FRINGE_BITMAP, MAX_STANDARD_FRINGE_BITMAPS):
+ Define explicitly.
+ (Qtruncation, Qcontinuation, Qempty_line, Qtop_bottom)
+ (Qhollow_small): New variables.
+ (syms_of_fringe): Intern and staticpro them.
+ (question_mark_bits): Rename from unknown_bits.
+ (left_curly_arrow_bits): Rename from continuation_bits.
+ (right_curly_arrow_bits): Rename from continued_bits.
+ (left_triangle_bits): Rename from ov_bits.
+ (right_triangle_bits): Add.
+ (filled_rectangle_bits): Rename from filled_box_cursor_bits.
+ (hollow_rectangle_bits): Rename from hollow_box_cursor_bits.
+ (filled_square_bits): Add.
+ (vertical_bar_bits): Rename from bar_cursor_bits.
+ (horizontal_bar_bits): Rename from hbar_cursor_bits.
+ (empty_line_bits): Rename from zv_bits.
+ (standard_bitmaps): Update to use new names.
+ (draw_fringe_bitmap_1): Make static.
+ (get_logical_cursor_bitmap, get_logical_fringe_bitmap): New functions
+ to map from logical cursors and indicators to physical bitmaps.
+ (draw_fringe_bitmap): Resolve fringe cursor and overlay-arrow
+ bitmaps using symbol names instead of bitmap numbers.
+ (update_window_fringes): Use logical indicator symbol names
+ instead of bitmap numbers for logical. Add bitmap cache.
+ (LEFT_FRINGE, RIGHT_FRINGE): New helper macros.
+
+2006-02-20 Chong Yidong <[email protected]>
+
+ * regex.c: Revert 2006-02-19 change.
+ (xmalloc, xrealloc): Define these when not linked to Emacs.
+ Redefine malloc -> xmalloc, realloc -> xrealloc as in Emacs case.
+
+2006-02-19 Luc Teirlinck <[email protected]>
+
+ * regex.c (extend_range_table_work_area): Fix typo.
+
+2006-02-19 Richard M. Stallman <[email protected]>
+
+ * xterm.c (x_catch_errors): Use xmalloc.
+
+ * regex.c (extend_range_table_work_area): Call xmalloc and xrealloc.
+ (regex_compile): Likewise.
+ (regcomp): Use xmalloc.
+
+ * gtkutil.c (malloc_widget_value): Use xmalloc.
+
+ * vm-limit.c [HAVE_GETRLIMIT]: Include sys/resource.h.
+ (check_memory_limits) [HAVE_GETRLIMIT]: Use getrlimit.
+
+ * xmenu.c (digest_single_submenu): When pane_string is empty,
+ do initialize save_wv.
+
+2006-02-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * xdisp.c (update_menu_bar) [MAC_OS]: Don't set
+ w->update_mode_line if arg F is not the selected frame.
+
+ * macmenu.c (popup_activated_flag, submenu_id)
+ (next_menubar_widget_id): Remove variables.
+ (initialize_frame_menubar): Remove function.
+ (pop_down_menu, mac_menu_show): Simplify save value.
+ (dispose_menus): New function.
+ (pop_down_menu, fill_menubar): Use it.
+ (fill_submenu): Remove function. All uses changed to fill_menu.
+ (add_menu_item): Remove args SUBMENU and FORCE_DISABLE. New arg
+ POS. Don't call SetMenuItemHierarchicalID here.
+ (fill_menu): Add arg SUBMENU_ID. Return submenu_id that is to be
+ used next. Call SetMenuItemHierarchicalID here.
+ (fill_menubar): Add arg DEEP_P. All uses changed. Clean up menu
+ objects if needed. Reuse existing menu bar titles if possible.
+ (set_frame_menubar): Don't clean up menu objects here.
+
+2006-02-18 Chong Yidong <[email protected]>
+
+ * window.c (window_min_size_1): Ensure room for the scroll bar and
+ fringes.
+
+2006-02-17 Romain Francoise <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment to 1200000.
+
+2006-02-17 Stefan Monnier <[email protected]>
+
+ * alloc.c (Fmake_symbol): Comment-out left-over assert from before the
+ addition of the BLOCK_INPUTs.
+
+2006-02-17 Juanma Barranquero <[email protected]>
+
+ * window.c (Fset_window_scroll_bars): Doc fix.
+
+2006-02-17 Kenichi Handa <[email protected]>
+
+ * xdisp.c (display_mode_element): Call display_string with correct
+ PREC arg (which must be a number of characters, not column width).
+
+2006-02-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * frame.c (x_get_arg): Clear out PARAM in ALIST also on Mac.
+
+ * macfns.c (x_set_menu_bar_lines): Menu bar is always shown on Mac.
+
+ * macmenu.c (set_frame_menubar): Don't call DrawMenuBar.
+
+2006-02-14 Richard M. Stallman <[email protected]>
+
+ * frame.c (x_get_arg): Clear out all occurrences of PARAM in ALIST.
+
+ * m/ibms390x.h: New file.
+
+2006-02-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_tool_bar_detach_callback): Set show-arrow to the
+ value of x-gtk-whole-detached-tool-bar.
+ (xg_tool_bar_attach_callback): Set show-arrow to TRUE.
+
+ * xfns.c (syms_of_xfns): New variable: x-gtk-whole-detached-tool-bar.
+
+2006-02-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_x_to_emacs_modifiers): Make non-static.
+
+ * xterm.h: Declare x_x_to_emacs_modifiers.
+
+ * gtkutil.c (xg_tool_bar_button_cb): New function.
+ (xg_tool_bar_callback): Call x_x_to_emacs_modifiers to
+ store modifiers in event.
+ (update_frame_tool_bar): Connect button-release-event to
+ xg_tool_bar_button_cb.
+
+2006-02-13 Richard M. Stallman <[email protected]>
+
+ * .gdbinit (xwindow): Update the code to show the window box.
+
+2006-02-13 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (note_mouse_movement): Check for NULL FRAME_X_OUTPUT (frame).
+
+2006-02-12 Richard M. Stallman <[email protected]>
+
+ * cmds.c (internal_self_insert): Handle weird auto-fill-function.
+
+2006-02-11 Eli Zaretskii <[email protected]>
+
+ * keyboard.c (Venable_disabled_menus_and_buttons): New variable.
+ (syms_of_keyboard): DEVFAR_LISP and initialize it.
+ (parse_tool_bar_item, parse_menu_item): If that variable is
+ non-nil, don't disable menu items and tool-bar buttons.
+
+2006-02-11 Juanma Barranquero <[email protected]>
+
+ * doc.c (Fsubstitute_command_keys): Doc fix.
+
+2006-02-10 Thien-Thi Nguyen <[email protected]>
+
+ * data.c (Findirect_function): Rewrite docstring.
+ Fix omission bug: Declare new arg NOERROR.
+
+2006-02-10 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (x_set_mouse_color): Don't call rif->define_frame_cursor
+ if window_desc is not set yet.
+ (Fx_create_frame): Remove variable x_frame_name. Apply 2005-12-07
+ and 2006-01-26 changes for xfns.c. Call x_iconify_frame if frame
+ parameter `visibility' is `icon'.
+ (Fx_create_frame, x_create_tip_frame): Use "fontset-standard"
+ instead of "fontset-mac".
+ (Fx_focus_frame): New defun.
+ (syms_of_macfns): Defsubr it.
+
+ * macterm.c (mac_define_frame_cursor): Don't change pointer shape
+ for unfocused frame.
+ (x_raise_frame): Call BringToFront instead of SelectWindow.
+ (x_lower_frame): Use NULL instead of nil.
+ (x_make_frame_visible): Don't call SelectWindow.
+ (XTread_socket): Increment handling_signal at the start, decrement
+ it at the end.
+ [USE_CG_TEXT_DRAWING] (init_cg_text_anti_aliasing_threshold): Use
+ CFPreferencesGetAppIntegerValue instead of Fmac_get_preference.
+
+2006-02-10 Kim F. Storm <[email protected]>
+
+ * data.c (Findirect_function): Add NOERROR arg. All callers changed
+ to pass Qnil for NOERROR.
+
+ * keymap.c (current_minor_maps_error): Remove.
+ (current_minor_maps): Pass Qt for NOERROR to Findirect_function
+ instead of using internal_condition_case_1+current_minor_maps_error.
+
+2006-02-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): Must note mouse movement even for nil
+ frames for GTK, in that case it is the tool bar. This is so that
+ highlighted text get reset properly.
+
+2006-02-09 Juanma Barranquero <[email protected]>
+
+ * alloc.c (Fmake_bool_vector, Fpurecopy): Doc fixes.
+
+2006-02-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * window.c (adjust_window_trailing_edge): Check that shrinking
+ does not set a window to size zero or less.
+
+2006-02-08 Miles Bader <[email protected]>
+
+ * editfns.c (Fconstrain_to_field): Use Fget_char_property instead
+ of Fget_text_property (other field functions work with overlays as
+ well as text-properties).
+
+2006-02-07 Kenichi Handa <[email protected]>
+
+ * dispextern.h (unibyte_display_via_language_environment): Extern it.
+
+ * xterm.h (unibyte_display_via_language_environment):
+ * w32term.h (unibyte_display_via_language_environment):
+ * macterm.h (unibyte_display_via_language_environment): Delete extern.
+
+2006-02-07 Kenichi Handa <[email protected]>
+
+ * term.c (append_glyph): Refer to it->char_to_display instead of it->c.
+ (produce_glyphs): Set the character to print in
+ it->char_to_display. Handle unibyte-display-via-language-environment.
+ (produce_stretch_glyph): Set character to print in it->char_to_display.
+
+2006-02-06 Kenichi Handa <[email protected]>
+
+ * lread.c (openp): Initialize encoded_fn before GCPRO it.
+
+2006-02-05 Ken Raeburn <[email protected]>
+
+ * editfns.c (Fconstrain_to_field): Fix int/Lisp_Object mixup.
+
+ * lisp.h (XPNTR) [!NO_UNION_TYPE && !HAVE_SHM && !DATA_SEG_BITS]:
+ Cast bitfield value to EMACS_INT, to suppress gcc warning.
+
+ * xrdb.c (malloc, realloc, free) [emacs]: Undefine macros before
+ defining.
+
+2006-02-03 Kim F. Storm <[email protected]>
+
+ * xdisp.c: Cache last merged escape glyph face.
+ (last_escape_glyph_frame, last_escape_glyph_face_id)
+ (last_escape_glyph_merged_face_id): New variables.
+ (get_next_display_element): Use/update them.
+ (redisplay_internal): Reset them before redisplay.
+
+ * xdisp.c (set_iterator_to_next): Optimize 2004-12-13 fix.
+ Only recheck faces after displaying ellipsis.
+
+2006-02-02 Kenichi Handa <[email protected]>
+
+ * coding.c (decode_composition_emacs_mule): Fix handling of
+ incorrect format data.
+
+2006-01-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Use new tool bar function
+ gtk_toolbar_insert() so we can have tool bars of different sizes.
+
+2006-01-30 Luc Teirlinck <[email protected]>
+
+ * data.c (Flistp): Doc fix.
+
+2006-01-30 Juanma Barranquero <[email protected]>
+
+ * window.c (Fother_window, Fwindow_vscroll, Fset_window_vscroll):
+ Fix typos in docstrings.
+
+2006-01-28 Luc Teirlinck <[email protected]>
+
+ * data.c (Fcar, Fcdr): Add links to Elisp manual to the docstrings.
+
+2006-01-27 Chong Yidong <[email protected]>
+
+ * alloc.c (make_interval, allocate_string)
+ (allocate_string_data, make_float, Fcons, allocate_vectorlike)
+ (Fmake_symbol, allocate_misc): Use BLOCK_INPUT when accessing
+ global variables.
+
+2006-01-27 Eli Zaretskii <[email protected]>
+
+ * dired.c (DIRENTRY_NONEMPTY) [__CYGWIN__]: Don't use d_ino; use
+ the MSDOS definition.
+
+2006-01-26 Richard M. Stallman <[email protected]>
+
+ * alloc.c (check_pure_size): Make overflow message an "error message".
+
+ * keymap.c (Fmap_keymap): Doc fix.
+
+ * xfns.c (Fx_create_frame): Put all specified parms into f->param_alist
+ unless they were cleared out.
+
+ * frame.c (x_get_arg): "Clear out" the parm in ALIST if found there.
+
+2006-01-26 L$,1 q(Brentey K,Aa(Broly <[email protected]>
+
+ * editfns.c (Fconstrain_to_field): Fix behaviour on field boundaries.
+ (find_field): Set before_field to after_field when pos is at BEGV.
+ (Fline_beginning_position, Fline_end_position):
+ Clarify confusing doc string.
+
+ * cmds.c (Fbeginning_of_line, Fend_of_line): Clarify confusing doc
+ string.
+
+2006-01-26 Kenichi Handa <[email protected]>
+
+ * callproc.c (Fcall_process): GCPRO error_file. Encode infile,
+ current_dir, and error_file. On reporting an error, decode them
+ back.
+
+2006-01-24 Stefan Monnier <[email protected]>
+
+ * regex.c (IMMEDIATE_QUIT_CHECK): Use it with SYNC_INPUT as well.
+ (re_match_2_internal) <on_failure_jump, on_failure_jump_smart>:
+ Don't check for quit, since any loop will go through fail or jump.
+
+2006-01-24 Chong Yidong <[email protected]>
+
+ * alloc.c (allocate_string_data): Update next_free immediately, to
+ reduce risk of memory clobberage.
+
+2006-01-24 L$,1 q(Brentey K,Aa(Broly <[email protected]>
+
+ * xdisp.c (handle_invisible_prop): Set it->position to fix cursor
+ display when point moves across an ellipsis. If there are
+ adjacent invisible texts, don't lose the second one's ellipsis.
+ (x_produce_glyphs): Doc fix.
+
+2006-01-23 Stefan Monnier <[email protected]>
+
+ * xterm.c (x_catch_errors_unwind): Yet another int/Lisp_Object mixup.
+
+2006-01-23 Kim F. Storm <[email protected]>
+
+ * xdisp.c (handle_single_display_spec): Fix handling of space
+ property on char from string: set *position rather than
+ it->current.pos.
+ (produce_stretch_glyph): Reduce width of stretch glyphs so they
+ don't get wider than the window (unless truncate-lines is on).
+
+2006-01-22 Stefan Monnier <[email protected]>
+
+ * xterm.c: Avoid allocating Lisp data from a signal handler.
+ (x_error_message): New var to replace x_error_message_string.
+ (x_error_catcher, x_catch_errors, x_catch_errors_unwind)
+ (x_check_errors, x_had_errors_p, x_clear_errors, x_error_handler)
+ (syms_of_xterm): Use it instead of x_error_message_string.
+
+ * alloc.c (lisp_align_free): Add an assertion.
+ (make_interval, allocate_string, make_float, Fcons, Fmake_symbol)
+ (allocate_misc): If ENABLE_CHECKING is on, check we're not called from
+ a signal handler.
+
+2006-01-21 Luc Teirlinck <[email protected]>
+
+ * dired.c (syms_of_dired) <completion-ignored-extensions>: Doc fix.
+
+2006-01-21 Romain Francoise <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): Fix last change.
+ Update copyright year.
+
+2006-01-20 Eli Zaretskii <[email protected]>
+
+ * lread.c (Fload): Don't leak the file descriptor returned by
+ openp if we are going to signal an error.
+
+ * w32.c (sys_close): If FD is outside [0..MAXDESC) limits, pass it
+ directly to _close.
+ (sys_dup): Protect against new_fd larger than fd_info[] can handle.
+ (sys_read): If FD is outside [0..MAXDESC) limits, pass it directly
+ to _read.
+ (sys_write): If FD is outside [0..MAXDESC) limits, pass it
+ directly to _write.
+
+ * .gdbinit: Don't dereference Vsystem_type's Lisp_Symbol pointer
+ if it is NULL.
+
+2006-01-20 Kenichi Handa <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment to 1190000.
+
+2006-01-19 Chong Yidong <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): Use cursor type specified by
+ the selected buffer for the echo area too.
+
+2006-01-19 Richard M. Stallman <[email protected]>
+
+ * keymap.c (Fmap_keymap): Doc fix.
+
+ * s/irix6-5.h (GC_SETJMP_WORKS, GC_MARK_STACK): New definitions.
+
+ * keyboard.c (echo_char): Don't omit the space between first two
+ echoed chars.
+
+ * minibuf.c (read_minibuf): Fix previous change.
+
+2006-01-19 Kenichi Handa <[email protected]>
+
+ * xterm.c (handle_one_xevent): Handle keysyms 0x1000000..0x10000FF.
+
+2006-01-17 Richard M. Stallman <[email protected]>
+
+ * frame.c (x_frame_get_and_record_arg): Don't record Qunbound
+ value in f->param_alist.
+
+2006-01-15 Andreas Schwab <[email protected]>
+
+ * search.c (Freplace_match): Use UPPERCASEP instead of !NOCASEP.
+
+2006-01-13 Richard M. Stallman <[email protected]>
+
+ * Makefile.in: Define new macro WINDOW_SUPPORT.
+ (lisp): Use it.
+ (SOME_MACHINE_LISP): Add conditionally loaded files.
+
+2006-01-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c [USE_ATSUI] (atsu_get_text_layout_with_text_ptr)
+ [MAC_OS_X_VERSION_MAX_ALLOWED >= 1020]: Specify kATSLineUseQDRendering.
+ (XLoadQueryFont) [USE_ATSUI]: Display diacritical marks in
+ decomposed form.
+
+ * process.c [HAVE_INTTYPES_H]: Include inttypes.h.
+ (ifflag_table): Fix typo (IFF_OACTIV -> IFF_OACTIVE).
+ (Fnetwork_interface_info): Use HAVE_STRUCT_IFREQ_IFR_NETMASK
+ macro. Also try member ifr_addr when getting netmask.
+
+2006-01-10 Stefan Monnier <[email protected]>
+
+ * fileio.c (Fexpand_file_name): Remove redundant tests.
+ Fix elimination of // so that it doesn't prevent elimination of an
+ immediately following /. or /..
+
+2006-01-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_toggle_notify_cb): New function.
+ (xg_toggle_visibility_cb): Move setting of x_gtk_show_hidden_files to
+ xg_toggle_notify_cb.
+ (xg_get_file_with_chooser): Add callback to xg_toggle_notify_cb when
+ parameter value changes so the toggle button gets updated.
+
+2006-01-06 Nick Roberts <[email protected]>
+
+ * .gdbinit: Fix typo.
+
+2006-01-05 Eli Zaretskii <[email protected]>
+
+ * .gdbinit: Fix last change.
+
+2006-01-05 Kim F. Storm <[email protected]>
+
+ * process.c (Fmake_network_process): Use AF_INET instead of
+ AF_UNSPEC when AF_INET6 is not defined.
+
+2006-01-05 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (mac_coerce_file_name_ptr, mac_coerce_file_name_desc):
+ Don't check that the other type is known file-related one.
+
+ * macfns.c (Fx_server_version): Use gestaltSystemVersionMajor,
+ gestaltSystemVersionMinor, and gestaltSystemVersionBugFix on Mac
+ OS X 10.4 and later.
+
+2006-01-04 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_image_for_pixmap): If the image is from a file,
+ let GTK do all image processing. Importing Emacs own pixmaps to GTK
+ looks bad for inactive tool bar items with some Gnome themes.
+
+2006-01-04 Eli Zaretskii <[email protected]>
+
+ * .gdbinit: Avoid a warning message when x_error_quitter is not
+ compiled in.
+
+ * process.c [WINDOWSNT]: Undef AF_INET6 to disable IPv6 support
+ for w32.
+
+2006-01-04 Kim F. Storm <[email protected]>
+
+ * process.c: Add IPv6 support.
+ (Qipv4, Qipv6): New vars.
+ (syms_of_process): Intern and staticpro them.
+ (Fformat_network_address): Handle 9 or 8 element vector as IPv6 address
+ with or without port number. Handle 4 element vector as IPv4 address
+ without port number.
+ (conv_sockaddr_to_lisp, get_lisp_to_sockaddr_size)
+ (conv_lisp_to_sockaddr): Handle IPv6 addresses.
+ (Fmake_network_process): Use :family 'ipv4 and 'ipv6 to explicitly
+ request that address family only. :family nil or omitted means to
+ determine address family from the specified :host and :service.
+ (ifflag_table): Add missing OpenBSD IFF_ flags.
+ (server_accept_connection): Handle IPv6 addresses.
+ (init_process): Add (:family ipv4) and (:family ipv6) sub-features.
+
+ * .gdbinit: Undo last change. Instead, look at Vsystem_type to
+ determine which breakpoints to set.
+
+2006-01-03 Stefan Monnier <[email protected]>
+
+ * keymap.c (describe_map_compare): Yet another int/Lisp_Object mixup.
+
+ * window.h (Fwindow_minibuffer_p): Declare (for use in minibuf.c).
+
+2006-01-03 Romain Francoise <[email protected]>
+
+ * emacs.c (main): Update copyright year.
+
+2006-01-03 Ken Raeburn <[email protected]>
+
+ * callproc.c (delete_temp_file): Bind file-name-handler-alist to
+ nil for the call to internal_delete_file.
+
+2006-01-01 Ken Raeburn <[email protected]>
+
+ * callproc.c (Fcall_process_region): Bind file-name-handler-alist
+ to nil for the call to Fwrite_region.
+
+2005-12-31 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (read_minibuf): Clear out all other minibuffer windows.
+
+2005-12-31 Eli Zaretskii <[email protected]>
+
+ * emacs.c (gdb_pvec_type): A dummy variable for GDB's sake.
+
+2005-12-30 Luc Teirlinck <[email protected]>
+
+ * textprop.c (set_text_properties): Reword description of return value.
+ Return Qnil if caller wants to remove all text properties from a
+ string and the string already has no intervals.
+
+2005-12-30 Stefan Monnier <[email protected]>
+
+ * term.c (visible_cursor): New boolean var.
+ (set_terminal_modes, tty_show_cursor): Use "vs" or "ve" depending on
+ visible_cursor.
+ (syms_of_term): Export the new var as "visible-cursor".
+
+2005-12-30 Eli Zaretskii <[email protected]>
+
+ * .gdbinit: Tell users not to worry about GDB warnings that some
+ functions do not exist in the binary.
+
+2005-12-30 Andreas Schwab <[email protected]>
+
+ * process.c (Fnetwork_interface_info): Correctly terminate the
+ loop over ifflag_table.
+
+2005-12-29 Richard M. Stallman <[email protected]>
+
+ * lread.c (readevalloop): Test for reading a whole buffer
+ before actually reading anything. Handle all cases, including
+ START = END = nil and an already-narrowed buffer.
+ Convert END to a marker if it is a number.
+
+ * keymap.c (describe_map): Put sparse map elements into an array,
+ sort them, then output a sequence of identical bindings on one line.
+ (struct describe_map_elt): New data type.
+ (describe_map_compare): New function.
+
+2005-12-28 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_file_with_chooser): Change message shown
+ in file chooser.
+
+2005-12-27 Richard M. Stallman <[email protected]>
+
+ * lread.c (readevalloop): Set PT and ZV in the proper buffer,
+ not the current one.
+
+ * minibuf.c (Fminibuffer_message): Doc fix.
+ (read_minibuf): Set current_buffer->enable_multibyte_characters sooner.
+
+ * eval.c (do_autoload): Ignore elements of Vautoload_queue
+ where car is not symbol.
+
+2005-12-27 Kenichi Handa <[email protected]>
+
+ * charset.c (lisp_string_width): Check multibyteness of STRING.
+
+2005-12-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_show_hidden_files): New variable.
+ (syms_of_xfns): Defvar it.
+
+ * gtkutil.c (xg_toggle_visibility_cb): New function.
+ (xg_get_file_with_chooser): Add toggle hidden files and a message
+ to the new file chooser dialog. Show hidden files if
+ x_show_hidden_files is non-zero.
+
+2005-12-26 Richard M. Stallman <[email protected]>
+
+ * keyboard.h: Undo previous change.
+
+ * Makefile.in (undo.o): Undo previous change.
+
+ * undo.c: Undo previous change.
+
+2005-12-26 Luc Teirlinck <[email protected]>
+
+ * keyboard.h: extern last_point_position_window.
+
+ * undo.c: include keyboard.h.
+
+ * Makefile.in (undo.o): Depend on keyboard.h.
+
+2005-12-26 Richard M. Stallman <[email protected]>
+
+ * commands.h (last_point_position_window): Declare.
+
+ * undo.c: Depend on window.h.
+ (record_point): Save old point from the correct window.
+
+ * keyboard.c (last_point_position_window): New variable.
+ (command_loop_1): Set last_point_position_window.
+ (syms_of_keyboard): Init it.
+
+ * Makefile.in (undo.o): Depend on window.h.
+
+2005-12-25 Richard M. Stallman <[email protected]>
+
+ * eval.c (un_autoload): Expect (0 . OFEATURES) in Vautoload_queue
+ to undo a `provide'.
+
+ * fns.c (Fprovide): Store (0 . OFEATURES) in Vautoload_queue.
+
+2005-12-25 Giorgos Keramidas <[email protected]>
+
+ * m/amdx86-64.h [__FreeBSD__] (START_FILES, LIB_STANDARD):
+ define for FreeBSD on this platform.
+
+2005-12-24 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.h (TYPE_FILE_NAME): New define.
+ (posix_pathname_to_fsspec, fsspec_to_posix_pathname): Remove externs.
+
+ * mac.c (posix_pathname_to_fsspec, fsspec_to_posix_pathname):
+ Add prototypes. Make static.
+ (mac_aedesc_to_lisp): Initialize err to noErr.
+ (mac_coerce_file_name_ptr, mac_coerce_file_name_desc)
+ (init_coercion_handler): New functions.
+ (Fmac_coerce_ae_data): Use coercion of Apple event data for
+ translation from/to file names.
+
+ * macterm.c: Don't include sys/param.h.
+ (init_coercion_handler): Add extern.
+ [MAC_OS8] (main): Call init_coercion_handler.
+ (mac_initialize) [MAC_OSX]: Likewise.
+ [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Use coercion of
+ Apple event data for translation from/to file names.
+
+ * macfns.c [TARGET_API_MAC_CARBON] (Fx_file_dialog): Likewise.
+
+ * image.c [MAC_OS] (find_image_fsspec): Likewise.
+
+2005-12-23 Martin Rudalics <[email protected]>
+
+ * insdel.c (insert, insert_and_inherit, insert_before_markers)
+ (insert_before_markers_and_inherit): Make sure FROM is correct
+ when `after-change-functions' are called.
+
+2005-12-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (Fx_uses_old_gtk_dialog): New function.
+
+ * gtkutil.c (xg_uses_old_file_dialog): New function.
+ (xg_get_file_name): Use xg_uses_old_file_dialog.
+
+ * gtkutil.h: Declare xg_uses_old_file_dialog.
+
+2005-12-22 Richard M. Stallman <[email protected]>
+
+ * xmenu.c (xmenu_show): Call inhibit_garbage_collection.
+
+2005-12-22 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (Fmac_coerce_ae_data) [MAC_OSX]: Fix memory leak.
+
+ * macgui.h (XCharStruct): Remove member `valid_p'.
+ (STORE_XCHARSTRUCT): Don't set member `valid_p'.
+ (XCharStructRow): New typedef.
+ (XCHARSTRUCTROW_CHAR_VALID_P, XCHARSTRUCTROW_SET_CHAR_VALID):
+ New macros.
+ (struct MacFontStruct): Add member `bounds'. Remove member
+ `per_char'. All uses for QuichDraw Text fonts are changed to
+ `bounds.per_char'. ATSUI font bounds are represented as an array
+ `bounds.rows' of XCharStructRow's, each of which consists of a
+ bitmap of valid entries and an array of char bounds.
+
+ * macterm.c (mac_per_char_metric): Add prototype.
+ (x_per_char_metric) [USE_CG_TEXT_DRAWING]: Remove prototype.
+ (mac_query_char_extents): New function.
+ (x_per_char_metric): Use it.
+ (XLoadQueryFont): Likewise. Consolidate min/max_bounds calculations.
+ [USE_CG_TEXT_DRAWING] (mac_draw_string_cg):
+ Use mac_per_char_metric instead of x_per_char_metric.
+ (mac_text_extents_16): New function.
+ (mac_compute_glyph_string_overhangs): Use it.
+ (mac_unload_font): Free member `bounds' in struct MacFontStruct.
+
+2005-12-21 Stefan Monnier <[email protected]>
+
+ * minibuf.c (Fdisplay_completion_list): Use XCAR/XCDR.
+ (Fminibuffer_completion_help): Remove duplicates before display.
+
+2005-12-21 L$,1 q(Brentey K,Aa(Broly <[email protected]>
+
+ * print.c (print_preprocess): Don't lose print_depth levels while
+ iterating.
+
+2005-12-21 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (Qmac_apple_event): Add extern.
+ (set_frame_menubar, mac_menu_show keymp_panes)
+ (single_keymap_panes, list_of_panes, list_of_item)
+ (single_menu_item): Add argument types to prototypes.
+ (mac_dialog_show) [HAVE_DIALOGS]: Likewise.
+ (struct skp): New struct (from xmenu.c).
+ (single_keymap_panes, single_menu_item, list_of_panes)
+ (list_of_item): Sync with xmenu.c.
+ (Fx_popup_menu, Fx_popup_dialog): Likewise. Don't get window from
+ POSITION if it is mac-apple-event event.
+ (menubar_selection_callback): Don't use menu_command_in_progress.
+ (set_frame_menubar): First parse all submenus, then make
+ widget_value trees from them. Don't allocate any widget_value
+ objects until we are done with the parsing.
+ (parse_single_submenu, digest_single_submenu): New functions.
+ (single_submenu): Function deleted, replaced by those two.
+ (install_menu_quit_handler) [HAVE_CANCELMENUTRACKING]: Don't create
+ or dispose of EventHandlerUPP. Install hander to all submenus.
+ (mac_menu_show) [!HAVE_MULTILINGUAL_MENU]: Use ENCODE_MENU_STRING
+ instead of ENCODE_SYSTEM.
+ (free_frame_menubar, fill_submenu, fill_menu): Don't use NULL for
+ integer values.
+ [HAVE_DIALOGS] (mac_dialog_show): Sync with xdialog_show (in xmenu.c).
+ (add_menu_item) [TARGET_API_MAC_CARBON]: Use CFString functions to
+ format menu item string. Don't use NULL for integer value.
+
+ * macterm.h (struct mac_output): Remove unused member
+ menu_command_in_progress.
+
+2005-12-20 Juri Linkov <[email protected]>
+
+ * xmenu.c (Fx_popup_menu): Set Vmenu_updating_frame to f if
+ position is non-nil, else set it to nil.
+
+ * macmenu.c (Fx_popup_menu): Add `else' to set
+ Vmenu_updating_frame to nil only if position is nil.
+
+ * w32menu.c (Fx_popup_menu): Add `else' to set
+ Vmenu_updating_frame to nil only if position is nil.
+
+2005-12-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * keyboard.c (make_lispy_event): Drag-and-drop items are now
+ stored in member `args' of struct input_event.
+
+ * termhooks.h (struct input_event): Fix comment for DRAG_N_DROP_EVENT.
+
+ * xselect.c (x_handle_dnd_message): Drag-and-drop items are now
+ stored in member `args' of struct input_event.
+
+ * w32term.c (construct_drag_n_drop): Likewise.
+
+ * macterm.c (mac_do_receive_drag): Likewise.
+ (x_use_underline_position_properties): Undo 2005-07-13 change.
+ (syms_of_macterm) <x-use-underline-position-properties>: Likewise.
+ (mac_use_core_graphics, mac_wheel_button_is_mouse_2)
+ (mac_pass_command_to_system, mac_pass_control_to_system):
+ New boolean variables renamed from Lisp_Object ones
+ Vmac_use_core_graphics, Vmac_wheel_button_is_mouse_2,
+ Vmac_pass_command_to_system, and Vmac_pass_control_to_system.
+ All uses changed.
+ (syms_of_macterm): DEFVAR_BOOL them. Remove previous DEFVAR_LISPs.
+ Make them user options.
+ (mac_handle_command_event, mac_store_services_event):
+ Call create_apple_event_from_event_ref without 5th argument.
+ (backtranslate_modified_keycode): Mask off modifier keys that are
+ mapped to some Emacs modifiers before passing it to KeyTranslate.
+ (syms_of_macterm): Make variables `mac-emulate-three-button-mouse',
+ `mac-wheel-button-is-mouse-2', and `mac-*-modifier' user options.
+ Fix docstrings of `mac-*-modifier'.
+
+ * mac.c (create_apple_event_from_event_ref): Remove arg `types'.
+ (do_applescript): Change argument types to Lisp_Object.
+ All uses changed.
+
+ * macterm.h (create_apple_event_from_event_ref): Remove 5th
+ argument from extern.
+
+2005-12-18 Dan Nicolaescu <[email protected]>
+
+ * xfns.c (Fx_backspace_delete_keys_p): In case we cannot determine
+ the answer, return `lambda', not nil.
+
+2005-12-17 Eli Zaretskii <[email protected]>
+
+ * makefile.w32-in (bootstrap-temacs): Warn that parts of commands
+ enclosed in $(ARGQUOTE)s should not be split between two lines, as
+ that will break with GNU Make >3.80, when sh.exe is used and
+ arg quoting is with '..'.
+
+2005-12-17 Chong Yidong <[email protected]>
+
+ * print.c (print_preprocess): Just signal an error if print_depth
+ is exceeded.
+
+2005-12-17 Eli Zaretskii <[email protected]>
+
+ * .gdbinit: Set a breakpoint on w32_abort.
+
+2005-12-16 Juri Linkov <[email protected]>
+
+ * minibuf.c (Fminibuffer_completion_contents): New Lisp function
+ created from minibuffer_completion_contents.
+ (minibuffer_completion_contents): Remove.
+ (do_completion, Fminibuffer_complete_word)
+ (Fminibuffer_completion_help): Replace minibuffer_completion_contents
+ with Fminibuffer_completion_contents.
+ (syms_of_minibuf): Add Sminibuffer_completion_contents.
+ (Fdisplay_completion_list): Doc fix.
+ (display_completion_list_1): Use `nil' for second arg of
+ `Fdisplay_completion_list'.
+
+2005-12-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (compute_tip_xy): Handle negative dx and dy.
+
+ * w32fns.c (compute_tip_xy): Ditto.
+
+ * macfns.c (compute_tip_xy): Ditto.
+
+2005-12-14 Chong Yidong <[email protected]>
+
+ * print.c (print_preprocess): Go to a deeper print_depth to avoid
+ print_object loop.
+
+2005-12-14 Kyotaro HORIGUCHI <[email protected]> (tiny change)
+
+ * coding.c (code_convert_region_unwind): GCPRO arg.
+
+2005-12-12 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (compute_tip_xy): Calculate root_y the same way as root_x,
+ i.e. dy is offset from top of frame instead of bottom.
+
+ * macfns.c (compute_tip_xy): Ditto.
+
+ * w32fns.c (compute_tip_xy): Ditto.
+
+ * gtkutil.c (SSDATA): New macro to remove compiler warnings.
+ (xg_get_image_for_pixmap, xg_create_frame_widgets)
+ (xg_get_file_with_chooser): Use SSDATA instead of SDATA.
+
+ * xmenu.c (menubar_selection_callback): Do nothing if the callback
+ is for an unselected radio menu item.
+
+2005-12-11 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (syms_of_xdisp) <blink-cursor-alist>: Doc fix.
+
+ * lisp.h [! NO_UNION_TYPE] (EQ): Use == so args are computed just once.
+
+ * keymap.c (Fset_keymap_parent, store_in_keymap): Use CHECK_IMPURE.
+ (Flookup_key): Doc fix.
+ (syms_of_keymap) <function-key-map>: Doc fix.
+
+ * fns.c (Frequire): Treat evaluating from a source file
+ like loading the file.
+
+ * floatfns.c (Flog): Doc fix.
+
+ * fileio.c (Finsert_file_contents): Set Vdeactivate_mark
+ when we change the buffer.
+
+2005-12-11 Juri Linkov <[email protected]>
+
+ * minibuf.c (display_completion_list_1):
+ Call `minibuffer_completion_contents' instead of using `nil' as
+ second arg of `Fdisplay_completion_list'.
+ (keys_of_minibuf): Unbind SPC in
+ Vminibuffer_local_filename_completion_map (see also related
+ change on 2005-12-06).
+
+2005-12-11 YAMAMOTO Mitsuharu <[email protected]>
+
+ * emacs.c (main) [MAC_OS8]: Undo previous change.
+
+ * macselect.c (syms_of_macselect) <mac-apple-event-map>:
+ Initialize to nil. Keymap is now created in lisp/term/mac-win.el.
+
+2005-12-10 YAMAMOTO Mitsuharu <[email protected]>
+
+ * Makefile.in (macselect.o): Depend on keymap.h.
+
+ * emacs.c (main) [MAC_OS8]: Call syms_of_keymap before
+ syms_of_macselect.
+
+ * image.c (init_image) [MAC_OS]: Don't call EnterMovies.
+ [!HAVE_GIF && MAC_OS] (gif_load): Call EnterMovies.
+
+ * keyboard.c (Qmac_apple_event) [MAC_OS]: New variable.
+ (syms_of_keyboard) [MAC_OS]: Initialize it.
+ (make_lispy_event) [MAC_OS]: Build lisp event for MAC_APPLE_EVENT.
+
+ * mac.c (Qundecoded_file_name): New variable.
+ (syms_of_mac): Initialize it.
+ (mac_aelist_to_lisp, mac_aedesc_to_lisp): New functions.
+ [TARGET_API_MAC_CARBON] (create_apple_event_from_event_ref): New fun.
+ (Fmac_coerce_ae_data): New defun.
+ (syms_of_mac): Defsubr it.
+
+ * macselect.c: Include keymap.h.
+ (mac_ready_for_apple_events): New variable.
+ (Vmac_apple_event_map, Qmac_apple_event_class)
+ (Qmac_apple_event_id): New variables.
+ (syms_of_macselect): Initialize them.
+ (Qundefined, mac_store_apple_event): Add externs.
+ (struct apple_event_binding): New struct.
+ (find_event_binding_fun, find_event_binding)
+ (mac_find_apple_event_spec, defer_apple_events)
+ (mac_handle_apple_event, init_apple_event_handler)
+ (copy_scrap_flavor_data): New functions.
+ (Fmac_process_deferred_apple_events): New defun.
+ (syms_of_macselect): Defsubr it.
+ (mac_store_services_event): Fix extern.
+ (mac_handle_service_event): Don't allocate Lisp objects during
+ asynchronous input processing. Use mac_store_services_event
+ instead of mac_store_application_menu_event.
+
+ * macterm.c (Qmac_ready_for_drag_n_drop, Qapplication, Qabout)
+ (Qpreferences): Remove variables.
+ (syms_of_macterm): Don't initialize them.
+ (Qhicommand) [USE_CARBON_EVENTS]: New variable.
+ (syms_of_macterm) [USE_CARBON_EVENTS]: Initialize it.
+ (init_required_apple_events, do_ae_open_application)
+ (do_ae_print_documents, do_ae_open_documents)
+ (do_ae_quit_application): Remove functions and prototypes.
+ (mac_ready_for_apple_events, Qundefined, init_apple_event_handler)
+ (mac_find_apple_event_spec): Add externs.
+ (mac_store_application_menu_event): Remove function.
+ (mac_store_apple_event, mac_make_lispy_event_code): New functions.
+ (mac_handle_command_event): Create Apple event from Carbon event.
+ Use mac_store_apple_event instead of mac_store_application_menu_event.
+ [MAC_OSX] (mac_store_services_event): Likewise.
+ (struct SelectionRange, SelectionRange): Remove struct and typedef.
+ [MAC_OS8] (main): Call init_apple_event_handler instead of
+ init_required_apple_events.
+ (mac_initialize) [MAC_OSX]: Likewise.
+ [!USE_CARBON_EVENTS] (mac_wait_next_event):
+ Use mac_ready_for_apple_events instead of Qmac_ready_for_drag_n_drop.
+
+ * macterm.h (mac_make_lispy_event_code, mac_aedesc_to_lisp):
+ Add externs.
+ (create_apple_event_from_event_ref) [TARGET_API_MAC_CARBON]: Likewise.
+ (Fmac_get_preference): Add EXFUN.
+
+ * termhooks.h (enum event_kind) [MAC_OS]: Add new MAC_APPLE_EVENT
+ event.
+
+2005-12-09 Richard M. Stallman <[email protected]>
+
+ * xfns.c (Fx_create_frame): Reinstate previous change.
+
+2005-12-09 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (w32_abort) [__GNUC__]: Add instructions for attaching
+ GDB to the abort dialog.
+
+2005-12-09 Kyotaro HORIGUCHI <[email protected]> (tiny change)
+
+ * indent.c (Fvertical_motion): Force move if starting on
+ stretch glyph.
+
+2005-12-08 Richard M. Stallman <[email protected]>
+
+ * lread.c (read_escape) <\s>: Don't treat strings specially.
+
+ * xfns.c (Fx_create_frame): Comment out previous change.
+
+2005-12-07 L$,1 q(Brentey K,Aa(Broly <[email protected]>
+
+ * xfns.c (Fx_create_frame): Initialize Vdefault_minibuffer_frame,
+ when needed.
+
+2005-12-06 Stefan Monnier <[email protected]>
+
+ * minibuf.c (keys_of_minibuf): Just unbind SPC in
+ Vminibuffer_local_filename_completion_map rather than forcing it
+ explicitly to the same binding as the global map.
+
+2005-12-06 Ken Raeburn <[email protected]>
+
+ * buffer.c (Fkill_buffer): Avoid dangerous side effects in NILP args.
+ * bytecode.c (Fbyte_code): Likewise.
+ * fileio.c (internal_delete_file, Fread_file_name_internal): Likewise.
+ * minibuf.c (Fminibuffer_complete_and_exit): Likewise.
+ * undo.c (truncate_undo_list): Likewise.
+
+2005-12-05 Richard M. Stallman <[email protected]>
+
+ * window.c (enlarge_window): Eliminate arg preserve_before.
+ Assume it is 0. All callers changed.
+ (Fenlarge_window, Fshrink_window): Likewise.
+
+2005-12-02 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (compute_tip_xy): Put tip above pointer if it doesn't
+ fit below.
+
+2005-12-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h: Add prototype for xg_set_icon_from_xpm_data.
+
+ * xfns.c (x_real_positions): int ign => unsigned int.
+ (xg_set_icon_from_xpm_data): Remove unused variable err.
+ (x_set_name_internal, Fx_create_frame, xg_set_icon): Add cast
+ to remove compiler warning.
+ (compute_tip_xy): Put tip above pointer if it doesn't fit below.
+
+2005-12-02 David Reitter <[email protected]>
+
+ * minibuf.c (Fcompleting_read): If Vminibuffer_completing_file_name is
+ non-nil, use the new keymaps Vminibuffer_local_filename_completion_map
+ and Vminibuffer_local_must_match_filename_map keymaps.
+ (keys_of_minibuf): Bind SPC in the new file-name completion keymaps.
+
+ * keymap.c (Vminibuffer_local_filename_completion_map)
+ (Vminibuffer_local_must_match_filename_map): New variables.
+ (syms_of_keymap): DEFVAR_LISP them, initialize them, and set their
+ parent to be Vminibuffer_local_completion_map and
+ Vminibuffer_local_must_match_map, respectively.
+
+ * commands.h (Vminibuffer_local_filename_completion_map)
+ (Vminibuffer_local_must_match_filename_map): Declare the new keymaps.
+
+2005-12-01 Stefan Monnier <[email protected]>
+
+ * window.c (Fset_window_configuration): Don't accidentally copy the
+ window-point of one window to another.
+
+2005-11-30 L$,1 q(Brentey K,Aa(Broly <[email protected]>
+
+ * buffer.c (Fpop_to_buffer): Remove superfluous call to record_buffer.
+
+2005-11-30 Kim F. Storm <[email protected]>
+
+ * alloc.c: Include fcntl.h. Define O_WRONLY if not defined.
+ (valid_lisp_object_p) [!GC_MARK_STACK]: Validate pointer by
+ passing it to `emacs_write'.
+
+2005-11-29 Ari Roponen <[email protected]> (tiny change)
+
+ * atimer.c (stop_other_atimers): Fix loop to correctly compute `prev'.
+
+2005-11-27 Richard M. Stallman <[email protected]>
+
+ * window.c (adjust_window_trailing_edge): New function.
+ (Fadjust_window_trailing_edge): New function.
+ (syms_of_window): Defsubr it.
+ (window_deletion_count): New variable.
+ (delete_window): Update window_deletion_count.
+
+2005-11-26 Eli Zaretskii <[email protected]>
+
+ * minibuf.c (syms_of_minibuf): Mention the extension of
+ `completion-auto-help's meaning by complete.el.
+
+2005-11-26 Henrik Enberg <[email protected]>
+
+ * xfaces.c (Finternal_set_lisp_face_attribute_from_resource):
+ Handle :inherit property as a lisp expression.
+
+2005-11-24 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (Qcontrol): Rename from Qctrl. All uses changed.
+ (syms_of_macterm): Staticpro Qcontrol, Qmeta, Qalt, Qhyper,
+ Qsuper, and Qmodifier_value.
+ (Vmac_control_modifier, Vmac_option_modifier)
+ (Vmac_command_modifier, Vmac_function_modifier)
+ (Vmac_emulate_three_button_mouse, Vmac_wheel_button_is_mouse_2)
+ (Vmac_pass_command_to_system, Vmac_pass_control_to_system)
+ (Vmac_charset_info_alist): Doc fixes.
+
+2005-11-23 YAMAMOTO Mitsuharu <[email protected]>
+
+ * emacs.c (main) [MAC_OSX]: Change working directory to home
+ directory if `-psn_*' option is specified.
+
+ * mac.c (DECODE_UTF_8): Remove macro.
+ [TARGET_API_MAC_CARBON] (cfstring_to_lisp_nodecode): New function
+ created from cfstring_to_lisp.
+ [TARGET_API_MAC_CARBON] (cfstring_to_lisp): Use it.
+ (xrm_get_preference_database) [TARGET_API_MAC_CARBON]: Likewise.
+
+ * macterm.h (cfstring_to_lisp_nodecode) [TARGET_API_MAC_CARBON]:
+ Add prototype.
+
+2005-11-21 Ken Raeburn <[email protected]>
+
+ * keymap.c (shadow_lookup): Use make_number to pass a number to
+ Fsubstring.
+
+2005-11-21 Juri Linkov <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment to 1180000.
+
+2005-11-20 Chong Yidong <[email protected]>
+
+ * xfaces.c (Finternal_set_lisp_face_attribute):
+ Use :ignore-defface for new frame defaults when `unspecified' is
+ supplied.
+ (Finternal_get_lisp_face_attribute): Hide :ignore-defface.
+ (merge_face_vectors): Don't do :ignore-defface overwriting here.
+ (Finternal_merge_in_global_face): Do it here.
+
+2005-11-20 Juri Linkov <[email protected]>
+
+ * charset.c (invalid_character): Use Lisp-readable syntax
+ for octal and hex. Reorder decimal, octal and hex values.
+
+2005-11-20 Nick Roberts <[email protected]>
+
+ * lisp.h: Use typedef when Lisp_Object is EMACS_INT so that
+ this type is recognised when debugging.
+
+2005-11-19 Andreas Schwab <[email protected]>
+
+ * .gdbinit (nextcons, xcdr, xfloat): Update for changes in
+ Lisp_Cons and Lisp_Float.
+
+2005-11-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c [USE_CG_TEXT_DRAWING] (cg_text_anti_aliasing_threshold):
+ New variable.
+ [USE_CG_TEXT_DRAWING] (init_cg_text_anti_aliasing_threshold): New fun.
+ (init_font_name_table) [USE_ATSUI && USE_CG_TEXT_DRAWING]: Use it.
+ [USE_CG_TEXT_DRAWING] (mac_draw_string_cg): Don't do antialiasing if
+ font size is smaller than or equal to cg_text_anti_aliasing_threshold.
+
+2005-11-17 Chong Yidong <[email protected]>
+
+ * image.c (x_create_bitmap_from_xpm_data): Free attributes on fail.
+
+ * xfaces.c (Qignore_defface): New variable.
+ (syms_of_xfaces): Provide `:ignore-defface'.
+ (IGNORE_DEFFACE_P): New macro.
+ (check_lface_attrs, lface_fully_specified_p)
+ (Finternal_set_lisp_face_attribute)
+ (Fface_attribute_relative_p, Fmerge_face_attribute):
+ Handle Qignore_defface as a possible value.
+ (merge_face_vectors): The merged face is `unspecified' if the
+ mergee specifies `:ignore-defface'.
+
+2005-11-16 Stefan Monnier <[email protected]>
+
+ * lread.c (readevalloop): Add missing GCPROs.
+
+2005-11-16 Chong Yidong <[email protected]>
+
+ * xfns.c (xg_set_icon_from_xpm_data): New function.
+
+ * gnu.h (gnu_xpm_bits): Rename from gnu_bits.
+ (gnu_xbm_bits): Rename from gnu_bits (xbm version).
+
+ * xterm.c (x_bitmap_icon): Use the xpm if available.
+
+ * image.c (x_create_bitmap_from_xpm_data): New function.
+ (x_create_bitmap_from_xpm_data): Initialize XpmAttributes.
+
+2005-11-15 Luc Teirlinck <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): Add rfn-eshadow.
+
+2005-11-16 Nick Roberts <[email protected]>
+
+ * .gdbinit: Make SIGTSTP work like SIGINT normally does.
+
+2005-11-15 Andreas Schwab <[email protected]>
+
+ * lisp.h (struct Lisp_Cons): Make cdr a union.
+ (XCDR_AS_LVALUE): Adjust.
+ (struct Lisp_Float): Make data a union.
+ (XFLOAT_DATA): Adjust.
+
+ * alloc.c (free_float): Make free list chaining aliasing-safe.
+ (make_float): Likewise.
+ (free_cons): Likewise.
+ (Fcons): Likewise.
+ (check_cons_list): Likewise.
+ (Fmake_symbol): Likewise.
+ (allocate_misc): Likewise.
+ (free_misc): Likewise.
+ (gc_sweep): Likewise.
+
+2005-11-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (HASHKEY_QUERY_CACHE): New define.
+ (xrm_create_database, xrm_q_put_resource): Empty query cache.
+ (xrm_get_resource): Use query cache.
+
+ * image.c (init_image) [MAC_OS]: Don't call EnterMovies if
+ inhibit_window_system is set.
+
+2005-11-13 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macgui.h (USE_CG_TEXT_DRAWING): New define.
+ (struct MacFontStruct) [USE_CG_TEXT_DRAWING]: New members cg_font
+ and cg_glyphs.
+
+ * macterm.c [USE_CG_TEXT_DRAWING] (mac_draw_string_cg): New function.
+ (x_draw_glyph_string_foreground) [USE_CG_TEXT_DRAWING]: Use it.
+ (XLoadQueryFont) [USE_CG_TEXT_DRAWING]: Set members cg_font and
+ cg_glyphs in struct MacFontStruct if synthesized bold or italic is
+ not used and font substitution never occurs for ASCII and Latin-1
+ characters.
+ (XLoadQueryFont): Maximum and minimum metrics are now those among
+ ASCII characters.
+ (XLoadQueryFont) [!MAC_OS8 || USE_ATSUI]: Apply WebKit-style
+ height adjustments for Courier, Helvetica, and Times.
+
+ * s/darwin.h (LIBS_CARBON) [!HAVE_CARBON]: Remove `-framework Carbon'.
+
+2005-11-11 David Reitter <[email protected]>
+
+ * macterm.c (syms_of_macterm): Remove macCtrlKey, macShiftKey,
+ macMetaKey, macAltKey. Introduce Qctrl, Qmeta,
+ Vmac_control_modifier / mac-control-modifier,
+ Vmac_option_modifier / mac-option-modifier,
+ Vmac_command_modifier / mac-command-modifier.
+ (mac_to_emacs_modifiers): Use the new style modifier
+ variables. Return UInt32 (modifiers are longs now.)
+ (backtranslate_modified_keycode): New function (refactoring).
+ (XTread_socket): Use new modifier variables and refactored function.
+ (mac_determine_quit_char_modifiers): Remove macMetaKey (there is
+ no dedicated meta key. Not in use anyway.)
+ (convert_fn_keycode): Map Fn-keys to their original keycode
+ using a table (english keyboard only).
+
+2005-11-11 Kim F. Storm <[email protected]>
+
+ * .gdbinit (pitx): Fix output format if n_overlay_strings > 0.
+ Add post hook to "backtrace" to always dump lisp call stack to
+ increase chance of people sending it to us when reporting bugs.
+
+ * doc.c (Fsubstitute_command_keys): Doc fix.
+
+ * dispextern.h (struct it): New member ignore_overlay_strings_at_pos_p.
+
+ * xdisp.c (handle_stop): Skip overlay string handling if
+ ignore_overlay_strings_at_pos_p is set.
+ (set_iterator_to_next): At end of display vector, set
+ ignore_overlay_strings_at_pos_p if dpvec came from an overlay
+ string, so we skip those overlay strings at current pos.
+
+2005-11-10 Lars Hansen <[email protected]>
+
+ * fileio.c (file-regular-p): Doc fix.
+
+2005-11-10 Kim F. Storm <[email protected]>
+
+ * alloc.c (valid_lisp_object_p): New function to validate that
+ an object is really a valid Lisp_Object.
+
+ * lisp.h (valid_lisp_object_p): Add prototype.
+
+ * print.c (safe_debug_print): New function to be called from gdb
+ to print Lisp objects; use valid_lisp_object_p to avoid crashing
+ if user tries to print something which is not a Lisp object.
+
+ * .gdbinit (pp, pp1): Use safe_debug_print.
+ (pv, pv1): New commands to print value of a lisp variable.
+
+2005-11-10 Nick Roberts <[email protected]>
+
+ * .gdbinit (pp1): New user-defined function.
+
+2005-11-09 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c [MAC_OSX] (image_load_quartz2d): Fix memory leak.
+
+ * mac.c [MAC_OSX] (init_mac_osx_environment): Reinitialize locale
+ related variables for dumped executable.
+
+ * unexmacosx.c (unexec_write_zero): New function.
+ (copy_data_segment): Clear uninitialized local variables in
+ statically linked libraries.
+
+ * s/darwin.h (C_SWITCH_SYSTEM): Remove -fno-common.
+
+2005-11-09 Juri Linkov <[email protected]>
+
+ * keymap.c (shadow_lookup): If Flookup_key returns a number,
+ call it again with a sub-key-sequence, and if its return value
+ is non-nil (sub-key is bound), return nil.
+
+2005-11-08 Kim F. Storm <[email protected]>
+
+ * process.c (Fsignal_process): Recognize signal names with and
+ without SIG prefix, e.g. SIGHUP and HUP.
+
+ * search.c (search_buffer): No need to initialize base_pat.
+
+2005-11-04 Stefan Monnier <[email protected]>
+
+ * window.c (Fget_lru_window, Fget_largest_window, window_loop):
+ Don't abuse the `mini' arg. Use the `obj' arg instead.
+
+2005-11-04 Kim F. Storm <[email protected]>
+
+ * xdisp.c (show_mouse_face): Clear mouse face to eol.
+
+2005-11-03 Dan Nicolaescu <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): Add emacs-lisp/syntax.elc,
+ font-lock.elc and jit-lock.elc.
+
+2005-11-03 Richard M. Stallman <[email protected]>
+
+ * window.c (Fenlarge_window): Rename SIDE to HORIZONTAL.
+ (enlarge_window): Rename WIDTHFLAG to HORIZ_FLAG.
+ (CURBEG, CURSIZE): Use HORIZ_FLAG instead of WIDTHFLAG.
+
+ * sheap.c (STATIC_HEAP_SIZE): Increment both definitions.
+
+ * alloc.c (refill_memory_reserve): Move decl out of conditionals.
+
+2005-11-03 Stefan Monnier <[email protected]>
+
+ * window.c (Fdisplay_buffer): Fix last change to not use
+ a dedicated window.
+
+2005-11-01 Kim F. Storm <[email protected]>
+
+ * fringe.c (update_window_fringes): Undo 2005-10-27 change.
+ Instead, rotate the bottom angle bitmap 180 degrees to indicate
+ that the bottom row does not end in a newline.
+
+2005-11-01 Andreas Schwab <[email protected]>
+
+ * unexelf.c (unexec): Handle .plt section in BSS segment.
+
+2005-11-01 Stefan Monnier <[email protected]>
+
+ * lread.c (readevalloop): Yet another int/Lisp_Object mixup (YAILOM).
+
+ * window.c (window_loop): For LRU and LARGEST, let the `mini' argument
+ determine whether to consider dedicated windows as well.
+ (Fget_lru_window, Fget_largest_window): Add `dedicated' argument.
+ (Fdisplay_buffer): Do consider dedicated windows in those cases where
+ we will split the window rather than reuse it.
+ Don't try to use windows on other displays.
+
+2005-10-31 Dan Nicolaescu <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment to 1170000.
+
+2005-10-31 Romain Francoise <[email protected]>
+
+ * macfns.c: Update copyright year.
+ * m/gould.h: Likewise.
+
+2005-10-30 Kim F. Storm <[email protected]>
+
+ * xdisp.c (display_line): Restore it->current_x and call
+ extend_face_to_end_of_line when last glyph doesn't fit on line.
+ (set_glyph_string_background_width): Remove specific tests here
+ to see if face background should extend to end of line. Simplify.
+
+2005-10-30 Richard M. Stallman <[email protected]>
+
+ * alloc.c (BYTES_USED): Use uordblks, not arena.
+ (bytes_used_when_reconsidered): New variable.
+ (emacs_blocked_free): Set that.
+
+2005-10-29 Chong Yidong <[email protected]>
+
+ * alloc.c (emacs_blocked_free): Fix typo.
+
+2005-10-29 Richard M. Stallman <[email protected]>
+
+ * data.c (Fmake_variable_frame_local): Doc fix.
+
+ * xdisp.c (handle_fontified_prop): Do nothing if memory full.
+ (format_mode_line_unwind_data): New arg SAVE_PROPTRANS
+ controls whether to save and restore mode_line_proptrans_alist.
+ Callers changed.
+ (unwind_format_mode_line): Work with that feature.
+ (redisplay_internal): Don't call prepare_menu_bars if memory full.
+ (move_elt_to_front): New function.
+ (display_mode_element): Use move_elt_to_front.
+ Don't bother munging text props on a null string.
+ Delete obsolete elts from mode_line_proptrans_alist.
+ (decode_mode_spec): Test Vmemory_full, not spare_memory.
+ (Fformat_mode_line): Clear mode_line_proptrans_alist after saving.
+
+ * lisp.h (memory_full_cons_threshold): Declare.
+ (internal_lisp_condition_case): Declare.
+
+ * alloc.c (syms_of_alloc) <memory-full>: Doc fix.
+ (Fmemory_full_p): Function deleted.
+ (syms_of_alloc): Don't defsubr it.
+ (memory_full_cons_threshold): New variable.
+ (spare_memory): Now a vector of 7 elts.
+ (buffer_memory_full): Don't set Vmemory_full here.
+ (xfree): Don't try to refill here.
+ (emacs_blocked_free): Record BYTES_USED in local var.
+ (memory_full): Now free all the slots in spare_memory.
+ (refill_memory_reserve): Allocate each slot in spare_memory.
+ (init_alloc_once): Call refill_memory_reserve.
+
+ * keyboard.c (command_loop_1): Don't set Vmemory_full here.
+
+ * eval.c (internal_lisp_condition_case): New function.
+ (Fcondition_case): Use internal_lisp_condition_case.
+ (Feval): Test Vmemory_full and memory_full_cons_threshold.
+ (Ffuncall): Likewise.
+
+ * bytecode.c (Fbyte_code): Use internal_lisp_condition_case.
+
+2005-10-29 Stefan Monnier <[email protected]>
+
+ * syntax.c (Fparse_partial_sexp): Fix docstring.
+
+2005-10-28 Romain Francoise <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment to 1130000.
+
+2005-10-28 Richard M. Stallman <[email protected]>
+
+ * xfns.c (syms_of_xfns): Provide `x' as feature.
+
+ * xdisp.c (decode_mode_spec): Define %e to indicate memory full.
+
+ * editfns.c (Fformat): Don't include string padding
+ between info[n].start and info[n].end.
+
+ * alloc.c (spare_memory): No longer static.
+ (xfree) [!SYSTEM_MALLOC]: Call refill_memory_reserve.
+
+ * puresize.h (BASE_PURESIZE): Increment to 1120000.
+
+2005-10-27 Chong Yidong <[email protected]>
+
+ * data.c (Fmake_variable_frame_local): Add clarification to docstring.
+
+ * fringe.c (update_window_fringes): Handle case where buffer ends
+ with a newline.
+
+2005-10-27 Kenichi Handa <[email protected]>
+
+ * coding.h (DECODE_SYSTEM): Fix argument name; name->str.
+
+2005-10-24 Kenichi Handa <[email protected]>
+
+ * charset.h (charset_mule_unicode_0100_24ff)
+ (charset_mule_unicode_2500_33ff, charset_mule_unicode_e000_ffff):
+ Extern them.
+
+ * charset.c (charset_mule_unicode_0100_24ff)
+ (charset_mule_unicode_2500_33ff, charset_mule_unicode_e000_ffff):
+ New variables.
+ (Fsetup_special_charsets): Initialize them.
+
+ * xterm.c (handle_one_xevent): Handle keysyms directly mapped to
+ supported Unicode characters.
+
+2005-10-25 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_to_x_font): Avoid forcing font widths.
+
+2005-10-25 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c [MAC_OS] (image_load_qt_1): Check image size.
+ Use GraphicsImportGetImageDescription instead of
+ GraphicsImportGetNaturalBounds.
+ [MAC_OSX] (image_load_quartz2d): Check image size.
+ [MAC_OS] (xpm_load_image): Likewise.
+
+ * macterm.c (last_mouse_glyph_frame): New var.
+ (note_mouse_movement): Say mouse moved if current frame differs
+ from last_mouse_glyph_frame, and update last_mouse_glyph_frame.
+ (XTmouse_position): Set last_mouse_glyph_frame.
+ (XTread_socket): Clear last_mouse_glyph_frame on mouse up/down event.
+ (mac_draw_string_common) [USE_ATSUI && WORDS_BIG_ENDIAN]: Fix typo.
+ Use EndianU16_BtoN.
+ (mac_draw_string_common) [MAC_OSX]: Don't use ATSUClearLayoutControls.
+ (x_per_char_metric, XLoadQueryFont)
+ [MAC_OS_X_VERSION_MAX_ALLOWED < 1020]: Use device origins to get
+ glyph bounds.
+ (mac_to_x_fontname, mac_do_list_fonts)
+ (mac_initialize_display_info): Change screen resolutions to 72dpi.
+
+2005-10-25 Masatake YAMATO <[email protected]>
+
+ * minibuf.c (Fdisplay_completion_list): Small doc fix.
+
+2005-10-24 Kim F. Storm <[email protected]>
+
+ * xterm.c: Undo 2005-10-23 change.
+ (last_mouse_glyph_frame): New var.
+ (note_mouse_movement): Say mouse moved if current frame differs
+ from last_mouse_glyph_frame, and update last_mouse_glyph_frame.
+ (XTmouse_position): Set last_mouse_glyph_frame.
+ (handle_one_xevent): Clear last_mouse_glyph_frame [instead of
+ last_mouse_glyph] on mouse up/down event.
+
+ * editfns.c (Fcompare_buffer_substrings): Fix last change.
+
+2005-10-23 Stefan Monnier <[email protected]>
+
+ * editfns.c (Fcompare_buffer_substrings): Handle multibyte chars.
+
+2005-10-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (note_mouse_movement): Always call note_mouse_highlight
+ so tool tips don't interfere with press on tool bar button.
+
+2005-10-23 Richard M. Stallman <[email protected]>
+
+ * casetab.c (Fset_case_table): Doc fix.
+
+ * lread.c (build_load_history): Replace STREAM arg with ENTIRE.
+ (readevalloop): Compute ENTIRE properly.
+ (syms_of_lread) <load-history>: Doc fix.
+
+2005-10-21 Richard M. Stallman <[email protected]>
+
+ * lread.c (Fload): Simplify gcpro structure.
+ Gcpro FOUND as well as FILE, but not EFOUND.
+ Unless preloading, record FOUND instead of FILE in Vload_history.
+ Rename repeat local FILE to MSG_FILE.
+ (syms_of_lread) <load-history>: Doc fix.
+
+2005-10-21 Kenichi Handa <[email protected]>
+
+ * search.c (boyer_moore): Add parens to fix and/or precedence bug.
+
+2005-10-20 Kim F. Storm <[email protected]>
+
+ * buffer.c (clone_per_buffer_values): Remove unused var tem.
+ (init_buffer): Remove unused vars dotstat, pwdstat.
+
+ * ccl.c (check_ccl_update): Remove unused var vp.
+
+ * fileio.c (auto_save_error): Call SAFE_FREE.
+
+ * fns.c (Fchar_table_range): Remove unused var i.
+
+ * minibuf.c (display_completion_list_1): New wrapper function
+ for Fdisplay_completion_list.
+ (Fminibuffer_completion_help): Use it.
+
+ * term.c (encode_terminal_code): Remove unused var src_start.
+
+ * window.c (Fwindow_tree): Remove unused var alist.
+
+ * xterm.c (x_calc_absolute_position): Remove unused vars win_x, win_y.
+
+2005-10-20 Aubrey Jaffer <[email protected]> (tiny change)
+
+ * unexelf.c (unexec): Fix calls to `fatal' with less than 3 arguments.
+
+2005-10-20 Olli Savia <[email protected]> (tiny change)
+
+ * syssignal.h [__Lynx__]: Undef SIGPOLL along with SIGIO.
+
+2005-10-20 Andreas Schwab <[email protected]>
+
+ * minibuf.c (Fdisplay_completion_list): Doc fix.
+
+2005-10-19 Kim F. Storm <[email protected]>
+
+ * image.c (check_image_size): Handle integer Vmax_image_size value
+ directly as max pixel value. Use default frame size for null frame.
+ (syms_of_image) <max-image-size>: Describe integer value.
+
+2005-10-19 Romain Francoise <[email protected]>
+
+ * emacs.c (main): Update copyright year.
+
+2005-10-18 Chong Yidong <[email protected]>
+
+ * image.c (Vmax_image_size): New variable.
+ (check_image_size): New function.
+ (xbm_read_bitmap_data, pbm_load, png_load, jpeg_load, tiff_load)
+ (gif_load, gs_load): Use it.
+ (lookup_image): Try loading again if previous load failed.
+ (xbm_read_bitmap_data): Add a new argument, a pointer to the frame
+ to display in, NULL if none.
+ (xbm_load_image, xbm_file_p): Pass xbm_read_bitmap_data the new
+ argument.
+
+2005-10-18 Richard M. Stallman <[email protected]>
+
+ * search.c (Fstring_match): Doc fix.
+
+2005-10-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (note_mouse_movement): Use PtInRect.
+ (XTread_socket): Also ignore mouse motion just before a button
+ release event. Don't process button release event when mouse is
+ not grabbed.
+
+2005-10-16 Masatake YAMATO <[email protected]>
+
+ * minibuf.c (Fdisplay_completion_list): Add new optional
+ argument COMMON_SUBSTRING. Bind `completion-common-substring'
+ to the optional argument during running `completion-setup-hook'.
+
+2005-10-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c [TARGET_API_MAC_CARBON] (get_cfstring_encoding_from_lisp):
+ Allow nil as argument.
+ [TARGET_API_MAC_CARBON] (Fmac_code_convert_string): Regard nil
+ for encoding arguments as UTF-16 in native byte order, no BOM.
+
+ * macfns.c (Fx_create_frame): Add debugging code.
+ (Fx_show_tip): Set frame pixel width and height.
+
+ * macterm.c (MAC_WINDOW_NORMAL_GC): Remove macro.
+ (FRAME_NORMAL_GC): New macro.
+ (mac_draw_line, mac_clear_area, mac_clear_window)
+ (mac_fill_rectangle, mac_draw_string, mac_draw_string_16)
+ (mac_draw_image_string, mac_draw_image_string_16): Rename from
+ XDrawLine, XClearArea, XClearWindow, XFillRectangle, XDrawString,
+ XDrawString16, XDrawImageString, and XDrawImageString16, respectively.
+ All uses changed.
+ (mac_draw_line, mac_erase_rectangle, mac_clear_area)
+ (mac_clear_window, mac_draw_bitmap, mac_draw_rectangle)
+ (mac_invert_rectangle, mac_draw_string_common, mac_draw_string)
+ (mac_draw_string_16, mac_draw_image_string)
+ (mac_draw_image_string_16, mac_copy_area, mac_copy_area_with_mask)
+ (mac_scroll_area): Drawing functions now take frame as destination.
+ All uses changed.
+ (mac_draw_string_common): Get port height with FRAME_PIXEL_HEIGHT.
+ (x_draw_fringe_bitmap): Set clipping area in face->gc.
+
+ * macterm.h (mac_clear_area): Add extern.
+
+2005-10-14 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (note_mouse_movement, XTread_socket): Apply 2005-10-14
+ changes for xterm.c.
+
+ * w32term.c (note_mouse_movement, w32_read_socket): Likewise.
+
+2005-10-14 Kenichi Handa <[email protected]>
+
+ * search.c (search_buffer): Give up BM search on case-fold-search
+ if one of a target character has a case-equivalence of different
+ charset even if that target charcter is an ASCII.
+
+ * casefiddle.c (casify_object): Fix for the case that case
+ conversion change the byte length.
+
+2005-10-14 Kim F. Storm <[email protected]>
+
+ * xterm.c (note_mouse_movement): Return 1 if mouse moved; 0 otherwise.
+ (handle_one_xevent): Only clear help_echo_string; restore it if
+ note_mouse_movement didn't record any mouse movement.
+
+ * xdisp.c (pos_visible_p): Convert w->hscroll to pixels before use.
+ (remember_mouse_glyph): Clear RECT if mouse is over an image glyph.
+
+ * keyboard.c (make_lispy_position): Adjust wx for left margin if
+ ON_TEXT.
+ (Fposn_at_x_y): Fix calculation of x coordinate.
+ (Fposn_at_point): Return nil if point is hscrolled out of view.
+
+2005-10-13 Andreas Schwab <[email protected]>
+
+ * sysdep.c (request_sigio, unrequest_sigio): Do nothing in
+ non-interactive mode.
+
+2005-10-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * xterm.c, w32term.c, macterm.c (note_mouse_movement): Undo last change.
+
+2005-10-12 Kim F. Storm <[email protected]>
+
+ * xterm.c (handle_one_xevent): Clear last_mouse_glyph on mouse up/down.
+
+2005-10-12 Romain Francoise <[email protected]>
+
+ * buffer.c (init_buffer): Rename `rc' to `len' for clarity.
+
+2005-10-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * xdisp.c (remember_mouse_glyph): Use MATRIX_BOTTOM_TEXT_ROW to
+ get end of text rows. Obtain header-line/mode-line rows directly.
+
+ * xterm.c, w32term.c, macterm.c (note_mouse_movement):
+ Restore help_echo_string if mouse is moved inside last_mouse_glyph.
+
+2005-10-12 Kim F. Storm <[email protected]>
+
+ * xdisp.c (remember_mouse_glyph): New generic version based on
+ glyph_rect and remember_mouse_glyph from xterm.c enhanced to
+ properly handle all different window areas.
+
+ * dispextern.h (remember_mouse_glyph): Add prototype.
+
+ * xterm.c (glyph_rect, remember_mouse_glyph): Remove X versions.
+ (note_mouse_movement, XTmouse_position): Use generic
+ remember_mouse_glyph, add last_mouse_glyph arg.
+
+ * w32term.c (note_mouse_movement): Fix last_mouse_glyph check.
+ (glyph_rect, remember_mouse_glyph): Remove w32 specific versions.
+ (note_mouse_movement, w32_mouse_position): Use generic
+ remember_mouse_glyph, add last_mouse_glyph arg.
+
+ * macterm.c (note_mouse_movement): Add call to remember_mouse_glyph.
+ (glyph_rect, remember_mouse_glyph): Remove mac specific versions.
+ (XTmouse_position): Adapt to use generic remember_mouse_glyph
+ instead of pixel_to_glyph_coords.
+
+ * window.c (coordinates_in_window): Fix x position for ON_RIGHT_MARGIN.
+ Fix x position for ON_TEXT when left margin width > 0.
+
+2005-10-11 Kim F. Storm <[email protected]>
+
+ * window.c (coordinates_in_window): Fix y position for ON_SCROLL_BAR.
+
+ * keyboard.c (make_lispy_position): Fix buffer calculations for
+ mouse click or movement in right fringe and the margins.
+
+2005-10-11 Juanma Barranquero <[email protected]>
+
+ * image.c (fn_jpeg_stdio_src): Don't define it.
+ (init_jpeg_functions): Don't initialize `fn_jpeg_stdio_src'.
+ (our_common_init_source): Rename from `our_init_source'.
+ (our_common_term_source): Rename from `our_term_source'.
+ (our_memory_fill_input_buffer): Rename from
+ `our_fill_input_buffer'.
+ (our_memory_skip_input_data): Rename from `our_skip_input_data'.
+ (jpeg_memory_src): Use the new names.
+ (struct jpeg_stdio_mgr): New struct.
+ (JPEG_STDIO_BUFFER_SIZE): New constant.
+ (our_stdio_fill_input_buffer, our_stdio_skip_input_data)
+ (jpeg_file_src): New functions.
+ (jpeg_load): Use `jpeg_file_src' instead of `fn_jpeg_stdio_src'.
+
+2005-10-11 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (PER_CHAR_METRIC): Remove unused macro.
+ (fm_font_family_alist): New variable.
+ (syms_of_macterm): Initialize and staticpro it.
+ (decode_mac_font_name): Replace '-' in family name with '_' if it
+ occurs just once. Lower family name.
+ (parse_x_font_name): Rename from x_font_name_to_mac_font_name.
+ All uses changed. Remove argument MF and code conversion for it.
+ Add argument SIZE. Rename argument MF_DECODED to FAMILY, and CS
+ to CHARSET. Parse font size. Lower family name. Return integer
+ value for status of parsing.
+ (init_font_name_table) [USE_ATSUI]: Use decode_mac_font_name.
+ Don't use Fdowncase because family name is already lowered by
+ decode_mac_font_name.
+ (init_font_name_table): Always call decode_mac_font_name.
+ Add pair of family name and its reference to fm_font_family_alist.
+ (mac_clear_font_name_table): Clear fm_font_family_alist.
+ (XLoadQueryFont): Move font size parsing part to parse_x_font_name.
+ Lookup fm_font_family_alist to get font family reference.
+ (XLoadQueryFont) [USE_ATSUI]: Don't use Fdowncase because family
+ name is already lowered by parse_x_font_name.
+
+2005-10-11 Kim F. Storm <[email protected]>
+
+ * xterm.c (glyph_rect): Return 0 if position is outside text area.
+
+ * keyboard.c (make_lispy_position): Fix buffer position calculation for
+ mouse click or movement in fringe.
+
+2005-10-10 Jason Rumney <[email protected]>
+
+ * xterm.c (remember_mouse_glyph): New function.
+ (note_mouse_movement): Use it to remember the current glyph if changed.
+ (XTmouse_position): Fix calculation of fake glyph under mouse.
+ Move code to calculate glyph under mouse into remember_mouse_glyph.
+
+2005-10-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * emacs.c (USAGE3, standard_args): -nb => -nbi.
+
+2005-10-10 Juanma Barranquero <[email protected]>
+
+ * frame.c (Fredirect_frame_focus): Fix typos in docstring.
+ (next_frame, prev_frame, set_term_frame_name): Make static.
+
+ * window.c (Fwindow_tree): Fix spelling.
+
+2005-10-09 Romain Francoise <[email protected]>
+
+ * window.c (Fwindow_end): Don't try to redisplay if non-interactive.
+
+2005-10-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * emacs.c (standard_args): Remove options -i, -itype, --icon-type.
+ Add options -nb, --no-bitmap-icon.
+
+ * xfns.c (Fx_create_frame): Make bitmapIcon have default on.
+
+2005-10-08 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macgui.h (MAX_CLIP_RECTS): New define.
+ (struct _XGC): New member clip_region.
+ (struct _XGC) [MAC_OSX && USE_ATSUI]: New members n_clip_rects and
+ clip_rects.
+
+ * macterm.c (GC_CLIP_REGION): New macro.
+ (saved_port_clip_region): New variable.
+ (mac_begin_clip, mac_end_clip): New functions.
+ (XDrawLine, mac_erase_rectangle, mac_draw_bitmap, XFillRectangle)
+ (mac_draw_rectangle, mac_draw_string_common, mac_copy_area)
+ (mac_copy_area_with_mask, mac_scroll_area): Use them.
+ (mac_set_clip_rectangle, mac_reset_clipping): Remove functions.
+ [USE_ATSUI] (atsu_get_text_layout_with_text_ptr)
+ [MAC_OS_X_VERSION_MAX_ALLOWED < 1020]: Specify kATSLineFractDisable.
+ (mac_draw_string_common) [MAC_OSX && USE_ATSUI]: Clip to clipping
+ rectangles stored in gc.
+ (XFreeGC): Dispose of clipping region.
+ (mac_set_clip_rectangles, mac_reset_clip_rectangles): New functions.
+ (x_draw_fringe_bitmap, x_set_glyph_string_clipping)
+ (x_draw_relief_rect, x_draw_box_rect, x_draw_stretch_glyph_string)
+ (x_draw_glyph_string, x_clip_to_row, x_draw_hollow_cursor)
+ (x_draw_bar_cursor): Use them.
+ (x_set_glyph_string_clipping): Use get_glyph_string_clip_rects to
+ get multiple clipping rectangles.
+
+ * macterm.h (mac_term_init): Add types to extern.
+ (struct mac_output): Remove members mWP and pending_menu_activation.
+ Put members scroll_bar_foreground_pixel and
+ scroll_bar_background_pixel in #if 0.
+ (FRAME_MAC_WINDOW, FRAME_X_WINDOW): Use window_desc.
+
+ * xfaces.c (x_create_gc, x_free_gc) [MAC_OS]: Add BLOCK_INPUT.
+ Add debugging code.
+
+2005-10-08 Kim F. Storm <[email protected]>
+
+ * window.c (window_tree, Fwindow_tree): Rename fns added 2005-10-04.
+
+2005-10-07 Kim F. Storm <[email protected]>
+
+ * dispnew.c (redraw_overlapped_rows, redraw_overlapping_rows)
+ [!HAVE_WINDOW_SYSTEM]: Don't declare them...
+ (update_window) [!HAVE_WINDOW_SYSTEM]: ...and don't call them.
+
+2005-10-07 YAMAMOTO Mitsuharu <[email protected]>
+
+ * dispextern.h (struct glyph_string): Rename member for_overlaps_p
+ to for_overlaps. Now occupy 3 bits.
+ (OVERLAPS_PRED, OVERLAPS_SUCC, OVERLAPS_BOTH)
+ (OVERLAPS_ERASED_CURSOR): New defines.
+ (struct redisplay_interface): Add new OVERLAPS arg to member
+ fix_overlapping_area.
+ (x_fix_overlapping_area): Add new OVERLAPS arg.
+ (get_glyph_string_clip_rects): Add extern.
+
+ * dispnew.c (redraw_overlapping_rows):
+ Call rif->fix_overlapping_area with new OVERLAPS arg as redrawn part.
+
+ * xdisp.c: Rename member for_overlaps_p in struct glyph_string to
+ for_overlaps.
+ (get_glyph_string_clip_rects): New function created from
+ get_glyph_string_clip_rect. Set clipping rectangles according to the
+ value of for_overlaps. Enable to store multiple clipping rectangles.
+ (get_glyph_string_clip_rect): Use get_glyph_string_clip_rects.
+ (fill_composite_glyph_string, fill_glyph_string, draw_glyphs):
+ Rename argument OVERLAPS_P to OVERLAPS. All uses in macros changed.
+ (x_fix_overlapping_area): Add OVERLAPS arg. Pass it to draw_glyphs.
+ (draw_phys_cursor_glyph): Set width of erased cursor to use it for
+ calculating clipping rectangles later. Call x_fix_overlapping_area
+ with new OVERLAPS arg to draw only erased cursor area.
+ (expose_overlaps): Call x_fix_overlapping_area with new OVERLAPS arg
+ to draw overlaps in both preceding and succeeding rows.
+
+ * xterm.c, w32term.c, macterm.c: Rename member for_overlaps_p in
+ struct glyph_string to for_overlaps.
+
+2005-10-04 Richard M. Stallman <[email protected]>
+
+ * alloc.c (refill_memory_reserve): Conditionalize the body,
+ not the function's existence.
+
+2005-10-04 Kim F. Storm <[email protected]>
+
+ * window.c (window_split_tree): New function.
+ (Fwindow_split_tree): New defun.
+ (syms_of_window): Defsubr it.
+
+2005-10-04 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_invert_rectangle): New function.
+ (XTflash): Use it.
+
+2005-10-04 Stefan Monnier <[email protected]>
+
+ * regex.h (re_char): Don't expose it in the interface.
+ (re_set_whitespace_regexp): Adjust the arg's type to not use it.
+
+ * regex.c (re_char): Move it back here.
+ (re_set_whitespace_regexp): Change the arg's type to not use it.
+
+ * keyboard.c (make_lispy_event): If point has moved between down and up
+ event, make it a drag, not a click, to mirror what
+ mouse-drag-region expects.
+
+2005-10-02 Dan Nicolaescu <[email protected]>
+
+ * lisp.h (fatal): Undo previous change.
+ * term.c (fatal): Undo previous change.
+
+2005-10-01 Richard M. Stallman <[email protected]>
+
+ * xfaces.c (face_color_gray_p): Colors close to black count as gray.
+
+2005-10-01 Kim F. Storm <[email protected]>
+
+ * xdisp.c (try_window): Skip scroll-margin check if ZV is visible.
+
+2005-10-01 YAMAMOTO Mitsuharu <[email protected]>
+
+ * keyboard.c (init_keyboard) [MAC_OSX]: Don't install SIGINT handler.
+
+ * macfns.c (start_hourglass): Apply 2005-05-07 change for xfns.c.
+ (x_create_tip_frame) [GLYPH_DEBUG]: Uncomment debugging code.
+ (Fx_create_frame, x_create_tip_frame) [USE_ATSUI]:
+ Try ATSUI-compatible 12pt Monaco font first.
+
+ * macgui.h (struct _XCharStruct): New member valid_p.
+ (STORE_XCHARSTRUCT): Set valid_p.
+ (struct MacFontStruct) [USE_ATSUI]: New member mac_style.
+
+ * macterm.c (mac_draw_string_common, x_per_char_metric)
+ (mac_compute_glyph_string_overhangs, init_font_name_table)
+ (XLoadQueryFont, mac_unload_font) [USE_ATSUI]: Add ATSUI support.
+ (atsu_get_text_layout_with_text_ptr) [USE_ATSUI]: New function.
+ (x_draw_glyph_string_background)
+ (x_draw_glyph_string_foreground) [MAC_OS8 && USE_ATSUI]: Don't use
+ XDrawImageString. Always draw background and foreground separately.
+ (x_draw_glyph_string_foreground) [USE_ATSUI]: Don't use 8-bit
+ functions for one-byte chars when using ATSUI-compatible fonts.
+ (atsu_font_id_hash) [USE_ATSUI]: New variable.
+ (syms_of_macterm) [USE_ATSUI]: Initialize and staticpro it.
+ (XLoadQueryFont): Set min_byte1, max_byte1, min_char_or_byte2, and
+ max_char_or_byte2 more in detail.
+ (quit_char_comp, mac_check_for_quit_char) [MAC_OSX]: Remove functions.
+
+2005-09-30 Dan Nicolaescu <[email protected]>
+
+ * image.c (slurp_file, xbm_read_bitmap_data): Cast to the correct type.
+ * xterm.c (handle_one_xevent, handle_one_xevent): Likewise.
+
+ * unexelf.c (fatal): Fix prototype.
+
+ * term.c (fatal): Implement using varargs.
+
+ * regex.c (re_char): Move typedef ...
+ * regex.h (re_char): ... here.
+ (re_iswctype, re_wctype, re_set_whitespace_regexp): New prototypes.
+
+ * emacs.c (malloc_set_state): Fix return type.
+ (endif): Fix type.
+
+ * lisp.h (fatal): Add argument types.
+
+ * dispextern.h (fatal): Delete prototype.
+
+ * systime.h (make_time): Prototype moved from ...
+ * editfns.c (make_time): ... here.
+
+ * editfns.c: Move systime.h include after lisp.h.
+ * dired.c:
+ * xsmfns.c:
+ * process.c: Likewise.
+
+ * alloc.c (old_malloc_hook, old_realloc_hook, old_realloc_hook):
+ Add parameter types.
+ (__malloc_hook, __realloc_hook, __free_hook): Fix prototypes.
+ (emacs_blocked_free): Change definition to match __free_hook.
+ (emacs_blocked_malloc): Change definition to match __malloc_hook.
+ (emacs_blocked_realloc): Change definition to match __realloc_hook.
+
+2005-09-30 Romain Francoise <[email protected]>
+
+ * minibuf.c (Fread_buffer): Follow convention for reading from the
+ minibuffer with a default value. Doc fix.
+
+2005-09-29 Juri Linkov <[email protected]>
+
+ * editfns.c (Fmessage, Fmessage_box, Fmessage_or_box):
+ Rename argument name `string' to `format-string'.
+ (Fformat): Doc fix.
+
+2005-09-28 Kim F. Storm <[email protected]>
+
+ * image.c (gif_load): Fix size of allocated image buffer
+ for images where a sub-image may be larger than the image's
+ total height/width specifications.
+
+2005-09-28 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macgui.h (struct _XCharStruct): Each member now takes short value.
+
+2005-09-27 Dan Nicolaescu <[email protected]>
+
+ * xfaces.c (lookup_derived_face): Add parameter type.
+
+ * xdisp.c (cursor_row_fully_visible_p): Add parameter type.
+
+ * marker.c (verify_bytepos): Add parameter type.
+
+ * process.c (get_operating_system_release): Move prototype ...
+
+ * systime.h (get_operating_system_release): ... here.
+
+ * xterm.c (handle_one_xevent): Refer to union field to match the
+ type required by the function definition.
+ (set_vertical_scroll_bar): Move prototype ...
+
+ * xterm.h: ... here.
+
+ * fns.c (internal_equal, seed_random): Fix prototypes.
+ (internal_equal): Add missing parameter.
+
+2005-09-25 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (update_menu_bindings): Variable deleted.
+ (syms_of_keyboard): Don't defvar it.
+ (parse_menu_item): Don't test it.
+
+2005-09-23 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fformat): Explicitly test for end of format string
+ and don't use `index'.
+
+2005-09-23 Dan Nicolaescu <[email protected]>
+
+ * s/aix4-2.h (BROKEN_GET_CURRENT_DIR_NAME):
+ Define BROKEN_GET_CURRENT_DIR_NAME.
+
+ * sysdep.c (get_current_dir_name): Also define if
+ BROKEN_GET_CURRENT_DIR_NAME.
+
+ * m/ibmrs6000.h: Test for USG5, not USG5_4.
+
+2005-09-22 Kim F. Storm <[email protected]>
+
+ * xdisp.c (message_dolog): Add warning about GC and Lisp strings.
+ (message2): Fix commentary. Ok to use alloca'ed memory.
+ Still not ok to use Lisp string data (because of GC).
+ (set_message): Add comment why GC cannot happen.
+
+2005-09-22 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (xlfdpat_block_match_1): Fix assertion.
+ (init_font_name_table) [TARGET_API_MAC_CARBON]: Don't add style
+ variants for a scalable font multiple times.
+
+2005-09-21 YAMAMOTO Mitsuharu <[email protected]>
+
+ * process.c (create_process) [RTU || UNIPLUS || DONT_REOPEN_PTY]:
+ Setup slave tty options before forking.
+
+2005-09-20 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_set_geometry): Do a gtk_window_move if program
+ positions have been set for the frame (as is done for frames in
+ special-display-buffer-names).
+
+2005-09-19 Kim F. Storm <[email protected]>
+
+ * editfns.c (Fformat): Don't scan past end of format string that
+ ends in %. Reported by Johan Bockg,Ae(Brd.
+
+2005-09-18 Andreas Schwab <[email protected]>
+
+ * window.h (struct window): Remove height_fixed_p, no longer set.
+
+ * window.c (make_window): Don't initialize height_fixed_p.
+ (window_fixed_size_p): Don't use it.
+
+2005-09-18 John Paul Wallington <[email protected]>
+
+ * data.c (Fdefalias): Signal an error if SYMBOL is not a symbol.
+
+2005-09-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * Makefile.in (SOME_MACHINE_OBJECTS): Undo previous change.
+
+ * macfns.c (image_cache_refcount, dpyinfo_refcount) [GLYPH_DEBUG]:
+ New variables.
+ [TARGET_API_MAC_CARBON] (Fx_file_dialog): Don't allow multiple
+ file selection.
+
+ * sysdep.c [MAC_OS8]: Don't include stdlib.h. Include sys/param.h.
+
+2005-09-17 Eli Zaretskii <[email protected]>
+
+ * Makefile.in (XMENU_OBJ) [!HAVE_CARBON]: Reinstate variable.
+ (obj): Use XMENU_OBJ, not a literal xmenu.o.
+
+2005-09-16 Romain Francoise <[email protected]>
+
+ * fileio.c (syms_of_fileio) <write-region-inhibit-fsync>: Doc fix.
+
+2005-09-15 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (overlay_arrow_at_row): Add HAVE_WINDOW_SYSTEM conditional.
+ (display_mode_element): Instead of `lisp_string' and `this',
+ record `offset' and increment that.
+ `last_offset' replaces `last'.
+
+ * Makefile.in (XMENU_OBJ): Variable deleted.
+ (obj): Use xmenu.o unconditionally.
+ (SOME_MACHINE_OBJECTS): Delete xmenu.o.
+
+ * emacs.c (main): Don't conditionalize syms_of_xmenu on HAVE_XMENU.
+
+2005-09-15 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_vertically): Don't try to fetch byte BEGV-1.
+ (reseat_at_next_visible_line_start): Likewise (in xassert).
+
+2005-09-14 Romain Francoise <[email protected]>
+
+ * fileio.c (write_region_inhibit_fsync): New variable.
+ (Fwrite_region): Use it to skip call to fsync.
+ (syms_of_fileio): Initialize it.
+
+2005-09-14 Kenichi Handa <[email protected]>
+
+ * coding.c (code_convert_region_unwind): Argument format changed.
+ (run_pre_post_conversion_on_str): If pre-write-conversion function
+ changed the current buffer, delete the new buffer.
+ (run_pre_write_conversin_on_c_str): Likewise.
+
+ * fileio.c (Fexpand_file_name): Check multibyteness of
+ default_directory.
+
+2005-09-13 Kenichi Handa <[email protected]>
+
+ * composite.c (compose_chars_in_text): Delete it.
+
+ * composite.h (compose_chars_in_text): Delete extern.
+
+2005-09-13 Kim F. Storm <[email protected]>
+
+ * print.c (print_error_message): Fix last change.
+
+2005-09-12 Kim F. Storm <[email protected]>
+
+ * composite.c (compose_chars_in_text): Fix setup of `pend'.
+ Unconditionally reload `ptr' and `pend' after eval.
+
+ * xdisp.c (message3): Pass copy of lisp string to message_dolog.
+
+ * print.c (print_error_message): Pass copy of caller name to
+ message_dolog.
+
+ * fileio.c (auto_save_error): Pass copy of lisp string to message2.
+
+2005-09-12 Kenichi Handa <[email protected]>
+
+ * xdisp.c (display_mode_element): Be sure to make variables THIS
+ and LISP_STRING point into a string data of ELT.
+
+2005-09-12 Kim F. Storm <[email protected]>
+
+ * editfns.c (Ftranslate_region_internal): Reload `tt' after
+ signal_after_change that may have GC'ed.
+ (Fmessage, Fmessage_box, Fmessage_or_box): Doc fix.
+
+ * keymap.c (Fdescribe_buffer_bindings): Reload `translate'
+ after insert while runs signal_after_change.
+
+ * minibuf.c (Fminibuffer_complete_word): Move `completion_string'
+ declaration to where it is used.
+
+ * w32.c (check_windows_init_file): Fix allocation of error buffer.
+
+ * xfns.c (x_encode_text): Declare static. Add FREEP arg.
+ (x_set_name_internal): Call x_encode_text with new FREEP arg to
+ know if xfree is needed instead of guessing.
+
+ * xterm.h (x_encode_text): Remove prototype.
+
+2005-09-11 Chris Prince <[email protected]> (tiny change)
+
+ * w32term.c (x_bitmap_icon): Load small icons too.
+
+2005-09-10 Romain Francoise <[email protected]>
+
+ * buffer.c (init_buffer): Grow buffer to add directory separator
+ and terminal zero. Fix typos.
+
+2005-09-10 Eli Zaretskii <[email protected]>
+
+ * buffer.c (init_buffer): Fix error message for failed call to
+ get_current_dir_name.
+ (get_current_dir_name): Remove prototype.
+
+ * xsmfns.c (get_current_dir_name): Remove prototype.
+
+ * lisp.h (get_current_dir_name) [!HAVE_GET_CURRENT_DIR_NAME]:
+ Add prototype.
+
+ * sysdep.c [WINDOWSNT]: Add prototype for getwd.
+ Don't #undef NULL after including blockinput.h.
+
+ * config.in: Regenerated.
+
+2005-09-10 Giuseppe Scrivano <[email protected]>
+
+ Remove the MAXPATHLEN limitations:
+
+ * sysdep.c (get_current_dir_name) [!HAVE_GET_CURRENT_DIR_NAME]:
+ New function.
+
+ * buffer.c (init_buffer): Use it.
+
+ * xsmfns.c (smc_save_yourself_CB): Ditto.
+
+2005-09-09 Kim F. Storm <[email protected]>
+
+ * doc.c (Fsubstitute_command_keys): Lookup key binding for
+ commands that are remapped from some other command.
+
+ * xdisp.c (try_window_reusing_current_matrix): Clear mode_line_p
+ flag in disabled rows below the window.
+
+ * frame.h (struct frame): New member updated_p.
+
+ * xdisp.c (redisplay_internal): Mark updated frames in new updated_p
+ member. Remove local `updated' array and associated variables.
+
+2005-09-07 Kim F. Storm <[email protected]>
+
+ * xdisp.c (handle_display_prop): Respect overlay window property.
+
+ * xdisp.c (try_window): Remove superfluous cursor_height calculation.
+ Fixes crash reported by YAMAMOTO Mitsuharu.
+
+2005-09-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (struct xlfdpat_block, struct xlfdpat): New structs.
+ (xlfdpat_destroy, xlfdpat_create, xlfdpat_exact_p)
+ (xlfdpat_block_match_1, xlfdpat_match): New functions.
+ (xlfdpat_block_match): New macro.
+ (mac_to_x_fontname): Don't use tolower for non-ASCII characters.
+ (x_font_name_to_mac_font_name): Set coding.dst_multibyte to 0.
+ (add_font_name_table_entry): Increase font_name_table_size more
+ rapidly.
+ (mac_c_string_match): Remove function.
+ (mac_do_list_fonts): Use XLFD pattern match instead of regular
+ expression match.
+
+ * xfaces.c (xstrlwr): Don't use tolower for non-ASCII characters.
+
+2005-09-03 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (redisplay_internal): Make UPDATED as long as needed.
+ (move_it_in_display_line_to): Stop after last char on line even
+ on a windowing terminal, if that's the specified stop position.
+
+ * fns.c (Fsort): Doc fix.
+
+ * editfns.c (Fpropertize): Don't insist that properties be symbols.
+
+2005-09-02 Stefan Monnier <[email protected]>
+
+ * dired.c (directory_files_internal_unwind, directory_files_internal)
+ (file_name_completion): Use a Save_Value object rather than a cons of
+ two 16bit ints to store the DIR*.
+ (directory_files_internal, file_name_completion): Handle both EINTR and
+ EAGAIN consistently after `readdir'.
+
+2005-09-01 Stefan Monnier <[email protected]>
+
+ * intervals.c (update_interval): Add position info in error.
+
+ * dispnew.c (window_to_frame_hpos, update_window):
+ Avoid gcc warning about unused variable `f'.
+
+2005-08-31 Jason Rumney <[email protected]>
+
+ * w32menu.c (add_menu_item): If unicode_append_menu returns an
+ error, revert to using AppendMenu.
+
+2005-08-31 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c (PIX_MASK_DRAW, PIX_MASK_RETAIN): Remove argument.
+ All uses changed.
+ [MAC_OS] (XPutPixel, XGetPixel): Add efficient versions for common
+ cases.
+ (x_create_x_image_and_pixmap) [MAC_OS]: Don't call x_destroy_x_image.
+ [MAC_OS] (find_image_fsspec) [!MAC_OSX]: Don't use FSRef.
+ Use posix_pathname_to_fsspec.
+ [MAC_OS] (xpm_load_image): Fill in background_transparent field
+ while we have mask.
+
+ * macgui.h [!TARGET_API_MAC_CARBON] (GetPixDepth): New define.
+
+ * macterm.h (PIX_MASK_DRAW, PIX_MASK_RETAIN): Move defines to image.c.
+
+2005-08-29 Stefan Monnier <[email protected]>
+
+ * syntax.c (update_syntax_table): Properly reproduce the special +1
+ setting of e_property at the end of the buffer when bumping into the
+ INTERVALS_AT_ONCE limit.
+
+2005-08-27 Eli Zaretskii <[email protected]>
+
+ * emacs.c (USAGE1): Fix the description of the -Q option.
+
+2005-08-26 Stefan Monnier <[email protected]>
+
+ * xdisp.c (pos_visible_p): Yet another int/Lisp_Object mixup (YAILOM).
+
+2005-08-26 Kim F. Storm <[email protected]>
+
+ * xdisp.c (resize_mini_window): Fix 2005-08-20 change.
+ Don't move PT to new window start.
+
+2005-08-25 YAMAMOTO Mitsuharu <[email protected]>
+
+ * keyboard.c (kbd_buffer_get_event) [MAC_OS]: Make events for
+ ICONIFY/DEICONIFY_EVENT.
+
+ * macterm.c (mac_copy_area, mac_copy_area_with_mask):
+ Restore background color.
+ (mac_handle_visibility_change): New function.
+ (x_make_frame_invisible, x_iconify_frame)
+ (XTread_socket) [!USE_CARBON_EVENTS]: Use it.
+ [USE_CARBON_EVENTS] (mac_handle_window_event)
+ (install_window_handler): Handle visibility change events.
+ (x_make_frame_visible): Don't reposition window if it is iconified
+ or asked for visible before. Select and uncollapse window when it
+ is made visible.
+ (x_make_frame_invisible): Don't reset x_highlight_frame.
+ (x_iconify_frame): Likewise. Make invisible frame visible before
+ it is iconified.
+ (read_socket_inev): Move variable outside #if USE_CARBON_EVENTS.
+ (do_window_update): Don't change visibility of invisible frame.
+
+2005-08-22 Juri Linkov <[email protected]>
+
+ * term.c (turn_on_face): Check for TS_set_foreground and
+ TS_set_background depending on standout_mode. Simplify.
+
+2005-08-21 Kim F. Storm <[email protected]>
+
+ * fringe.c (update_window_fringes): Only put TOP and BOTTOM
+ bitmaps on fully visible rows.
+
+ * fringe.c (update_window_fringes): Replace FORCE_P arg with
+ KEEP_CURRENT_P arg; if non-zero, don't update current row fringes,
+ and return 0.
+
+ * xdisp.c (redisplay_window): Call update_window_fringes with
+ KEEP_CURRENT_P non-0 if we are going to refresh fringes later.
+
+2005-08-20 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (display_echo_area_1): Get display start pos from w->start.
+ (resize_mini_window): Set w->start, and PT, so as to display the tail
+ end of the buffer, if it doesn't all fit.
+
+2005-08-18 Kim F. Storm <[email protected]>
+
+ * xdisp.c (calc_pixel_width_or_height): Use actual display
+ resolution when available instead of Vdisplay_pixels_per_inch.
+
+2005-08-17 Kim F. Storm <[email protected]>
+
+ * xdisp.c (pos_visible_p): Adjust X value if window is hscrolled.
+
+ * dispnew.c (buffer_posn_from_coords): Check that target row is
+ within matrix.
+
+2005-08-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_wm_set_icon_pixmap): Move GTK specific code to
+ xg_set_frame_icon and call it.
+
+ * gtkutil.c (xg_set_frame_icon): New function.
+
+ * gtkutil.h (xg_set_frame_icon): Declare it.
+
+2005-08-16 Kim F. Storm <[email protected]>
+
+ * dispnew.c (increment_row_positions): Skip non-enabled rows.
+
+ * window.c (SAVED_WINDOW_VECTOR_SIZE): Remove dangerous define.
+ (Fcurrent_window_configuration): Use VECSIZE macro instead.
+
+2005-08-15 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (message3_nolog): Clear echo_message_buffer.
+
+2005-08-15 Kim F. Storm <[email protected]>
+
+ * lisp.h (QUIT) [!SYNC_INPUT]: Throw t to Vthrow_on_input.
+
+ * process.c (deactivate_process, status_notify, read_process_output)
+ (update_status, status_convert, decode_status, allocate_pty)
+ (make_process, remove_process, list_processes_1)
+ (create_process_1, unwind_request_sigio, read_process_output)
+ (send_process, keyboard_bit_set): Declare static.
+ (Fdelete_process): Simplify. Pass process to status_notify, so we
+ don't try to read output from it.
+ (status_notify): New arg deleting_process--don't try to read
+ output from that process.
+
+ * lisp.h (deactivate_process, status_notify, read_process_output):
+ Remove prototypes.
+
+2005-08-14 Richard M. Stallman <[email protected]>
+
+ * image.c (syms_of_image): Init Qxbm, Qpbm before calling
+ define_image_type.
+
+2005-08-13 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_pixbuf_from_pix_and_mask): New function.
+ (xg_get_image_for_pixmap): Move some code to
+ xg_get_pixbuf_from_pix_and_mask, and call it.
+
+ * gtkutil.h (xg_get_pixbuf_from_pix_and_mask): Declare.
+
+ * xterm.c (x_wm_set_icon_pixmap): Call xg_get_pixbuf_from_pix_and_mask
+ to get an GTK icon and set it with GTK functions to avoid having GTK
+ override an icon set with just X functions.
+
+2005-08-11 Richard M. Stallman <[email protected]>
+
+ * image.c (syms_of_image): Init image_types here, and call
+ define_image_type.
+ (init_image): Not here.
+
+2005-08-09 Richard M. Stallman <[email protected]>
+
+ * bytecode.c (BYTE_CODE_QUIT): Throw t to Vthrow_on_input.
+
+ * lisp.h (QUIT): Throw t to Vthrow_on_input.
+
+2005-08-09 Thien-Thi Nguyen <[email protected]>
+
+ * floatfns.c (Fexpt): Use floats for negative exponent.
+
+2005-08-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_modify_menubar_widgets): Remove semicolon that
+ should not be there, causing menu display errors with GTK 2.6.9.
+
+2005-08-07 Richard M. Stallman <[email protected]>
+
+ * floatfns.c (Fexpt): Undo previous change.
+
+ * dispnew.c (Fframe_or_buffer_changed_p): Take an arg
+ so it can be used with various state vectors.
+
+ * emacs.c (endif): Convert -script into -scriptload.
+ (standard_args): Add -scriptload. Allow -basic-display with one dash.
+
+ * fns.c (syms_of_fns): Add `emacs' to features.
+
+ * term.c (set_terminal_modes): If no TS_termcap_modes string,
+ output newlines to scroll the old screen contents off the screen.
+
+2005-08-06 Thien-Thi Nguyen <[email protected]>
+
+ * floatfns.c (Fexpt): Use floats for negative exponent.
+ Reported by D Goel.
+
+2005-08-02 Richard M. Stallman <[email protected]>
+
+ * frame.c (Fframe_char_width): Doc fix.
+
+2005-07-30 Juanma Barranquero <[email protected]>
+
+ * xdisp.c (syms_of_xdisp) <redisplay-end-trigger-functions>:
+ Defvar it.
+
+2005-07-28 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (my_set_window_pos, my_show_window): Don't declare.
+ (my_create_window, my_create_tip_window): Make static.
+
+ * w32term.c (my_show_window, my_set_window_pos, my_set_focus)
+ (my_set_foreground_window, my_destroy_window): Make static.
+
+2005-07-26 Paul Eggert <[email protected]>
+
+ Merge gnulib getopt implementation into Emacs.
+
+ * s/cygwin.h (C_SWITCH_SYSTEM): Remove, since gettext.h is
+ now part of lib-src.
+
+2005-07-26 Stefan Monnier <[email protected]>
+
+ * eval.c (Fdefvar): Allow (defvar enable-multibyte-characters).
+
+2005-07-25 Jason Rumney <[email protected]>
+
+ * w32menu.c (w32_menu_display_help): Suppress tooltip when
+ navigating menus with the keyboard.
+
+2005-07-23 Richard M. Stallman <[email protected]>
+
+ * insdel.c (syms_of_insdel): staticpro combine_after_change_buffer.
+
+ * bytecode.c (MAYBE_GC): Test gc_cons_threshold and
+ gc_relative_threshold, one by one.
+
+ * keyboard.c (read_char): Test gc_cons_threshold.
+ (syms_of_keyboard): staticpro Qecho_area_clear_hook.
+
+ * eval.c (Feval, Ffuncall): Test gc_cons_threshold and
+ gc_relative_threshold, one by one.
+
+ * alloc.c (gc_cons_threshold): Not static.
+ (gc_cons_combined_threshold): Var deleted.
+ (gc_relative_threshold): New variable.
+ (Fgarbage_collect, init_alloc_once): Compute gc_relative_threshold
+ instead of gc_cons_combined_threshold.
+
+ * lisp.h (gc_cons_threshold, gc_relative_threshold): Declare.
+ (gc_cons_combined_threshold): Declaration deleted.
+
+2005-07-23 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c: Don't include stdlib.h or string.h.
+ (Fdo_applescript, Fmac_file_name_to_posix)
+ (Fmac_file_name_to_posix): Doc fixes.
+ [TARGET_API_MAC_CARBON] (Fmac_get_preference)
+ (Fmac_code_convert_string): Likewise.
+ [MAC_OSX] (init_mac_osx_environment): Fall back on terminal mode
+ if the executable is not contained in a bundle.
+
+ * macfns.c: Don't include stdlib.h or string.h. Include atimer.h.
+ (gray_width, gray_height): Remove defines.
+ (gray_bits, gray_bitmap_width, gray_bitmap_height)
+ (gray_bitmap_bits): Remove variables.
+ (lispy_function_keys): Remove extern.
+ (free_frame_menubar): Add extern.
+ (x_window_to_frame): Remove function.
+ (unwind_create_tip_frame): Add declaration.
+ (x_set_name_internal): New function.
+ (x_set_name, x_set_title): Use it.
+ (Fx_create_frame, Fx_display_grayscale_p, Fx_display_pixel_width)
+ (Fx_display_pixel_height, Fx_display_planes)
+ (Fx_display_color_cells, Fx_server_max_request_size)
+ (Fx_server_vendor, Fx_server_version, Fx_display_screens)
+ (Fx_display_mm_height, Fx_display_mm_width)
+ (Fx_display_backing_store, Fx_display_visual_class)
+ (Fx_display_save_under, Fx_synchronize, Fx_show_tip): Doc fixes.
+
+ * macmenu.c (Fx_popup_menu, Fx_popup_dialog): Doc fixes.
+
+ * macselect.c (Fx_own_selection_internal): Follow error conventions.
+ (Fx_get_selection_internal, Fx_selection_owner_p)
+ (Fx_selection_exists_p): Doc fixes.
+ (syms_of_macselect) <selection-converter-alist>: Likewise.
+
+2005-07-21 Juanma Barranquero <[email protected]>
+
+ * buffer.c (syms_of_buffer) <cursor-type>: Doc fix.
+
+ * ccl.c (Fregister_ccl_program): Fix typos in docstring.
+ (Fccl_execute_on_string): Likewise; add usage info.
+
+ * composite.c (Fcompose_region_internal)
+ (Fcompose_string_internal):
+ Improve argument/docstring consistency.
+
+ * minibuf.c (Fminibuffer_prompt_end, Feval_minibuffer):
+ Fix typos in docstrings.
+
+ * textprop.c (Fnext_char_property_change)
+ (Fprevious_char_property_change): Doc fixes.
+
+ * window.c (Fset_window_margins, Fset_window_fringes):
+ Improve argument/docstring consistency.
+
+ * xfaces.c (Finternal_lisp_face_p): Doc fix.
+
+2005-07-21 Andreas Schwab <[email protected]>
+
+ * eval.c (restore_stack_limits): Return a value.
+
+2005-07-20 Juanma Barranquero <[email protected]>
+
+ * eval.c (Fdefvar): Doc fix.
+
+2005-07-20 Kim F. Storm <[email protected]>
+
+ * fileio.c (Fdo_auto_save, do_auto_save_unwind):
+ Use make_save_value to unwind protect stream.
+
+ * lread.c (Fload, load_unwind):
+ Use make_save_value to unwind protect stream.
+
+2005-07-19 Juanma Barranquero <[email protected]>
+
+ * eval.c (Fprog2, Fcalled_interactively_p),
+ (syms_of_eval) <debug-on-quit>: Doc fixes.
+ (syms_of_eval) <max-specpdl-size>:
+ (Finteractive_p): Fix typos in docstrings.
+
+2005-07-19 Kim F. Storm <[email protected]>
+
+ * w32fns.c (Vx_hand_shape): Variable removed.
+ (syms_of_w32fns): Intern and staticpro Qw32_charset_default.
+
+2005-07-19 Kenichi Handa <[email protected]>
+
+ * fns.c (Fstring_as_multibyte): Escape backslashes in the docstring.
+
+2005-07-18 Stefan Monnier <[email protected]>
+
+ * buffer.h (Fgenerate_new_buffer_name): Declare (for use in coding.c).
+
+2005-07-18 Kim F. Storm <[email protected]>
+
+ * frame.h (struct frame): New member already_hscrolled_p.
+
+ * xdisp.c (redisplay_internal): Only try to hscroll each frame once
+ to avoid redisplay looping hscrolling back and forth ad infinitum.
+
+2005-07-18 Juri Linkov <[email protected]>
+
+ * buffer.c (scroll-up-aggressively, scroll-down-aggressively):
+ * keymap.c (Fminor_mode_key_binding):
+ * macterm.c (mac-emulate-three-button-mouse):
+ Delete duplicate duplicate words.
+
+2005-07-18 Ken Raeburn <[email protected]>
+
+ * minibuf.c (Ftest_completion): Fix odd syntax in test.
+
+2005-07-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (x_set_cursor_color): Use XSetBackground and XSetForeground.
+
+ * macgui.h (struct _XGC): New struct.
+ (GC): Use it.
+ (GCForeground, GCBackground, GCFont): Use X11 mask values.
+ (XCreateGC, XParseGeometry): Move externs to macterm.h.
+
+ * macterm.c (x_bitmap_icon, x_make_frame_visible): Remove declarations.
+ (XSetFont): Add declaration.
+ (mac_set_forecolor, mac_set_backcolor, mac_set_colors):
+ Remove functions.
+ (GC_FORE_COLOR, GC_BACK_COLOR, GC_FONT, MAC_WINDOW_NORMAL_GC):
+ New defines.
+ (XDrawLine, mac_draw_line_to_pixmap, XClearWindow)
+ (mac_draw_bitmap, XCreatePixmapFromBitmapData, XFillRectangle)
+ (mac_draw_rectangle, mac_draw_string_common, mac_scroll_area):
+ Use them.
+ (mac_erase_rectangle): New function.
+ (XClearArea, x_draw_fringe_bitmap, x_clear_glyph_string_rect)
+ (x_draw_stretch_glyph_string): Use it.
+ (XChangeGC, XCreateGC, XGetGCValues, XSetForeground)
+ (XSetBackground, XSetFont): Adjust for new GC implementation.
+ (x_draw_fringe_bitmap, x_draw_box_rect): Use GC to set colors.
+ (XTset_vertical_scroll_bar): Clear area under scroll bar.
+
+ * macterm.h (struct mac_display_info): Change types of
+ scratch_cursor_gc black_relief.gc, and white_relief.gc to GC.
+ (XCreateGC, XParseGeometry): Move externs from macgui.h.
+
+ * xfaces.c [MAC_OS] (XCreateGC): Remove extern.
+
+2005-07-16 Richard M. Stallman <[email protected]>
+
+ * buffer.c (Fmake_overlay): Doc fix.
+
+2005-07-16 Eli Zaretskii <[email protected]>
+
+ * w32proc.c (syms_of_ntproc): staticpro Qhigh, Qlow,
+ Vw32_valid_locale_ids, and Vw32_valid_codepages.
+
+2005-07-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c [TARGET_API_MAC_CARBON] (Fmac_code_convert_string):
+ Use Fstring_as_unibyte instead of string_make_unibyte.
+
+2005-07-15 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (select_frame_for_redisplay): Use find_symbol_value.
+
+2005-07-15 Kim F. Storm <[email protected]>
+
+ * xdisp.c: Fix redisplay loop in last change.
+ (IT_POS_VALID_AFTER_MOVE_P): New macro.
+ (move_it_vertically_backward, move_it_by_lines): Use it.
+
+2005-07-14 Jason Rumney <[email protected]>
+
+ * w32.c (init_environment): Default HOME directory to user's
+ appdata directory if possible.
+
+2005-07-14 Kim F. Storm <[email protected]>
+
+ * .gdbinit (pitx): Fix output format. Print string charpos.
+
+ * lread.c (syms_of_lread): Initialize seen_list.
+
+ * search.c (syms_of_search): Staticpro searchbuf.whitespace_regexp.
+
+ * syntax.c (syms_of_syntax): Staticpro lisp objects in gl_state.
+ Staticpro re_match_object.
+
+2005-07-14 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macselect.c (get_scrap_target_type_list): Avoid NULL pointer
+ dereference.
+
+ * macterm.c (mac_window_to_frame): Remove duplicate define.
+
+2005-07-14 Kenichi Handa <[email protected]>
+
+ * coding.c (code_convert_region_unwind): ARG is changed to a cons.
+ (code_convert_region): Adjust for the above change.
+ (set_conversion_work_buffer): If the work buffer is already in
+ use, generate a new buffer and return it. Otherwise return Qnil.
+ (run_pre_post_conversion_on_str): Adjust for the above change.
+ (run_pre_write_conversin_on_c_str): Likewise.
+
+2005-07-13 Kim F. Storm <[email protected]>
+
+ * xdisp.c (start_display): Don't reseat to next visible line start
+ if current start position is in a string or image.
+ (move_it_vertically_backward): Be sure to move out of strings and
+ images when moving it2 forward.
+ (move_it_by_lines): When moving forward, move to next buffer
+ position if we end up in a string or image. When moving backward,
+ count rows moved over when moving to start of current row in case
+ row starts in middle of a string or image. Also move further
+ backward if we end up in a string or image.
+ (try_cursor_movement): If overlay string spans multiple lines,
+ move backward to set cursor on start of an overlay string.
+ (cursor_row_p): Row is ok if cursor is at newline from string, but
+ string starts on this line (so we always position cursor at start
+ of string).
+
+ * indent.c (Fvertical_motion): If start position is on an image,
+ don't move back if we move too far (that's almost certain to happen).
+
+ * xdisp.c (cursor_row_fully_visible_p): Allow partially visible
+ row in minibuffer windows.
+ (try_window): Don't check margins in minibuffer windows.
+
+2005-07-13 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c: Don't include stdlib.h or composite.h.
+ (x_use_underline_position_properties, last_mouse_press_frame)
+ (x_noop_count, Qvendor_specific_keysyms): Remove unused variables.
+ (syms_of_macterm, mac_initialize): Don't initialize them.
+ (waiting_for_input, initial_argv, initial_argc)
+ (Vcommand_line_args, Vx_no_window_manager, errno, window_scroll)
+ (set_frame_menubar, path_from_vol_dir_name): Remove externs.
+ (extra_keyboard_modifiers): Fix type in extern.
+ (x_window_to_frame, x_window_to_scroll_bar): Remove declarations.
+ (x_scroll_bar_report_motion): Add argument types to declaration.
+ (mac_compute_glyph_string_overhangs): Add declaration.
+ (disable_mouse_highlight): Remove unused variable.
+ [USE_TOOLKIT_SCROLL_BARS] (construct_scroll_bar_click)
+ (x_scroll_bar_handle_press, x_scroll_bar_handle_release)
+ (x_scroll_bar_handle_drag): Remove argument `timestamp'.
+ All callers changed.
+ [USE_TOOLKIT_SCROLL_BARS] (construct_scroll_bar_click): Don't set
+ timestamp.
+ [USE_CARBON_EVENTS] (mac_handle_mouse_event): Likewise.
+ (x_scroll_bar_create, XTset_vertical_scroll_bar): Show scroll bar
+ only when its width is less than the height.
+ (XTredeem_scroll_bar): Sync with xterm.c.
+ (font_name_table, font_name_table_size, font_name_count):
+ Make static.
+ (drag_and_drop_file_list): Remove variable. Previous use is now
+ local to function.
+ (do_ae_open_documents): Move DRAG_N_DROP event construction part
+ from XTread_socket.
+ (XTread_socket): Consolidate setting of event timestamp.
+ Move DRAG_N_DROP event construction part to do_ae_open_documents.
+ Support extra_keyboard_modifiers.
+
+ * xfaces.c (try_font_list) [MAC_OS]: Try font family name
+ beginning with that for ASCII.
+
+2005-07-13 Stefan Monnier <[email protected]>
+
+ * alloc.c (gc_cons_combined_threshold, Vgc_cons_percentage): New vars.
+ (Fgarbage_collect, init_alloc_once): Set gc_cons_combined_threshold.
+ (syms_of_alloc): Declare gc-cons-percentage.
+
+ * eval.c (Feval, Ffuncall):
+ * keyboard.c (read_char):
+ * bytecode.c (MAYBE_GC): Use gc_cons_combined_threshold.
+
+ * lisp.h (gc_cons_combined_threshold): Declare.
+
+2005-07-12 Kim F. Storm <[email protected]>
+
+ * coding.c (Qprocess_argument):
+ * coding.h (Qprocess_argument): Remove unused var.
+
+ * xselect.c (intern): Remove dup. intern and staticpro for QTIMESTAMP.
+
+2005-07-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c [!TARGET_API_MAC_CARBON]: Include charset.h, coding.h, and
+ Endian.h.
+ [!MAC_OSX] (fchmod, fchown): New functions.
+ (mac_get_code_from_arg): Don't accept Lisp integer as argument.
+ Use SBYTES and EndianU32_BtoN.
+ (mac_get_object_from_code): Return 4 byte string even if argument
+ is 0. Use make_unibyte_string and EndianU32_NtoB.
+ (Fmac_get_file_creator, Fmac_get_file_type, Fmac_set_file_creator)
+ (Fmac_set_file_type): Fix documents and argument declarations.
+ Don't specify kFSCatInfoNodeFlags. Support Mac OS Classic.
+
+2005-07-11 Stefan Monnier <[email protected]>
+
+ * window.c (Frecenter): Yet another int/Lisp_Object mixup (YAILOM).
+
+2005-07-11 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfaces.c (x_update_menu_appearance): Use fontSet resource for
+ Lucid if X_I18N, font otherwise.
+
+2005-07-10 Steven Tamm <[email protected]>
+
+ * mac.c (Fmac_get_file_type, Fmac_get_file_creator): Add.
+ (Fmac_set_file_type, Fmac_set_file_creator): Add.
+ (mac_get_object_from_code, mac_get_code_from_arg): Add.
+
+2005-07-10 Richard M. Stallman <[email protected]>
+
+ * lread.c (Qeval_buffer_list, Veval_buffer_list): New vars.
+ (syms_of_lread): Set up eval-buffer-list.
+ (Feval_buffer, Feval_region): Bind eval-buffer-list.
+
+2005-07-08 Richard M. Stallman <[email protected]>
+
+ * eval.c (Fdefvar): Allow defvaring a constant to itself quoted.
+
+2005-07-08 Kim F. Storm <[email protected]>
+
+ * keyboard.c (menu_bar_items): Don't GCPRO menu_bar_items_vector here.
+ (syms_of_keyboard): Initialize and staticpro menu_bar_items_vector.
+
+2005-07-07 Kim F. Storm <[email protected]>
+
+ * window.c (Frecenter): Fix last change (set iarg before use).
+
+2005-07-06 Richard M. Stallman <[email protected]>
+
+ * window.c (Frecenter): When arg is inside the scroll margin,
+ move it out of the margin.
+
+2005-07-06 Jason Rumney <[email protected]>
+
+ * w32console.c (initialize_w32_display): Detect when the console
+ dimensions are insane, and default to 80x25 instead.
+ (w32_use_full_screen_buffer): Default to nil.
+
+2005-07-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_draw_vertical_window_border): Use foreground of
+ VERTICAL_BORDER_FACE_ID for vertical border line.
+ (mac_encode_char): Call check_ccl_update in advance.
+ (mac_to_x_fontname, x_font_name_to_mac_font_name)
+ (init_font_name_table, mac_do_list_fonts, XLoadQueryFont):
+ Don't assume that font family length is less than 32.
+ (x_compute_min_glyph_bounds): Make static.
+ (x_load_font): Never set fonts_changed_p to zero.
+
+2005-07-04 Lute Kamstra <[email protected]>
+
+ * Update FSF's address in GPL notices.
+
+2005-07-03 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (try_window): Fix previous change in how it handles
+ a partially-visible line or one only partly past the margin.
+
+ * window.c (window_scroll_pixel_based): Take account
+ of this_scroll_margin when finding point when scrolling up.
+
+2005-06-29 Ralf Angeli <[email protected]>
+
+ * window.c (window_scroll_pixel_based, window_scroll_line_based):
+ Handle `scroll-preserve-screen-position' non-nil, non-t specially.
+ (syms_of_window) <scroll-preserve-screen-position>: Doc fix.
+
+2005-07-02 Juri Linkov <[email protected]>
+
+ * w32term.c (w32_draw_vertical_window_border): Use foreground of
+ VERTICAL_BORDER_FACE_ID for vertical border line.
+
+2005-07-02 Eli Zaretskii <[email protected]>
+
+ * fileio.c (Fcopy_file): Rearrange the code that calls fchown and
+ fchmod so that chmod doesn't get called on MSDOS before the file
+ is closed.
+
+2005-07-01 Jason Rumney <[email protected]>
+
+ * w32term.c (cleartype_active): New flag for enabling sub-pixel
+ workaround.
+ (w32_initialize): Initialize it.
+ (w32_native_per_char_metric): Allow a couple of extra pixels when
+ Cleartype is active.
+
+ * w32term.c (w32_initialize): Move check for screen reader here
+ from syms_of_w32term.
+
+2005-06-30 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): bzero compose_status when nbytes
+ is not zero.
+
+2005-07-01 Masatake YAMATO <[email protected]>
+
+ * emacs.c (main): Passing ADD_NO_RANDOMIZE to `personality'.
+
+2005-06-30 Juri Linkov <[email protected]>
+
+ * xdisp.c (x_draw_vertical_border): If left fringe is not present
+ decrease x coord of vertical border by 1 pixel to not occupy text
+ area of the right window.
+
+ * xterm.c (x_draw_vertical_window_border): Use foreground of
+ VERTICAL_BORDER_FACE_ID for vertical border line.
+
+ * term.c (turn_on_face): In standout mode apply specified
+ fg to bg, and specified bg to fg (this makes the logic of
+ inversion on terminal consistent with X).
+
+2005-06-29 Juanma Barranquero <[email protected]>
+
+ * eval.c (user_variable_p_eh): New function.
+ (Fuser_variable_p): Use it. Clarify docstring.
+ Return t for aliases of user options, nil for alias loops.
+
+2005-06-27 Richard M. Stallman <[email protected]>
+
+ * eval.c (Fdefvar): Improve error message.
+
+2005-06-27 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c [USE_CARBON_EVENTS] (mac_convert_event_ref): Fix last
+ change.
+
+2005-06-27 Juanma Barranquero <[email protected]>
+
+ * eval.c (Fdefvar): Don't try to set constant symbols.
+
+2005-06-25 Richard M. Stallman <[email protected]>
+
+ * macfns.c (Fx_show_tip): Pass new arg to try_window.
+
+ * w32fns.c (Fx_show_tip): Pass new arg to try_window.
+
+ * xfns.c (Fx_show_tip): Pass new arg to try_window.
+
+ * xdisp.c (try_window): New arg CHECK_MARGINS. Calls changed.
+ (redisplay_window): Handle try_window reporting point in scroll margin.
+
+ * dispextern.h (try_window): Declare new arg.
+
+ * fileio.c (Fcopy_file): New arg PRESERVE_UID_GID.
+ Use fchmod to copy the file modes.
+ (Frename_file): Don't copy UID and GID here;
+ instead, specify t for PRESERVE_UID_GID when calling Fcopy_file.
+
+ * eval.c (call_debugger): Take full care of extending stack limits
+ to make space for the debugger, and restore the change afterward.
+ Bind debug-on-error to nil.
+ (restore_stack_limits): New subroutine.
+ (Fsignal): Extend specpdl bound along with eval depth bound,
+ for calling edebug. Don't do either one, for calling debugger.
+ (find_handler_clause): Don't bind debug-on-error here.
+ Don't unbind anything either.
+ Temporarily advance max_specpdl_size for calling
+ internal_with_output_to_temp_buffer.
+ (grow_specpdl): Don't alter max_specpdl_size before signaling
+ an error.
+ (syms_of_eval) <max-specpdl-size>: Doc fix.
+
+ * lread.c (read1): 0.0e+NaN should make a "positive" NaN.
+
+2005-06-24 Eli Zaretskii <[email protected]>
+
+ * fileio.c (Frename_file): Undo last change: no need to ifdef away
+ chown on DOS_NT platforms.
+
+ * w32.c (sys_chown): New function.
+
+ * s/ms-w32.h (chown): New; define to sys_chown.
+
+2005-06-24 Juanma Barranquero <[email protected]>
+
+ * xdisp.c (syms_of_xdisp) <nobreak-char-display>: Doc fix.
+ (syms_of_xdisp) <void-text-area-pointer>: Doc fix.
+
+ * fileio.c (Frename_file)[!DOS_NT]: Don't call chown on MSDOS/Windows.
+
+2005-06-23 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (get_next_display_element): Finish reversing the tests of
+ Vnobreak_char_display.
+
+ * xdisp.c (Vnobreak_char_display): Rename from Vshow_nonbreak_escape.
+ All uses changed.
+ (Qnobreak_space): Rename from Qno_break_space. All uses changed.
+ (syms_of_xdisp): Define nobreak-char-display and nobreak-space.
+
+ * fileio.c (Frename_file): Preserve owner and group, if possible,
+ when copying.
+
+2005-06-23 Juanma Barranquero <[email protected]>
+
+ * abbrev.c (Funexpand_abbrev):
+ * category.c (Fmake_category_set):
+ * dispnew.c (Fsleep_for, Fsit_for):
+ * editfns.c (Fsubst_char_in_region):
+ * eval.c (Fdefvar, Fdefconst, Feval, Ffuncall):
+ * frame.c (make_frame_without_minibuffer):
+ * lread.c (read_vector):
+ * macfns.c (check_x_frame):
+ * process.c (Fstop_process, Fcontinue_process):
+ * search.c (Freplace_match):
+ * syntax.c (Fstring_to_syntax):
+ * w32fns.c (check_x_frame, check_x_display_info):
+ * xfaces.c (x_supports_face_attributes_p):
+ * xselect.c (Fx_own_selection_internal): Follow error conventions.
+
+ * image.c (fn_png_init_io): Don't define it.
+ (init_png_functions) [HAVE_NTGUI]: Don't initialize fn_png_init_io.
+ (png_read_from_file): New function, based on png_read_from_memory.
+ (png_load): Use it, instead of fn_png_init_io.
+
+2005-06-23 Kim F. Storm <[email protected]>
+
+ * search.c (Fmatch_data): Remove evaporate option.
+ (Fset_match_data): Do not mention evaporate option in doc string.
+ Add commentary explaining evaporate arg (for internal use only).
+ (unwind_set_match_data): Add comment on evaporate use.
+
+2005-06-22 Miles Bader <[email protected]>
+
+ * xfaces.c (Qvertical_border): Rename from `Qvertical_divider'.
+ (realize_basic_faces, syms_of_xfaces): Update references to it.
+ * dispextern.h (enum face_id): Rename `VERTICAL_DIVIDER_FACE_ID'
+ to `VERTICAL_BORDER_FACE_ID'.
+ * dispnew.c (build_frame_matrix_from_leaf_window): Update references.
+
+2005-06-21 Juri Linkov <[email protected]>
+
+ * dispextern.h: Add extern Qframe_set_background_mode.
+
+ * xfaces.c: Rename obsolete function Qframe_update_face_colors to
+ Qframe_set_background_mode.
+
+ * frame.c (Fmodify_frame_parameters):
+ Call frame-set-background-mode after changing the background color
+ on non-window non-dos branch.
+
+2005-06-21 Juanma Barranquero <[email protected]>
+
+ * fns.c (Fchar_table_range):
+ * process.c (Fmake_network_process): Fix spellings.
+
+2005-06-20 Kim F. Storm <[email protected]>
+
+ * fns.c (Fsort): Doc fix.
+
+2005-06-20 Miles Bader <[email protected]>
+
+ * xfaces.c (Qvertical_divider): New variable.
+ (realize_basic_faces): Realize its face.
+ (syms_of_xfaces): Initialize it.
+
+ * dispextern.h (enum face_id): Add `VERTICAL_DIVIDER_FACE_ID'.
+
+ * dispnew.c (build_frame_matrix_from_leaf_window): Display vertical
+ window-separator on ttys using `vertical-divider' face by default.
+
+2005-06-17 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (get_next_display_element):
+ Reverse test of Vshow_nonbreak_escape.
+
+ * term.c (produce_special_glyphs): Use spec_glyph_lookup_face.
+ (Ftty_no_underline): New function.
+ (syms_of_term): defsubr it.
+
+ * keyboard.c (read_char): Call restore_getcjmp after jump occurs.
+
+ * dispnew.c (spec_glyph_lookup_face): New function.
+ (build_frame_matrix_from_leaf_window): Use it.
+
+ * dispextern.h (spec_glyph_lookup_face): Add declaration.
+
+ * buffer.c (syms_of_buffer) <cursor-type>: Doc fix.
+
+2005-06-12 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (read_char): After catching a longjmp,
+ call restore_getcjmp.
+
+2005-06-17 Juanma Barranquero <[email protected]>
+
+ * xselect.c (lisp_data_to_selection_data): Fix spelling.
+
+2005-06-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_compute_glyph_string_overhangs): Don't set
+ overhangs unless the given glyph type is noncomposite CHAR_GLYPH.
+ [USE_CARBON_EVENTS] (mac_convert_event_ref): Convert dead key down
+ events.
+ (XTread_socket): Don't pass keyboard events with the option
+ modifier to the system when Vmac_command_key_is_meta is nil or
+ Vmac_option_modifier is non-nil.
+ [USE_CARBON_EVENTS] (read_socket_inev): New variable.
+ [USE_CARBON_EVENTS] (init_command_handler): Fix argument.
+ [USE_CARBON_EVENTS] (mac_handle_mouse_event): New Carbon event
+ handler function.
+ (install_window_handler) [USE_CARBON_EVENTS]: Install it.
+ (XTread_socket) [USE_CARBON_EVENTS]: Move mouse wheel event
+ handler part to mac_handle_mouse_event.
+
+2005-06-14 Juanma Barranquero <[email protected]>
+
+ * eval.c (Fdefvaralias): Rename arguments SYMBOL and ALIASED to
+ NEW-ALIAS and BASE-VARIABLE, respectively.
+
+2005-06-13 Stefan Monnier <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Lisp_Object/int mixup.
+ (get_phys_cursor_geometry, format_mode_line_unwind_data)
+ (get_line_height_property, x_produce_glyphs): Remove unused vars.
+
+ * coding.c (run_pre_post_conversion_on_str): Remove unused var `buf'.
+
+2005-06-13 Eli Zaretskii <[email protected]>
+
+ * w32term.c (x_use_underline_position_properties): New variable.
+ (x_draw_glyph_string): Remind in a comment to change doc string of
+ x-use-underline-position-properties if/when underline positioning
+ is implemented.
+ (syms_of_w32term): DEFVAR_BOOL x-use-underline-position-properties,
+ and initialize it to nil.
+
+2005-06-12 Jason Rumney <[email protected]>
+
+ * w32fns.c (NEWOPENFILENAME): New struct.
+ (Fx_file_dialog): Use it to trick the system into giving us up to
+ date dialogs on systems that are documented to support it.
+ Do not set OFN_FILEMUSTEXIST flag if looking for a directory.
+
+2005-06-12 Eli Zaretskii <[email protected]>
+
+ * w32fns.c (w32_abort): Use the MB_YESNO dialog instead of
+ MB_ABORTRETRYIGNORE. Never return, even if DebugBreak does.
+
+2005-06-11 Eli Zaretskii <[email protected]>
+
+ * image.c (x_create_x_image_and_pixmap) [HAVE_NTGUI]: Cast 4th arg
+ to CreateDIBSection to avoid a compiler warning.
+ (pbm_load): Cast 3rd arg to IMAGE_BACKGROUND to avoid a compiler
+ warning.
+ (png_load): Cast return values of fn_png_create_read_struct and
+ fn_png_create_info_struct, to avoid compiler warnings on W32.
+ Cast 3rd arg to IMAGE_BACKGROUND and image_background_transparent
+ to avoid compiler warnings.
+ (jpeg_load): Cast return value of fn_jpeg_std_error to avoid a
+ compiler warning on W32. Cast 3rd arg to IMAGE_BACKGROUND to
+ avoid a compiler warning.
+ (tiff_load): Cast return values of fn_TIFFOpen and
+ fn_TIFFClientOpen to avoid compiler warning on W32. Cast 3rd arg
+ to IMAGE_BACKGROUND to avoid a compiler warning.
+ (gif_load): Cast return values of fn_DGifOpenFileName and
+ fn_DGifOpen to avoid compiler warnings on W32. Cast 3rd arg to
+ IMAGE_BACKGROUND to avoid a compiler warning.
+ (DrawText) [HAVE_NTGUI || MAC_OS]: If already defined, undef
+ before redefining.
+
+ * w32bdf.c (create_offscreen_bitmap): Cast `bitsp' to `void **' in
+ the call to CreateDIBSection, to avoid a compiler warning.
+
+2005-06-11 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fx_file_dialog): Unblock input before falling back to
+ minibuffer.
+ * macfns.c (Fx_file_dialog): Likewise.
+
+2005-06-10 Eli Zaretskii <[email protected]>
+
+ * makefile.w32-in ($(TEMACS)): Depend on addsection.exe.
+
+2005-06-10 Juanma Barranquero <[email protected]>
+
+ * process.c (syms_of_process) [ADAPTIVE_READ_BUFFERING]:
+ * w32fns.c (syms_of_w32fns): Fix spellings.
+
+2005-06-10 Eli Zaretskii <[email protected]>
+
+ * unexw32.c (COPY_CHUNK, COPY_PROC_CHUNK): Add a new argument
+ `verbose'; print diagnostic messages only if it is non-zero.
+ All callers changed to pass a zero value unless DEBUG_DUMP is defined
+ in the environment.
+ (copy_executable_and_dump_data): Print section names with %.8s.
+
+2005-06-10 Masatake YAMATO <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Call clear_mouse_face
+ when mouse_face is not given.
+
+2005-06-09 Luc Teirlinck <[email protected]>
+
+ * window.c (Fselect_window): Adapt call to Fselect_frame.
+
+ * lisp.h: Update EXFUN of Fselect_frame.
+
+ * keyboard.c (command_loop_1): Adapt call to Fselect_frame.
+
+ * frame.c (Fhandle_switch_frame, Fselect_frame): Delete unused arg
+ no_enter.
+ (Fset_mouse_position, Fset_mouse_pixel_position, Ficonify_frame):
+ Adapt to above change.
+
+2005-06-10 Juanma Barranquero <[email protected]>
+
+ * fns.c (Fmemq, Fmaphash): Doc fixes.
+
+2005-06-09 Juanma Barranquero <[email protected]>
+
+ * xfaces.c (Fdisplay_supports_face_attributes_p):
+ Fix typo in docstring.
+
+2005-06-08 Steven Tamm <[email protected]>
+
+ * unexmacosx.c (copy_data_segment): Copy __la_sym_ptr2 section
+ used by gcc4 on intel mac.
+
+2005-06-09 Kim F. Storm <[email protected]>
+
+ * search.c (Fmatch_data): Add optional RESEAT arg. Unchain markers
+ in REUSE list if non-nil; free them if equal to evaporate.
+ (Fset_match_data): Add optional RESEAT arg. Unchain markers in LIST
+ if non-nil; free them if equal to evaporate. Use XCAR/XCDR.
+ (restore_search_regs): Rename from restore_match_data. Uses changed.
+ (unwind_set_match_data): New function.
+ (record_unwind_save_match_data): New function like save-match-data.
+
+ * lisp.h (Fmatch_data, Fset_match_data): Fix EXFUN.
+ (record_unwind_save_match_data): Add prototype.
+ (restore_search_regs): Rename from restore_match_data.
+
+ * composite.c (compose_chars_in_text):
+ * eval.c (do_autoload):
+ * macmenu.c (set_frame_menubar):
+ * process.c (read_process_output, exec_sentinel):
+ * xmenu.c (set_frame_menubar):
+ * xdisp.c (prepare_menu_bars, update_menu_bar, update_tool_bar):
+ * w32menu.c (set_frame_menubar):
+ Use record_unwind_save_match_data.
+
+2005-06-08 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (get_next_display_element): Alter previous change:
+ Distinguish Vshow_nonbreak_escape = t or not t.
+ For t, use escape_glyph once again, as before previous change.
+ Use space or hyphen for display, instead of the non-ASCII char.
+ (syms_of_xdisp) <show-nonbreak-escape>: Doc fix.
+
+ * process.c (Fstart_process): Don't touch command_channel_p slot.
+
+ * process.h (struct process): Delete command_channel_p.
+
+2005-06-07 Masatake YAMATO <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight):
+ Check the overlapping of re-rendering area to avoid flickering.
+ (note_mouse_highlight): Call clear_mouse_face if PART
+ is not ON_MODE_LINE nor ON_HEADER_LINE.
+
+2005-06-07 Kim F. Storm <[email protected]>
+
+ * process.c: Improve commentary for adaptive read buffering.
+
+2005-06-06 Stefan Monnier <[email protected]>
+
+ * xterm.c (x_create_toolkit_scroll_bar): Use XtNarrowScrollbars
+ if available.
+
+2005-06-06 Jan Dj,Ad(Brv <[email protected]>
+
+ * macmenu.c (menu_quit_handler, install_menu_quit_handler):
+ New functions for popping down menus on C-g.
+ (set_frame_menubar, mac_menu_show): Call install_menu_quit_handler.
+
+ * macterm.c: Make mac_quit_char_modifiers and mac_quit_char_keycode
+ non-static.
+
+ * config.in: Add HAVE_CANCELMENUTRACKING.
+
+2005-06-06 Eli Zaretskii <[email protected]>
+
+ * w32heap.h (OFFSET_TO_RVA, RVA_TO_OFFSET, RVA_TO_PTR): Remove macros.
+
+ * unexw32.c (RVA_TO_PTR): Move here from w32heap.h.
+
+ * w32proc.c (RVA_TO_PTR): New macro.
+
+ * w32heap.c (RVA_TO_PTR): No need to #undef now.
+
+ * makefile.w32-in ($(BLD)/emacs.$(O), $(BLD)/w32select.$(O)):
+ Depend on w32heap.h.
+
+2005-06-06 Luc Teirlinck <[email protected]>
+
+ * keyboard.c (command_loop_1): Update Vthis_original_command.
+
+2005-06-06 Richard M. Stallman <[email protected]>
+
+ * xmenu.c (popup_get_selection): Undo previous change.
+
+2005-06-06 Juri Linkov <[email protected]>
+
+ * xdisp.c (Qno_break_space): New variable.
+ (syms_of_xdisp): Initialize it.
+ (get_next_display_element): Add no-break space and soft hypen
+ codes for iso8859-2 and iso8859-5. Don't add `\' for them.
+ Use `no-break-space' face for no-break spaces.
+
+2005-06-06 Jan Dj,Ad(Brv <[email protected]>
+
+ * window.c (delete_window): Handle the case where a h/vchild has
+ a h/vchild.
+
+2005-06-05 Eli Zaretskii <[email protected]>
+
+ * w32.c (sys_setsockopt): Change arg 4 to `const void *'. In the
+ call to pfn_setsockopt, cast optval to `const char *'.
+
+2005-06-04 Eli Zaretskii <[email protected]>
+
+ * w32.c (gettimeofday): Use struct _timeb, not struct timeb.
+ (open_unc_volume): Cast return value of map_w32_filename, to avoid
+ compiler warnings.
+
+ * s/ms-w32.h (fileno): Don't define if already defined.
+
+ * emacs.c: Include w32heap.h, to avoid compiler warning about sbrk.
+
+ * makefile.w32-in (DOC): Define to point to the generated DOC-X.
+
+2005-06-04 Richard M. Stallman <[email protected]>
+
+ * xmenu.c (popup_get_selection): Click not in menu deactivates menu.
+
+2005-06-04 Jan Dj,Ad(Brv <[email protected]>
+
+ * macmenu.c (cleanup_popup_menu): New function.
+ (Fx_popup_menu): Unwind protect cleanup_popup_menu in case
+ mac_menu_show Quit:s.
+ (mac_menu_show): Quit on cancel if not popped up on click (i.e.
+ a dialog).
+
+2005-06-04 Kim F. Storm <[email protected]>
+
+ * coding.c (decode_coding_string): Handle CODING_FINISH_INTERRUPT.
+
+ * callproc.c (Fcall_process): Don't use alloca to gradually
+ increase size of buf, as it effectively uses twice the necessary
+ space on the stack. Instead, pre-allocate buf of full size, and
+ gradually increase the read size.
+
+ * bytecode.c (BYTE_CODE_QUIT): Check Vthrow_on_input.
+
+ * eval.c (unbind_to): Preserve value of Vquit_flag.
+
+ * xterm.c (handle_one_xevent): Also ignore mouse motion just
+ before a button release event.
+
+2005-06-03 Juanma Barranquero <[email protected]>
+
+ * xfaces.c (Finternal_lisp_face_equal_p): Really report
+ on faces in a frame, if the argument FRAME is non-nil.
+ Improve argument/docstring consistency.
+
+2005-06-02 Kim F. Storm <[email protected]>
+
+ * xdisp.c (MODE_LINE_NOPROP_LEN): New macro.
+ (x_consider_frame_title, Fformat_mode_line): Save offset into
+ mode_line_noprop_buf rather than pointer, in case buffer is relocated.
+
+2005-06-01 Kim F. Storm <[email protected]>
+
+ * fns.c (mapcar1): Maybe exit loop if original sequence was modified.
+
+2005-06-01 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_to_x_fontname, mac_do_list_fonts): Set XLFD
+ resolution fields for scalable fonts to 0.
+
+ * xfaces.c (build_scalable_font_name): Round pixel size to the
+ nearest integer.
+
+2005-06-01 Kim F. Storm <[email protected]>
+
+ * xdisp.c (display_mode_line): Support nested calls to redisplay
+ and format-mode-line. Set mode_line_target to MODE_LINE_DISPLAY.
+
+2005-05-31 Stefan Monnier <[email protected]>
+
+ * fileio.c (Finsert_file_contents):
+ * xdisp.c (note_mode_line_or_margin_highlight): Lisp_Object/int mixup.
+
+2005-05-31 Kim F. Storm <[email protected]>
+
+ * xdisp.c (mode_line_noprop_buf, mode_line_noprop_buf_end)
+ (mode_line_noprop_ptr): Rename from frame_title_*.
+ (store_mode_line_noprop_char): Rename from store_frame_title_char.
+ (store_mode_line_noprop): Rename from store_frame_title.
+ (mode_line_target): New enum to specify current output target
+ for mode line formatting.
+ (display_mode_element): Test it rather than frame_title_ptr and
+ mode_line_string_list to determine where output should go.
+ (mode_line_proptrans_alist, mode_line_string_alist): Make static.
+ (Vmode_line_unwind_vector): New variable.
+ (format_mode_line_unwind_data, unwind_format_mode_line):
+ New functions for unwind protection in mode line formatting.
+ (x_consider_frame_title): Use them and new local var 'title_start'
+ to support nested calls to format-mode-line and redisplay.
+ Set mode_line_target to MODE_LINE_TITLE.
+ (Fformat_mode_line): Use them and new local var 'string_start' to
+ support nested calls to format-mode-line and redisplay.
+ Set mode_line_target to MODE_LINE_NOPROP or MODE_LINE_STRING.
+ Don't trim trailing dashes.
+ (decode_mode_spec): Don't make infinite number of trailing dashes
+ for MODE_LINE_NOPROP and MODE_LINE_STRING targets.
+ (syms_of_xdisp): Initialize and staticpro mode_line_string_face,
+ mode_line_string_face_prop, and Vmode_line_unwind_vector.
+ (init_xdisp): Initialize mode_line_noprop_ptr to start of _buf.
+ Initialize mode_line_target to MODE_LINE_DISPLAY.
+
+2005-05-29 Richard M. Stallman <[email protected]>
+
+ * buffer.c (Fbuffer_local_value): Call indirect_variable.
+
+2005-05-28 Masatake YAMATO <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Change the
+ pointer to a hand cursor when hoovering over a mouse-face.
+
+2005-05-27 Kenichi Handa <[email protected]>
+
+ * xterm.c (x_encode_char): Call check_ccl_update in advance.
+
+ * ccl.c: Now an element of Vccl_program_table is a vector of
+ length 4, not 3.
+ (ccl_get_compiled_code): New arg idx. Caller changed.
+ Adjust for the change of Vccl_program_table.
+ (setup_ccl_program): Adjust for the change of Vccl_program_table.
+ (check_ccl_update): New function.
+ (Fregister_ccl_program): Use ASET to set an element of a vector.
+ Adjusted for the change of Vccl_program_table.
+
+ * ccl.h (struct ccl_program): New member idx.
+ (check_ccl_update): Extern it.
+
+2005-05-27 Juanma Barranquero <[email protected]>
+
+ * image.c (Vimage_library_alist): Move from image.el.
+ (syms_of_image): Defvar it.
+ (lookup_image_type): Use it.
+
+ * buffer.c (Fbuffer_local_value): Make argument name match its use
+ in docstring.
+
+2005-05-26 Juanma Barranquero <[email protected]>
+
+ * keyboard.c (Frecursive_edit): Fix typo in docstring.
+ (Fposn_at_x_y): Make argument name match its use in docstring.
+
+2005-05-26 Lute Kamstra <[email protected]>
+
+ * eval.c (Frun_hooks): Mention run-mode-hooks in docstring.
+
+2005-05-24 Masatake YAMATO <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Use b and e
+ as loop sentinels.
+
+2005-05-24 Nick Roberts <[email protected]>
+
+ * xmenu.c (Fx_popup_dialog): Add a third boolean argument to
+ select frame title ("Question"/"Information").
+ (xdialog_show): Use it.
+
+ * macmenu.c (Fx_popup_dialog, mac_dialog_show): As for xmenu.c.
+
+ * w32menu.c (Fx_popup_dialog, w32_dialog_show): As for xmenu.c.
+
+ * fns.c (Fyes_or_no_p, Fy_or_n_p): Call Fx_popup_dialog with
+ a third argument (Qnil).
+
+ * lisp.h: x-popup-dialog can have three arguments.
+
+ * editfns.c (Fmessage_box): Use "Information" for frame title.
+
+2005-05-23 Thien-Thi Nguyen <[email protected]>
+
+ * termcap.c [VMS]: Include <starlet.h>.
+
+2005-05-23 Masatake YAMATO <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Add code
+ for mouse-face. Change the type of the first argument from `window'
+ to `Lisp_Object'.
+ (note_mouse_highlight): Call note_mode_line_or_margin_highlight with
+ window instead of w.
+
+2005-05-22 Andreas Schwab <[email protected]>
+
+ * process.c (send_process): Move misplaced volatile.
+
+2005-05-21 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (display_mode_element): If we're processing a list and
+ padding is specified, put it after the last element.
+
+2005-05-21 Eli Zaretskii <[email protected]>
+
+ * fileio.c (Fexpand_file_name) [DOS_NT]: Don't try to support
+ "superroot" on DOS_NT systems.
+
+2005-05-21 David Hunter <[email protected]> (tiny change)
+
+ * process.c (send_process): Restore the SIGPIPE handler if we
+ catch a SIGPIPE.
+
+2005-05-20 Juanma Barranquero <[email protected]>
+
+ * image.c (lookup_image, png_read_from_memory): Remove hacks (and
+ misleading comments).
+ (DEF_IMGLIB_FN): Use C calling convention for image libraries.
+
+2005-05-20 KOBAYASHI Yasuhiro <[email protected]>
+
+ * window.c (Fwindow_inside_edges, Fwindow_inside_pixel_edges):
+ Correct the right value.
+
+2005-05-19 Nick Roberts <[email protected]>
+
+ * keyboard.c (syms_of_keyboard): Remove Lisp variables
+ post-command-idle-hook and post-command-idle-delay.
+ (command_loop_1): Don't try to execute post-command-idle-hook.
+
+2005-05-16 Kim F. Storm <[email protected]>
+
+ * xdisp.c (handle_display_prop): Handle empty replacement.
+ (handle_single_display_spec): Return -1 for empty replacement.
+
+ * keyboard.c (adjust_point_for_property): Skip empty overlay string.
+
+ * .gdbinit (pitx): Print more info about iterator.
+
+2005-05-16 Andreas Schwab <[email protected]>
+
+ * unexmacosx.c (unexec_realloc): Move declarations before statements.
+
+2005-05-14 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (message3): Call cancel_echoing.
+
+ * alloc.c (Fmemory_full_p): New function.
+ (syms_of_alloc): defsubr it.
+
+ * process.c (send_process_trap): Unblock SIGPIPE.
+ (send_process): Reset SIGPIPE handler before reporting error.
+
+2005-05-14 Nick Roberts <[email protected]>
+
+ * emacs.c (syms_of_emacs): Fix doc string for system-type.
+
+2005-05-13 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Ffind_file_name_handler): Handle lambda-exp as handler.
+ (Finsert_file_contents): If we read 0 bytes from a special file,
+ unlock the visited file if we locked it.
+ (Fmake_symbolic_link, Frecent_auto_save_p): Doc fixes.
+ (Ffile_exists_p, Ffile_symlink_p): Doc fixes.
+
+2005-05-13 YAMAMOTO Mitsuharu <[email protected]>
+
+ * emacs.c (main) [MAC_OS8]: Call init_atimer before mac_term_init.
+
+ * keyboard.c (readable_events) [USE_TOOLKIT_SCROLL_BARS]:
+ Regard toolkit scroll bar thumb drag events as squeezable and prevent
+ redisplay from being paused by them.
+
+ * mac.c [!MAC_OSX]: Include keyboard.h and syssignal.h.
+ [!MAC_OSX] (target_ticks): Remove variable.
+ [!MAC_OSX] (check_alarm, pause, index): Remove functions.
+ [!MAC_OSX && __MRC__] (sys_strftime): Likewise.
+ [!MAC_OSX] (select): If fd 0 is not set in rfds and some input
+ event occurs before timeout, behave as if the function were interrupted.
+ [!MAC_OSX] (sigblock, sigsetmask, alarm): Simulate SIGALRM
+ handling using Time Manager routines.
+ [!MAC_OSX] (mac_atimer_task, mac_atimer_qlink, signal_mask):
+ New variables.
+ [!MAC_OSX] (mac_atimer_handler, set_mac_atimer, remove_mac_atimer)
+ (setitimer): New functions.
+
+ * macfns.c, macmenu.c: Don't include signal.h.
+
+ * macterm.c [USE_TOOLKIT_SCROLL_BARS] (get_control_part_bounds):
+ Rename from get_control_part_bound. All callers changed.
+ (x_scroll_bar_clear): New function.
+ (x_clear_frame): Use it.
+ (XTset_vertical_scroll_bar): Don't call Draw1Control.
+ (x_scroll_bar_handle_click): Change type of second argument from
+ int to ControlPartCode.
+ (check_alarm): Remove declaration.
+ (XTread_socket) [!TARGET_API_MAC_CARBON]: Don't call it.
+ (XTread_socket): Use ControlPartCode instead of SInt16.
+
+2005-05-13 Nozomu Ando <[email protected]>
+
+ * unexmacosx.c: Include assert.h.
+ (MACOSX_MALLOC_MULT16): New define.
+ [MACOSX_MALLOC_MULT16] (ptr_in_unexec_regions): Determine whether
+ ptr is in unexec regions by checking it is multiple of 16.
+ (unexec_malloc_header_t): New typedef.
+ (unexec_malloc, unexec_realloc, unexec_free): Store and use
+ allocated size information in unexec_malloc_header.
+
+2005-05-10 Richard M. Stallman <[email protected]>
+
+ * xterm.c (noinclude): Add #undef.
+
+ * image.c, xfns.c, xmenu.c: Don't include signal.h.
+
+2005-05-09 Juanma Barranquero <[email protected]>
+
+ * fileio.c (Fexpand_file_name, Frename_file, Fadd_name_to_file)
+ (Fmake_symbolic_link, Faccess_file, Frecent_auto_save_p):
+ Doc fixes.
+
+ * dired.c (Ffile_name_completion): Make argument name
+ match its use in docstring.
+
+2005-05-08 Luc Teirlinck <[email protected]>
+
+ * eval.c (Fdefvaralias): Remove any pre-existing
+ variable-documentation property of the alias.
+
+2005-05-07 Thien-Thi Nguyen <[email protected]>
+
+ * xfns.c (start_hourglass): Do nothing when running on a tty.
+
+2005-05-07 Juanma Barranquero <[email protected]>
+
+ * fns.c (Fchar_table_range): Fix typos in docstring.
+
+2005-05-06 Stefan Monnier <[email protected]>
+
+ * fns.c (Fchar_table_range): Yet Another Int/Lisp_Object Mixup.
+
+2005-05-06 Eli Zaretskii <[email protected]>
+
+ * lread.c (Flocate_file_internal): Doc fix.
+
+ * Makefile.in (lisp, shortlisp): Add jka-cmpr-hook.elc.
+
+2005-05-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macselect.c (x_own_selection): Accept Lisp string as result of
+ selection converter function.
+ (x_clear_frame_selections): Don't call x-lost-selection-functions
+ if Emacs is not owner of the selection.
+ (Vmac_services_selection): Put variable and initialization in
+ #ifdef MAC_OSX.
+ (syms_of_macselect) [MAC_OSX]: Set default value of
+ Vmac_services_selection to PRIMARY.
+
+ * macterm.c (toolkit_scroll_bar_interaction): Remove unused variable.
+ (mac_handle_tool_bar_click): Remove unused function and declaration.
+ [USE_TOOLKIT_SCROLL_BARS] (scroll_bar_timer_callback)
+ (install_scroll_bar_timer, set_scroll_bar_timer)
+ (control_part_code_to_scroll_bar_part, construct_scroll_bar_click)
+ (get_control_part_bound, x_scroll_bar_handle_press)
+ (x_scroll_bar_handle_release, x_scroll_bar_handle_drag)
+ (x_set_toolkit_scroll_bar_thumb): New functions and declarations.
+ [USE_TOOLKIT_SCROLL_BARS] (last_scroll_bar_part, scroll_bar_timer)
+ (scroll_bar_timer_event_posted_p): New variables.
+ [USE_TOOLKIT_SCROLL_BARS] (SCROLL_BAR_FIRST_DELAY)
+ (SCROLL_BAR_CONTINUOUS_DELAY): New macros.
+ (x_scroll_bar_create): Set control reference with NewControl.
+ (x_scroll_bar_create) [USE_TOOLKIT_SCROLL_BARS]:
+ Initialize track_top and track_height to nil.
+ (x_scroll_bar_set_handle, x_scroll_bar_note_movement):
+ Put functions in #ifndef USE_TOOLKIT_SCROLL_BARS.
+ (XTset_vertical_scroll_bar): Don't make space between scroll bar
+ and associated window.
+ (XTset_vertical_scroll_bar) [MAC_OSX]: Get scroll bar area width
+ from window config.
+ (XTset_vertical_scroll_bar) [USE_TOOLKIT_SCROLL_BARS]:
+ Set track_top and track_height to nil when scroll bar size is changed.
+ Recalculate them if they are nil.
+ (XTread_socket) [MAC_OSX]: Use control kind to determine if the
+ clicked control is a scroll bar.
+ (XTread_socket) [USE_TOOLKIT_SCROLL_BARS]: Use toolkit scroll bar
+ event handler functions. Don't add modifiers to scroll bar click
+ events. Call scroll bar release handler when window is deactivated.
+ (mac_initialize): Remove unused code for X toolkit.
+ (syms_of_macterm) [!USE_TOOLKIT_SCROLL_BARS]:
+ Initialize Vx_toolkit_scroll_bars to nil.
+
+ * macterm.h (struct scroll_bar) [USE_TOOLKIT_SCROLL_BARS]:
+ New members track_top and track_height.
+
+ * sysselect.h [DARWIN || MAC_OSX]: Temporarily undefine
+ init_process when including sys/select.h.
+
+2005-05-05 Luc Teirlinck <[email protected]>
+
+ * eval.c (Fdefvaralias): Doc fix.
+
+ * xmenu.c (Fx_popup_menu, Fx_popup_dialog): Doc fixes.
+
+2005-05-05 Kim F. Storm <[email protected]>
+
+ * buffer.c (init_buffer_once): Set cursor_in_non_selected_windows
+ default value.
+ (syms_of_buffer): Add default-cursor-in-non-selected-windows.
+ Fix type of cursor-in-non-selected-windows.
+
+2005-05-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * mac.c: #undef init_process so not to conflict with system headers.
+
+2005-05-02 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer): Define cursor-in-non-selected-windows.
+
+ * buffer.h (struct buffer): Add cursor_in_non_selected_windows slot.
+
+ * xdisp.c (Vcursor_in_non_selected_windows)
+ (Qcursor_in_non_selected_windows): Vars deleted.
+ (syms_of_xdisp): Don't initialize them.
+ (get_window_cursor_type): Use cursor_in_non_selected_windows
+ buffer slot.
+
+2005-05-02 Kim F. Storm <[email protected]>
+
+ * macros.c (executing_kbd_macro_index): Rename from
+ executing_macro_index. All uses changed.
+ (executing_kbd_macro_iterations): Rename from
+ executing_macro_iterations. All uses changed.
+ (executing_kbd_macro): Rename from executing_macro.
+ All uses changed.
+ (syms_of_macros): Rename Lisp var executing-macro-index to
+ executing-kbd-macro-index.
+
+ * xdisp.c (move_it_in_display_line_to): Fix last change.
+
+2005-05-01 Luc Teirlinck <[email protected]>
+
+ * xmenu.c (Fx_popup_menu): Doc fix.
+
+ * charset.c (syms_of_charset): Delete defsubr for Schars_in_region.
+
+2005-05-02 Jason Rumney <[email protected]>
+
+ * emacs.c (USAGE3, USAGE4): Keep strings below 2048 bytes.
+
+2005-05-02 Nozomu Ando <[email protected]>
+
+ * sysselect.h: Fix typo.
+
+2005-05-02 Nick Roberts <[email protected]>
+
+ * charset.c (Fchars_in_region): Remove as obsolete.
+
+2005-05-01 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_in_display_line_to): Stop if we move beyond
+ TO_CHARPOS. This may happen if last glyphs was an image or stretch
+ glyph.
+
+2005-05-01 Luc Teirlinck <[email protected]>
+
+ * dispnew.c (sit_for): Vexecuting_macro -> Vexecuting_kbd_macro.
+
+2005-05-01 Richard M. Stallman <[email protected]>
+
+ * xmenu.c [not HAVE_X_TOOLKIT] (xmenu_show):
+ If user cancels the menu, quit unless FOR_CLICK.
+
+ * macros.c (Vexecuting_kbd_macro): Rename from Vexecuting_macro.
+ All uses changed.
+ (syms_of_macros): Define only executing-kbd-macro, not executing-macro.
+ * keyboard.c: Change Vexecuting_macro to Vexecuting_kbd_macro.
+ * macros.h (Vexecuting_kbd_macro): Declare instead of Vexecuting_macro.
+ * commands.h (Vexecuting_kbd_macro): Likewise.
+
+2005-05-01 Thien-Thi Nguyen <[email protected]>
+
+ * sysdep.c (get_frame_size) [VMS]: Use a fresh i/o channel.
+
+2005-04-30 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Ffind_file_name_handler): Handle the `operations'
+ property of the file name handler.
+ (Qoperations): New variable.
+ (syms_of_fileio): Initialize and staticpro it.
+
+ * xdisp.c (set_message_1): Delete xassert.
+
+2005-04-29 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c: Don't include time.h. Include sysselect.h after systime.h.
+
+ * macfns.c (Fx_server_version): Add BLOCK_INPUT around Gestalt.
+
+ * macgui.h [HAVE_CARBON && MAC_OSX]: Don't undefine/define mktime
+ before/after including Carbon.h if there is a working mktime.
+
+2005-04-28 Kim F. Storm <[email protected]>
+
+ * xfaces.c (resolve_face_name): Add arg SIGNAL_P. Calls changed.
+ Fix cyclic alias check. If alias loop is detected, signal
+ circular-list error if SIGNAL_P, and return Qdefault if !SIGNAL_P.
+
+2005-04-28 Lute Kamstra <[email protected]>
+
+ * eval.c (do_autoload): Record only autoloads in the autoload
+ property of symbols.
+
+2005-04-28 Nick Roberts <[email protected]>
+
+ * emacs.c (USAGE1): Add --basic-display and --quick options.
+
+2005-04-27 Kim F. Storm <[email protected]>
+
+ * data.c (syms_of_data) Staticpro Qcyclic_variable_indirection.
+
+2005-04-26 Richard M. Stallman <[email protected]>
+
+ * window.c (Fsame_window_p, Fspecial_display_p): Doc fixes.
+ (syms_of_window): Doc fixes.
+
+ * indent.c (Fvertical_motion): Undo previous change.
+
+2005-04-26 Kenichi Handa <[email protected]>
+
+ * fns.c (char_table_range): New function.
+ (Fchar_table_range): Signal an error if characters in the range
+ have inconsistent values. Don't check the parent.
+
+2005-04-25 Kenichi Handa <[email protected]>
+
+ * fontset.c (fontset_set): Fix previous change.
+
+2005-04-24 Richard M. Stallman <[email protected]>
+
+ * indent.c (Fvertical_motion): Bind fontification-functions to nil.
+
+2005-04-24 Eli Zaretskii <[email protected]>
+
+ * regex.c (re_search_2, re_match_2_internal): Convert second arg
+ of RE_TRANSLATE to int, to shut up GCC warnings.
+
+ * fileio.c (Fcopy_file): Doc fix.
+ [MSDOS]: Fix call to emacs_open: buffer_file_type not defined and
+ not needed.
+
+2005-04-24 YAMAMOTO Mitsuharu <[email protected]>
+
+ * Makefile.in [HAVE_CARBON] (MAC_OBJ): Add macselect.o.
+ (SOME_MACHINE_OBJECTS): Likewise.
+ (mac.o): Depend on ccl.h.
+ (macselect.o): New target.
+
+ * emacs.c (main) [MAC_OS8 || MAC_OSX && HAVE_CARBON]:
+ Call syms_of_macselect.
+
+ * frame.c (Fdelete_frame) [MAC_OS]: Call x_clear_frame_selections.
+
+ * mac.c [!TARGET_API_MAC_CARBON]: Don't include charset.h or coding.h.
+ (QCLIPBOARD): Remove variable.
+ (syms_of_mac): Don't initialize it.
+ (Fmac_paste_function, Fmac_cut_function, Fx_selection_exists_p):
+ Remove functions.
+ (syms_of_mac): Don't defsubr them.
+ [TARGET_API_MAC_CARBON] (Qmime_charset, QNFD, QNFKD, QNFC, QNFKC)
+ (QHFS_plus_D, QHFS_plus_C): New variables.
+ (syms_of_mac) [TARGET_API_MAC_CARBON]: Initialize them.
+ [TARGET_API_MAC_CARBON] (get_cfstring_encoding_from_lisp)
+ (cfstring_create_normalized): New functions.
+ [TARGET_API_MAC_CARBON] (Fmac_code_convert_string): Likewise.
+ (syms_of_mac) [TARGET_API_MAC_CARBON]: Defsubr it.
+
+ * macterm.c (handling_window_update, terminate_flag):
+ Remove variables.
+ (do_window_update, do_ae_quit_application, XTread_socket):
+ Don't use them.
+ (WNE_SLEEP_AT_SUSPEND, WNE_SLEEP_AT_RESUME): Don't define.
+ [USE_CARBON_EVENTS && MAC_OSX] (mac_handle_service_event)
+ (init_service_handler): Move to macselect.c. Remove declarations.
+ [USE_CARBON_EVENTS && MAC_OSX] (init_service_handler): Add extern.
+ (Qapplication, Qabout): New variables.
+ (syms_of_mac): Initialize them.
+ [USE_CARBON_EVENTS && MAC_OSX] (Qpreferences, Qservices, Qpaste)
+ (Qperform): New variables.
+ (syms_of_mac) [USE_CARBON_EVENTS && MAC_OSX]: Initialize them.
+ (do_get_menus) [TARGET_API_MAC_CARBON]: Don't call AppendResMenu.
+ (do_menu_choice): Unhighlight menu bar also when menu_id is 0.
+ (mac_store_application_menu_event, init_menu_bar): New functions.
+ [USE_CARBON_EVENTS] (mac_handle_command_event)
+ (init_command_handler): New functions.
+ (mac_handle_window_event): Return noErr on window update event.
+ (do_ae_quit_application): Call mac_store_application_menu_event.
+ (mac_initialize) [USE_CARBON_EVENTS]: Call init_command_handler
+ and init_menu_bar.
+
+ * macterm.h (x_clear_frame_selections): Add extern.
+
+ * macselect.c: New file for selection processing on Mac OS.
+
+2005-04-23 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fcopy_file): New arg MUSTBENEW.
+ (Frename_file): Pass new arg to Fcopy_file.
+
+ * window.c (window_size_fixed): Variable deleted.
+ (syms_of_window): Initialize window-size-fixed to nil.
+ But don't DEFVAR window_size_fixed.
+
+2005-04-23 Andreas Schwab <[email protected]>
+
+ * m/macppc.h (LD_SWITCH_MACHINE) [LINUX]: Don't define.
+ (START_FILES, LIB_STANDARD) [LINUX && _ARCH_PPC64]: Override to
+ use lib64 instead of lib.
+ (_LP64) [_ARCH_PPC64]: Define if not defined.
+
+2005-04-23 David Hunter <[email protected]> (tiny change)
+
+ * s/ms-w32.h (HAVE_PWD_H): Define.
+
+2005-04-22 Kenichi Handa <[email protected]>
+
+ * fns.c (copy_sub_char_table): Explicitly copy the default value
+ of the sub-chartable.
+
+ * fontset.c (fontset_set): When a sub-chartable is created,
+ explicitly sets the defalt value.
+
+2005-04-22 Kim F. Storm <[email protected]>
+
+ * fns.c (Fplist_get): Replace by Fsafe_plist_get.
+ (Fsafe_plist_get): Rename to Fplist_get.
+ (Fsafe_get): Remove, as Fget now uses safe Fplist_get.
+ (defsubr): Remove defsubr for Fsafe_plist_get and Fsafe_get.
+
+ * lisp.h (Fsafe_plist_get, Fsafe_get): Remove EXFUN.
+
+ * xdisp.c (store_mode_line_string, produce_stretch_glyph)
+ (note_mode_line_or_margin_highlight, note_mouse_highlight):
+ Use Fplist_get instead of Fsafe_plist_get.
+
+ * xfaces.c (resolve_face_name): Use Fget instead of Fsafe_get.
+
+2005-04-21 Miles Bader <[email protected]>
+
+ * xdisp.c (dump_glyph_row): Don't display overlay_arrow_p field.
+
+2005-04-20 Thien-Thi Nguyen <[email protected]>
+
+ * sysdep.c: Remove reference to defunct vms-pwd.h.
+ * dired.c: Likewise. Also, for pwd.h, use HAVE_PWD_H, not !VMS.
+ * editfns.c, fileio.c, filelock.c, sysdep.c, xrdb.c: Likewise.
+
+ * config.in: Regenerate.
+
+2005-04-20 Kenichi Handa <[email protected]>
+
+ * lisp.h (CHAR_TABLE_DEFAULT_SLOT_ASCII): New macro.
+ (CHAR_TABLE_DEFAULT_SLOT_8_BIT_CONTROL): New macro.
+ (CHAR_TABLE_DEFAULT_SLOT_8_BIT_GRAPHIC): New macro.
+
+ * alloc.c (make_sub_char_table): Argument changed to initial
+ value of the slots.
+
+ * data.c (Faref): Handle special slots used as default values of
+ ascii, eight-bit-control, eight-bit-control. Don't ignore a
+ default value set for a group of characters.
+ (Faset): Signal an error if IDXVAL is not a valid character code.
+ Make a sub-chartable with correct initial value.
+
+ * fns.c (Fset_char_table_range): Don't set slots used as default
+ values for ascii, eight-bit-control, eight-bit-graphic.
+ Don't call Faref with charset-id.
+ (Fset_char_table_default): Document how to treat normal character
+ argument. Handle special slots used as default values of ascii,
+ eight-bit-control, eight-bit-control. Make a sub chartable if
+ necessary.
+
+2005-04-20 Kenichi Handa <[email protected]>
+
+ * search.c (boyer_moore): Fix previous change.
+
+2005-04-19 Kim F. Storm <[email protected]>
+
+ * xdisp.c (setup_for_ellipsis): Reset saved_face_id to use default
+ face unless last visible char and first invisible char have the
+ same face. Also use default face if saved_face_id is undefined.
+
+2005-04-19 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macgui.h (MacFontStruct): Remove member `fontname'. Add member
+ `full_name'.
+ [TARGET_API_MAC_CARBON] (MacFontStruct): Use type int for
+ mac_scriptcode member.
+
+ * macterm.c (Qbig5, Qcn_gb, Qsjis, Qeuc_kr): Remove variables.
+ (syms_of_mac): Don't initialize them.
+ (Vmac_charset_info_alist): New variable.
+ (syms_of_mac): Defvar it.
+ (create_text_encoding_info_alist): New function.
+ (decode_mac_font_name, mac_to_x_fontname)
+ (x_font_name_to_mac_font_name, init_font_name_table): Don't hard
+ code the correspondence among XLFD charsets, Mac script codes, and
+ Emacs coding systems. Use Vmac_charset_info_alist and result of
+ create_text_encoding_info_alist instead.
+ (init_font_name_table) [TARGET_API_MAC_CARBON]: Use Font Manager
+ routines also on Mac OS Classic.
+ (init_font_name_table) [!TARGET_API_MAC_CARBON]:
+ Use add_font_name_table_entry.
+ (mac_do_list_fonts): Regard 0 in XLFD scaleble fields as
+ specified. Derive unspecified scalable fields from specified one.
+ (x_list_fonts): Consider Valternate_fontname_alist.
+ (kDefaultFontSize): Change value from 9 to 12.
+ (XLoadQueryFont): Get decoded font family, font face, and charset
+ from x_font_name_to_mac_font_name. Set full name of loaded font.
+ (mac_unload_font): Free `full_name' member.
+ (x_load_font): Don't try XLoadQueryFont if x_list_fonts returns
+ NULL. Copy full_name member of struct MacFontStruct to that of
+ struct font_info.
+
+2005-04-19 Kim F. Storm <[email protected]>
+
+ * xdisp.c (handle_stop): Set saved_face_id to current face if
+ selective_display_ellipsis_p so ellipsis will be shown in same
+ face as preceding text.
+ (setup_for_ellipsis): Don't set saved_face_id here.
+ (next_element_from_display_vector): Default to saved_face_id.
+
+ * fns.c (Fsafe_get): New function.
+ (syms_of_fns): Defsubr it.
+
+ * lisp.h (Fsafe_get): EXFUN it.
+
+ * xfaces.c (resolve_face_name): Use Fsafe_get to avoid redisplay
+ loops in case of bad face property lists. Limit number of face
+ alias lookups to 10 (in case of face alias loops).
+
+2005-04-18 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct glyph_row): New member overlay_arrow_bitmap.
+ It replaces the corresponding member from struct window, as a
+ window may now show multiple overlay arrows.
+ Remove member overlay_arrow_p, superseeded by overlay_arrow_bitmap.
+
+ * dispnew.c (row_equal_p, update_window_line, scrolling_window):
+ Compare overlay_arrow_bitmap than overlay_arrow_p members.
+
+ * fringe.c (draw_fringe_bitmap): Use overlay_arrow_bitmap from row
+ rather than from window.
+ (update_window_fringes): Compare overlay_arrow_bitmap rather than
+ overlay_arrow_p members.
+ (Ffringe_bitmaps_at_pos): Return fringe overlay_arrow_bitmap name
+ if not default.
+
+ * window.h (struct window): Remove member overlay_arrow_bitmap.
+
+ * window.c (make_window): Don't initialize overlay_arrow_bitmap.
+
+ * xdisp.c (overlay_arrow_string_or_property): Remove PBITMAP arg.
+ Calls changed. Don't check for overlay-arrow-bitmap property here.
+ (overlay_arrow_at_row): Remove PBITMAP arg. Instead, if left
+ fringe is present, return Lisp integer for bitmap (or -1 for default).
+ Fix value of overlay-arrow-bitmap property to be a symbol, use
+ lookup_fringe_bitmap to parse it.
+ (display_line): Change call to overlay_arrow_at_row. Store integer
+ return value as overlay bitmap in row rather than window.
+ Only show overlay arrow if row displays text, or if no other overlay
+ arrow is seen in window (if overlay marker is at point-max).
+
+2005-04-18 Thien-Thi Nguyen <[email protected]>
+
+ * xfaces.c (realize_x_face) [!HAVE_WINDOW_SYSTEM]: Return NULL.
+
+2005-04-18 Lute Kamstra <[email protected]>
+
+ * lread.c (Vloads_in_progress): Static.
+ * fns.c (Vloads_in_progress): Remove extern.
+ (load_in_progress): Add extern.
+ (Frequire): Use load_in_progress instead of Vloads_in_progress.
+
+2005-04-18 Thien-Thi Nguyen <[email protected]>
+
+ * xmenu.c (Fx_popup_menu): Initialize error_name to NULL.
+
+2005-04-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (XTread_socket): Don't beep on keyboard input even if
+ no frame is visible.
+
+2005-04-16 Dan Nicolaescu <[email protected]>
+
+ * term.c (struct keys): Add support for shifted keys.
+
+2005-04-16 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (with_echo_area_buffer): Delete WHICH < 0 case.
+ (set_message): Call with_echo_area_buffer with WHICH = 0.
+ (set_message_1): Erase the echo area buffer first thing.
+ (echo_area_display): Don't clear echo_message_buffer.
+
+2005-04-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * Makefile.in (mac.o): Depend on charset.h and coding.h.
+
+ * mac.c: Include charset.h and coding.h.
+ [TARGET_API_MAC_CARBON] (Qutf_8): Remove extern.
+ [TARGET_API_MAC_CARBON] (cfstring_create_with_string): New function.
+ [TARGET_API_MAC_CARBON] (Fmac_get_preference): Use it.
+
+ * macfns.c [TARGET_API_MAC_CARBON] (Fx_file_dialog): Likewise.
+
+ * image.c [MAC_OSX] (image_load_quartz2d): Likewise.
+
+ * macterm.c (x_autoselect_window_p): Remove variable.
+ (last_window): New variable.
+ (XTreassert_line_highlight, x_change_line_highlight):
+ Remove declarations.
+ (mac_focus_changed, x_detect_focus_change): New functions and
+ declarations.
+ (XTextExtents16, front_emacs_window): Remove function.
+ (mac_focus_frame): New function.
+ (XTmouse_position, do_menu_choice, do_zoom_window, XTread_socket)
+ (mac_check_for_quit_char): Use it instead of front_emacs_window.
+ (x_scroll_bar_report_motion): Obtain window from control owner.
+ (x_make_frame_invisible): Set window manager size hint.
+ (do_mouse_moved): Remove function.
+ (XTread_socket): Move its contents here. Generate select-window
+ event on mouse movement if needed. Use x_detect_focus_change on
+ activate/deactivate events. Don't deiconify frame or invalidate
+ window rectangle when dnd items are dropped.
+ Don't activate/deactivate root control.
+ (frame_highlight, frame_unhighlight): Activate/deactivate root
+ control here.
+ (syms_of_macterm): Delete DEFVAR_BOOL for x_autoselect_window_p.
+
+ * macterm.h (cfstring_create_with_string) [TARGET_API_MAC_CARBON]:
+ New extern.
+
+2005-04-15 Luc Teirlinck <[email protected]>
+
+ * Makefile.in: Define new macro TOOLTIP_SUPPORT.
+ (lisp): Use it.
+ (SOME_MACHINE_LISP): Add tooltip.
+
+2005-04-14 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c [!TARGET_API_MAC_CARBON]: Include MacLocales.h.
+ Don't include TextEncodingConverter.h.
+ (mac_system_script_code, Vmac_system_locale): New variables.
+ (syms_of_mac): Defvar them.
+ (mac_get_system_locale): New function.
+
+ * macfns.c (x_set_name, x_set_title) [!TARGET_API_MAC_CARBON]:
+ Use ENCODE_SYSTEM to encode title bar string.
+ (x_create_tip_frame): Apply 2005-03-18 change for xfns.c.
+ (Fx_file_dialog) [TARGET_API_MAC_CARBON && !MAC_OSX]:
+ Use CFStringGetSystemEncoding to get system default string encoding.
+
+ * macterm.c [!TARGET_API_MAC_CARBON]: Don't include
+ TextEncodingConverter.h.
+
+2005-04-13 Steven Tamm <[email protected]>
+
+ * macterm.c (syms_of_macterm): Remove redundant definition of
+ mac-pass-control-to-system.
+
+2005-04-12 Stefan Monnier <[email protected]>
+
+ * window.c (Fset_window_configuration): Be careful when you choose
+ among several possible points for the new_current_buffer.
+
+2005-04-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * keyboard.c (poll_for_input) [SYNC_INPUT]: Don't call
+ poll_for_input_1. Set interrupt_input_pending to 1 instead.
+ (Qlanguage_change) [MAC_OS]: New variable.
+ (syms_of_keyboard) [MAC_OS]: Intern and staticpro it.
+ (kbd_buffer_get_event) [MAC_OS]: Make event for LANGUAGE_CHANGE_EVENT.
+
+ * macterm.c (mac_keyboard_text_encoding)
+ (current_mac_keyboard_text_encoding): Remove variables.
+ (XTread_socket): Store language-change event if keyboard script change
+ is detected. Don't convert input to `mac_keyboard_text_encoding'.
+ (syms_of_macterm): Delete DEFVAR_INT for mac-keyboard-text-encoding.
+
+ * termhooks.h (enum event_kind) [MAC_OS]: Add LANGUAGE_CHANGE_EVENT.
+
+2005-04-10 Richard M. Stallman <[email protected]>
+
+ * emacs.c (standard_args): Rename --bare-bones to --quick.
+ Add -D aka --basic-display.
+
+ * buffer.c (Fmake_indirect_buffer): Clear out some local variables.
+
+2005-04-09 Richard M. Stallman <[email protected]>
+
+ * keymap.c (where_is_internal): Convert a string used as event type
+ into "(any string)".
+
+ * lread.c (Vloads_in_progress): Not static.
+ * fns.c (Vloads_in_progress): Add extern.
+ (Frequire): Don't do LOADHIST_ATTACH if Vloads_in_progress is nil.
+
+2005-04-09 Thien-Thi Nguyen <[email protected]>
+
+ * dispnew.c (mirror_line_dance): Avoid crash if W2 is null.
+
+2005-04-09 Lute Kamstra <[email protected]>
+
+ * print.c (PRINTPREPARE): Check if the marker PRINTCHARFUN is
+ within the accessible part of the buffer.
+
+2005-04-09 Kim F. Storm <[email protected]>
+
+ * lread.c (readevalloop): Add args START and END as region in
+ current buffer to read. Callers changed.
+ When specified, narrow to this region only when reading,
+ not during eval. Track next point to read from during eval.
+ Also restore point to "real" buffer position before eval.
+ (Feval_region): Don't save excursion and restriction here, and
+ don't narrow to region. Just pass region to readevalloop.
+ Note: Point is now preserved even when PRINTFLAG is nil.
+
+2005-04-08 Kim F. Storm <[email protected]>
+
+ * xdisp.c (syms_of_xdisp): Init overlay-arrow-string to "=>".
+
+2005-04-06 Kim F. Storm <[email protected]>
+
+ * emacs.c (standard_args): Add -Q, --bare-bones, -bare-bones.
+
+2005-04-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (cfdate_to_lisp): Add `const' for variable `epoch_gdate'.
+ (Fmac_get_preference): Doc fix.
+
+ * macfns.c (Fx_create_frame, x_create_tip_frame):
+ Add "fontset-mac" to fallback font/fontsets.
+
+2005-04-04 Kim F. Storm <[email protected]>
+
+ * alloc.c (Fgarbage_collect): Call CHECK_CONS_LIST before and after gc.
+
+ * eval.c (Ffuncall): Always call CHECK_CONS_LIST on entry.
+ Call it again after autoload.
+
+2005-04-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * alloc.c (allocate_string_data): Call BLOCK_INPUT before calling
+ mallopt.
+
+ * ralloc.c (r_alloc_init): Ditto.
+
+2005-04-01 Kenichi Handa <[email protected]>
+
+ * lisp.h (Vascii_upcase_table, Vascii_canon_table)
+ (Vascii_eqv_table): Extern them.
+
+ * casetab.c (set_case_table): If standard is nonzero, setup
+ Vascii_upcase_table, Vascii_canon_table, and Vascii_eqv_table.
+
+ * search.c (looking_at_1): Use current_buffer->case_canon_table,
+ not DOWNCASE_TABLE.
+ (string_match_1): Likewise.
+ (fast_c_string_match_ignore_case): Use Vascii_canon_table, not
+ Vascii_downcase_table.
+ (fast_string_match_ignore_case): Likewise.
+ (search_buffer): Fix checking of boyer-moore usability.
+ (boyer_moore): Calculate translate_prev_byte1/2/3 in advance.
+ No need of tranlating characters in PAT. Fix calculation of
+ simple_translate.
+
+2005-03-31 Stefan Monnier <[email protected]>
+
+ * xterm.c [HAVE_XAW3D]: Include ThreeD.h for XtNbeNiceToColormap.
+ (x_create_toolkit_scroll_bar): Test XtNbeNiceToColormap before using it.
+ Use XtNtopShadowPixel and XtNbottomShadowPixel.
+ (x_set_toolkit_scroll_bar_thumb): Remove ugly old hack that didn't
+ really work and that breaks with some versions of Xaw3d.
+
+2005-03-31 Kenichi Handa <[email protected]>
+
+ * coding.c (syms_of_coding): Fix previous change.
+
+2005-03-30 Stefan Monnier <[email protected]>
+
+ * fileio.c (search_embedded_absfilename): Fix last change.
+
+2005-03-25 Kenichi Handa <[email protected]>
+
+ * coding.c (syms_of_coding): Suggest to use set-coding-category in
+ the docstring of coding-category-list.
+
+2005-03-31 Kim F. Storm <[email protected]>
+
+ * keyboard.c (Qmouse_fixup_help_message): New var.
+ (syms_of_keyboard): Intern and staticpro it.
+ (show_help_echo): Apply mouse-fixup-help-message to help string.
+
+2005-03-30 Kim F. Storm <[email protected]>
+
+ * xdisp.c (display_line): Allow multiple overlay arrows in window.
+
+2005-03-28 Stefan Monnier <[email protected]>
+
+ * fileio.c (Fexpand_file_name): Use IS_DEVICE_SEP.
+ (file_name_absolute_p): New fun, extracted from Ffile_name_absolute_p.
+ (Ffile_name_absolute_p): Use it.
+ (search_embedded_absfilename): New fun, extracted from
+ Fsubstitute_in_file_name. Use file_name_absolute_p.
+ Free the pw data after use.
+ (Fsubstitute_in_file_name): Use it.
+ After cutting a prefix, re-check file-name-handler.
+
+2005-03-26 Lennart Borgman <[email protected]>
+
+ * w32term.h (x_output): Add focus_state.
+
+ * w32term.c (x_focus_changed, w32_detect_focus_change): New functions.
+ (w32_read_socket) <WM_SETFOCUS>: Call w32_detect_focus_change.
+
+2005-03-25 Stefan Monnier <[email protected]>
+
+ * minibuf.c (Fminibuffer_complete_and_exit, Fself_insert_and_exit):
+ Use Fexit_minibuffer.
+ (Fexit_minibuffer): Mark it as no-return, deactivate the mark.
+
+2005-03-24 Stefan Monnier <[email protected]>
+
+ * dired.c (Ffile_attributes): Add a missing gcpro.
+
+ * alloc.c (make_number): The arg can be bigger than `int'.
+ * lisp.h (make_number): Make prototype more precise.
+
+ * process.c, dired.c (Vfile_name_coding_system)
+ (Vdefault_file_name_coding_system):
+ * callproc.c (Vdoc_file_name, Vfile_name_coding_system)
+ (Vdefault_file_name_coding_system): Remove unused declarations.
+
+2005-03-24 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (create_and_show_popup_menu): Just remove menu and return
+ if it failed to pop up (Gnome "show pointer on ctrl" option makes
+ menus fail to pop up).
+
+2005-03-24 Stefan Monnier <[email protected]>
+
+ * xdisp.c (get_next_display_element): Also use `\ ' & `\-' for latin-9.
+ Just prepend a backslash without replacing the NBSP by an SPC.
+
+2005-03-22 Kim F. Storm <[email protected]>
+
+ * xfaces.c (lookup_derived_face): Add arg SIGNAL_P.
+ * dispextern.h (lookup_derived_face): Fix prototype.
+ * msdos.c (XMenuActivate): Fix call to lookup_derived_face.
+
+ * xdisp.c (handle_single_display_spec): Derive left-fringe and
+ right-fringe face from fringe face.
+
+ * fringe.c (draw_fringe_bitmap_1, Fset_fringe_bitmap_face):
+ Derive face from fringe face.
+
+2005-03-22 Jan Dj,Ad(Brv <[email protected]>
+
+ * xrdb.c (x_load_resources): Undo previous change (2005-03-18).
+
+2005-03-22 David Kastrup <[email protected]>
+
+ * textprop.c (Fnext_char_property_change)
+ (Fprevious_char_property_change): Allow marker as limit.
+ (Fnext_single_char_property_change)
+ (Fprevious_single_char_property_change): Check that limit is a
+ number in strings.
+ (Fnext_single_char_property_change): Coerce position to integer.
+ (Fprevious_single_char_property_change): Same here.
+
+2005-03-21 Thien-Thi Nguyen <[email protected]>
+
+ * s/openbsd.h (LD_SWITCH_SYSTEM_tmp): Define if undefined.
+
+2005-03-19 Stefan Monnier <[email protected]>
+
+ * frame.c (Fignore_event): Remove.
+ (syms_of_frame): Don't defsubr it.
+
+ * keyboard.c (keys_of_keyboard): Just use `ignore' instead of the
+ redundant `ignore-event'.
+
+2005-03-19 Eli Zaretskii <[email protected]>
+
+ * unexec.c (write_segment, unexec): Move these functions to avoid
+ forward references (which cause errors with "gcc -gcoff").
+
+2005-03-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_create_tip_frame): Remove setting of Vx_resource_name so
+ that it doesn't become "tooltip". The specbind is enough.
+
+ * xrdb.c (x_load_resources): Use different char *helv when I18N
+ is present.
+
+2005-03-17 Kenichi Handa <[email protected]>
+
+ * coding.c (syms_of_coding): Docstring of coding-category-list fixed.
+
+2005-03-17 Stefan Monnier <[email protected]>
+
+ * xfaces.c (x_update_menu_appearance) [HAVE_X_I18N]:
+ Use xic_create_fontsetname even for non-Motif menus.
+ Don't forget to free the fontsetname.
+
+ * xfns.c (xic_create_fontsetname): Add a final catch-all font pattern.
+
+2005-03-17 Richard M. Stallman <[email protected]>
+
+ * dispnew.c (mirror_line_dance): Set W2 according to FRAME_FROM.
+
+ * fileio.c (Fcopy_file, Frename_file, Fadd_name_to_file)
+ (Fmake_symbolic_link): Use G to read the new file name.
+
+ * callint.c (Finteractive): Document G option.
+ (Fcall_interactively): Implement G option.
+
+ * buffer.c (buffer_lisp_local_variables): New function,
+ broken out from Fbuffer_local_variables.
+ (clone_per_buffer_values): Use buffer_lisp_local_variables.
+
+2005-03-17 Stefan Monnier <[email protected]>
+
+ * xfns.c (xic_create_fontsetname): Add `motif' argument.
+ Always return a freshly allocated string.
+ (xic_create_xfontset): Adjust call.
+
+ * xfaces.c (x_update_menu_appearance) [USE_MOTIF]:
+ Use xic_create_fontsetname to create a fontset so utf-8 locales work.
+ (dump_realized_face): Fix warning.
+
+ * emacs.c (Fkill_emacs): YAILOM.
+
+ * frame.c (Fignore_event): Fix ancient obscure C-u handling bug.
+
+2005-03-17 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (HASHKEY_TERMINAL): Remove.
+ (HASHKEY_MAX_NID): New macro.
+ (xrm_q_get_resource_1): Rename from xrm_q_get_resource. Add extra
+ argument.
+ (xrm_q_get_resource): Call xrm_q_get_resource_1 with extra argument.
+ (xrm_create_database, xrm_q_put_resource)
+ (xrm_merge_string_database, xrm_q_get_resource_1)
+ (xrm_q_get_resource): Change resource database representation so
+ that it may not use multiple hash tables for a single database.
+ [TARGET_API_MAC_CARBON] (xrm_cfproperty_list_to_value): YAILOM.
+
+2005-03-16 Stefan Monnier <[email protected]>
+
+ * xmenu.c (ENCODE_MENU_STRING) [HAVE_X_I18N]: Use ENCODE_SYSTEM.
+
+ * coding.h (ENCODE_SYSTEM, DECODE_SYSTEM) [!WINDOWSNT]: Use the
+ locale-coding-system, as was already done for WINDOWSNT.
+
+ * keyboard.c (read_char): Only do the 7-bit-meta -> 27-bit-meta
+ translation for chars in the 0-255 range.
+
+2005-03-16 Lute Kamstra <[email protected]>
+
+ * floatfns.c (Ffloor): Doc fix.
+
+2005-03-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c: Include macterm.h instead of directly including Carbon.h.
+ [TARGET_API_MAC_CARBON] (Qstring, Qnumber, Qboolean, Qdate, Qdata)
+ (Qarray, Qdictionary): New variables.
+ (syms_of_mac) [TARGET_API_MAC_CARBON]: Initialize them.
+ [TARGET_API_MAC_CARBON] (Qutf_8): Add extern.
+ [TARGET_API_MAC_CARBON] (DECODE_UTF_8): New macro.
+ [TARGET_API_MAC_CARBON] (struct cfdict_context): New struct used
+ in callback for CFDictionaryApplyFunction.
+ [TARGET_API_MAC_CARBON] (cfdata_to_lisp, cfstring_to_lisp)
+ (cfnumber_to_lisp, cfdate_to_lisp, cfboolean_to_lisp)
+ (cfobject_desc_to_lisp, cfdictionary_add_to_list)
+ (cfdictionary_puthash, cfproperty_list_to_lisp): New functions.
+ [TARGET_API_MAC_CARBON] (Fmac_get_preference): New function.
+ (syms_of_mac) [TARGET_API_MAC_CARBON]: Defsubr it.
+ (P, LOOSE_BINDING, SINGLE_COMPONENT, HASHKEY_TERMINAL): New macro.
+ (skip_white_space, parse_comment, parse_include_file)
+ (parse_binding, parse_component, parse_resource_name, parse_value)
+ (parse_resource_line, xrm_create_database, xrm_q_put_resource)
+ (xrm_merge_string_database, xrm_q_get_resource, xrm_get_resource)
+ (xrm_cfproperty_list_to_value, xrm_get_preference_database):
+ New functions.
+
+ * macfns.c (mac_get_rdb_resource): Remove function.
+ (x_get_string_resource): Use xrm_get_resource.
+
+ * macgui.h (XrmDatabase): Typedef to Lisp_Object.
+
+ * macterm.c (x_list_fonts): FONT-LIST-CACHE is now cadr part of
+ name_list_element.
+ (mac_make_rdb): Create resource database from preferences and
+ argument string.
+ (mac_term_init): Save resource database to cddr part of
+ name_list_element.
+
+ * macterm.h (xrm_merge_string_database, xrm_get_resource)
+ (xrm_get_preference_database): Add externs.
+ [TARGET_API_MAC_CARBON] (cfdata_to_lisp, cfstring_to_lisp)
+ (cfnumber_to_lisp, cfdate_to_lisp, cfboolean_to_lisp)
+ (cfobject_desc_to_lisp, cfproperty_list_to_lisp): Likewise.
+
+ * process.c (init_process): Change `#ifdef DARWIN' to `#if
+ defined (DARWIN) || defined (MAC_OSX)'.
+
+ * s/darwin.h (DARWIN): Don't define.
+
+2005-03-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (Qhyper, Qsuper, Qmeta, Qalt, Qctrl, Qcontrol, Qshift):
+ Remove unused variables.
+ (syms_of_macfns): Don't initialize them. Likewise for
+ Qface_set_after_frame_default. Defvar and initialize
+ Vx_window_horizontal_drag_shape.
+ (x_set_mouse_color): Change mouse pointer shape.
+ (mac_window) [!MAC_OSX]: Create root control.
+ (Fx_create_frame): Remove initializations of mouse pointer shapes.
+ (hourglass_started): New function (from xfns.c).
+ (start_hourglass, cancel_hourglass): Put function body in #ifdef
+ MAC_OSX.
+ (show_hourglass) [TARGET_API_MAC_CARBON]: Create progress
+ indicator for each non-tooltip frame if needed, and show it.
+ (hide_hourglass) [TARGET_API_MAC_CARBON]: Hide progress indicators.
+
+ * macgui.h [!TARGET_API_MAC_CARBON]: Include Appearance.h and
+ Controls.h. Use ThemeCursor instead of CursHandle.
+
+ * macterm.c (activate_scroll_bars, deactivate_scroll_bars):
+ Remove functions and declarations.
+ (mac_set_colors): Take argument for saving background color.
+ All callers changed.
+ (XDrawLine, XClearArea, mac_draw_bitmap, XFillRectangle)
+ (mac_draw_rectangle, mac_draw_string_common): Save and Restore
+ background color.
+ (x_update_end, mac_do_track_drag): Don't reset background color.
+ (mac_define_frame_cursor) [!TARGET_API_MAC_CARBON]:
+ Use SetThemeCursor.
+ (x_set_window_size) [TARGET_API_MAC_CARBON]: Move progress
+ indicator control to the upper-right corner of the window.
+ (arrow_cursor) [!TARGET_API_MAC_CARBON]: Remove variable.
+ (do_init_managers) [!TARGET_API_MAC_CARBON]: Don't initialize it.
+ (do_window_update): Update controls after updating content area.
+ (mac_handle_window_event): Remove unused extern.
+ (XTread_socket): Check both control handle and control part code
+ to determine whether a scroll bar is clicked. Activate/deactivate
+ root control instead of contained scroll bar controls.
+ (make_mac_terminal_frame): Use ThemeCursor constants.
+
+ * macterm.h (struct mac_output) [TARGET_API_MAC_CARBON]:
+ New member hourglass_control.
+ (HOURGLASS_WIDTH, HOURGLASS_HEIGHT): New defines.
+ (activate_scroll_bars, deactivate_scroll_bars): Remove declarations.
+
+2005-03-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (keycode_to_xkeysym_table): Change mapping so that it
+ coincides with that in Apple X11 except `clear', `enter' on
+ laptops, and fn + `enter' on laptops.
+
+2005-03-12 Stefan Monnier <[email protected]>
+
+ * xmenu.c (ENCODE_MENU_STRING): Explicitly use string_make_unibyte.
+ (list_of_panes, list_of_items, Fx_popup_menu): Use XCAR/XCDR.
+ (digest_single_submenu, xmenu_show): Use ENCODE_MENU_STRING.
+
+ * xfns.c (xic_defaut_fontset): New constant.
+ (xic_create_fontsetname): New function.
+ Extracted from create_frame_xic. Try to generate a slightly
+ better fontset.
+ (xic_create_xfontset): Use it.
+ (create_frame_xic): Simplify.
+
+2005-03-11 Stefan Monnier <[email protected]>
+
+ * fileio.c (Fmake_symbolic_link): Fix last change.
+
+2005-03-11 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Frename_file, Fadd_name_to_file)
+ (Fmake_symbolic_link): If NEWNAME or LINKNAME is a directory,
+ expand the basename of FILE relative to it.
+
+2005-03-11 Kenichi Handa <[email protected]>
+
+ * fileio.c (Finsert_file_contents): Call Fcheck_coding_system
+ before calling setup_coding_system so that autoloading of a coding
+ system work.
+
+2005-03-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (hourglass_started): New function.
+
+ * dispextern.h: Declare hourglass_started.
+
+ * keyboard.c (Fexecute_extended_command): Restart hourglass
+ after call to Fcompleting_read if already started.
+
+ * gtkutil.c (xg_update_scrollbar_pos): Call x_sync so that the
+ GTK main loop is entered in xterm.c, thus doing the redraw.
+
+2005-03-10 Kim F. Storm <[email protected]>
+
+ * xdisp.c (pos_visible_p): Fix X value in last line of buffer.
+
+2005-03-08 Kenichi Handa <[email protected]>
+
+ * frame.c (x_set_font): Call set_default_ascii_font if an
+ available font is found.
+
+ * fontset.c (set_default_ascii_font): New function.
+ (syms_of_fontset): Don't set FONTSET_ASCII (Vdefault_fontset) here.
+
+ * fontset.h (set_default_ascii_font): Extern it.
+
+2005-03-07 Kim F. Storm <[email protected]>
+
+ * xdisp.c (CLEAR_IMAGE_CACHE_COUNT): New const.
+ (clear_image_cache_count): New var.
+ (redisplay_internal): Don't clear face and image caches in the
+ middle of redisplay; do it afterwards.
+
+ * blockinput.h (TOTALLY_UNBLOCK_INPUT): Avoid dangling else.
+
+ * xdisp.c (notice_overwritten_cursor): Check that phys_cursor.vpos
+ is valid. If not, clear phys_cursor_on_p and return.
+
+2005-03-07 Andreas Schwab <[email protected]>
+
+ * blockinput.h (UNBLOCK_INPUT_TO): Always call UNBLOCK_INPUT.
+
+2005-03-06 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (Ftop_level): Let Fthrow deal with UNBLOCK_INPUT.
+
+ * eval.c (unwind_to_catch): Use UNBLOCK_INPUT_TO.
+ (Feval, Ffuncall): Use CHECK_CONS_LIST.
+
+ * lisp.h (CHECK_CONS_LIST): New macro (two definitions).
+
+ * blockinput.h (UNBLOCK_INPUT_TO): New macro.
+ (TOTALLY_UNBLOCK_INPUT): Handle a pending signal if any.
+
+2005-03-05 Juri Linkov <[email protected]>
+
+ * emacs.c (USAGE1): Replace Info node name "command arguments"
+ with "emacs invocation".
+ (USAGE3): Fix usage of `--color=MODE' which actually doesn't
+ allow arguments `--color' and `MODE' to be separated by space.
+ Add --no-blinking-cursor, -nbc.
+ (standard_args): Add -nbc, --no-blinking-cursor.
+
+2005-03-04 Thien-Thi Nguyen <[email protected]>
+
+ * s/vms.h: Define NO_HYPHENS_IN_FILENAMES.
+ * s/vms4-4.h, s/vms5-5.h: Undefine NO_HYPHENS_IN_FILENAMES.
+ * fileio.c (Fexpand_file_name) [VMS]:
+ Use NO_HYPHENS_IN_FILENAMES, not VMS4_4.
+ * doc.c (munge_doc_file_name) [VMS]: Likewise.
+ (Fsnarf_documentation): Call munge_doc_file_name.
+
+2005-03-04 Thien-Thi Nguyen <[email protected]>
+
+ * s/vms.h (FILE_SYSTEM_CASE): New macro.
+ * fileio.c (Fexpand_file_name) [VMS]: Don't upcase the name
+ "manually"; this is now handled generally via FILE_SYSTEM_CASE.
+
+2005-03-04 YAMAMOTO Mitsuharu <[email protected]>
+
+ * emacs.c (main): Change `#ifdef HAVE_CARBON' to `#if
+ defined (MAC_OSX) && defined (HAVE_CARBON)'.
+
+ * image.c [!MAC_OSX && TARGET_API_MAC_CARBON]: Include QuickTime.h.
+
+ * mac.c [!MAC_OSX && HAVE_CARBON]: Include Carbon.h.
+ [!MAC_OSX] (select) [TARGET_API_MAC_CARBON]: Use ReceiveNextEvent.
+ (posix_pathname_to_fsspec, fsspec_to_posix_pathname): New functions.
+ (mac_clear_font_name_table): Move extern to macterm.h.
+
+ * macfns.c (install_window_handler): Move extern to macterm.h.
+ (Fx_file_dialog): Check STRINGP (default_filename) to see it is
+ valid. Don't check !NILP (dir) because it is already checked with
+ CHECK_STRING.
+ (Fx_file_dialog) [!MAC_OSX]: Use FSSpec instead of FSRef for
+ specifying the default location and obtaining the selected filename.
+
+ * macgui.h [!MAC_OSX && HAVE_CARBON]: Include Carbon.h.
+
+ * macmenu.c [TARGET_API_MAC_CARBON]: Don't include headers that
+ are included via Carbon.h.
+
+ * macterm.c [TARGET_API_MAC_CARBON && !MAC_OSX]:
+ Define USE_CARBON_EVENTS to 1.
+ (qd) [__MRC__ && TARGET_API_MAC_CARBON]: Don't declare.
+ (x_free_frame_resources): Call remove_window_handler for
+ non-tooltip windows.
+ [TARGET_API_MAC_CARBON]: Don't include headers that are included
+ via Carbon.h.
+ [TARGET_API_MAC_CARBON] (mac_do_track_dragUPP)
+ (mac_do_receive_dragUPP): New variables.
+ (mac_handle_service_event, init_service_handler): Put declarations
+ and definitions in #ifdef MAC_OSX.
+ (install_window_handler) [TARGET_API_MAC_CARBON]: Create UPPs for
+ drag-and-drop handler functions and register them.
+ (remove_window_handler): New function.
+ (do_ae_open_documents, mac_do_receive_drag) [!MAC_OSX]:
+ Use fsspec_to_posix_pathname.
+ (main): Change #if !TARGET_API_MAC_CARBON to #ifdef MAC_OS8.
+ (XTread_socket) [!MAC_OSX]: Don't pass keyboard events to TSM.
+ [MAC_OS8] (make_mac_terminal_frame) [TARGET_API_MAC_CARBON]:
+ Set default cursors.
+ (mac_initialize) [USE_CARBON_EVENTS && !MAC_OSX]: Don't call
+ init_service_handler or init_quit_char_handler.
+ (mac_initialize) [!MAC_OSX]: Don't call MakeMeTheFrontProcess.
+
+ * macterm.h (install_window_handler, remove_window_handler)
+ (posix_pathname_to_fsspec, fsspec_to_posix_pathname)
+ (mac_clear_font_name_table): New externs.
+
+2005-03-03 Thien-Thi Nguyen <[email protected]>
+
+ * fileio.c (FILE_SYSTEM_CASE): Define macro if not already defined.
+ (Ffile_name_directory): Use FILE_SYSTEM_CASE unconditionally.
+ (Fexpand_file_name): Likewise.
+
+2005-03-03 Thien-Thi Nguyen <[email protected]>
+
+ * emacs.c (Fkill_emacs): Use EXIT_SUCCESS;
+ no longer special-case VMS. Add bogus return value.
+
+2005-03-02 Kim F. Storm <[email protected]>
+
+ * dispextern.h (XASSERTS): Define to 0 if not already defined.
+ (xassert) [!XASSERTS]: Define dummy version.
+
+2005-03-02 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): YABX (yet another bogus xassert).
+ Reported by David Kastrup.
+
+2005-03-01 Ehud Karni <[email protected]>
+
+ * xdisp.c (get_next_display_element): Fix control and escape
+ glyph from display vector.
+
+2005-03-01 Stefan Monnier <[email protected]>
+
+ * keyboard.c (Fposn_at_x_y): Check integerness of X and Y.
+
+2005-02-27 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (fast_find_position): Rename END to BEG.
+ (syms_of_xdisp) <menu-bar-update-hook>: Doc fix.
+
+2005-02-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_resize_outer_widget): Remove unneeded call to
+ gtk_window_resize and x_wm_set_size_hint.
+
+2005-02-25 Kim F. Storm <[email protected]>
+
+ * dispextern.h (OVERLAY_STRING_CHUNK_SIZE): Increase from 3 to 16.
+
+ * xdisp.c (init_from_display_pos): Don't read past end of
+ it->overlay_strings array.
+
+2005-02-25 Stephan Stahl <[email protected]> (tiny change)
+
+ * buffer.c (syms_of_buffer): Fix typo.
+
+2005-02-23 Lute Kamstra <[email protected]>
+
+ * buffer.c (Foverlay_buffer): Doc fix.
+
+2005-02-22 Kim F. Storm <[email protected]>
+
+ * minibuf.c (Ftry_completion, Fall_completions): Allow both string
+ and symbol keys in alists and hash tables.
+
+ * xdisp.c (fast_find_position): Fix search for start of overlay.
+
+2005-02-21 Kim F. Storm <[email protected]>
+
+ * window.c (window_scroll_pixel_based): When scrolling backwards,
+ handle partial visible line at end of window even when we hit PT.
+
+2005-02-21 Stefan Monnier <[email protected]>
+
+ * keymap.h: Declare Fcurrent_active_maps, used in doc.c.
+
+2005-02-21 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_vertically_backward): Eliminate two xasserts.
+ I think those asserts are bogus if buffer contains invisible text
+ or images.
+
+2005-02-21 David Kastrup <[email protected]>
+
+ * gtkutil.c (xg_create_frame_widgets): UNBLOCK_INPUT on error.
+
+2005-02-20 Kim F. Storm <[email protected]>
+
+ * xdisp.c (pos_visible_p): Be sure to move to the specified
+ position. Always get the full ascent / descent of the
+ corresponding row, to return reliable rtop and rbot values.
+ (back_to_previous_visible_line_start): Fix 2005-01-18 change.
+ Must look one character back, as back_to_previous_line_start
+ returns position after the newline.
+ (move_it_vertically_backward): Fix heuristic for when to move further
+ back in case line_height * 2/3 is larger than window height.
+ (cursor_row_fully_visible_p): Rename make_cursor_line_fully_visible_p
+ as it does not do anything anymore. Add arg current_matrix_p to
+ use current matrix rather than desired matrix when set.
+ (try_cursor_movement): Don't scroll to make cursor row fully
+ visible if cursor didn't move. This avoids unexpected recentering
+ in case of blinking cursor or accepting process output.
+ Use current matrix to check cursor row visibility.
+ (redisplay_window): Fix whether to recenter or move to top in case
+ cursor line is taller than window height.
+ (find_first_unchanged_at_end_row): Stop search if we reach a row
+ which not enabled (instead of abort).
+
+2005-02-18 Kim F. Storm <[email protected]>
+
+ * xfaces.c (Finternal_set_lisp_face_attribute): Allow :color property
+ to be nil in a :box attribute value list; customize prints that
+ as lisp value when no box color is specified.
+
+ * .gdbinit (pitx, pit): Pretty print display iterator.
+ (prowx, prow): Pretty print glyph row.
+ (pcursorx, pcursor): Pretty print a window cursor.
+ (pwinx, pwin): Pretty print struct window.
+
+2005-02-18 Stefan Monnier <[email protected]>
+
+ * alloc.c (BLOCK_BYTES): Harmless typo.
+
+2005-02-17 Andreas Schwab <[email protected]>
+
+ * xfns.c (hack_wm_protocols): Use correct type for last parameter
+ of XGetWindowProperty to avoid aliasing issues.
+ (Fx_window_property): Likewise.
+
+ * xselect.c (Fx_disown_selection_internal): Use union of struct
+ input_event and struct selection_input_event to avoid aliasing issues.
+
+ * xterm.c (handle_one_xevent): Use union of struct input_event and
+ struct selection_input_event to avoid aliasing issues.
+ (SET_SAVED_MENU_EVENT): Adapt reference to inev.
+
+2005-02-17 Kim F. Storm <[email protected]>
+
+ * dispextern.h (enum it_method): New enum.
+ (GET_FROM_*): Its members.
+ (struct it): Change member method from function pointer to enum.
+
+ * xdisp.c (check_it, init_from_display_pos, handle_stop)
+ (setup_for_ellipsis, handle_single_display_spec)
+ (handle_composition_prop, next_overlay_string)
+ (get_overlay_strings, reseat_1, reseat_to_string)
+ (next_element_from_ellipsis, BUFFER_POS_REACHED_P)
+ (in_display_vector_p, display_line, get_next_display_element):
+ Change it->method from function pointer to enum.
+ (get_next_element): New array to map it->method to function.
+ (get_next_display_element): Use it.
+ (set_iterator_to_next): Use switch instead of if/else chain.
+
+2005-02-15 Benjamin Riefenstahl <[email protected]>
+
+ * w32select.c: Summary: Thorough rework to implement Unicode
+ clipboard operations and delayed rendering.
+
+ Drop last_clipboard_text and related code, keep track of
+ ownership via clipboard_owner instead. Drop old #if0 sections.
+
+ (DEFAULT_LCID, ANSICP, OEMCP, QUNICODE, QANSICP, QOEMCP)
+ (clipboard_owner, modifying_clipboard, cfg_coding_system)
+ (cfg_codepage, cfg_lcid, cfg_clipboard_type, current_text)
+ (current_coding_system, current_requires_encoding)
+ (current_num_nls, current_clipboard_type, current_lcid):
+ New static variables.
+
+ (convert_to_handle_as_ascii, convert_to_handle_as_coded)
+ (render, render_all, run_protected, lisp_error_handler)
+ (owner_callback, create_owner, setup_config)
+ (enum_locale_callback, cp_from_locale, coding_from_cp):
+ New local functions.
+
+ (term_w32select, globals_of_w32select): New global functions.
+
+ (Fw32_set_clipboard_data): Ignore parameter FRAME, use
+ clipboard_owner instead. Use delayed rendering and provide
+ all text formats. Provide CF_LOCALE if necessary.
+
+ (Fw32_get_clipboard_data): Handle CF_UNICODETEXT and
+ CF_LOCALE. Fall back to CF_TEXT, if CF_UNICODETEXT is not
+ available. Force DOS line-ends for decoding.
+
+ (Fx_selection_exists_p): Handle CF_UNICODETEXT.
+
+ (syms_of_w32select): Init and register new variables.
+
+ * w32.h: Add prototypes for globals_of_w32select and
+ term_w32select. Make the neighboring K&R declarations into
+ prototypes, too.
+
+ * emacs.c: Include w32.h to get function prototypes.
+ (main): Call globals_of_w32select.
+
+ * w32.c (term_ntproc): Call term_w32select.
+
+ * s/ms-w32.h: Guard MSC-specific #pragmas with an #ifdef.
+
+2005-02-16 Kim F. Storm <[email protected]>
+
+ * xdisp.c (BUFFER_POS_REACHED_P): Return true if pos reached and
+ at end of display vector.
+
+2005-02-15 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (get_next_display_element): Fix escape-glyph criterion
+ for mode and header lines.
+
+ * lread.c (syms_of_lread) <user-init-file>: Doc fix.
+
+ * keymap.h (describe_map_tree): Change decl.
+
+ * keyboard.c (command_loop_1): Always use safe_run_hooks
+ to run Qdeferred_action_function.
+
+ * keymap.c (describe_map_tree): New arg MENTION_SHADOW. Calls changed.
+ (describe_map, describe_vector): Likewise. When it's 1,
+ don't omit shadowed bindings, instead mark them as shadowed.
+
+ * doc.c (Fsubstitute_command_keys): Compute list of shadowing maps
+ for describe_map_tree. Pass 1 for MENTION_SHADOW.
+
+ * data.c (Fsetq_default): Allow no arg case.
+
+2005-02-14 Kenichi Handa <[email protected]>
+
+ * coding.c (encode_coding_string): Always return a unibyte string.
+ If NOCOPY is nonzero and there's no need of encoding, make STR
+ unibyte directly.
+
+ * xselect.c (lisp_data_to_selection_data): If OBJ is a non-ASCII
+ multibyte string, signal an error instead of aborting.
+
+2005-02-12 Dan Nicolaescu <[email protected]>
+
+ * keyboard.c: If HAVE_FCNTL_H include fcntl.h.
+
+2005-02-12 Kim F. Storm <[email protected]>
+
+ * xdisp.c (expose_window): Don't fix overlaps for mode lines.
+
+2005-02-10 Kim F. Storm <[email protected]>
+
+ * xdisp.c (try_window_id): Set first_unchanged_at_end_row to NULL
+ if it moves outside window or it doesn't display text.
+
+2005-02-09 Kim F. Storm <[email protected]>
+
+ * undo.c (Fprimitive_undo): Check that undo function does not
+ switch buffer.
+
+2005-02-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * xselect.c (selection_data_to_lisp_data): For the special case
+ type == XA_ATOM, data contains array of int, not array of Atom.
+ (x_property_data_to_lisp, selection_data_to_lisp_data):
+ Comment update: data must be array of int for format == 32.
+
+2005-02-08 Stefan Monnier <[email protected]>
+
+ * undo.c (Fprimitive_undo): Check veracity of delta,start,end.
+
+2005-02-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (Fx_change_window_property): Use long array when format is 32.
+ (Fx_window_property): If format is 32 and long is bigger than 32 bits,
+ convert long array returned from XGetWindowProperty to an int array.
+ (x_set_tool_bar_lines): Check that width and height is greater than
+ zero before clearing area.
+
+ * xselect.c (x_reply_selection_request): Pass long array to
+ XChangeProperty so that 64 bit longs are handeled correctly.
+ (x_get_window_property): If format is 32 and long is bigger than 32
+ bits convert data from XGetWindowProperty from long array to int array.
+ (lisp_data_to_selection_data): When the input is a vector and the
+ format is 32, allocate a long array even if long is bigger than 32 bits.
+ (x_fill_property_data): Use char, short and long as the man page
+ for XChangeProperty specifies. This way the data returned is OK for
+ both 32 and 64 bit machines.
+ (x_handle_dnd_message): Calculate size correctly even for 64 bit
+ machines.
+ (Fx_send_client_event): Undo change from 2005-02-05,
+ x_fill_property_data now handles that case.
+
+ * xfns.c (Fx_backspace_delete_keys_p): Add comment about the
+ reason for the approach in the code.
+
+2005-02-07 Kim F. Storm <[email protected]>
+
+ * undo.c (Fprimitive_undo): Record max one dummmy apply element.
+
+2005-02-06 Richard M. Stallman <[email protected]>
+
+ * eval.c (Frun_hook_with_args)
+ (Frun_hook_with_args_until_success)
+ (Frun_hook_with_args_until_failure): Doc fixes.
+
+2005-02-05 Andreas Schwab <[email protected]>
+
+ * sysdep.c (sys_subshell): Properly terminate execlp argument list.
+
+2005-02-05 Jan Dj,Ad(Brv <[email protected]>
+
+ * xselect.c (Fx_send_client_event, x_handle_dnd_message): Handle
+ the longs in a XClientMessageEvent correctly when long is 64 bits.
+
+2005-02-05 Eli Zaretskii <[email protected]>
+
+ * xfaces.c (face_color_supported_p): Use HAVE_WINDOW_SYSTEM
+ instead of HAVE_X_WINDOWS, for non-X windowed sessions.
+
+2005-02-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (menubar_selection_callback): Force out GTK buffered
+ events so the menu event comes after them. This is to prevent sit-for
+ from exiting on buffered events directly after a menu selection,
+ lisp code for Help => About Emacs uses sit-for.
+
+ * gtkutil.c (create_menus): Connect selection-done event instead of
+ the deactivate event to deactivate_cb. This will make the last
+ leave event come before the call to deactivate_cb, so the leave
+ event does not make sit-for exit after a menu selection.
+
+2005-02-03 Kim F. Storm <[email protected]>
+
+ * dispnew.c (build_frame_matrix_from_leaf_window)
+ [!GLYPH_DEBUG]: Fix xassert.
+
+ * xfaces.c (x_free_gc) [!GLYPH_DEBUG]: Fix xassert.
+
+ * xfns.c (unwind_create_frame) [!GLYPH_DEBUG]: Fix xassert.
+
+2005-02-03 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c: Use MAC_OS_X_VERSION_MAX_ALLOWED to conditionalize by
+ the compiling OS version.
+
+ * macfns.c (x_create_tip_frame): Likewise.
+
+ * macterm.c (mac_draw_string_common, x_make_frame_visible): Likewise.
+
+2005-02-03 Richard M. Stallman <[email protected]>
+
+ * xterm.c (x_error_quitter): On GCC 3 and up, specify noinline.
+
+ * xdisp.c (echo_area_display): Clear echo_message_buffer.
+
+ * buffer.c (Fbury_buffer): Doc fix.
+
+2005-02-02 Steven Tamm <[email protected]>
+
+ * macfns.c (unwind_create_frame): Fix compile error due to
+ xassert being uncondition, but predicate is.
+ * dispnew.c (update_window): Fix compile error due to
+ xassert being uncondition, but predicate is.
+
+2005-02-02 Miles Bader <[email protected]>
+
+ * dispextern.h (xassert): Enable unconditionally.
+
+2005-02-02 Kim F. Storm <[email protected]>
+
+ * undo.c (Fprimitive_undo): Fix dummy apply undo entry.
+
+2005-02-02 Kenichi Handa <[email protected]>
+
+ * casefiddle.c (casify_object): Enable changing characters of
+ different byte length.
+ (casify_region): Fix loop condition, args to replace_range_2, and
+ update opoint_byte.
+
+ * insdel.c (replace_range_2): Fix bugs in adjusting markers and point.
+
+2005-02-01 Kim F. Storm <[email protected]>
+
+ * xdisp.c (back_to_previous_visible_line_start): Reset iterator
+ stack before calling handle_display_prop.
+
+2005-01-31 Kim F. Storm <[email protected]>
+
+ * undo.c (Qapply): New lisp var.
+ (syms_of_undo): Intern and staticpro it.
+ (Fprimitive_undo): Support formats (apply FUNNAME . ARGS) and
+ (apply DELTA BEG END FUNNAME . ARGS) instead of (FUNNAME . ARGS).
+
+ * buffer.c (syms_of_buffer) <buffer-undo-list>: Doc fix.
+
+2005-01-30 Jesper Harder <[email protected]>
+
+ * macterm.c (syms_of_macterm) <mac-reverse-ctrl-meta>
+ <mac-emulate-three-button-mouse>: Fix docstring indentation.
+
+2005-01-29 Luc Teirlinck <[email protected]>
+
+ * undo.c (syms_of_undo) <undo-outer-limit>: Doc update.
+ Increase value to 3 Meg.
+
+2005-01-29 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (show_hourglass): Use FRAME_X_WINDOW as parent for GTK,
+ button events are not received otherwise.
+
+2005-01-29 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer) <buffer-undo-list>: Doc fix.
+
+ * undo.c (Fprimitive_undo): Handle (FUNNAME . ARGS) by calling FUNNAME.
+
+2005-01-28 Stefan Monnier <[email protected]>
+
+ * keymap.c (access_keymap): YAILOM.
+
+2005-01-27 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_phys_cursor_geometry): New function to calculate
+ phys cursor position and size for hollow cursor. Position is
+ aligned with get_glyph_string_clip_rect and ensures that a hollow
+ cursor is shown, even when the actual glyph is not visible.
+
+ * dispextern.h (get_phys_cursor_geometry): Add prototype.
+
+ * xterm.c (x_clip_to_row): Ensure y >= 0.
+ (x_draw_hollow_cursor): Use get_phys_cursor_geometry.
+
+ * w32term.c (x_draw_hollow_cursor): Use get_phys_cursor_geometry.
+
+ * macterm.c (x_draw_hollow_cursor): Use get_phys_cursor_geometry.
+
+2005-01-27 Stefan Monnier <[email protected]>
+
+ * xterm.c (x_error_quitter): Add a prototype. Make it static again.
+
+2005-01-27 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_glyph_string_clip_rect): Always show a cursor
+ glyph, even when row is only partially visible and actual cursor
+ position is not visible.
+
+2005-01-24 Richard M. Stallman <[email protected]>
+
+ * xterm.c (x_error_quitter): No longer static, and moved after
+ x_error_handler.
+
+2005-01-24 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_by_lines): If we move forward after going too
+ far back, cancel move if end position is same as start position.
+
+2005-01-24 YAMAMOTO Mitsuharu <[email protected]>
+
+ * dispextern.h (struct glyph_string): New members clip_head and
+ clip_tail.
+
+ * xdisp.c (get_glyph_string_clip_rect): Restrict horizontal clip
+ region to the area between clip_head and clip_tail.
+ (draw_glyphs): Record the area that need to be actually redrawn to
+ the new variables clip_head and clip_tail when there are
+ overhangs. Set values of these variables to the corresponding
+ members in struct glyph_string. Refine x coordinates for
+ notice_overwritten_cursor using clip_head and clip_tail.
+
+ * macgui.h (STORE_XCHARSETSTRUCT): New macro.
+
+ * macterm.c (mac_compute_glyph_string_overhangs): Implement with
+ QDTextBounds.
+ (x_draw_glyph_string): Don't fill the background of the successor
+ of a glyph with a right overhang if the successor will draw a cursor.
+ (XLoadQueryFont): Obtain font metrics using QDTextBounds.
+ (x_redisplay_interface): Add entry for compute_glyph_string_overhangs.
+
+2005-01-24 Kim F. Storm <[email protected]>
+
+ * window.c (window_scroll_pixel_based): Fix scrolling in the wrong
+ direction if window height was smaller than next-screen-context-lines.
+ Now always scroll at least one line in the requested direction.
+ Ensure that we actually do scroll backwards when requested to do so.
+
+ * xdisp.c (redisplay_window): Only try to make cursor line fully
+ visible once (to avoid redisplay loop).
+
+2005-01-23 Kim F. Storm <[email protected]>
+
+ * window.c (Fpos_visible_in_window_p): Simplify return value for
+ partially visible rows.
+ (window_scroll_pixel_based): Adapt to that change.
+
+ * window.c (window_scroll_pixel_based): Force moving to next line
+ if scrolling doesn't move start point, e.g. if looking at tall image.
+
+ * xdisp.c (pos_visible_p): Return 0 if non-interactive.
+ Clear last_height before calling line_bottom_y to get real height.
+ Fix calculation of y.
+
+2005-01-22 Steven Tamm <[email protected]>
+
+ * s/darwin.h: Removed PTY_ITERATION from here.
+ (DARWIN): Define.
+
+ * process.c (init_process): Default process-connection-type to
+ nil on darwin 6 or less, t if it is 7 or higher. This way the
+ broken pty behavior is still allowed on darwin 6 for interactive
+ processes for people that know what they are doing.
+
+2005-01-22 Kim F. Storm <[email protected]>
+
+ * window.c (auto_window_vscroll_p): New boolean.
+ (syms_of_window): DEFVAR_BOOL it.
+ (Fpos_visible_in_window_p): Extend return value to include RTOP
+ and RBOT values if FULLY is nil.
+ (window_scroll_pixel_based): Adjust vscroll for partially visible
+ rows if auto_window_vscroll_p is set.
+ (Fset_window_vscroll): Do nothing if vscroll is not modified.
+
+ * xdisp.c (pos_visible_p): Replace FULLY arg by RTOP and RBOT args
+ to return number of partially invisible pixels at top and bottom
+ of the dislay row at POS.
+
+ * lisp.h (pos_visible_p): Fix prototype.
+
+2005-01-21 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fcopy_file): Doc fix.
+
+2005-01-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_tool_bar_detach_callback): Remove unused variable bw.
+ (xg_get_file_name): Move declaration ofx_use_old_gtk_file_dialog to
+ start of function for older compilers.
+
+2005-01-20 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fmessage): If arg is "", return "" (as before).
+
+ * keymap.c (access_keymap): Protect from bad value of meta_prefix_char.
+
+ * .gdbinit (xgetptr, xgetint, xgettype): Copy $arg0 into a temp
+ variable.
+
+2005-01-20 Steven Tamm <[email protected]>
+
+ * editfns.c (Voperating_system_release): Add.
+ (init_editfns): Assign new variable operating-system-release
+ based on call to uname if available.
+ (get_operating_system_release): Add function to
+ allow c-level access to operating system release.
+
+ * config.h: Regenerated.
+
+ * s/darwin.h (PTY_ITERATION): Don't allow PTYs on darwin 6 or less.
+ (MIN_PTY_KERNEL_VERSION): Define minimum kernel version for
+ using ptys as '7'.
+
+2005-01-20 Kim F. Storm <[email protected]>
+
+ * alloc.c (STRING_MARKED_P, VECTOR_MARKED_P): Return boolean.
+
+ * xterm.c (x_draw_glyph_string_box): Fix last_x for full width rows.
+ Thanks to Chong Yidong <[email protected]> for debugging this.
+
+ * macterm.c (x_draw_glyph_string_box): Likewise.
+
+ * w32term.c (x_draw_glyph_string_box): Likewise.
+
+ * indent.c (Fvertical_motion): Temporarily disable selective display.
+
+2005-01-19 Kim F. Storm <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Fix :pointer
+ image property.
+
+ * fns.c (sweep_weak_table): Advance prev pointer when we keep a pair.
+
+2005-01-18 Kim F. Storm <[email protected]>
+
+ * xdisp.c (fast_find_position): Backtrack to find first row if
+ charpos is inside a display overlay that spans multiple lines.
+
+2005-01-18 Kenichi Handa <[email protected]>
+
+ * coding.c (decode_coding_iso2022): Translate invalid codes if
+ translation-table is specified.
+
+2005-01-18 Kim F. Storm <[email protected]>
+
+ * xdisp.c (back_to_previous_visible_line_start): Undo 2004-12-28
+ change. If handle_display_prop indicates newline is replaced by
+ image or text, move back to start of relevant overlay or interval
+ and continue scan from there. Simplify.
+
+2005-01-17 Kim F. Storm <[email protected]>
+
+ * dispnew.c (mode_line_string, marginal_area_string):
+ Fix off-by-one error in search for glyph.
+
+2005-01-16 Kim F. Storm <[email protected]>
+
+ * macterm.c (syms_of_macterm) <mac-allow-anti-aliasing>: Doc fix.
+
+2005-01-16 Steven Tamm <[email protected]>
+
+ * macterm.c (mac_to_x_fontname): Remove spurious argument.
+
+2005-01-16 Andreas Schwab <[email protected]>
+
+ * macterm.c (mac_draw_string_common): Fix compilation on OSX 10.1.
+
+2005-01-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * fringe.c (Fdefine_fringe_bitmap, init_fringe): When assigning
+ fringe_faces, cast result from xmalloc/xrealloc to Lisp_Object *.
+
+2005-01-16 YAMAMOTO Mitsuharu <[email protected]>
+
+ * keyboard.c (READABLE_EVENTS_DO_TIMERS_NOW)
+ (READABLE_EVENTS_FILTER_EVENTS, READABLE_EVENTS_IGNORE_SQUEEZABLES):
+ New flags for readable_events.
+ (get_filtered_input_pending, readable_filtered_events): Remove.
+ (tracking_off): Call readable_events and get_input_pending with
+ flag READABLE_EVENTS_DO_TIMERS_NOW.
+ (readable_events): Move code from old readable_filtered_events here,
+ but check new READABLE_EVENTS_* in argument flags instead of previous
+ two boolean arguments do_timers_now and filter_events.
+ If we are doing mouse tracking and the mouse moved, return only if
+ READABLE_EVENTS_IGNORE_SQUEEZABLES is not set in flags.
+ (swallow_events): Call get_input_pending with flag
+ READABLE_EVENTS_DO_TIMERS_NOW.
+ (get_input_pending): Move code from old get_filtered_input_pending
+ here. Replace boolean arguments do_timers_now, filter_events with
+ flags, and pass flags to readable_events. Document new
+ READABLE_EVENTS_* flags.
+ (detect_input_pending_ignore_squeezables): New function.
+ (detect_input_pending_run_timers): Call get_input_pending with flag
+ READABLE_EVENTS_DO_TIMERS_NOW.
+ (Finput_pending_p): Call get_input_pending with flags
+ READABLE_EVENTS_DO_TIMERS_NOW and READABLE_EVENTS_FILTER_EVENTS.
+
+ * dispnew.c (update_window, update_frame_1): Replace calls to
+ detect_input_pending with detect_input_pending_ignore_squeezables
+ so that redisplay is not paused if the event queue contains only
+ mouse movements.
+
+ * lisp.h: Declare detect_input_pending_ignore_squeezables.
+
+2005-01-15 Steven Tamm <[email protected]>
+
+ * macterm.c (Vmac_use_core_graphics): Declare variable for
+ mac-allow-anti-aliasing.
+ (syms_of_macterm): DEFVAR_LISP and initialize it.
+ (mac_draw_string_common): Use core graphics text rendering if
+ mac-allow-anti-aliasing is enabled.
+
+ * macfns.c (Fx_file_dialog): Save As dialog includes only the
+ file name in the text box.
+
+2005-01-15 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (x_set_foreground_color, x_set_background_color):
+ Sync with xfns.c.
+ (mac_window, x_create_tip_frame): Use XSetWindowBackground.
+ * macterm.c (XSetBackground, XSetWindowBackground): New functions.
+ * macterm.h (XSetBackground, XSetWindowBackground): Add externs.
+
+2005-01-14 Kim F. Storm <[email protected]>
+
+ * keyboard.c (Fposn_at_x_y): Add optional arg WHOLE.
+
+2005-01-13 Richard M. Stallman <[email protected]>
+
+ * keymap.c (Fcurrent_active_maps): Ignore Voverriding_local_map
+ if Voverriding_terminal_local_map is non-nil.
+
+ * keyboard.c (syms_of_keyboard): Doc fix.
+
+2005-01-13 Kim F. Storm <[email protected]>
+
+ * xdisp.c (Fformat_mode_line): Fix last change. Remove NO_PROPS arg
+ (specify 0 for FACE instead). Reorder arg list. Doc fix.
+
+2005-01-12 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (Fformat_mode_line): New arg FACE specifies a default
+ face property for characters that don't specify one.
+
+ * fns.c (Frequire): Record in load-history unconditionally.
+
+2005-01-10 Kim F. Storm <[email protected]>
+
+ * dispextern.h (merge_faces): Rename from merge_into_realized_face.
+
+ * xfaces.c (merge_faces): Rename from merge_into_realized_face.
+ Callers changed.
+ Add support to merge with lisp face id too (if face_name is t).
+
+ * xdisp.c (get_next_display_element, next_element_from_display_vector):
+ Don't lookup lface_id from display table glyphs here; instead use
+ merge_faces to merge the lisp face id into current face.
+
+2005-01-09 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct it): New member dpvec_face_id.
+ (merge_into_realized_face): Add prototype.
+
+ * xfaces.c (merge_into_realized_face): New function. Used to
+ merge escape-glyph face or face from display table into current face.
+
+ * xdisp.c (Vshow_nonbreak_escape): New lisp var.
+ (syms_of_xdisp): DEFVAR_LISP it.
+ (escape_glyph_face): Remove var.
+ (redisplay_window): Don't initialize it.
+ (setup_for_ellipsis, get_next_display_element):
+ Set it->dpvec_face_id to -1.
+ (get_next_display_element): Test Vshow_nonbreak_escape.
+ Do not setup escape_glyph_face.
+ Properly merge escape-glyph face or face from display table with
+ current face for escape and control characters.
+ Set it->dpvec_face_id to relevant face id instead of adding it to each
+ element of display vector.
+ (next_element_from_display_vector): If it->dpvec_face_id is set,
+ use that instead of lface_id from glyph itself.
+
+2005-01-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h (struct x_output): New member, toolbar_detached.
+
+ * gtkutil.c (xg_create_frame_widgets): Set initial tool bar height to
+ 38.
+ (xg_tool_bar_detach_callback): Set toolbar_detached to 1.
+ (xg_tool_bar_attach_callback): Set toolbar_detached to 0.
+ (xg_create_tool_bar): Initialize toolbar_detached.
+ (update_frame_tool_bar): Only set FRAME_TOOLBAR_HEIGHT (f) if
+ toolbar_detached is zero.
+
+2005-01-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (create_and_show_popup_menu): Pass zero as button to
+ gtk_menu_popup if not for_click, so callbacks for the menu are called.
+
+ * gtkutil.c (xg_gtk_scroll_destroy, xg_create_scroll_bar)
+ (xg_tool_bar_callback, xg_tool_bar_help_callback)
+ (update_frame_tool_bar): Cast to EMACS_INT to avoid compiler warning.
+
+ * xselect.c (x_get_foreign_selection, x_fill_property_data)
+ (Fx_get_atom_name, Fx_send_client_event): Replace XFLOAT with
+ XFLOAT_DATA to get extract number from Lisp object.
+
+2005-01-07 Kim F. Storm <[email protected]>
+
+ * xdisp.c (set_iterator_to_next): Fix 2004-12-13 change.
+ Set stop_charpos to current charpos instead of 0.
+
+2005-01-06 Nick Roberts <[email protected]>
+
+ * xdisp.c (Fformat_mode_line): First arg now required.
+
+2005-01-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (XLoadQueryFont): Correctly handle 0 size
+ font widths that are returned from some Japanese fonts.
+
+2005-01-06 Kim F. Storm <[email protected]>
+
+ * fringe.c (fringe_faces): Change to Lisp_Object pointer.
+ (draw_fringe_bitmap_1): Lookup user defined fringe faces here.
+ (destroy_fringe_bitmap): Set fringe_faces element to nil.
+ (Fdefine_fringe_bitmap, init_fringe): Change allocation of
+ fringe_faces array and init elements to nil.
+ (Fset_fringe_bitmap_face): Set fringe_faces to face name instead of
+ non-persistent face id.
+ (mark_fringe_data): New function for GC.
+
+ * alloc.c (mark_fringe_data): Declare extern.
+ (Fgarbage_collect): Call mark_fringe_data.
+
+ * alloc.c (overrun_check_free): Invalidate freed memory if
+ XMALLOC_CLEAR_FREE_MEMORY is defined.
+
+2005-01-05 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c: Include sys/param.h.
+ [TARGET_API_MAC_CARBON] (mac_nav_event_callback): New declaration
+ and function.
+ [TARGET_API_MAC_CARBON] (Fx_file_dialog): Use MAXPATHLEN for size
+ of filename string. Set event callback function when creating
+ dialog boxes. Add code conversions for filenames. Don't dispose
+ of apple event descriptor record if failed to create it.
+
+ * macterm.c: Include sys/param.h.
+ [USE_CARBON_EVENTS] (mac_handle_window_event): Add handler for
+ kEventWindowUpdate.
+ (install_window_handler) [USE_CARBON_EVENTS]: Register it.
+ (do_ae_open_documents) [TARGET_API_MAC_CARBON]: Get FSRef instead
+ of FSSpec from apple event descriptor record.
+ (do_ae_open_documents) [TARGET_API_MAC_CARBON]: Use MAXPATHLEN for
+ size of filename string.
+ [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Likewise.
+ [TARGET_API_MAC_CARBON] (mac_do_receive_drag): Return error when a
+ file dialog is in action.
+ [TARGET_API_MAC_CARBON] (mac_do_track_drag): Likewise.
+ Reject only when there are no filename items. Set background color
+ before (un)highlighting the window below the dragged items.
+ (XTread_socket) [USE_CARBON_EVENTS]: Don't call do_window_update.
+
+2005-01-05 Romain Francoise <[email protected]>
+
+ * term.c (encode_terminal_code): Fix buffer size computation.
+
+2005-01-04 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (Fformat_mode_line): Doc fix.
+
+2005-01-04 Stefan Monnier <[email protected]>
+
+ * alloc.c (refill_memory_reserve): Move.
+ (emacs_blocked_free, emacs_blocked_malloc, emacs_blocked_realloc)
+ (reset_malloc_hooks, uninterrupt_malloc) [SYNC_INPUT]: Don't define.
+
+2005-01-03 Richard M. Stallman <[email protected]>
+
+ * window.c (window_scroll_pixel_based): Don't correct preserve_y
+ for CURRENT_HEADER_LINE_HEIGHT when moving backwards.
+
+2005-01-03 Jason Rumney <[email protected]>
+
+ * w32bdf.c (w32_load_bdf_font): Set fontp->average_width and
+ fontp->space_width to FONT_WIDTH so they are valid.
+
+ * w32fns.c (w32_load_system_font): Set FONT_WIDTH to maximum, not
+ average width. Set fontp->average_width and fontp->space_width to
+ their appropriate values.
+
+ * w32term.c (x_new_font): Set FRAME_COLUMN_WIDTH to
+ fontp->average_width, not FONT_WIDTH. Set FRAME_SPACE_WIDTH to
+ fontp->space_width.
+
+2005-01-03 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (x_new_font): Set FRAME_SPACE_WIDTH.
+ (x_font_min_bounds, XLoadQueryFont): Use the correct font width
+ metrics for max and min bounds.
+ (x_load_font): Correctly calculate average font width metrics.
+
+2005-01-02 Richard M. Stallman <[email protected]>
+
+ * alloc.c (Fgarbage_collect): Don't truncate_undo_list on dead buffers.
+
+2004-12-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): Clear area in expose event for GTK.
+
+2004-12-31 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (setup_for_ellipsis, get_next_display_element):
+ Set it->ellipsis_p to 1 or 0.
+ (display_line): Record whether row ends in mid-ellipsis.
+ (set_cursor_from_row): If ends in ellipsis, find start of it.
+ (cursor_row_p): If PT's at the end of the ellipsis the row
+ ends within, don't display cursor on this row.
+
+ * dispextern.h (struct it): New element ellipsis_p.
+ (struct glyph_row): New element ends_in_ellipsis_p.
+
+ * xdisp.c (BUFFER_POS_REACHED_P): We haven't reached the specified
+ position if we're reading from something other than the buffer.
+
+ * window.c (window_scroll_pixel_based): Only look at
+ Vscroll_preserve_screen_position if the old PT can't be kept.
+ (syms_of_window) <scroll-preserve-screen-position>: Doc fix.
+
+2004-12-30 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_line_height_property): New function extracted from
+ original calc_line_height_property.
+ (calc_line_height_property): Rework. Handle t and (nil . ratio).
+ (x_produce_glyphs): Use them to handle line-height and
+ line-spacing according to new height spec.
+ (Qtotal): Remove.
+ (syms_of_xdisp): Remove intern and staticpro for Qtotal.
+
+2004-12-30 Kenichi Handa <[email protected]>
+
+ * fileio.c (Finsert_file_contents): Don't use
+ current_buffer->buffer_file_coding_system even if REPLACE is
+ non-nil. Call Qafter_insert_file_set_coding with the second arg VISIT.
+
+ * fontset.h (struct font_info): New members space_width and
+ average_width.
+
+ * frame.h (struct frame): New member space_width.
+ (FRAME_SPACE_WIDTH): New macro.
+
+ * xterm.h (struct x_display_info): New member Xatom_AVERAGE_WIDTH.
+
+ * xterm.c (x_new_font): Set FRAME_COLUMN_WIDTH to
+ fontp->average_width, not FONT_WIDTH. Set FRAME_SPACE_WIDTH to
+ fontp->space_width.
+ (x_load_font): Calculate fontp->space_width and fontp->average_width.
+ (x_term_init): Initialize dpyinfo->Xatom_AVERAGE_WIDTH.
+
+ * xdisp.c (x_produce_glyphs): Calculate tab width by
+ FRAME_SPACE_WIDTH, not FRAME_COLUMN_WIDTH.
+
+2004-12-29 Sanghyuk Suh <[email protected]>
+
+ * macterm.c (SelectionRange): Add Xcode position apple event struct.
+ (do_ae_open_documents): Handle Xcode-style file position open events.
+
+2004-12-29 Luc Teirlinck <[email protected]>
+
+ * buffer.c (syms_of_buffer) <vertical-scroll-bar>: Correct typo.
+
+2004-12-29 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer) <vertical-scroll-bar>: Doc fix.
+
+2004-12-29 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (install_window_handler): Modify extern to return OSErr
+ value.
+ (mac_window): Handle return value of install_window_handler.
+
+ * macterm.c (reflect_byte): Remove function.
+ (mac_create_bitmap_from_bitmap_data): Don't call reflect_byte.
+ Lookup table instead.
+ (mac_do_font_lists): Simplify calculation of the longest
+ nonspecial string.
+ (init_mac_drag_n_drop): Remove function and declaration.
+ (mac_initialize) [TARGET_API_MAC_CARBON]: Don't call
+ init_mac_drag_n_drop.
+ (mac_do_track_drag): New function and declaration.
+ (install_window_handler): Return OSErr value.
+ (install_window_handler) [TARGET_API_MAC_CARBON]:
+ Register handlers for tracking/receiving drag-and-drop items.
+ (do_ae_open_documents): Generate unibyte strings for filenames.
+ (mac_do_receive_drag) [TARGET_API_MAC_CARBON]: Likewise.
+ Reject only non-filename items. Set event modifiers, and return value.
+
+2004-12-28 Dan Nicolaescu <[email protected]>
+
+ * coding.c (decode_coding): Fix previous change.
+
+2004-12-28 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (back_to_previous_visible_line_start):
+ Don't call handle_display_prop.
+
+2004-12-28 Dan Nicolaescu <[email protected]>
+
+ * coding.c (decode_coding_XXX, decode_composition_emacs_mule)
+ (decode_coding_emacs_mule, encode_coding_emacs_mule)
+ (decode_coding_iso2022, encode_designation_at_bol)
+ (encode_coding_iso2022, decode_coding_sjis_big5, decode_eol)
+ (decode_coding): Constify arguments and local vars.
+
+2004-12-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (popup_get_selection): Only pop down dialogs
+ on C-g and Escape.
+ (popup_get_selection): Remove parameter down_on_keypress.
+ (create_and_show_popup_menu, create_and_show_dialog):
+ Remove parameter down_on_keypress to popup_get_selection.
+
+2004-12-27 YAMAMOTO Mitsuharu <[email protected]>
+
+ * dispextern.h: Change HAVE_CARBON to MAC_OS.
+ (struct glyph_string): Likewise.
+
+ * emacs.c (main) [MAC_OS8]: Call mac_term_init instead of
+ mac_initialize.
+
+ * fileio.c (Fnext_read_file_uses_dialog_p, Fread_file_name):
+ Change TARGET_API_MAC_CARBON to HAVE_CARBON.
+
+ * fns.c (vector): Change MAC_OSX to MAC_OS.
+
+ * frame.c (x_set_frame_parameters, x_report_frame_params)
+ (x_set_fullscreen): Remove #ifndef HAVE_CARBON.
+ (x_set_border_width, Vdefault_frame_scroll_bars):
+ Change HAVE_CARBON to MAC_OS.
+
+ * image.c [MAC_OS]: Include sys/stat.h.
+ [MAC_OS && !MAC_OSX]: Include sys/param.h, ImageCompression.h, and
+ QuickTimeComponents.h.
+
+ * mac.c [!MAC_OSX] (mac_wait_next_event): Add extern.
+ [!MAC_OSX] (select): Use mac_wait_next_event.
+ [!MAC_OSX] (run_mac_command): Change EXEC_SUFFIXES to Vexec_suffixes.
+ [!MAC_OSX] (select, run_mac_command): Change `#ifdef
+ TARGET_API_MAC_CARBON' to `#if TARGET_API_MAC_CARBON'.
+ (mac_clear_font_name_table): Add extern.
+ (Fmac_clear_font_name_table): New defun.
+ (syms_of_mac): Defsubr it.
+ [MAC_OSX] (SELECT_POLLING_PERIOD_USEC): New define.
+ [MAC_OSX] (select_and_poll_event): New function.
+ [MAC_OSX] (sys_select): Use it.
+ [MAC_OSX && SELECT_USE_CFSOCKET] (socket_callback): New function.
+ [MAC_OSX && SELECT_USE_CFSOCKET]
+ (SELECT_TIMEOUT_THRESHOLD_RUNLOOP, EVENT_CLASS_SOCK): New defines.
+ [MAC_OSX] (sys_select) [SELECT_USE_CFSOCKET]: Use CFSocket and
+ RunLoop for simultaneously monitoring two kinds of inputs, window
+ events and process outputs, without periodically polling.
+
+ * macfns.c (mac_initialized): Remove extern.
+ (stricmp): Put in #if 0. All callers changed to use xstricmp in
+ xfaces.c.
+ (strnicmp): Decrement `n' at the end of each loop, not the beginning.
+ (check_mac): Use the term "Mac native windows" instead of "Mac OS".
+ (check_x_display_info, x_display_info_for_name): Sync with xfns.c.
+ (mac_get_rdb_resource): New function (from w32reg.c).
+ (x_get_string_resource): Use it.
+ (install_window_handler): Add extern.
+ (mac_window): New function.
+ (Fx_create_frame): Use it instead of make_mac_frame.
+ Set parameter for Qfullscreen. Call x_wm_set_size_hint.
+ (Fx_open_connection, Fx_close_connection): New defuns.
+ (syms_of_macfns): Defsubr them.
+ (x_create_tip_frame) [TARGET_API_MAC_CARBON]:
+ Add kWindowNoUpdatesAttribute to the window attribute.
+ (x_create_tip_frame) [!TARGET_API_MAC_CARBON]: Use NewCWindow.
+ (x_create_tip_frame): Don't call ShowWindow.
+ (Fx_show_tip): Call ShowWindow.
+ (Fx_file_dialog): Change `#ifdef TARGET_API_MAC_CARBON' to `#if
+ TARGET_API_MAC_CARBON'.
+ (mac_frame_parm_handlers): Set handlers for Qfullscreen.
+ (syms_of_macfns) [MAC_OSX]: Initialize mac_in_use to 0.
+
+ * macgui.h [!MAC_OSX]: Don't include Controls.h. Include Windows.h.
+ (Window): Typedef to WindowPtr and move outside `#if
+ TARGET_API_MAC_CARBON'.
+ (XSizeHints): New struct.
+
+ * macterm.c (x_update_begin, x_update_end)
+ [TARGET_API_MAC_CARBON]: Disable screen updates during update of a
+ frame.
+ (x_draw_glyph_string_background, x_draw_glyph_string_foreground)
+ [MAC_OS8]: Use XDrawImageString/XDrawImageString16.
+ (construct_mouse_click): Put in #if 0.
+ (x_check_fullscreen, x_check_fullscreen_move): Remove decls.
+ (x_scroll_bar_create, x_scroll_bar_handle_click): Change `#ifdef
+ TARGET_API_MAC_CARBON' to `#if TARGET_API_MAC_CARBON'.
+ (activate_scroll_bars, deactivate_scroll_bars)
+ [!TARGET_API_MAC_CARBON]: Use ActivateControl/DeactivateControl.
+ (x_make_frame_visible) [TARGET_API_MAC_CARBON]: Reposition window
+ if the position is neither user-specified nor program-specified.
+ (x_free_frame_resources): Free size_hints.
+ (x_wm_set_size_hint): Allocate size_hints if needed. Set size_hints.
+ (mac_clear_font_name_table): New function.
+ (mac_do_list_fonts): Initialize font_name_table if needed.
+ (x_list_fonts): Don't initialize font_name_table. Add BLOCK_INPUT
+ around mac_do_list_fonts.
+ (mac_unload_font): New function.
+ (x_load_font): Add BLOCK_INPUT around XLoadQueryFont.
+ (init_mac_drag_n_drop, mac_do_receive_drag): Enclose declarations
+ and definitions with #if TARGET_API_MAC_CARBON.
+ [USE_CARBON_EVENTS] (mac_handle_window_event): Add decl.
+ (install_window_handler): Add decl.
+ (do_window_update): Add BeginUpdate/EndUpdate for the tooltip
+ window. Use UpdateControls. Get the rectangle that should be
+ updated and restrict the target of expose_frame to it.
+ (do_grow_window): Set minimum height/width according to size_hints.
+ (do_grow_window) [TARGET_API_MAC_CARBON]: Use ResizeWindow.
+ (do_zoom_window): Don't use x_set_window_size.
+ [USE_CARBON_EVENTS] (mac_handle_window_event): New function.
+ (install_window_handler): New function.
+ [!USE_CARBON_EVENTS] (mouse_region): New variable.
+ [!USE_CARBON_EVENTS] (mac_wait_next_event): New function.
+ (XTread_socket) [USE_CARBON_EVENTS]: Move call to
+ GetEventDispatcherTarget inside BLOCK_INPUT.
+ (XTread_socket) [!USE_CARBON_EVENTS]: Use mac_wait_next_event.
+ Update mouse_region when mouse is moved.
+ (make_mac_frame): Remove.
+ (make_mac_terminal_frame): Put in #ifdef MAC_OS8.
+ Initialize mouse pointer shapes. Change values of f->left_pos and
+ f->top_pos. Don't use make_mac_frame. Use NewCWindow.
+ Don't call ShowWindow.
+ (mac_initialize_display_info) [MAC_OSX]: Create mac_id_name from
+ Vinvocation_name and Vsystem_name.
+ (mac_make_rdb): New function (from w32term.c).
+ (mac_term_init): Use it. Add BLOCK_INPUT. Error if display has
+ already been opened. Don't pass argument to
+ mac_initialize_display_info. Don't set dpyinfo->height/width.
+ Add entries to x_display_list and x_display_name_list.
+ (x_delete_display): New function.
+ (mac_initialize): Don't call mac_initialize_display_info.
+ (syms_of_macterm) [!MAC_OSX]: Don't call Fprovide.
+
+ * macterm.h (check_mac): Add extern.
+ (struct mac_output): New member size_hints.
+ (FRAME_SIZE_HINTS): New macro.
+ (mac_unload_font): Add extern.
+
+ * xdisp.c (expose_window, expose_frame): Remove kludges for Mac.
+
+ * xfaces.c (clear_font_table) [MAC_OS]: Call mac_unload_font.
+
+2004-12-27 Richard M. Stallman <[email protected]>
+
+ * buffer.c (Fbuffer_disable_undo): Delete (move to simple.el).
+ (syms_of_buffer): Don't defsubr it.
+
+ * process.c (list_processes_1): Set undo_list instead
+ of calling Fbuffer_disable_undo.
+
+ * xdisp.c (single_display_spec_string_p): Rename from
+ single_display_prop_string_p.
+ (single_display_spec_intangible_p): Rename from
+ single_display_prop_intangible_p.
+ (handle_single_display_spec): Rename from handle_single_display_prop.
+ Rewritten to be easier to understand.
+
+ Change in load-history format. Functions now get (defun . NAME),
+ and variables get just NAME.
+
+ * data.c (Fdefalias): Use (defun . FN_NAME) in LOADHIST_ATTACH.
+
+ * eval.c (Fdefun, Fdefmacro): Use (defun . FN_NAME) in LOADHIST_ATTACH.
+ (Fdefvaralias, Fdefvar, Fdefconst): Use just SYM in LOADHIST_ATTACH.
+ (Qdefvar): Var deleted.
+ (syms_of_eval): Don't initialze it.
+
+ * lread.c (syms_of_lread) <load-history>: Doc fix.
+
+2004-12-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (popup_get_selection): Pop down on C-g.
+ (set_frame_menubar): Install translations for Lucid/Motif/Lesstif that
+ pops down menu on C-g.
+ (xdialog_show): If dialog popped down and no button in the dialog was
+ pushed, call Fsignal to quit.
+ (xmenu_show): In no toolkit version, if menu returns NO_SELECT call
+ Fsignal to quit.
+
+ * xfns.c (Fx_file_dialog): Motif/Lesstif version: Pop down on C-g.
+
+ * gtkutil.c (xg_initialize): Install bindings for C-g so that
+ dialogs and menus pop down.
+
+2004-12-27 Kenichi Handa <[email protected]>
+
+ * coding.c (code_convert_region): Fix calculation of `ratio'.
+
+2004-12-25 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Make the value of
+ tool-bar-button-margin control margins of images in tool bar.
+
+ * alloc.c (check_depth): New variable.
+ (overrun_check_malloc, overrun_check_realloc): Only add
+ overhead and write check pattern if check_depth is 1 (to handle
+ recursive calls). Increase/decrease check_depth in entry/exit.
+ (overrun_check_free): Only check for overhead if check_depth is 1.
+ Increase/decrease check_depth in entry/exit.
+
+2004-12-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c (input_available_signal): Call SIGNAL_THREAD_CHECK
+ before touching input_available_clear_time, to avoid accessing it
+ from multiple threads.
+
+2004-12-23 Jason Rumney <[email protected]>
+
+ * image.c (__WIN32__) [HAVE_NTGUI]: Define for correct behaviour
+ of JPEG library.
+
+2004-12-22 Richard M. Stallman <[email protected]>
+
+ * emacs.c (main): If batch mode, set Vundo_outer_limit to nil.
+
+ * lisp.h (Vundo_outer_limit): Fix decl.
+
+ * undo.c (Vundo_outer_limit): Replaces undo_outer_limit.
+ Uses changed.
+ (syms_of_undo): Initialize appropriately.
+ (truncate_undo_list): If it's nil, there's no limit.
+
+2004-12-22 Kenichi Handa <[email protected]>
+
+ * xselect.c (Fx_get_cut_buffer_internal): Return a unibyte string.
+
+2004-12-21 Richard M. Stallman <[email protected]>
+
+ * eval.c (unwind_to_catch): Clear immediate_quit.
+
+ * xdisp.c (get_next_display_element): Display codes 8a0 and 8ad
+ specially as `\ ' and `\-'.
+
+ * keyboard.c (kbd_buffer_store_event_hold):
+ In the code for while-no-input, handle immediate_quit.
+
+ * alloc.c (Fgarbage_collect): Update call to truncate_undo_list.
+ Call that at the very start.
+ (undo_limit, undo_strong_limit, undo_outer_limit): Move to undo.c.
+ (syms_of_alloc): Don't define undo-limit,
+ undo-strong-limit and undo-outer-limit here.
+
+ * undo.c (truncate_undo_list): Return void.
+ Take just one argument, the buffer.
+ Make it current, and inhibit recursive GC.
+ Access and update the undo list directly; return void.
+ Refer to the undo...limit variables directly.
+ Test undo_outer_limit only after counting the whole current command.
+ When it's exceeded, call the function in undo-outer-limit-function.
+ (undo_limit, undo_strong_limit, undo_outer_limit): From alloc.c.
+ (Vundo_outer_limit_function): New variable.
+ (syms_of_undo): Define undo-limit, undo-strong-limit
+ and undo-outer-limit here, and undo-outer-limit-function.
+ Doc fixes.
+
+ * lisp.h (truncate_undo_list): Update decl.
+
+2004-12-21 Piet van Oostrum <[email protected]>
+
+ * fileio.c (Fread_file_name): Delete duplicates in
+ file-name-history when history_delete_duplicates is true.
+
+2004-12-20 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_do_list_fonts): Fix memory leak.
+
+2004-12-20 Richard M. Stallman <[email protected]>
+
+ * regex.c (re_match_2_internal) <symend, wordend>:
+ Fix calls to UPDATE_SYNTAX_TABLE_FORWARD.
+
+2004-12-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (endif, x_font_name_to_mac_font_name):
+ Use maccentraleurroman instead of maccentraleuropean
+ (mac_c_string_match, mac_do_list_fonts): Speed up font search by
+ quickly finding a specific font without needing regexps.
+
+2004-12-15 Jan Dj,Ad(Brv <[email protected]>
+
+ * syssignal.h: Declare main_thread.
+ (SIGNAL_THREAD_CHECK): New macro.
+
+ * keyboard.c (input_available_signal): Move thread checking code
+ to macro SIGNAL_THREAD_CHECK and call that macro.
+ (interrupt_signal): Call SIGNAL_THREAD_CHECK.
+
+ * alloc.c (uninterrupt_malloc): Move main_thread to emacs.c.
+
+ * emacs.c: Define main_thread.
+ (main): Initialize main_thread.
+ (handle_USR1_signal, handle_USR2_signal, fatal_error_signal)
+ (memory_warning_signal): Call SIGNAL_THREAD_CHECK.
+
+ * floatfns.c (float_error): Call SIGNAL_THREAD_CHECK.
+
+ * dispnew.c (window_change_signal): Call SIGNAL_THREAD_CHECK.
+
+ * sysdep.c (select_alarm): Call SIGNAL_THREAD_CHECK.
+
+ * process.c (send_process_trap, sigchld_handler):
+ Call SIGNAL_THREAD_CHECK.
+
+ * data.c (arith_error): Call SIGNAL_THREAD_CHECK.
+
+ * atimer.c (alarm_signal_handler): Call SIGNAL_THREAD_CHECK.
+
+ * xterm.c (xg_scroll_callback): Update XG_LAST_SB_DATA before
+ returning when xg_ignore_gtk_scrollbar is true.
+
+2004-12-14 Kim F. Storm <[email protected]>
+
+ * keyboard.c (read_char): Save and restore echo_string when
+ handling input method.
+
+2004-12-13 Richard M. Stallman <[email protected]>
+
+ * eval.c (syms_of_eval) <quit-flag>: Doc fix.
+
+ * keyboard.c (Vthrow_on_input): New variable.
+ (syms_of_keyboard): Defvar and initialize it.
+ (kbd_buffer_store_event_hold): Handle Vthrow_on_input.
+
+ * lisp.h (QUIT): Check for Vthrow_on_input.
+ (Vthrow_on_input): Declare it.
+
+2004-12-13 Kim F. Storm <[email protected]>
+
+ * xdisp.c (set_iterator_to_next): Reset stop_charpos after display
+ vector.
+
+2004-12-12 Richard M. Stallman <[email protected]>
+
+ * indent.c (Fvertical_motion): Call move_it_by_lines even if LINES = 0.
+
+ * minibuf.c (Fall_completions): Add var `zero' and use it in loop.
+ (Ftry_completion): Really use outer `zero'; eliminate inner one.
+
+2004-12-12 Kenichi Handa <[email protected]>
+
+ * term.c (encode_terminal_code): Fix previous change.
+
+2004-12-11 Stefan Monnier <[email protected]>
+
+ * keyboard.c (handle_async_input): Remove pthread mutex handling.
+ (input_available_signal): Move pthread thingy to !SYNC_INPUT branch.
+
+ * syntax.c (Fforward_word): Avoid non-idempotent side-effects
+ in macro arguments.
+
+ * minibuf.c (Ftry_completion, Fall_completions): Don't use
+ XFASTINT blindly.
+
+ * emacs.c (main, Fdump_emacs): Don't touch malloc hooks if SYNC_INPUT.
+
+2004-12-11 Jan Dj,Ad(Brv <[email protected]>
+
+ * w32term.c (x_calc_absolute_position): Remove calculation of
+ difference between inner and outer window. Don't subtract difference
+ for left and top calculations.
+
+ * xterm.c (x_calc_absolute_position): Don't subtract outer_pixel_diff
+ for left and top calculations. Remove call to x_real_positions.
+ [Bug report by Drew Adams in November.]
+ (x_check_expected_move): Do not set change_gravity to 1 when calling
+ x_set_offset.
+
+2004-12-08 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (get_next_display_element): Use `escape-glyph' for
+ control chars and escaped octal codes.
+ (Qescape_glyph): New variable.
+ (syms_of_xdisp): Initialize it.
+ (escape_glyph_face): New variable.
+ (redisplay_window): Initialize it.
+
+2004-12-07 Paul Eggert <[email protected]>
+
+ * image.c (our_fill_input_buffer, jpeg_load, CHECK_LIB_AVAILABLE)
+ (init_image): Use 1 rather than TRUE. TRUE's not always defined.
+
+2004-12-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * emacs.c (Fdump_emacs): Add ! defined (SYSTEM_MALLOC) around
+ reset_malloc_hooks.
+
+ * keyboard.c (handle_async_input, input_available_signal):
+ Add ! defined (SYSTEM_MALLOC) around thread code.
+
+ * alloc.c: Add comment about the reason for (UN)BLOCK_INPUT_ALLOC.
+
+2004-12-07 Stefan Monnier <[email protected]>
+
+ * eval.c (init_eval_once): Increase max_specpdl_size to 1000.
+
+ * config.in: Regenerate.
+
+2004-12-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (Fx_popup_menu): Correct documentation about position.
+ (xmenu_show): Do not call XTranslateCoordinates. Adjust position
+ if not given by a mouse click to correspond with x-popup-menu
+ documentation.
+
+ * config.in: Regenerate.
+
+ * gtkutil.c: Include signal.h and syssignal.h.
+ (xg_get_file_name): Block and unblock __SIGRTMIN if defined.
+
+ * alloc.c: If HAVE_GTK_AND_PTHREAD, include pthread.h,
+ new variables main_thread and alloc_mutex,
+ define (UN)BLOCK_INPUT_ALLOC to use alloc_mutex to protect
+ emacs_blocked_* calls and only do (UN)BLOCK_INPUT in the main thread.
+ If not HAVE_GTK_AND_PTHREAD, (UN)BLOCK_INPUT_ALLOC is the same
+ as (UN)BLOCK_INPUT.
+ (emacs_blocked_free, emacs_blocked_malloc)
+ (emacs_blocked_realloc): Use (UN)BLOCK_INPUT_ALLOC.
+ (uninterrupt_malloc): Initialize main_thread and alloc_mutex.
+ (reset_malloc_hooks): New function.
+
+ * lisp.h: Declare reset_malloc_hooks.
+
+ * emacs.c (Fdump_emacs): Call reset_malloc_hooks.
+
+ * keyboard.c: Conditionally include pthread.h.
+ (handle_async_input, input_available_signalt): If not in the main
+ thread, block signal, send signal to main thread and return.
+
+ * gtkutil.c (xg_get_file_with_chooser): Handle local files only.
+ Set current folder in file chooser if default_filename is a directory.
+
+2004-12-05 Stefan Monnier <[email protected]>
+
+ * regex.c (GET_UNSIGNED_NUMBER): Signal an error when reaching the end.
+ Remove redundant correctness checks.
+ (regex_compile): Fix up error codes for \{..\} expressions.
+
+2004-12-05 Richard M. Stallman <[email protected]>
+
+ * regex.c (regex_compile): Fix end-of-pattern case for space.
+
+2004-12-03 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.h (cfstring_create_with_utf8_cstring): Add prototype.
+ * mac.c (cfstring_create_with_utf8_cstring): Add to prevent
+ crashes with invalid characters.
+ * macmenu.c (add_menu_item): Use it.
+ * image.c (image_load_quartz2d): Likewise.
+ * macfns.c (x_set_name, x_set_title): Likewise.
+ (Fx_file_dialog): Likewise. Use constant CFRefs instead of
+ creating them each time for labels.
+
+2004-12-02 Richard M. Stallman <[email protected]>
+
+ * config.in (RE_TRANSLATE_P): If make_number is not a macro,
+ don't use it here.
+
+ * eval.c (Fcalled_interactively_p): Don't check INTERACTIVE.
+ (interactive_p): Skip Scalled_interactively_p frames
+ like Sinteractive_p frames.
+ (unwind_to_catch): Clear handling_signal.
+
+ * data.c (Fmake_variable_buffer_local): Doc fix.
+ (Fmake_local_variable): Doc fix.
+
+ * insdel.c (insert_from_string_before_markers)
+ (insert_from_string): Don't modify buffer on empty insertion.
+
+ * window.c (Fget_lru_window, Fget_largest_window): Doc fixes.
+
+2004-12-01 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (add_menu_item): Fallback on MacRoman if encoding
+ menu text as UTF8 fails.
+
+2004-12-01 Kim F. Storm <[email protected]>
+
+ * alloc.c: Add commentary for last change.
+ (XMALLOC_PUT_SIZE, XMALLOC_GET_SIZE): New macros to handle
+ sizeof(size_t) != 4.
+ (overrun_check_malloc, overrun_check_realloc, overrun_check_free):
+ Use them. Also clear header and trailer of freed memory.
+ (GC_STRING_OVERRUN_COOKIE_SIZE): Rename from GC_STRING_EXTRA.
+ (string_overrun_cookie): Rename from string_overrun_pattern.
+ (GC_STRING_EXTRA): Define from GC_STRING_OVERRUN_COOKIE_SIZE.
+
+2004-12-01 Andreas Schwab <[email protected]>
+
+ * lisp.h: Declare string_to_multibyte.
+
+2004-12-01 Kenichi Handa <[email protected]>
+
+ * w32console.c (w32con_write_glyphs): Decide coding here.
+ Adjusted for the change of encode_terminal_code.
+
+ * term.c (encode_terminal_code): Don't make it "static".
+
+2004-11-30 Kenichi Handa <[email protected]>
+
+ * term.c (encode_terminal_buf, encode_terminal_bufsize): New variables.
+ (encode_terminal_code): Argument changed. Encode all
+ characters at once, and return a pointer to the result of encoding.
+ (write_glyphs): Decide coding here. Adjusted for the above change.
+ (insert_glyphs): Likewise.
+ (term_init): Initialize encode_terminal_bufsize to 0.
+
+ * coding.c (Vcode_conversion_workbuf_name): New variable.
+ (syms_of_coding): Initialize and staticpro it.
+ (set_conversion_work_buffer): New function.
+ (run_pre_post_conversion_on_str): Use it.
+ (run_pre_write_conversin_on_c_str): New function.
+
+ * coding.h (run_pre_write_conversin_on_c_str): Extern it.
+
+2004-11-30 YAMAMOTO Mitsuharu <[email protected]>
+
+ * keyboard.c: Don't undef SIGIO
+ * s/darwin.h (NO_SOCK_SIGIO): Define NO_SOCK_SIGIO on carbon
+ * Makefile.in (mac.o): Depend on blockinput.h and atimer.h.
+ (macfns.o): Don't depend on ccl.h.
+ * macfns.c (mac_frame_parm_handlers): Set handlers for
+ Qleft_fringe and Qright_fringe.
+ * macterm.c (mac_fill_rectangle_to_pixmap)
+ (mac_draw_rectangle_to_pixmap, mac_copy_area_to_pixmap)
+ (mac_copy_area_with_mask_to_pixmap, x_draw_image_foreground_1):
+ Put in #if 0.
+ (mac_scroll_area) [TARGET_API_MAC_CARBON]: Use ScrollWindowRect.
+ (x_flush) [TARGET_API_MAC_CARBON]: Don't traverse frames.
+ (XFlush) [TARGET_API_MAC_CARBON]: Define to an empty replacement.
+ (x_draw_glyph_string_background, x_draw_glyph_string_foreground)
+ [!MAC_OS8]: Added ifdef'd out code for os8. Don't use
+ XDrawImageString. Always draw background and foreground separately.
+ (x_draw_image_foreground): Use clipping instead of computing the
+ intersection rectangle.
+ (x_draw_image_glyph_string): Don't draw an image with mask to a
+ pixmap.
+ (x_redisplay_interface): Set flush_display_optional member to 0.
+ (XTread_socket): Correctly reset the TEConverter
+ object.
+
+2004-11-30 Kim F. Storm <[email protected]>
+
+ * lisp.h: New defines to enable buffer overrun checking.
+ (GC_CHECK_STRING_OVERRUN, GC_CHECK_STRING_FREE_LIST)
+ (XMALLOC_OVERRUN_CHECK, GC_CHECK_CONS_LIST): Add.
+
+ * alloc.c: Add more checks for buffer overruns.
+ (XMALLOC_OVERRUN_CHECK_SIZE, xmalloc_overrun_check_header)
+ xmalloc_overrun_check_trailer, overrun_check_malloc)
+ overrun_check_realloc, overrun_check_free): Add.
+ (GC_STRING_EXTRA, string_overrun_pattern): Add.
+ (check_sblock, allocate_string_data, compact_small_strings):
+ Set and check string_overrun_pattern if GC_CHECK_STRING_OVERRUN.
+ (check_cons_list): Condition on GC_CHECK_CONS_LIST.
+ (check_string_free_list): Add.
+ (allocate_string, sweep_strings): Call check_string_free_list.
+
+ * emacs.c (malloc_initialize_hook): Don't free malloc_state_ptr if
+ XMALLOC_OVERRUN_CHECK to avoid crash during load.
+
+2004-11-29 Kim F. Storm <[email protected]>
+
+ * fns.c (concat): Use SAFE_ALLOCA.
+
+2004-11-29 Stefan Monnier <[email protected]>
+
+ * sysdep.c (emacs_write): Don't use QUIT.
+
+2004-11-29 Kenichi Handa <[email protected]>
+
+ * buffer.c (init_buffer): Set current_buffer->directory to a
+ multibyte string made by string_to_multibyte.
+
+ * emacs.c (init_cmdargs): Set unibyte strings in Vcommand_line_args.
+
+2004-11-27 Andreas Schwab <[email protected]>
+
+ * alloc.c (mark_stack): Call GC_MARK_SECONDARY_STACK if defined.
+
+ * s/gnu-linux.h: Enable no-op gcpros on ia64.
+ (GC_MARK_SECONDARY_STACK) [__ia64__]: Define.
+
+ * filelock.c (lock_file_1): Call get_boot_time early.
+ Increase buffer size.
+
+2004-11-27 Eli Zaretskii <[email protected]>
+
+ * lisp.h (DECL_ALIGN): Define non-trivially only if NO_DECL_ALIGN
+ is not defined.
+
+2004-11-27 Kim F. Storm <[email protected]>
+
+ * search.c (syms_of_search) <search-spaces-regexp>: Move 'doc:'
+ marker out of doc string.
+
+2004-11-26 Stefan Monnier <[email protected]>
+
+ * s/darwin.h (POSIX_SIGNALS): Undo the removal of 2002-08-25,
+ which was not mentioned in the log.
+
+2004-11-26 Kim F. Storm <[email protected]>
+
+ * fringe.c (update_window_fringes): Prefer truncation bitmaps over
+ angle bitmaps at top/bottom line.
+
+ * xdisp.c: Undo recent changes for restoring saved_face_id. Instead,
+ set it when it->method is set to next_element_from_display_vector.
+ (setup_for_ellipsis): Add LEN argument. Callers changed.
+ Set it->saved_face_id.
+ (get_next_display_element): Use loop instead of recursion.
+ Set it->saved_face_id. Combine duplicate code for ctr chars.
+ (next_element_from_display_vector): Do not set it->saved_face_id.
+ (next_element_from_ellipsis): Use setup_for_ellipsis.
+
+2004-11-26 Eli Zaretskii <[email protected]>
+
+ * eval.c (Fdefvar): Declare pdl from last change as `volatile' to
+ prevent compiler warnings.
+
+2004-11-25 Stefan Monnier <[email protected]>
+
+ * keyboard.c (command_loop_1): Print a message describing the key
+ the user just pressed when this key has no binding.
+
+ * sysdep.c (sys_signal): Don't use SA_RESTART if SYNC_INPUT is set.
+ (emacs_open, emacs_read, emacs_write): Check QUIT when interrupted.
+
+ * lread.c (readchar): Check QUIT when `getc' is interrupted.
+
+2004-11-24 Richard M. Stallman <[email protected]>
+
+ * coding.c (run_pre_post_conversion_on_str): Bind Qinhibit_read_only.
+
+ * buffer.c (syms_of_buffer) <indicate-buffer-boundaries>: Doc fix.
+
+2004-11-24 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_in_display_line_to, display_line):
+ Restore saved_face_id also when truncate-lines or hscrolled.
+
+2004-11-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_file_name): Rename use-old-gtk-file-dialog to
+ x-use-old-gtk-file-dialog.
+
+ * xfns.c: Define x_use_old_gtk_file_dialog.
+ (syms_of_xfns): Rename use-old-gtk-file-dialog to x-... Move it
+ outside ifdef USE_GTK.
+
+2004-11-23 Stefan Monnier <[email protected]>
+
+ * coding.h (ENCODE_FILE, DECODE_FILE, ENCODE_SYSTEM, DECODE_SYSTEM):
+ Don't use XFASTINT blindly.
+
+ * config.in (RE_TRANSLATE_P): Don't use XFASTINT blindly.
+
+ * indent.c (skip_invisible): Avoid non-idempotent side-effects
+ in macro arguments.
+
+ * keymap.c (Flookup_key): Check INTEGERP before XINT.
+
+ * lread.c (oblookup): Don't use XFASTINT blindly.
+
+ * window.c (Fset_window_scroll_bars): Don't use XINT if it isn't int.
+ (decode_next_window_args, window_loop): Don't use XFASTINT blindly.
+
+2004-11-23 Kim F. Storm <[email protected]>
+
+ * dispextern.h (MATRIX_ROW_ENDS_IN_MIDDLE_OF_CHAR_P)
+ (MATRIX_ROW_STARTS_IN_MIDDLE_OF_CHAR_P): Not if dpvec_index is zero.
+
+ * xfaces.c (lookup_named_face): Add signal_p arg. Return -1 if
+ signal_p is zero and face name is unknown.
+ (Fx_list_fonts): Don't signal error in lookup_named_face.
+ (Fface_font): Signal error in lookup_named_face.
+ (ascii_face_of_lisp_face): Likewise.
+
+ * dispextern.h (lookup_named_face): Fix prototype.
+
+ * xdisp.c (handle_single_display_prop): Don't signal error in
+ lookup_named_face for unknown fringe face name.
+ (highlight_trailing_whitespace): Don't signal error in
+ lookup_named_face if trailing-whitespace face unknown.
+ (calc_line_height_property): Don't signal error in
+ lookup_named_face if specified face name is unknown.
+
+ * fringe.c (update_window_fringes): Show top row indicator if
+ window has header-line. Don't show arrow at bob and eob
+ if the boundary indicators are not used.
+ (Fset_fringe_bitmap_face): Signal error in lookup_named_face.
+
+ * window.c (set_window_buffer): Clear display_error_modiff.
+
+2004-11-22 Kim F. Storm <[email protected]>
+
+ * fringe.c (update_window_fringes): Provide sensible fall-back
+ value for non-nil indicate-buffer-boundaries setting.
+
+2004-11-22 Markus Rost <[email protected]>
+
+ * minibuf.c (Fminibuffer_complete_and_exit): Fix previous change.
+
+2004-11-22 Stefan Monnier <[email protected]>
+
+ * eval.c (Fdefvar): Warn when var is let-bound but globally void.
+
+2004-11-21 Kim F. Storm <[email protected]>
+
+ * xdisp.c (erase_phys_cursor): Clear hollow cursor inside TEXT_AREA.
+
+ * xterm.c (x_clip_to_row): Add area arg. Callers changed.
+ (x_draw_hollow_cursor, x_draw_bar_cursor): Clip to TEXT_AREA.
+
+ * w32term.c (w32_clip_to_row): Add area arg. Callers changed.
+ (x_draw_hollow_cursor, x_draw_bar_cursor): Clip to TEXT_AREA.
+
+ * macterm.c (x_clip_to_row): Add area arg. Callers changed.
+ (x_draw_hollow_cursor, x_draw_bar_cursor): Clip to TEXT_AREA.
+
+ * xdisp.c (move_it_in_display_line_to, display_line):
+ Restore saved_face_id if overflow-newline-into-fringe is enabled and
+ line is continued before or in middle of element from display vector.
+
+ * indent.c (Fvertical_motion): Fix last change. Use another
+ method to detect if iterator moved too far ahead after reseat.
+
+ * xdisp.c (IT_EXPAND_MATRIX_WIDTH): New macro. Do not
+ expand matrix width for overflow in zero-width area.
+ (append_glyph, append_composite_glyph, produce_image_glyph)
+ (append_stretch_glyph): Use it to avoid loop in redisplay.
+ (note_mode_line_or_margin_highlight): Don't let help-echo from
+ string override help-echo from image map.
+
+2004-11-20 Luc Teirlinck <[email protected]>
+
+ * fns.c (Fyes_or_no_p): Call Fread_from_minibuffer with extra argument.
+ * callint.c (Fcall_interactively): Ditto.
+
+2004-11-20 Stefan Monnier <[email protected]>
+
+ * minibuf.c (Fminibuffer_complete_and_exit):
+ Fixup the case of the completed value, for case-indep completion.
+
+2004-11-20 Richard M. Stallman <[email protected]>
+
+ * lisp.h (Fread_from_minibuffer): Add arg in decl.
+
+ * minibuf.c (read_minibuf): New arg KEEP_ALL. Callers changed.
+ (Fread_from_minibuffer): New arg KEEP_ALL. Callers changed.
+
+ * search.c (Vsearch_spaces_regexp):
+ Rename from Vsearch_whitespace_regexp. All uses changed.
+
+2004-11-20 Thien-Thi Nguyen <[email protected]>
+
+ * eval.c (init_eval_once): Increase `max_specpdl_size' to 650.
+
+2004-11-19 Richard M. Stallman <[email protected]>
+
+ * search.c (Vsearch_whitespace_regexp): New variable.
+ (syms_of_search): Defvar it.
+ (compile_pattern_1): Call re_set_whitespace_regexp with it.
+ (search_buffer): No regexp is trivial if Vsearch_whitespace_regexp
+ is non-nil.
+ (struct regexp_cache): New element whitespace_regexp.
+ (syms_of_search): Initialize whitespace_regexp elements.
+ (compile_pattern): Compare whitespace_regexp elements.
+ (compile_pattern_1): Set whitespace_regexp elements.
+
+ * regex.c (regex_compile): Substitute whitespace_regexp
+ for spaces, if it is nonzero.
+ (whitespace_regexp): New variable.
+ (re_set_whitespace_regexp): New function.
+
+2004-11-19 Kim F. Storm <[email protected]>
+
+ * indent.c (Fvertical_motion): Fix last change.
+
+2004-11-18 Kim F. Storm <[email protected]>
+
+ * indent.c (Fvertical_motion): Undo 2004-11-16 change.
+ Instead, move back again if reseating moves too far ahead.
+
+2004-11-17 Luc Teirlinck <[email protected]>
+
+ * xdisp.c (message3): Call clear_message.
+
+2004-11-17 Kim F. Storm <[email protected]>
+
+ * xdisp.c (erase_phys_cursor): Adjust cursor row visible height.
+
+2004-11-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_file_name): Typo in HAVE_GTK_FILE_SELECTION_NEW.
+
+ * xmenu.c (x_menu_in_use): Remove.
+ (x_menu_set_in_use): Also set popup_activated_flag.
+
+ * xfns.c (Fx_file_dialog): Call popup_activated instead of
+ x_menu_in_use. Call x_menu_set_in_use in Motif version also.
+
+ * xterm.h (x_menu_in_use): Remove.
+
+2004-11-16 Richard M. Stallman <[email protected]>
+
+ * keymap.c (Fmap_keymap): New arg SORT-FIRST.
+ Use map-keymap-internal to implement that.
+
+ * indent.c (Fvertical_motion): In batch mode, use vmotion directly.
+
+2004-11-16 Stefan Monnier <[email protected]>
+
+ * xdisp.c (get_glyph_string_clip_rect, init_glyph_string): Check it's
+ a window before using XWINDOW.
+
+ * window.c (make_window, Fselect_window, make_dummy_parent)
+ (save_window_save):
+ * frame.c (make_frame):
+ * fns.c (concat): Avoid side-effects inside XSETFASTINT's arguments.
+
+ * lisp.h (NILP): Use EQ rather than XFASTINT.
+
+2004-11-16 Kim F. Storm <[email protected]>
+
+ * fringe.c (Fdefine_fringe_bitmap): Always set 'h'. Simplify.
+
+ * indent.c (Fvertical_motion): Fix last change. Only reseat when
+ moving backwards.
+
+2004-11-16 Luc Teirlinck <[email protected]>
+
+ * dispextern.h: Extern reseat_at_previous_visible_line_start.
+
+2004-11-16 Kenichi Handa <[email protected]>
+
+ * xdisp.c (display_mode_element): Fix previous change (calculate
+ end position of substring to display correctly).
+
+2004-11-16 Kim F. Storm <[email protected]>
+
+ * keyboard.c (Fposn_at_point): Remove extra */ after doc string.
+ Reported by Andrew M. Scott.
+
+2004-11-15 Kim F. Storm <[email protected]>
+
+ * fns.c (Fsafe_plist_get): New defun.
+ (syms_of_fns): Defsubr it.
+
+ * lisp.h (Fsafe_plist_get): Add EXFUN.
+
+ * xdisp.c (store_mode_line_string, produce_stretch_glyph):
+ Use Fsafe_plist_get.
+ (note_mode_line_or_margin_highlight, note_mouse_highlight):
+ Fix image map element parsing. Use Fsafe_plist_get.
+
+2004-11-15 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (get_next_display_element): Fix previous change.
+
+2004-11-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * window.c (shrink_windows): Handle special case of one window left
+ when trying to shrink the final reminder. Grow windows if
+ total_removed is less than total_shrink.
+
+ * xmenu.c (pop_down_menu): Remove global variable current_menu,
+ extract pointer from arg with XSAVE_VALUE.
+ (create_and_show_popup_menu, create_and_show_dialog, xmenu_show):
+ Construct arg to record_unwind_protect with make_save_value.
+
+2004-11-13 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (reseat_at_previous_visible_line_start): No longer static.
+ (get_next_display_element): Fix previous change to apply only to \n.
+
+ * indent.c (Fvertical_motion): Scan to PT from start of line to
+ make iterator consistent.
+
+ * minibuf.c (syms_of_minibuf) <completion-ignore-case>: Doc fix.
+
+2004-11-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (pop_down_file_dialog): Add BLOCK_INPUT.
+
+ * xfns.c (Fx_file_dialog): Call x_menu_in_use and x_menu_set_in_use.
+ Record unwind with clean_up_file_dialog.
+
+ * xterm.h (x_menu_in_use, x_menu_set_in_use, x_menu_wait_for_event):
+ Declare.
+
+ * xmenu.c (x_menu_in_use, x_menu_set_in_use): New functions.
+
+2004-11-13 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_file_sel_ok, xg_file_sel_cancel)
+ (xg_file_sel_destroy): Remove.
+ (xg_file_response_cb, pop_down_file_dialog)
+ (xg_get_file_name_from_chooser, xg_get_file_name_from_selector):
+ New functions.
+ (xg_get_file_with_chooser, xg_get_file_with_selection):
+ Take new arg func, set it to xg_get_file_name_from_chooser/selector.
+ Move common code to xg_get_file_name. Return widget created.
+ (xg_get_file_name): Set name, transient for, modal and destroy
+ with parent here. Connect response signal to xg_file_response_cb,
+ connect delete-event to gtk_true. Record pop_down_file_dialog
+ for unwind. Do event loop and call x_menu_wait_for_event in loop.
+ (xg_create_widget): Make dialogs modal.
+
+ * xmenu.c (unuse_menu_items, pop_down_menu): Arg is of type
+ Lisp_Object.
+ (popup_get_selection): Move unwind protect ...
+ (create_and_show_popup_menu, create_and_show_dialog): ... to here.
+ Move destroy of widget to pop_down_menu.
+ (popup_widget_loop): Move unwind protect ...
+ (create_and_show_popup_menu, create_and_show_dialog): ... to here.
+ Move destroy of widget to pop_down_menu.
+ (pop_down_menu): BLOCK_INPUT and destroy widget/window.
+ (xmenu_show): Record unwind pop_down_menu. Move XMenuDestroy,
+ x_mouse_leave and grabbed = 0 to pop_down_menu.
+
+2004-11-13 Kim F. Storm <[email protected]>
+
+ * xdisp.c (make_cursor_line_fully_visible_p): New variable.
+ (syms_of_xdisp): DEFVAR_BOOL it.
+ (make_cursor_line_fully_visible, try_cursor_movement)
+ (try_window_id): Use it.
+
+2004-11-12 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct glyph_row): New member extra_line_spacing.
+ (struct it): New member max_extra_line_spacing.
+ (MR_PARTIALLY_VISIBLE, MR_PARTIALLY_VISIBLE_AT_TOP)
+ (MR_PARTIALLY_VISIBLE_AT_BOTTOM): New helper macros.
+ (MATRIX_ROW_PARTIALLY_VISIBLE_P): Fix to return false if invisible
+ part of last line is only extra line spacing (so the text on the
+ line is fully visible). Use helper macros.
+ Add W arg (to use them). All callers changed.
+ (MATRIX_ROW_PARTIALLY_VISIBLE_AT_TOP_P)
+ (MATRIX_ROW_PARTIALLY_VISIBLE_AT_BOTTOM_P): Use helper macros.
+
+ * window.c (window_scroll_pixel_based, Frecenter):
+ Use move_it_vertically_backward directly.
+ (Frecenter): Fix calculation of new start pos for negative arg.
+ Before, the new start pos was sometimes chosen too far back, so
+ the last line became only partially visible, and thus would be
+ either only semi-visible or automatically scrolled to the middle
+ of the window by redisplay.
+
+ * xdisp.c (init_iterator): Clear it.max_extra_line_spacing.
+ (move_it_vertically_backward): Don't recure to move further back.
+ (move_it_vertically): Remove superfluous condition.
+ (move_it_by_lines): Clear last_height when moved 0 lines.
+ (resize_mini_window): Use it.max_extra_line_spacing.
+ (display_tool_bar_line): Clear row->extra_line_spacing.
+ (try_scrolling): Use move_it_vertically_backward directly.
+ (redisplay_window): Likewise.
+ (compute_line_metrics): Set row->extra_line_spacing.
+ (display_line, display_string): Likewise.
+ (x_produce_glyphs): Update it->max_extra_line_spacing.
+
+ * xmenu.c (pop_down_menu): Return nil.
+
+2004-11-12 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (x_menu_wait_for_event): New function.
+ (popup_get_selection, popup_widget_loop): Call x_menu_wait_for_event
+ to handle timers.
+ (popup_widget_loop): Add argument do_timers.
+ (create_and_show_popup_menu, create_and_show_dialog): Pass 1 for
+ do_timers to popup_widget_loop.
+ (xmenu_show): Call XMenuActivateSetWaitFunction so that
+ x_menu_wait_for_event is called by XMenuActivate.
+ (create_and_show_popup_menu): Pass 1 for do_timers to
+ popup_get_selection.
+ (pop_down_menu): New function.
+ (popup_get_selection, popup_widget_loop): Unwind protect to
+ pop_down_menu.
+ (popup_widget_loop): Add argument widget.
+ (create_and_show_popup_menu, create_and_show_dialog): Pass new
+ argument widget to popup_widget_loop.
+
+2004-11-10 Stefan Monnier <[email protected]>
+
+ * keymap.c (Fkeymap_prompt): Accept symbol keymaps.
+
+2004-11-09 Kim F. Storm <[email protected]>
+
+ * xselect.c: Include <sys/types.h> and <unistd.h> (for getpid).
+ Fix various comments referring to XEvents instead of input events.
+ (x_queue_event): Fix format strings.
+ (x_stop_queuing_selection_requests): Likewise.
+
+ * xdisp.c (produce_image_glyph): Remove unused variable 'face_ascent'.
+ (pint2hrstr): Add extra braces to silence compiler.
+
+ * print.c (print_object): Fix format string.
+
+ * lread.c (read1): Fix next_char matching.
+
+ * lisp.h (Fdelete): Add EXFUN.
+ (replace_range_2): Add prototype.
+
+ * keyboard.c (read_avail_input): Remove unused variable 'discard'.
+
+ * intervals.h (NULL_INTERVAL_P): Add separate version when
+ ENABLE_CHECKING is not defined to silence compiler.
+ (compare_string_intervals): Add prototype.
+
+ * fringe.c (destroy_fringe_bitmap): Fix return type.
+ (Ffringe_bitmaps_at_pos): Remove unused var 'old_buffer'.
+
+ * emacs.c (Fdump_emacs): Fix format string.
+
+ * doc.c: Include <ctype.h>.
+ (Fsubstitute_command_keys): Remove unused variable 'firstkey'.
+
+ * data.c (store_symval_forwarding): Remove unused variables.
+
+ * callint.c (Fcall_interactively): Remove unused variable 'funcar'.
+
+2004-11-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * Makefile.in (stamp-oldxmenu): If HAVE_GTK, don't add dependencies
+ to ${OLDXMENU}.
+
+2004-11-09 Kim F. Storm <[email protected]>
+
+ * process.c (Fmake_network_process): Remove kludge for interrupted
+ connects on BSD. If connect is interrupted, just close socket and
+ start over rather than sleeping and retry with same socket.
+
+2004-11-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * .cvsignore: Add buildobj.lst.
+
+ * doc.c: New variable Vbuild_files.
+ (Fsnarf_documentation): If Vbuild_files is nil, populate it with
+ file names from buildobj.lst. Only attach docstrings from files
+ that are in Vbuild_files.
+ (syms_of_doc): Defvar Vbuild_files.
+
+ * Makefile.in (SOME_MACHINE_OBJECTS): Add fringe.o, image.o
+ and w32*.o.
+ (temacs${EXEEXT}): Generate buildobj.lst when temacs is linked.
+ (mostlyclean): Rm buildobj.lst.
+
+ * makefile.w32-in ($(TEMACS)): Generate buildobj.lst when temacs
+ is linked.
+
+2004-11-09 Kim F. Storm <[email protected]>
+
+ * fringe.c (update_window_fringes): Update fringe bitmaps if
+ cur and row ends_at_zv_p differs. If bitmaps of a row is updated,
+ also update previous row to get rid of misc. artifacts.
+
+2004-11-08 Kim F. Storm <[email protected]>
+
+ * xdisp.c (fast_find_position): Fix start pos if header line present.
+ (note_mouse_highlight): Clear mouse face if we move out of text area.
+
+2004-11-08 Eli Zaretskii <[email protected]>
+
+ * editfns.c: Move #include "systime.h" before <sys/resource.h>.
+ Don't include <sys/time.h> explicitly.
+ Include <stdio.h> unconditionally, not just on MacOS.
+
+2004-11-08 Kenichi Handa <[email protected]>
+
+ * fontset.c (fontset_pattern_regexp): Cancel my previous change;
+ don't pay attention to '\' before '*'.
+ (fontset_pattern_regexp): Change the meaning of the second arg.
+ (Fnew_fontset): Call fs_query_fontset, not Fquery_fontset.
+ (check_fontset_name): Try NAME as literal at first, and if it
+ failes, try NAME as pattern.
+
+2004-11-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * emacs.c (Fdump_emacs): Only output warning on GNU/Linux.
+
+2004-11-07 Andreas Schwab <[email protected]>
+
+ * lisp.h (Fmsdos_downcase_filename): Declare.
+ * dired.c (Fmsdos_downcase_filename): Don't declare here.
+ * fileio.c: Likewise.
+
+2004-11-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * dosfns.c (Fdos_memget, Fdos_memput): Use integer variable offs in
+ comparisons with integers instead of Lisp_Object address.
+ (Fmsdos_set_keyboard): Declare argument allkeys.
+
+ * msdos.c (IT_set_frame_parameters): Use EQ, not ==, for Lisp_Object:s.
+
+ * dired.c (Fmsdos_downcase_filename): Declare extern on MSDOS to avoid
+ int/Lisp_Object mixup.
+
+ * fileio.c: Ditto.
+
+2004-11-06 Steven Tamm <[email protected]>
+
+ * editfns.c: Need to include sys/time.h before resource.h on darwin.
+
+2004-11-06 Richard M. Stallman <[email protected]>
+
+ * callint.c (Fcall_interactively): Avoid reusing EVENT for other data.
+
+ * xfaces.c (merge_named_face): GCPRO the face_name in the
+ named_merge_point struct that we make.
+ (merge_face_heights): Eliminate GCPRO arg. All callers changed.
+
+ * keyboard.c (command_loop_1): Change Vtransient_mark_mode
+ before deciding whether to inactivate mark.
+
+2004-11-06 Lars Brinkhoff <[email protected]>
+
+ * config.in: Regenerate (add HAVE_GETRUSAGE).
+ * editfns.c (Fget_internal_run_time): New function.
+ (syms_of_data): Defsubr it.
+ * fns.c (sxhash): As far as possible, merge calculation of
+ hash code for symbols and strings.
+
+2004-11-06 Eli Zaretskii <[email protected]>
+
+ * frame.c (syms_of_frame): Fix the example in the doc string.
+
+2004-11-06 Jan Dj,Ad(Brv <[email protected]>
+
+ * eval.c (Feval): Remove check for INPUT_BLOCKED_P.
+
+ * xmenu.c (popup_get_selection, create_and_show_popup_menu)
+ (create_and_show_dialog): Revert change from 2004-10-31.
+
+2004-11-05 Luc Teirlinck <[email protected]>
+
+ * macros.c (syms_of_macros) <defining-kbd-macro>: Doc fix.
+
+2004-11-05 Kim F. Storm <[email protected]>
+
+ * print.c (print_object): Print Lisp_Misc_Save_Value objects.
+
+ * fileio.c (Ffile_modes): Doc fix.
+ (auto_save_1): Check for Ffile_modes nil value.
+
+2004-11-05 Kim F. Storm <[email protected]>
+
+ * xselect.c (struct selection_event_queue, selection_queue)
+ (x_queue_selection_requests, x_queue_event)
+ (x_start_queuing_selection_requests)
+ (x_stop_queuing_selection_requests): Add new queue for selection
+ input events to replace previous XEvent queue in xterm.c.
+ (queue_selection_requests_unwind): Adapt to new queue.
+ (x_reply_selection_request): Adapt to new queue.
+ Unexpect wait_object in case of x errors (memory leak).
+ (x_handle_selection_request, x_handle_selection_clear): Make static.
+ (x_handle_selection_event): New function. May queue selection events.
+ (wait_for_property_change_unwind): Use save_value instead of cons.
+ Clear property_change_reply_object.
+ (wait_for_property_change): Abort if already waiting.
+ Use save_value instead of cons for unwind data.
+ (x_handle_property_notify): Skip events already arrived, but don't
+ free them, as "arrived" field is checked by wait_for_property_change,
+ and it will be freed by unwind or explicit unexpect_property_change.
+ (x_get_foreign_selection): Add to new queue.
+ (receive_incremental_selection): Don't unexpect wait_object when done
+ as it has already been freed by previous wait_for_property_change.
+
+ * xterm.h (x_start_queuing_selection_requests)
+ (x_stop_queuing_selection_requests, x_handle_selection_request)
+ (x_handle_selection_clear): Remove prototypes.
+ (x_handle_selection_event): Add prototype.
+
+ * xterm.c (handle_one_xevent): Don't queue X selection events
+ here, it may be too late if we start queuing after we have already
+ stored some selection events into the kbd buffer.
+ (struct selection_event_queue, queue, x_queue_selection_requests)
+ (x_queue_event, x_unqueue_events, x_start_queuing_selection_requests)
+ (x_stop_queuing_selection_requests): Remove/move to xselect.c.
+ (x_catch_errors_unwind): Block input around final XSync.
+
+ * keyboard.h (kbd_buffer_unget_event): Add prototype.
+
+ * keyboard.c (kbd_buffer_store_event_hold): Remove obsolete code.
+ (kbd_buffer_unget_event): New function.
+ (kbd_buffer_get_event, swallow_events): Combine SELECTION events
+ and use x_handle_selection_event.
+ (mark_kboards): Don't mark x and y of SELECTION_CLEAR_EVENT.
+
+2004-11-05 Jan Dj,Ad(Brv <[email protected]>
+
+ * xselect.c (TRACE3): New debug macro.
+ (x_reply_selection_request): Use it.
+ (receive_incremental_selection): In call to TRACE0, the name of
+ a symbol is in xname.
+
+2004-11-05 Kim F. Storm <[email protected]>
+
+ * fontset.c (fontset_pattern_regexp): Use unsigned char.
+
+2004-11-04 Jan Dj,Ad(Brv <[email protected]>
+
+ * fileio.c (Fnext_read_file_uses_dialog_p): New function.
+
+ * gtkutil.h (use_old_gtk_file_dialog): Declare.
+
+ * gtkutil.c: Make use_old_gtk_file_dialog non-static.
+ (xg_initialize): Move DEFVAR_BOOL for use_old_gtk_file_dialog ...
+ * xfns.c (syms_of_xfns): ... to here.
+
+ * gtkutil.c (xg_get_file_with_chooser): Expand DEFAULT_FILENAME if
+ it doesn't start with /.
+
+2004-11-04 Kenichi Handa <[email protected]>
+
+ * fontset.c (fontset_pattern_regexp): If '*' is preceded by '\',
+ treat it as a literal character.
+
+2004-11-03 Kim F. Storm <[email protected]>
+
+ * .gdbinit (ppt): New function.
+
+2004-11-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_window_to_scroll_bar): Only call
+ xg_get_scroll_id_for_window if toolkit scroll bars are used.
+
+ * gtkutil.c (xg_get_file_with_chooser): Use GTK_STOCK_OK instead
+ of save.
+
+2004-11-02 Andreas Schwab <[email protected]>
+
+ * window.c (Fscroll_right): Fix last change.
+
+2004-11-02 Kim F. Storm <[email protected]>
+
+ * Makefile.in (callproc.o): Depend on blockinput.h, atimer.h, systime.h.
+
+2004-11-02 YAMAMOTO Mitsuharu <[email protected]>
+
+ * callproc.c (Fcall_process): Block input around vfork.
+
+2004-11-02 Kim F. Storm <[email protected]>
+
+ * eval.c (Fcalled_interactively_p): Rename from Fcall_interactive_p.
+ (syms_of_eval): Defsubr it.
+
+2004-11-02 Richard M. Stallman <[email protected]>
+
+ * insdel.c (replace_range_2): New function.
+
+ * casefiddle.c (casify_region): Handle changes in byte-length
+ using replace_range_2.
+
+ * emacs.c (USAGE3): Delete --horizontal-scroll-bars, -hb.
+
+ * xdisp.c (back_to_previous_visible_line_start):
+ Subtract 1 from pos when checking previous newline for invisibility.
+
+ * window.c (window_scroll_pixel_based): Update preserve_y
+ for header line if any.
+ (Fscroll_left, Fscroll_right): Don't call interactive_p;
+ use a new second argument instead.
+
+ * eval.c (Fcall_interactive_p): New function.
+ (interactive_p): Don't test INTERACTIVE here.
+ (Finteractive_p): Doc fix.
+
+ * eval.c (Feval): Abort if INPUT_BLOCKED_P.
+
+2004-11-02 KOBAYASHI Yasuhiro <[email protected]>
+
+ * w32fns.c (w32_font_match): Use fast_string_match_ignore_case for
+ comparing font names.
+
+2004-11-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * fileio.c (Fread_file_name): Pass Qt as fifth parameter to
+ Fx_file_dialog if only directories should be read.
+
+ * lisp.h: Fx_file_dialog takes 5 parameters.
+
+ * xfns.c (Fx_file_dialog): Both Motif and GTK version:
+ Add parameter only_dir_p.
+ In Motif version, don't put DEFAULT_FILENAME in filter part of the
+ dialog, just text field part. Do not add DEFAULT_FILENAME
+ to list of files if it isn't there.
+ In GTK version, pass only_dir_p parameter to xg_get_file_name.
+
+ * macfns.c (Fx_file_dialog): Add parameter only_dir_p.
+ Check only_dir_p instead of comparing prompt to "Dired". When using
+ a save dialog, add option kNavDontConfirmReplacement, change title
+ to "Enter name", change text for save button to "Ok".
+
+ * w32fns.c (Fx_file_dialog): Add parameter only_dir_p.
+ Check only_dir_p instead of comparing prompt to "Dired".
+
+ * gtkutil.c (xg_get_file_with_chooser, xg_get_file_with_selection):
+ New functions, only defined ifdef HAVE_GTK_FILE_CHOOSER_DIALOG_NEW
+ and HAVE_GTK_FILE_SELECTION_NEW respectively.
+ (xg_get_file_name): Add parameter only_dir_p.
+ Call xg_get_file_with_chooser or xg_get_file_with_selection
+ depending on HAVE_GTK_FILE* and the value of use_old_gtk_file_dialog.
+ (xg_initialize): New DEFVAR_BOOL use_old_gtk_file_dialog.
+
+ * gtkutil.h (xg_get_file_name): Add parameter only_dir_p.
+
+ * config.in: Rebuild (added HAVE_GTK_FILE_*).
+
+2004-11-01 Kim F. Storm <[email protected]>
+
+ * process.c (connect_wait_mask, num_pending_connects):
+ Only declare and use them if NON_BLOCKING_CONNECT is defined.
+ (init_process): Initialize them if NON_BLOCKING_CONNECT defined.
+ (IF_NON_BLOCKING_CONNECT): New helper macro.
+ (wait_reading_process_output): Only declare and use local vars
+ Connecting and check_connect when NON_BLOCKING_CONNECT is defined.
+
+2004-11-01 Andy Petrusenco <[email protected]> (tiny change)
+
+ * w32term.c (x_scroll_run): Delete region objects after use.
+
+2004-10-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c: Add prototypes for forward function declarations.
+ (popup_get_selection): Remove parameter do_timers, remove call to
+ timer_check.
+ (create_and_show_popup_menu, create_and_show_dialog):
+ Remove parameter do_timers from call to popup_get_selection.
+
+ * xdisp.c (update_tool_bar): Pass a copy of f->tool_bar_items to
+ tool_bar_items and assign the result to f->tool_bar_items if
+ not equal. Move BLOCK/UNBLOCK_INPUT from around call to
+ tool_bar_items to assignment of result.
+
+ * atimer.c (alarm_signal_handler): Do not call set_alarm if
+ pending_atimers is non-zero.
+
+2004-10-31 Kim F. Storm <[email protected]>
+
+ * dispnew.c (margin_glyphs_to_reserve): Don't use ncols_scale_factor.
+
+2004-10-28 Will <[email protected]>
+
+ * macterm.c: Allow user to assign key modifiers to the Mac Option
+ key via a 'mac-option-modifier' variable.
+
+2004-10-28 Stefan Monnier <[email protected]>
+
+ * xselect.c (Vx_lost_selection_functions, Vx_sent_selection_functions):
+ Rename from Vx_lost_selection_hooks and Vx_sent_selection_hooks.
+ (x_handle_selection_request, x_handle_selection_clear)
+ (x_clear_frame_selections, syms_of_xselect): Adjust accordingly.
+
+2004-10-28 Richard M. Stallman <[email protected]>
+
+ * w32fns.c (Fx_server_vendor, Fx_server_version): Doc fixes.
+
+ * xfns.c (Fx_server_vendor, Fx_server_version): Doc fixes.
+
+2004-10-27 Stefan Monnier <[email protected]>
+
+ * syntax.c (scan_sexps_forward): Give precedence to a 2-char
+ comment-starter over a 1-char one.
+
+2004-10-27 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (get_next_display_element): In mode lines,
+ treat newline and tab like other control characters.
+
+ * editfns.c (Fmessage): Doc fix.
+
+ * indent.c (vmotion): When moving up, check the newline before.
+ Make prevline an int, not a Lisp_Object.
+
+2004-10-27 Kim F. Storm <[email protected]>
+
+ * editfns.c (Fformat): Allocate discarded table with SAFE_ALLOCA.
+ Only allocate info and discarded tables once.
+
+ * lisp.h (USE_SAFE_ALLOCA): Add and init sa_must_free integer.
+ (SAFE_ALLOCA, SAFE_ALLOCA_LISP): Increment it when malloc is used.
+ (SAFE_FREE): Test it to determine if we need to unwind to free.
+ Remove size arg. All users changed.
+ (SAFE_FREE_LISP): Remove. All users changed to use SAFE_FREE.
+
+2004-10-26 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c: Put empty line between comment and function body.
+ (xg_destroy_widgets): Rename from remove_from_container.
+ Just destroy all widgets in list. Argument wcont removed.
+ (xg_update_menubar, xg_update_submenu): Call xg_destroy_widgets
+ instead of remove_from_container.
+ (xg_display_close, xg_create_tool_bar, update_frame_tool_bar)
+ (free_frame_tool_bar): Add comment.
+
+ * xfns.c (xic_create_xfontset): Check that FRAME_XIC_BASE_FONTNAME
+ is not NULL before strcmp.
+
+2004-10-26 Kim F. Storm <[email protected]>
+
+ * callint.c (Fcall_interactively): Add 'U' code to get the
+ up-event discarded by a previous 'k' or 'K' argument.
+
+2004-10-26 David Kastrup <[email protected]>
+
+ * buffer.c (syms_of_buffer): Fix a few typos.
+
+2004-10-26 Jan Dj,Ad(Brv <[email protected]>
+
+ * xsmfns.c: Put empty line between comment and function body.
+ Use two spaces before comment end.
+
+2004-10-25 Kenichi Handa <[email protected]>
+
+ * fontset.c (fontset_pattern_regexp): Optimize for the case that
+ PATTERN is full XLFD.
+
+2004-10-24 Kenichi Handa <[email protected]>
+
+ * regex.h (enum reg_errcode_t): New value REG_ERANGEX.
+
+ * regex.c (re_error_msgid): Add an entry for REG_ERANGEX.
+ (regex_compile): Return REG_ERANGEX if appropriate.
+
+2004-10-22 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (xic_create_xfontset): Initialize missing_list to NULL.
+
+2004-10-21 K,Aa(Broly L$,1 q(Brentey <[email protected]>
+
+ * xterm.h (x_output): New member `xic_base_fontname'.
+ (FRAME_XIC_BASE_FONTNAME): New macro.
+ (xic_free_xfontset): Declare.
+
+ * xfns.c (xic_create_xfontset): Share fontsets between frames
+ based on base_fontname.
+ (xic_free_xfontset): New function.
+ (free_frame_xic): Use it.
+ (xic_set_xfontset): Ditto.
+
+ * xterm.c (xim_destroy_callback): Ditto.
+
+2004-10-20 B. Anyos <[email protected]> (tiny change)
+
+ * w32term.c (x_draw_glyph_string): Use overline_color for overlines.
+
+2004-10-20 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h (XSync): If USE_GTK, define XSync as process_all and then
+ XSync.
+
+ * emacs.c (my_heap_start, heap_bss_diff, MAX_HEAP_BSS_DIFF):
+ New variables and constant.
+ (main): Calculate heap_bss_diff. If we are dumping and the
+ heap_bss_diff is greater than MAX_HEAP_BSS_DIFF, set PER_LINUX32
+ and exec ourself again.
+ (Fdump_emacs): If heap_bss_diff is greater than MAX_HEAP_BSS_DIFF
+ print a warning.
+
+ * lastfile.c: Make my_endbss and my_endbss_static available on all
+ platforms.
+
+ * Makefile.in (RUN_TEMACS): Remove @SETARCH@.
+ * config.in (HAVE_PERSONALITY_LINUX32): Regenerate.
+
+2004-10-19 Luc Teirlinck <[email protected]>
+
+ * data.c (Flocal_variable_if_set_p): Doc fix.
+
+2004-10-19 Jason Rumney <[email protected]>
+
+ * w32.c (init_environment): Set emacs_dir correctly when running
+ emacs from the build directory.
+
+2004-10-19 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fdelete_and_extract_region):
+ If region is empty, return null string.
+
+2004-10-19 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.h (xg_update_scrollbar_pos): Remove arguments real_left
+ and canon_width.
+ (xg_frame_cleared): Remove.
+
+ * gtkutil.c (xg_frame_cleared, xg_fixed_handle_expose)
+ (xg_find_top_left_in_fixed): Remove.
+ (xg_create_scroll_bar): Put an event box widget between
+ the scroll bar widget and the edit widget.
+ (xg_show_scroll_bar): Show the parent widget (the event box).
+ (xg_remove_scroll_bar): Destroy parent (the event box) also.
+ (xg_update_scrollbar_pos): Remove arguments real_left and canon_width.
+ Move the parent (the event box) widget inside the fixed widget.
+ Move window clear to xterm.c.
+
+ * gtkutil.h (xg_frame_cleared): Remove.
+
+ * xterm.c (x_clear_frame): Remove call to xg_frame_cleared
+ (x_scroll_bar_create, XTset_vertical_scroll_bar):
+ Remove arguments left and width to xg_update_scrollbar_pos.
+ (XTset_vertical_scroll_bar): Do x_clear_area for USE_GTK also.
+
+2004-10-19 Kenichi Handa <[email protected]>
+
+ * xdisp.c (display_mode_element): Fix display of wide chars.
+
+2004-10-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_update_scrollbar_pos): Change XClearWindow to
+ gdk_window_clear and move gdk_window_process_all_updates after
+ clear so events are sent to the X server in correct order.
+
+2004-10-18 Kenichi Handa <[email protected]>
+
+ * fontset.c (fs_load_font): Use fast_string_match_ignore_case for
+ comparing font names.
+ (fs_query_fontset): Use fast_string_match for comparing fontset names.
+ (list_fontsets): Likewise.
+
+ * search.c (fast_string_match_ignore_case): New function.
+
+ * lisp.h (fast_string_match_ignore_case): Extern it.
+
+2004-10-17 Kim F. Storm <[email protected]>
+
+ * xdisp.c (overlay_arrow_at_row): Return overlay string rather
+ than bitmap if there is not left fringe.
+ (get_overlay_arrow_glyph_row): Also used on windows system.
+ (display_line): Display overlay string if no left fringe.
+
+2004-10-16 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_font_match): Encode font name being matched.
+
+2004-10-16 Richard M. Stallman <[email protected]>
+
+ * window.c (Fspecial_display_p): Doc fix.
+
+2004-10-15 Stefan Monnier <[email protected]>
+
+ * doc.c (Fsubstitute_command_keys): Fix remap-handling.
+ Don't ignore menus, because where-is-internal already does it for us.
+
+2004-10-15 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Only update fringes and vertical
+ border on window frames.
+
+2004-10-14 Andreas Schwab <[email protected]>
+
+ * m/ia64.h (DATA_SEG_BITS): Don't define.
+
+2004-10-14 Kim F. Storm <[email protected]>
+
+ * xterm.h: Include Xutil.h after keysym.h to work around bug
+ in some X versions.
+
+2004-10-13 Stefan Monnier <[email protected]>
+
+ * fns.c (map_char_table): Add missing gcpros.
+
+2004-10-13 Stefan Monnier <[email protected]>
+
+ * keymap.c (get_keymap): An autoload form is not a keymap.
+
+ * textprop.c (syms_of_textprop): Make `syntax-table' nonsticky.
+
+2004-10-13 Kim F. Storm <[email protected]>
+
+ * callproc.c (Fcall_process): Simplify handling of display arg.
+ Resume `display_on_the_fly' once a coding system is determined.
+
+ * xdisp.c (redisplay_preserve_echo_area): Fix last change.
+
+2004-10-12 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_preserve_echo_area): Flush display in case
+ caller, such as call-process, is not going to poll for input.
+ (calc_line_height_property): Handle case where it->object is nil.
+
+ * xterm.c (x_redisplay_interface): Fix flush_display_optional.
+
+2004-10-12 Kenichi Handa <[email protected]>
+
+ * xdisp.c (get_next_display_element):
+ If unibyte_display_via_language_environment is zero, display 8-bit
+ chars in octal in unibyte buffer.
+
+2004-10-12 Kim F. Storm <[email protected]>
+
+ * doc.c (Fsubstitute_command_keys): Ignore remappings unless there
+ are no ordinary bindings.
+
+2004-10-11 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (syms_of_xfns): Defsubr x-file-dialog for GTK also.
+
+2004-10-10 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (x_raise_frame): Add BLOCK_INPUT around SelectWindow.
+ (x_lower_frame): Add BLOCK_INPUT around SendBehind.
+ (make_mac_frame): Add BLOCK_INPUT around the making of a
+ terminal frame.
+ (mac_initialize): Add BLOCK_INPUT around carbon initialization.
+ * macgui.h (mktime): Use emacs_mktime.
+ * macfns.c (Fx_file_dialog): Add BLOCK_INPUT around more code.
+ Make a cancel file-open dialog be like C-g.
+ * mac.c (mktime): Use emacs_mktime.
+ (Fdo_applescript): Add BLOCK_INPUT around do_applescript.
+ (Fmac_paste_function): Add better error handling for carbon cut/paste.
+
+2004-10-10 Kim F. Storm <[email protected]>
+
+ * keyboard.c (timer_resume_idle): New function to resume idle
+ timer without resetting timers on the idle list.
+ (read_char): Use timer_resume_idle. Remove local var last_idle_start.
+ (timer_start_idle, timer_stop_idle): Declare static.
+ (read_key_sequence): Use timer_resume_idle instead of timer_start_idle.
+
+ * keyboard.h (timer_start_idle, timer_stop_idle): Remove prototypes.
+
+2004-10-08 Steven Tamm <[email protected]>
+
+ * config.in (HAVE_MALLOC_MALLOC_H): Regenerate.
+ * macterm.c (mac_check_for_quit_char): Remove warning for using
+ NULL where 0 should be used.
+ * unexmacosx.c: Use malloc/malloc.h on Tiger instead of
+ objc/malloc.h
+ * mac.c: Include time.h for Tiger compatibility.
+
+2004-10-07 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Fix flicker on vertical line between
+ windows. Update vertical line after drawing window fringes, but
+ only if actually drawing any bitmaps--or there is no fringe.
+
+ * xterm.c (x_update_window_end): Likewise.
+ * macterm.c (x_update_window_end): Likewise.
+ * w32term.c (x_update_window_end): Likewise.
+
+ * fringe.c (draw_window_fringes): Return value now indicates if
+ any fringe bitmaps were redrawn (or there are no fringes).
+
+ * dispextern.h (draw_window_fringes): Update prototype.
+
+2004-10-06 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (mac_get_window_bounds): Add extern.
+ (x_real_positions): Use mac_get_window_bounds.
+
+ * macmenu.c (update_submenu_strings): Apply 2004-09-07 change for
+ xmenu.c (YAILOM).
+
+ * macterm.c [!MAC_OSX]: Include Windows.h.
+ (front_emacs_window): Rename from mac_front_window. All uses
+ changed. Return the frontmost non-tooltip emacs window.
+ (mac_get_window_bounds): New function.
+ (x_calc_absolute_position): Use the difference of width and height
+ between the inner and outer window.
+ (x_set_offset): Specify window position by the coordinae of the
+ outer window. Adjust the position if the title bar is completely
+ outside the screen.
+ (app_is_suspended, app_sleep_time): Remove unused variables.
+ (do_app_resume, do_app_suspend): Remove their contents because
+ window-activate/deactivate events will do the job.
+ (do_zoom_window): Remove unused variables. Make compliant to the
+ standard way of zooming. Set f->left_pos and f->top_pos.
+ (XTread_socket): Don't use argument `expected'. Don't use
+ FrontWindow to determine the clicked window. Exclude unprocessed
+ mouseUp cases in the early stage. Add parentheses to fix operator
+ precedence.
+ (XTread_socket) [TARGET_API_MAC_CARBON]: Don't specify drag area.
+
+2004-10-05 Jan Dj,Ad(Brv <[email protected]>
+
+ * config.in: Regenerate.
+
+ * Makefile.in (RUN_TEMACS): Check HAVE_RANDOM_HEAPSTART instead of
+ HAVE_EXECSHIELD.
+
+2004-10-05 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_find_modifier_meanings): Ignore any Super or Hyper for
+ a row if Alt or Meta has been found for that row. Also stop scanning
+ for Keysyms for that row.
+
+2004-10-04 Kim F. Storm <[email protected]>
+
+ * fringe.c (Ffringe_bitmaps_at_pos): Change return value from cons
+ to list. Include overlay arrow bitmap in return value.
+
+ * xterm.c (XTset_vertical_scroll_bar): Improve handling of scroll
+ bars with fractional column width. If scroll bar separates two
+ windows, move it towards the window it belongs to. Only update
+ the padding area below the scroll bar widget when necessary,
+ i.e. when scroll bar widget is created, moved, or resized.
+
+ * xdisp.c (define_frame_cursor1): Do not change frame cursor
+ while tracking/dragging mouse.
+ (x_draw_vertical_border): Do not draw line if frame has scroll bars.
+
+ * window.c (coordinates_in_window): Relax check for cursor
+ on vertial border between mode lines.
+ (Fset_window_fringes): Do not allow negative widths.
+ (Fset_window_scroll_bars): Likewise.
+
+ * .gdbinit (pp): Shorthand for p ARG + pr.
+ (ff): New command: flush frame updates (X only).
+
+2004-10-03 Michael Albinus <[email protected]>
+
+ * fileio.c (auto_save_1) Call Ffile_modes for remote files.
+
+2004-09-30 Kenichi Handa <[email protected]>
+
+ * process.c (send_process): Free composition data.
+
+ * fileio.c (Finsert_file_contents): Free composition data.
+
+ * coding.c (code_convert_region): Don't skip ASCIIs if there are
+ compositions to encode.
+ (encode_coding_string): Likewise. Free composition data.
+
+2004-09-30 Florian Weimer <[email protected]>
+
+ * coding.c (code_convert_region): Free composition data.
+
+2004-09-29 Kim F. Storm <[email protected]>
+
+ * fringe.c: Remove limit on number of bitmaps.
+ (fringe_bitmaps, fringe_faces): Change to pointers.
+ (max_fringe_bitmaps): New var.
+ (Fdefine_fringe_bitmap): Expand fringe_bitmaps and fringe_faces.
+ (init_fringe): Allocate fringe_bitmaps and fringe_faces.
+
+ * dispextern.h (FRINGE_ID_BITS): Increase to 16 bits (64K bitmaps).
+ (struct glyph_row): Reorder fringe_bitmap related fields.
+ (struct it): Likewise.
+
+ * w32term.c (fringe_bmp): Change to pointer.
+ (max_fringe_bmp): New var.
+ (w32_define_fringe_bitmap): Expand fringe_bmp.
+ (w32_draw_fringe_bitmap): Check max_fringe_bmp.
+ (w32_destroy_fringe_bitmap): Likewise.
+
+2004-09-29 Kim F. Storm <[email protected]>
+
+ * fringe.c: Simplify last change.
+ (lookup_fringe_bitmap): New function.
+ (valid_fringe_bitmap_p, resolve_fringe_bitmap): Remove.
+ (Fdestroy_fringe_bitmap): Use lookup_fringe_bitmap.
+ Keep standard bitmaps in Vfringe_bitmaps.
+ (Fdefine_fringe_bitmap): Use lookup_fringe_bitmap.
+ (Fset_fringe_bitmap_face): Likewise.
+
+ * dispextern.h (lookup_fringe_bitmap): Add prototype.
+ (valid_fringe_bitmap_p): Remove prototype.
+
+ * xdisp.c (handle_single_display_prop): Use lookup_fringe_bitmap.
+
+2004-09-29 Kim F. Storm <[email protected]>
+
+ * fringe.c (destroy_fringe_bitmap, init_fringe_bitmap)
+ (w32_init_fringe, w32_reset_fringes): Fix bootstrap (NULL rif).
+
+ * dispextern.h (valid_fringe_bitmap_p): Fix prototype.
+
+ * fringe.c (Vfringe_bitmaps): New variable.
+ (syms_of_fringe): DEFVAR_LISP it.
+ (valid_fringe_bitmap_p): Rename from valid_fringe_bitmap_id_p.
+ Change arg to Lisp_Object and fail if not an integer.
+ (get_fringe_bitmap_name, resolve_fringe_bitmap)
+ (destroy_fringe_bitmap): New functions.
+ (Fdestroy_fringe_bitmap): Change arg to bitmap symbol.
+ Use destroy_fringe_bitmap. Remove symbol from Vfringe_bitmaps and
+ clear its fringe property.
+ (init_fringe_bitmap): Use destroy_fringe_bitmap instead of
+ Fdestroy_fringe_bitmap.
+ (Fdefine_fringe_bitmap): Add BITMAP arg specifying new or existing
+ bitmap symbol; remove WHICH arg. Add symbol to Vfringe_bitmaps
+ and set fringe property. Signal error if no free slots.
+ (Fset_fringe_bitmap_face): Change arg to bitmap symbol.
+ (Ffringe_bitmaps_at_pos): Return bitmap symbols instead of numbers.
+
+ * xdisp.c (handle_single_display_prop): Fringe bitmaps are now
+ symbols with a fringe property.
+
+2004-09-27 Kim F. Storm <[email protected]>
+
+ * buffer.c (syms_of_buffer) <indicate-buffer-boundaries>:
+ Doc fix. Format may now be a symbol or alist, not a cons.
+
+ * fringe.c (update_window_fringes): Handle new formats of
+ indicate-buffer-boundaries (symbol or alist). No longer
+ allow a simple cons.
+ (Ffringe_bitmaps_at_pos): Use nil value for no bitmap.
+
+2004-09-25 Jan Dj,Ad(Brv <[email protected]>
+
+ * config.in: Rebuild.
+
+2004-09-24 Jan Dj,Ad(Brv <[email protected]>
+
+ * config.in: Rebuild.
+
+ * Makefile.in: Run setarch i386 ./temacs if exec-shield is present.
+
+2004-09-18 Stefan Monnier <[email protected]>
+
+ * xterm.c (x_term_init): Work around a bug in some X servers.
+
+2004-09-18 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer) <default-major-mode>: Doc fix.
+
+ * xdisp.c (try_window_reusing_current_matrix):
+ Handle the case where we reach the old displayed text,
+ out of sync with the old line boundary.
+
+2004-09-14 Stefan Monnier <[email protected]>
+
+ * fileio.c (Finsert_file_contents): Fix case of replacement in a
+ narrowed buffer.
+
+2004-09-14 Kim F. Storm <[email protected]>
+
+ * puresize.h (PURESIZE_RATIO): Define based on BITS_PER_EMACS_INT.
+
+ * xfaces.c (Qface_no_inherit): New var.
+ (syms_of_xfaces): Intern and staticpro it.
+ (Finternal_make_lisp_face, Finternal_set_lisp_face_attribute)
+ (Finternal_copy_lisp_face, update_face_from_frame_parameter):
+ Don't increment face_change_count when face has non-nil
+ face-no-inherit property.
+
+2004-09-13 Stefan Monnier <[email protected]>
+
+ * bytecode.c (BYTE_CODE_QUIT): Add missing AFTER_POTENTIAL_GC.
+ (Fbyte_code): Remove dead code after `wrong_type_argument'.
+
+ * alloc.c (Fgarbage_collect): Mark keyboards, gtk data, and specpdl
+ before doing the mark_stack_check_gcpros since they're not on the stack.
+
+2004-09-12 Kim F. Storm <[email protected]>
+
+ * editfns.c (Fformat): Handle format strings with multiple text
+ properties. Reverse text property list from the format string,
+ so the positions are in increasing order.
+
+2004-09-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * xselect.c (x_reply_selection_request): XSync and UNBLOCK before
+ x_uncatch_errors so that possible protocol errors are delivered.
+
+2004-09-10 Eli Zaretskii <[email protected]>
+
+ * Makefile.in (msdos.o): Depend on buffer.h, commands.h, and
+ blockinput.h.
+ (dosfns.o): Depend on blockinput.h, window.h, dispextern.h,
+ charset.h, and coding.h
+ (w16select.o): Depend on buffer.h, charset.h, coding.h, and composite.h.
+ (term.o): Depend on window.h and keymap.h.
+ (abbrev.o): Depend on syntax.h.
+ (callint.o): Depend on keymap.h.
+ (casefiddle.o): Depend on charset.h and keymap.h.
+ (category.o): Depend on keymap.h.
+ (coding.o): Depend on dispextern.h.
+ (cmds.o): Depend on keyboard.h and keymap.h.
+ (dispnew.o): Depend on indent.h and intervals.h.
+ (doc.o): Depend on keymap.h.
+ (editfns.o): Depend on frame.h.
+ (emacs.o): Depend on dispextern.h.
+ (fileio.o): Don't depend on ccl.h.
+ (filelock.o): Depend on charset.h and coding.h.
+ (frame.o): Depend on w32term.h and macterm.h.
+ (insdel.o): Depend on region-cache.h.
+ (keyboard.o): Depend on keymap.h, w32term.h, and macterm.h.
+ (minibuf.o): Depend on $(INTERVALS_SRC) and keymap.h.
+ (search.o): Depend on $(INTERVALS_SRC).
+ (syntax.o): Depend on keymap.h, regex.h, and $(INTERVALS_SRC).
+ (window.o): Depend on keymap.h, blockinput.h, $(INTERVALS_SRC),
+ xterm.h, w32term.h, and macterm.h.
+ (xdisp.o): Depend on keyboard.h, $(INTERVALS_SRC), xterm.h,
+ w32term.h, and macterm.h.
+ (xfaces.o): Depend on keyboard.h, $(INTERVALS_SRC),
+ region-cache.h, xterm.h, w32term.h, and macterm.h.
+ (bytecode.o): Depend on dispextern.h, frame.h, and xterm.h.
+ (data.o): Depend on frame.h.
+ (fns.o): Depend on keymap.h, xterm.h, and blockinput.h.
+ (print.o): Depend on termchar.h and $(INTERVALS_SRC).
+ (lread.o): Depend on $(INTERVALS_SRC), termhooks.h, and coding.h.
+ (intervals.o): Depend on keymap.h.
+
+ * msdos.c (msdos_set_cursor_shape, IT_display_cursor):
+ Add debugging print-out to termscript.
+
+2004-09-09 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (decode_mode_spec): Use current buffer for most purposes.
+
+2004-09-08 Richard M. Stallman <[email protected]>
+
+ * window.c (Fset_window_buffer): Doc fix.
+
+ * xdisp.c (Fformat_mode_line): New arg BUFFER says which buffer to use.
+
+2004-09-08 Dan Nicolaescu <[email protected]>
+
+ * minibuf.c (history_delete_duplicates): New variable.
+ (read_minibuf): Use it.
+ (syms_of_minibuf): Create the corresponding lisp variable.
+
+2004-09-08 Kim F. Storm <[email protected]>
+
+ * xdisp.c (set_cursor_from_row): Also look at 'cursor' property in
+ overlay just before point.
+
+2004-09-07 Luc Teirlinck <[email protected]>
+
+ * buffer.h (struct buffer): Add auto_save_file_format field.
+ * buffer.c (reset_buffer, init_buffer_once):
+ Handle auto_save_file_format field.
+ (syms_of_buffer): Add DEFVAR_PER_BUFFER for
+ `buffer-auto-save-file-format'.
+ * fileio.c: Delete declaration for removed Vauto_save_file_format.
+ (build_annotations): Adapt to replacement of
+ `auto-save-file-format' with the new buffer-local variable
+ `buffer-auto-save-file-format'.
+ (syms_of_fileio): Delete DEFVAR_LISP for auto-save-file-format.
+
+2004-09-07 Jason Rumney <[email protected]>
+
+ * w32term.h (AppendMenuW_Proc): Move declaration from w32menu.c.
+
+ * w32fns.c (w32_wnd_proc) <WM_MEASUREITEM, WM_DRAWITEM>:
+ Handle Unicode menu titles.
+
+2004-09-07 Kim F. Storm <[email protected]>
+
+ * xdisp.c (set_cursor_from_row): Fix last change. Only use 'cursor'
+ property from text property or overlay strings at point.
+
+2004-09-07 Stefan Monnier <[email protected]>
+
+ * xmenu.c (update_submenu_strings): YAILOM.
+ (set_frame_menubar): Make sure last_i is initialized.
+
+2004-09-03 Jason Rumney <[email protected]>
+
+ * w32menu.c (_widget_value): Add lname and lkey.
+ (digest_single_submenu): Set lname and lkey in widget_value
+ instead of name and key.
+ (update_submenu_strings): New function.
+ (set_frame_menubar): Remove call to inhibit_garbage_collection,
+ call update_submenu_strings.
+
+ * w32menu.c (globals_of_w32menu): Check for Unicode API.
+ (digest_single_submenu, w32_menu_show): Encode menu strings as
+ UTF-8 if Unicode API is available.
+ (utf8to16): New function.
+ (add_menu_item): Use it when calling Unicode API.
+
+2004-09-03 Kim F. Storm <[email protected]>
+
+ * xdisp.c (set_cursor_from_row): Look for non-nil `cursor' property
+ in overlay or text-property strings; set cursor on corresponding
+ glyph rather than at end of the string.
+
+2004-09-02 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c (x_real_positions): Save the current window port and
+ set a new one before obtaining the global coordinate.
+ Use FRAME_MAC_WINDOW.
+ (x_set_name, x_set_title): Encode title to UTF8.
+ Use SetWindowTitleWithCFString.
+ (Fx_server_version): Get correct OS version.
+
+ * macmenu.c (add_menu_item): Remove unused variable `i'.
+ Don't let separator items destroy refence constants of other menu items.
+
+ * macterm.c (x_update_end): Move SetPortWindowPort to inside
+ BLOCK_INPUT.
+ (x_set_offset): Use FRAME_MAC_WINDOW.
+
+ * xdisp.c (note_mouse_highlight): Set the mouse pointer shape to
+ nontext_cursor if it is on a scroll bar.
+
+ * s/darwin.h (LIBS_CARBON): New define to specify libraries for
+ Carbon support.
+ (LD_SWITCH_SYSTEM_TEMACS): Don't link with unused libstdc++.
+ Use LIBS_CARBON.
+
+2004-09-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_set_name_internal): New function. Check if we shall call
+ xfree before ENCODE_UTF_8.
+ (x_set_name, x_set_title): Call x_set_name_internal.
+
+2004-08-31 NAKAMURA Toshikazu <[email protected]> (tiny change)
+
+ * w32fns.c (w32_load_font): If a BDF font is already loaded, do not
+ reload it.
+
+2004-08-30 Jan Dj,Ad(Brv <[email protected]>
+
+ * macmenu.c (_widget_value): Add lname and lkey.
+ (single_submenu): Set lname and lkey in widget_value
+ instead of name and key.
+ (update_submenu_strings): New function.
+ (set_frame_menubar): Remove call to inhibit_garbage_collection,
+ call update_submenu_strings.
+
+ * xmenu.c (digest_single_submenu): Set lname and lkey in widget_value
+ instead of name and key.
+ (update_submenu_strings): New function.
+ (set_frame_menubar): Remove call to inhibit_garbage_collection,
+ call update_submenu_strings.
+
+ * gtkutil.h (_widget_value): Added lname and lkey.
+
+2004-08-30 Steven Tamm <[email protected]>
+
+ * macmenu.c (mac_menu_show): Remove shadowing of menu variable
+ by using different names for inner loop variables.
+
+2004-08-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (set_frame_menubar): Reintroduce inhibit_garbage_collection
+ from 2002-07-15T00:01:[email protected] so that strings from ENCODE_UTF_8 isn't GC:ed before used.
+
+ * gtkutil.c (xg_create_frame_widgets): Compensate for tool bar when
+ tool bar items is 0.
+
+2004-08-26 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macmenu.c (ENCODE_MENU_STRING): Added to handle multibyte
+ strings in menu items.
+ (single_submenu): Use ENCODE_MENU_STRING
+ (mac_menu_show): Use ENCODE_MENU_STRING. Reset grabbed because
+ button release isn't passed to event loop
+ (add_menu_item): Use SetMenuItemWithCFString.
+
+2004-08-26 Steven Tamm <[email protected]>
+
+ * fileio.c (Fread_file_name): Call x_file_dialog on carbon on
+ tool-bar/menu click.
+ * macfns.c (Fx_file_dialog): Implement using NavServices.
+
+2004-08-24 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_catch_errors_unwind): Do not XSync if display has closed.
+
+ * xfns.c (x_window_to_frame, x_any_window_to_frame)
+ (x_non_menubar_window_to_frame, x_menubar_window_to_frame)
+ (x_top_window_to_frame): Return 0 if wdesc is None.
+
+2004-08-22 Richard M. Stallman <[email protected]>
+
+ * process.c (process_send_signal) [SIGNALS_VIA_CHARACTERS,
+ HAVE_TERMIOS]: If there's no char for this signal, drop through
+ and use system calls.
+
+ * bytecode.c (Fbyte_code) <unwind-protect>: Cannot GC.
+
+2004-08-20 Kim F. Storm <[email protected]>
+
+ * process.c (wait_reading_process_output): Rename from
+ wait_reading_process_input. All uses changed.
+ (wait_reading_process_output_1): Rename from
+ wait_reading_process_input_1. All uses changed.
+
+ * dispnew.c (Fsleep_for): Remove obsolete code.
+
+2004-08-20 Kenichi Handa <[email protected]>
+
+ * syntax.c (skip_chars): Fix for unibyte case.
+
+2004-08-19 Stefan Monnier <[email protected]>
+
+ * syntax.c (char_quoted): Mixup byte/char pos.
+ (back_comment): Fixup globals in all cases.
+
+2004-08-19 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_set_name, x_set_title): Encode title to UTF8 before
+ passing it to gtk_window_set_title.
+
+2004-08-19 Kim F. Storm <[email protected]>
+
+ * process.c (wait_reading_process_input): Clean up.
+ Add wait_for_cell, wait_proc, and just_wait_proc args
+ to avoid overloading `read_kbd' and `do_display' args.
+ Change read_kbd arg to int. All callers changed.
+
+ * process.c (process_send_signal): Use CDISABLE.
+
+ * sysdep.c (child_setup_tty, init_sys_modes): Use CDISABLE.
+
+2004-08-18 Kim F. Storm <[email protected]>
+
+ * process.c (Faccept_process_output): Add arg JUST-THIS-ONE;
+ forward to wait_reading_process_input via DO_DISPLAY arg.
+ (wait_reading_process_input): If DO_DISPLAY < 0 for a process
+ object, only process output from that process; also inhibit
+ running timers if DO_DISPLAY==-2.
+
+2004-08-17 Kim F. Storm <[email protected]>
+
+ * process.c (process_send_signal): Fix last change--use
+ _POSIX_VDISABLE instead of CVDISABLE when available.
+
+2004-08-16 Richard M. Stallman <[email protected]>
+
+ * sysdep.c (child_setup_tty) [SIGNALS_VIA_CHARACTERS]:
+ Set VQUIT and VINTR chars to the standard ones if they are unset.
+ [AIX]: Don't do that here. And don't force VINTR to standard
+ when SIGNALS_VIA_CHARACTERS.
+
+ * process.c (process_send_signal)
+ [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
+ Do nothing if the character is CVDISABLE.
+
+ * xfaces.c (merge_face_ref): Specifying `unspecified' is a no-op.
+
+ * intervals.c (move_if_not_intangible):
+ Force POSITION to be between BEGV and ZV.
+
+2004-08-14 John Paul Wallington <[email protected]>
+
+ * buffer.c (Frestore_buffer_modified_p): Doc fix.
+
+ * fileio.c (Fread_file_name): Doc fix.
+
+ * minibuf.c (syms_of_minibuf) <completion-ignore-case>: Doc fix.
+
+2004-08-09 Luc Teirlinck <[email protected]>
+
+ * keymap.c (Fmake_keymap, Fmap_keymap, Fwhere_is_internal): Doc fixes.
+
+2004-08-08 Luc Teirlinck <[email protected]>
+
+ * keyboard.c: Declare Qdisabled_command_function instead of
+ Qdisabled_command_hook.
+ (Fcommand_execute): Use Qdisabled_command_function instead of
+ Qdisabled_command_hook.
+ (syms_of_keyboard): Ditto.
+
+2004-08-07 Luc Teirlinck <[email protected]>
+
+ * keymap.c (Flocal_key_binding, Fglobal_key_binding)
+ (syms_of_keymap) <key-translation-map>: Doc fixes.
+
+2004-08-07 Stefan Monnier <[email protected]>
+
+ * window.c (window_list_1): YAILOM.
+
+ * fileio.c (make_temp_name): Handle multibyte prefixes.
+
+2004-08-06 Luc Teirlinck <[email protected]>
+
+ * keyboard.c (syms_of_keyboard) <overriding-terminal-local-map>:
+ Doc fix.
+
+2004-08-03 Kenichi Handa <[email protected]>
+
+ * coding.c (decode_coding_string): Adjust coding->consumed, and
+ etc. with shrinked_bytes.
+
+2004-08-03 Kim F. Storm <[email protected]>
+
+ * indent.c (compute_motion): Fix check for full width window
+ in non-window case. Do not count left truncation glyph on
+ window systems.
+
+2004-08-02 Luc Teirlinck <[email protected]>
+
+ * data.c (Finteractive_form): Doc fix.
+
+2004-08-02 Kim F. Storm <[email protected]>
+
+ * indent.c (compute_motion): Use actual window width if WIDTH is -1,
+ properly accounting for continuation glyph on non-window systems.
+ (Fcompute_motion): Use actual window width if WIDTH is nil, and
+ actual window width/height if TOPOS is nil, properly accounting for
+ continuation glyphs on non-window systems, and optional header lines.
+ (vmotion): Let compute_motion calculate actual window width.
+
+ * window.c (window_scroll_line_based): Let compute_motion
+ calculate actual window width.
+
+2004-08-02 Kim F. Storm <[email protected]>
+
+ * process.c (read_process_output): Use whole read buffer.
+ Don't trigger adaptive read buffering on errors.
+
+2004-07-31 Luc Teirlinck <[email protected]>
+
+ * keymap.c (Fset_keymap_parent, Fdefine_prefix_command): Doc fixes.
+
+ * keyboard.c (syms_of_keyboard) <disable-point-adjustment>: Doc fix.
+
+ * callint.c (Fcall_interactively): Doc fix.
+
+2004-07-30 Richard M. Stallman <[email protected]>
+
+ * abbrev.c (Fexpand_abbrev): Undo previous change.
+
+2004-07-30 Kim F. Storm <[email protected]>
+
+ * editfns.c (Fformat): Allocate extra (dummy) element in info.
+
+2004-07-28 Luc Teirlinck <[email protected]>
+
+ * eval.c (Fdefvar, Fdefconst): Doc fixes.
+
+2004-07-27 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_in_display_line_to): Check BUFFER_POS_REACHED_P after
+ we have ensured that the glyph fits on the current line (or returned
+ MOVE_LINE_CONTINUED otherwise).
+
+2004-07-26 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_in_display_line_to): If overflow-newline-into-fringe
+ is enabled, return MOVE_LINE_CONTINUED rather than MOVE_POS_MATCH_OR_ZV
+ if target position is at end of display line but char is not a newline.
+
+2004-07-25 Richard M. Stallman <[email protected]>
+
+ * window.c (coordinates_in_window): Return ON_SCROLL_BAR
+ instead of ON_VERTICAL_BORDER, when on scroll bar.
+ (Fcoordinates_in_window_p): Handle ON_SCROLL_BAR--return nil.
+
+ * dispextern.h (enum window_part): Add ON_SCROLL_BAR.
+
+ * window.c (Fcoordinates_in_window_p):
+ Take account of FRAME_INTERNAL_BORDER_WIDTH.
+
+ * alloc.c (check_cons_list): New function (contents commented out).
+
+2004-07-24 Luc Teirlinck <[email protected]>
+
+ * xfaces.c (Fcolor_supported_p): Doc fix.
+
+ * frame.c (Fselect_frame, Fset_frame_selected_window)
+ (Fframe_visible_p, Fraise_frame): Doc fixes.
+
+2004-07-24 Richard M. Stallman <[email protected]>
+
+ * keyboard.h (not_single_kboard_state): Declare.
+
+ * fileio.c (Fwrite_region): Doc fix.
+
+ * window.c (Fwindow_at): Take account of FRAME_INTERNAL_BORDER_WIDTH.
+
+ * abbrev.c (Fexpand_abbrev): Run Qpre_abbrev_expand_hook
+ only when a real abbrev is present.
+
+ * xfns.c (x_icon_verify): New function.
+ (Fx_create_frame): Use it.
+
+2004-07-22 Barry Fishman <[email protected]> (tiny change)
+
+ * s/gnu-linux.h: Use GC_MARK_STACK if __amd64__ is defined.
+
+2004-07-21 Kim F. Storm <[email protected]>
+
+ * window.h (struct glyph_matrix): New members nrows_scale_factor
+ and ncols_scale_factor.
+
+ * window.c (make_window): Initialize nrows_scale_factor and
+ ncols_scale_factor members.
+
+ * dispnew.c (margin_glyphs_to_reserve): Apply ncols_scale_factor.
+ (allocate_matrices_for_frame_redisplay): Fix left/right margin mix-up.
+ (required_matrix_height): Apply nrows_scale_factor.
+ (required_matrix_width): Apply ncols_scale_factor.
+
+ * xdisp.c (display_line): Increment nrows_scale_factor and set
+ fonts_changed_p if past last allocated row.
+ (append_glyph, append_composite_glyph, produce_image_glyph)
+ (append_stretch_glyph): Increment ncols_scale_factor and set
+ fonts_changed_p if current area is full.
+
+2004-07-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * widget.c (EmacsFrameDestroy): Don't abort if normal_gc is 0.
+
+2004-07-19 Luc Teirlinck <[email protected]>
+
+ * window.c (Fpos_visible_in_window_p, Fset_window_hscroll)
+ (Fwindow_inside_pixel_edges, Fwindow_end, Fset_window_point)
+ (Fset_window_start, Fscroll_up, Fscroll_down)
+ (Fother_window_for_scrolling, Fscroll_other_window)
+ (Fsave_window_excursion, Fset_window_vscroll)
+ (syms_of_window) <window-size-fixed>: Doc fixes.
+
+2004-07-19 KOBAYASHI Yasuhiro <[email protected]>
+
+ * w32fns.c (Fx_file_dialog): Use ENCODE_FILE instead of
+ ENCODE_SYSTEM for filenames.
+
+2004-07-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (sys_select): Block input around call to
+ ReceiveNextEvent to prevent breakage. Correctly handle
+ blocking on event queue only by calling ReceiveNextEvent
+ instead of select (since GUI events aren't on an fd).
+ (sys_read): Remove function
+ * sysdep.c: Remove redefine of read to sys_read if HAVE_CARBON.
+
+2004-07-18 YAMAMOTO Mitsuharu <[email protected]>
+
+ * mac.c (sys_select): Redo sys_select to use alarm-based
+ polling instead of 1 sec timeouts (like solaris).
+
+ * macterm.c (x_make_frame_visible): Comment in polling on
+ frame creation.
+
+ * keyboard.c: Undef SIGIO on Carbon.
+
+ * atimer.c (alarm_signal_handler): Call alarm handlers after
+ scheduling.
+
+ * eval.c (Feval): Remove quit_char test.
+
+ * process.c (wait_reading_process_input): Remove clearing
+ stdin for select call on process input.
+
+2004-07-18 Luc Teirlinck <[email protected]>
+
+ * xdisp.c (syms_of_xdisp) <window-scroll-functions>: Correct
+ capitalization error in docstring.
+
+2004-07-17 Juanma Barranquero <[email protected]>
+
+ * keyboard.c (not_single_kboard_state): Do nothing unless
+ MULTI_KBOARD is defined.
+
+2004-07-17 Richard M. Stallman <[email protected]>
+
+ * window.c (coordinates_in_window): Inside the window but outside
+ its box to the L or R, return ON_VERTICAL_BORDER.
+ (window_list_1): Rotate the list to start with WINDOW.
+
+ * print.c (print_preprocess): Test for print_depth at limit
+ before entering in being_printed.
+
+ * keyboard.c (not_single_kboard_state): New function.
+ (stuff_buffered_input): Now no-op only if no SIGTSTP.
+
+ * frame.c (Fdelete_frame): If we're in single_bboard_state on
+ this kboard, and we delete its last frame, go to any_kboard_state.
+
+ * buffer.c (syms_of_buffer) <transient-mark-mode>: Doc fix.
+
+2004-07-15 KOBAYASHI Yasuhiro <[email protected]>
+
+ * w32fns.c (Fx_file_dialog): Encode strings in system coding
+ system before passing them to OS functions for display.
+
+2004-07-15 David Kastrup <[email protected]>
+
+ * search.c (syms_of_search): Staticpro `saved_last_thing_searched'.
+ Apparently fixes an abort condition.
+
+2004-07-14 Luc Teirlinck <[email protected]>
+
+ * fileio.c (Fvisited_file_modtime): Return a list of two integers,
+ instead of a cons.
+
+2004-07-14 K,Aa(Broly L$,1 q(Brentey <[email protected]>
+
+ * keyboard.c (echo_dash): Do nothing if there already is a dash
+ at the end of the echo string.
+
+2004-07-12 Kim F. Storm <[email protected]>
+
+ * alloc.c (mark_object): Only look at Lisp_Misc_Save_Value
+ if GC_MARK_STACK.
+
+2004-07-10 Luc Teirlinck <[email protected]>
+
+ * buffer.c (Fswitch_to_buffer, Fpop_to_buffer): Doc fixes.
+
+ * window.c (Fwindow_buffer, Fother_window, Fget_lru_window)
+ (Fget_largest_window, Fget_buffer_window, Fdelete_windows_on)
+ (Freplace_buffer_in_windows, Fset_window_buffer)
+ (Fselect-window, Fdisplay-buffer, Fsplit_window): Doc fixes.
+ (syms_of_window): Expand docstring of `display-buffer-function'.
+
+2004-07-09 Luc Teirlinck <[email protected]>
+
+ * editfns.c (Ffloat_time, Fformat_time_string, Fdecode_time)
+ (Fcurrent_time_string, Fcurrent_time_zone): Mention in docstrings
+ that time values of the type (HIGH . LOW) are considered obsolete.
+
+2004-07-06 Luc Teirlinck <[email protected]>
+
+ * keyboard.c (syms_of_keyboard): Fix `keyboard-translate-table'
+ docstring.
+
+ * fns.c (Fclear_string): Declare `len' before call to CHECK_STRING.
+
+2004-07-06 John Paul Wallington <[email protected]>
+
+ * eval.c (Fdefmacro): Signal an error if NAME is not a symbol.
+
+ * fns.c (Fclear_string): Signal an error if STRING is not a string.
+
+2004-07-05 Jan Dj,Ad(Brv <[email protected]>
+
+ * macterm.c (mac_initialize_display_info): Use CGGetActiveDisplayList
+ instead of CGMainDisplayID (only in OSX 10.2 and later).
+
+2004-07-04 John Paul Wallington <[email protected]>
+
+ * fileio.c (read_file_name_completion_ignore_case): New variable.
+ (syms_of_fileio): Declare and initialise it.
+ (Fread_file_name): Bind `completion-ignore-case' to respect it.
+
+2004-07-03 Eli Zaretskii <[email protected]>
+
+ * msdos.c (dos_rawgetc): Use make_number to produce Lisp objects
+ for event.x and event.y.
+
+2004-07-01 Kenichi Handa <[email protected]>
+
+ * w32select.c (Fw32_set_clipboard_data): Update `nbytes' correctly
+ after getting a new string by pre-write-conversion.
+
+2004-06-30 Stefan Monnier <[email protected]>
+
+ * xterm.c (x_detect_focus_change): Remove unused var `nr_events'.
+ (x_calc_absolute_position): Remove unused var `child'.
+
+ * xfaces.c (x_supports_face_attributes_p)
+ (Fdisplay_supports_face_attributes_p): YAILOM.
+ (tty_supports_face_attributes_p): Remove unused var `i'.
+
+ * syntax.c (skip_chars): Remove unused labels fwd_unibyte_ok and
+ back_unibyte_ok.
+
+ * search.c (match_limit, Fmatch_data, Fset_match_data): YAILOM.
+
+ * fontset.c (Fset_fontset_font): Remove unused vars `family' and
+ `registry'.
+
+ * Makefile.in (${etc}DOC): Fix file name of make-docfile.
+
+2004-06-30 Andreas Schwab <[email protected]>
+
+ * image.c (CHECK_LIB_AVAILABLE): Add third parameter LIBRARIES.
+ (Finit_image_library): Pass LIBRARIES through to
+ CHECK_LIB_AVAILABLE. Declare parameters. Doc fix.
+ (lookup_image_type): Pass Qnil as second argument to
+ Finit_image_library.
+
+ * lisp.h (Finit_image_library): Declare.
+
+2004-06-29 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (do_window_activate, do_window_deactivate): Remove.
+ (XTread_socket): Send mouse button events to the toolbox
+ dispatcher even when the mouse is grabbed. Don't process window
+ activate events for non-Emacs windows. Replace function calls to
+ do_window_activate and do_window_deactivate with their contents.
+ Reset mouse grabbing status when a window is deactivated.
+
+2004-06-29 Steven Tamm <[email protected]>
+
+ * macterm.c (mac_get_emulated_btn)
+ (mac_event_to_emacs_modifiers): Fix emulated mouse button
+ support to correctly mask out modifiers.
+
+2004-06-29 David Kastrup <[email protected]>
+
+ * search.c (Fset_match_data): Allow buffer before end of list
+ which can happen if set-match-data is using a pre-consed list.
+
+2004-06-28 Steven Tamm <[email protected]>
+
+ * macterm.c (XTread_socket): Correctly set the frame position
+ after the window is moved.
+
+2004-06-28 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_image_for_pixmap): Call g_object_unref on
+ gpix and gmask just before return to avoid memory leak.
+ (xg_get_image_for_pixmap): Add workaround for monochrome displays
+ so insensitive and activated icons look ok.
+
+2004-06-27 Jason Rumney <[email protected]>
+
+ * w32fns.c (file_dialog_callback): Disable edit control if set
+ to directories only on CDN_INITDONE message.
+ (Fx_file_dialog): Default to directories only when prompt starts
+ with "Dired".
+
+2004-06-25 Kim F. Storm <[email protected]>
+
+ * alloc.c (allocate_misc): Update total_free_markers.
+ (free_misc): New function.
+ (safe_alloca_unwind, free_marker): Use it.
+
+ * lisp.h (free_misc): Add prototype.
+
+ * fns.c (Fmapconcat, Fmapcar): Remove superfluous GCPROs.
+
+2004-06-24 Richard M. Stallman <[email protected]>
+
+ * emacs.c (Vsignal_USR1_hook, Vsignal_USR2_hook): Definitions deleted.
+ (syms_of_emacs): Lisp variables deleted.
+
+2004-06-23 David Kastrup <[email protected]>
+
+ * search.c (Freplace_match): Adjust the match-data more thoroughly
+ when replacing strings in the buffer.
+ (Fmatch_data): When INTEGERS is non-nil and the last match was in
+ a buffer, add the buffer as last element to the match data.
+ (Fset_match_data): If an additional element of the match-data is a
+ buffer, restore it to last_thing_searched.
+ (save_search_regs): Save last_thing_searched as part of the match data.
+ (restore_match_data): Restore it again.
+
+2004-06-23 Luc Teirlinck <[email protected]>
+
+ * keymap.c (Ftext_char_description): Doc fix.
+ * doc.c (Fsnarf_documentation): Doc fix.
+
+2004-06-22 Kim F. Storm <[email protected]>
+
+ * fns.c (Fmapcar, Fmapconcat): GCPRO the args array.
+
+ * lisp.h (struct Lisp_Save_Value): New member dogc.
+ (SAFE_ALLOCA_LISP): Change second arg to number of elements.
+ Set dogc member in Lisp_Save_Value object so it will be GC'ed.
+ (SAFE_FREE_LISP): New macro.
+
+ * alloc.c (safe_alloca_unwind): Clear dogc and pointer members.
+ (make_save_value): Init new dogc member.
+ (mark_object): Mark Lisp_Save_Value pointer array if dogc is set.
+
+ * fns.c (Fmapconcat, Fmapcar): Use new SAFE_ALLOCA_LISP and
+ SAFE_FREE_LISP macros.
+
+2004-06-22 Kim F. Storm <[email protected]>
+
+ * lisp.h (SAFE_ALLOCA_LISP): New macro to allocate Lisp_Objects.
+ Temporarily inhibits GC if memory is xmalloc'ed, as the Lisp_Objects
+ in that memory area are unknown to GC. Add comments.
+
+ * fns.c (Fmapconcat, Fmapcar): Use SAFE_ALLOCA_LISP.
+
+2004-06-21 Kim F. Storm <[email protected]>
+
+ * lisp.h (MAX_ALLOCA): Define here.
+ (safe_alloca_unwind): Add prototype.
+ (USE_SAFE_ALLOCA, SAFE_ALLOCA, SAFE_FREE): New macros.
+
+ * alloc.c (safe_alloca_unwind): New function.
+
+ * casefiddle.c (casify_object): Use SAFE_ALLOCA.
+
+ * charset.c (Fstring): Use SAFE_ALLOCA.
+
+ * coding.c (MAX_ALLOCA): Remove define.
+
+ * data.c (MAX_ALLOCA): Remove define.
+ (Faset): Use SAFE_ALLOCA.
+
+ * editfns.c (Fformat, Ftranspose_regions): Use SAFE_ALLOCA.
+
+ * fns.c (string_make_multibyte, string_to_multibyte)
+ (string_make_unibyte, Fmapconcat, Fmapcar): Use SAFE_ALLOCA.
+ (MAX_ALLOCA): Remove define.
+ (Fbase64_encode_region, Fbase64_encode_string)
+ (Fbase64_decode_region, Fbase64_decode_string): Use SAFE_ALLOCA.
+ (Fbase64_encode_region, Fbase64_encode_string): Fix potential
+ memory leak if encoding fails.
+
+ * xdisp.c (add_to_log): Use SAFE_ALLOCA.
+
+2004-06-21 Eli Zaretskii <[email protected]>
+
+ * print.c (Fwith_output_to_temp_buffer): Doc fix.
+
+2004-06-20 Richard M. Stallman <[email protected]>
+
+ * xfaces.c (Finternal_copy_lisp_face): Small cleanup; doc fix.
+
+ * search.c (match_limit): Cleaner err msg when no match data available.
+
+ * window.c (syms_of_window): Doc fix.
+
+ * keyboard.c (command_loop_1): Handle values `only' and `identity'
+ for Vtransient_mark_mode.
+
+ * buffer.c (syms_of_buffer): Doc fix.
+
+2004-06-21 David Kastrup <[email protected]>
+
+ * minibuf.c (Ftry_completion, Fall_completions): Do lazy binding
+ and unbinding of `case-fold-search' according to
+ `completion-ignore-case' around calls of string-match and
+ predicates, respectively. Should give satisfactory performance
+ in all relevant cases.
+
+2004-06-17 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_draw_image_foreground_1): Subtract slice.x/y from
+ clip_x/y_origin.
+
+ * fns.c (string_to_multibyte): Use xmalloc/xfree instead of alloca.
+
+ * macfns.c (Fx_display_color_cells): Do not limit return value to 256.
+
+ * macterm.c (mac_initialize_display_info): Initialize n_planes correctly
+ on Mac OSX.
+
+2004-06-16 Luc Teirlinck <[email protected]>
+
+ * buffer.c (syms_of_buffer): Clarify `fill-column' docstring.
+
+2004-06-16 Kim F. Storm <[email protected]>
+
+ * dispextern.h (Vimage_types): Remove extern.
+
+2004-06-16 Miles Bader <[email protected]>
+
+ * image.c (lookup_image_type): Initialize image type if necessary.
+
+2004-06-15 Kim F. Storm <[email protected]>
+
+ * xdisp.c (try_cursor_movement): Exclude header line from scroll
+ margin at top of window.
+ (try_window_reusing_current_matrix): Calculate proper cursor position
+ after scrolling up with non-zero scroll margin, as the old cursor
+ position corresponds to value of PT before executing this command.
+ (try_window_id): Consider scroll margin at bottom of window too;
+ otherwise we fail to scroll when hl-line-mode is enabled.
+
+ * syntax.c (skip_chars): Only recognize [:class:] when it has the
+ proper format and class is a lower-case word.
+
+2004-06-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_get_image_for_pixmap): New function.
+ (xg_get_gdk_pixmap_and_mask): Remove.
+ (update_frame_tool_bar): Call xg_get_image_for_pixmap instead of
+ xg_get_gdk_pixmap_and_mask.
+
+ * xterm.h (struct x_display_info): Typo in comment fixed.
+
+2004-06-14 Juanma Barranquero <[email protected]>
+
+ * dispextern.h (Vimage_types): Make it conditional on
+ HAVE_WINDOW_SYSTEM.
+
+ * image.c (Vimage_types): Move from xdisp.c.
+ (Vimage_type_cache): New variable.
+ (define_image_type): New argument indicating whether an image
+ library was loaded; cache loaded status and return t on success,
+ nil otherwise.
+ (CACHE_IMAGE_TYPE, ADD_IMAGE_TYPE): New macros.
+ (w32_delayed_load): New function to load an image library from a
+ list of possible filenames.
+ (init_xpm_functions, init_png_functions, init_jpeg_functions)
+ (init_tiff_functions, init_gif_functions): Use `w32_delayed_load'.
+ (CHECK_LIB_AVAILABLE): Call `define_image_library' with new argument.
+ (Finit_image_library): New function, extracted from `init_image'.
+ Try to initialize an image library on demand and cache whether we
+ were successful or not.
+ (syms_of_image): Initialize `Vimage_types' and
+ `Vimage_type_cache'. Add recognized image types to Vimage_types.
+ Export `init-image-library'.
+ (init_image): Remove initialization of all image types, except xbm
+ and pbm.
+
+ * xdisp.c (Vimage_types): Delete (moved to image.c).
+
+2004-06-14 Andreas Schwab <[email protected]>
+
+ * minibuf.c (Ftry_completion, Fall_completions, Ftest_completion):
+ Avoid calling specbind when completion-regexp-list is empty.
+
+2004-06-13 Richard M. Stallman <[email protected]>
+
+ * regex.h (CHAR_CLASS_MAX_LENGTH, re_wctype_t, re_wchar_t)
+ (re_wctype, re_iswctype, re_wctype_to_bit):
+ Non-function definitions moved here from regex.c.
+
+ * regex.c (re_wctype, re_iswctype): Function defs longer static.
+ (CHAR_CLASS_MAX_LENGTH, re_wctype_t, re_wchar_t)
+ (re_wctype, re_iswctype, re_wctype_to_bit):
+ Non-function definitions moved to regex.h.
+
+ * window.c (Fselect_window): Doc fix.
+
+ * syntax.c: Include regex.h.
+ (skip_chars): New arg HANDLE_ISO_CLASSES. Callers changed.
+ If requested, make a list of classes, then check the scanned
+ chars for membership in them.
+ (in_classes): New function.
+ Doc fix.
+
+ * keyboard.c (cmd_error): Don't call any_kboard_state
+ if inside a recursive edit level.
+
+2004-06-13 K,Aa(Broly L$,1 q(Brentey <[email protected]>
+
+ * keyboard.c (command_loop): Call any_kboard_state before
+ command_loop_2 when at top level.
+
+2004-06-13 Andreas Schwab <[email protected]>
+
+ * print.c (print_object): Always use %ld for printing EMACS_INT.
+
+ * keyboard.c (cancel_hourglass_unwind): Return a value.
+ (modify_event_symbol): Always use %ld for printing EMACS_INT.
+ (Fexecute_extended_command): Likewise.
+
+ * syntax.h (SYNTAX_ENTRY_FOLLOW_PARENT): Rename local variable to
+ avoid clashes.
+ (SYNTAX): Likewise.
+ (SYNTAX_WITH_FLAGS): Likewise.
+ (SYNTAX_MATCH): Likewise.
+
+ * syntax.c (char_quoted): Avoid warning about undefined operation.
+ (find_defun_start): Likewise.
+ (scan_lists): Likewise.
+ (INC_FROM): Likewise.
+ (scan_sexps_forward): Likewise.
+
+ * image.c: Include <ctype.h>.
+
+ * xfaces.c (face_attr_equal_p): Declare parameters.
+
+2004-06-13 Kenichi Handa <[email protected]>
+
+ * ccl.c (CCL_READ_CHAR): If hit EOF, set REG to -1.
+
+2004-06-12 Matthew Mundell <[email protected]>
+
+ * eval.c (Fdefun): Signal an error if NAME is not a symbol.
+
+2004-06-12 Kenichi Handa <[email protected]>
+
+ * ccl.c (CCL_CALL_FOR_MAP_INSTRUCTION): Save eof_ic in
+ ccl_prog_stack_struct and update it.
+ (CCL_INVALID_CMD): If CCL_DEBUG is defined, call ccl_debug_hook.
+ (CCL_READ_CHAR): Get instruction counter from eof_ic, not from
+ ccl->eof_ic on EOF.
+ (ccl_debug_hook): New function.
+ (struct ccl_prog_stack): New member eof_ic.
+ (ccl_driver): Handle EOF in subrountine call correctly.
+
+2004-06-11 Kenichi Handa <[email protected]>
+
+ * coding.c (encode_coding_string): Check CODING_FINISH_INTERRUPT.
+
+2004-06-11 Kim F. Storm <[email protected]>
+
+ * emacs.c (shut_down_emacs): Inhibit redisplay during shutdown.
+
+2004-06-11 Juanma Barranquero <[email protected]>
+
+ * keyboard.c (Fposn_at_point): Doc fix.
+
+2004-06-11 David Kastrup <[email protected]>
+
+ * search.c (match_limit): Don't flag an error if match-data
+ exceeding the allocated search_regs.num_regs gets requested, just
+ return Qnil.
+
+2004-06-08 Miles Bader <[email protected]>
+
+ * xfaces.c (push_named_merge_point): Return 0 when a cycle is detected.
+
+2004-06-07 Juanma Barranquero <[email protected]>
+
+ * editfns.c (Fuser_login_name, Ffloat_time, Fencode_time)
+ (Fcurrent_time_string, Fcurrent_time_zone)
+ (Finsert_buffer_substring, Ftranspose_regions): Doc fixes.
+
+2004-06-07 Miles Bader <[email protected]>
+
+ * xfaces.c (struct named_merge_point): New type.
+ (push_named_merge_point): New function.
+ (merge_named_face): New function.
+ (merge_face_ref, face_at_buffer_position, face_at_string_position):
+ Use `merge_named_face'.
+ (merge_face_inheritance): Function removed.
+ (merge_face_ref): Rename from `merge_face_vector_with_property'.
+ Add new `err_msgs' and `named_merge_points' args. Return error
+ status. Only print error messages if ERR_MSGS is true. Don't try to
+ do :inherit attribute validation.
+ (merge_face_heights): Handle `unspecified' in both directions.
+ (merge_face_vectors): Rename `cycle_check' arg to `named_merge_points'.
+ Call `merge_face_ref' instead of `merge_face_inheritance'.
+ (Fdisplay_supports_face_attributes_p, Fface_attributes_as_vector)
+ (compute_char_face, face_at_buffer_position)
+ (face_at_string_position): Call `merge_face_ref' instead of
+ `merge_face_vector_with_property'.
+
+2004-06-07 Kenichi Handa <[email protected]>
+
+ * coding.c (find_safe_codings): Check NILP (safe_codings) only at
+ the necessary places.
+
+2004-06-07 Kim F. Storm <[email protected]>
+
+ * process.c (Fdelete_process): Undo 2004-05-28 change.
+ Instead, call status_notify also for network process.
+ (status_message): Use process instead of status as arg.
+ Give messages "deleted" or "connection broken by remote peer" for
+ an exited network process.
+ (status_notify): Change call to status_message.
+ (read_process_output): Increase readmax to 4096. Do not increase
+ buffer size for datagram channels (default is now large enough).
+
+2004-06-06 Steven Tamm <[email protected]>
+
+ * macfns.c (x_create_tip_frame): Fix Mac OS X 10.1 compilation
+ problem due to newly defined variable.
+
+2004-06-06 Miles Bader <[email protected]>
+
+ * xfaces.c (Fdisplay_supports_face_attributes_p): Give up
+ immediately if non-interactive or not initialized.
+
+2004-06-05 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (Fcompleting_read): Doc fix.
+
+2004-06-05 Andreas Schwab <[email protected]>
+
+ * macfns.c (x_create_tip_frame): Fix declaration after statement.
+
+2004-06-05 Juanma Barranquero <[email protected]>
+
+ * keymap.c (Fdescribe_vector): Fix docstring.
+ (Fkey_description, Fglobal_key_binding): Fix typo in docstring.
+
+2004-06-05 Miles Bader <[email protected]>
+
+ * xfaces.c (tty_supports_face_attributes_p): Make sure the specified
+ attributes have different values than the default face.
+
+2004-06-04 Eli Zaretskii <[email protected]>
+
+ * xfaces.c (x_supports_face_attributes_p): Make this function
+ conditional on HAVE_WINDOW_SYSTEM.
+ (Fdisplay_supports_face_attributes_p) [HAVE_WINDOW_SYSTEM]:
+ Don't call x_supports_face_attributes_p if it was not compiled in.
+
+2004-06-04 Miles Bader <[email protected]>
+
+ * xfaces.c (tty_supports_face_attributes_p): New function, mostly
+ from Ftty_supports_face_attributes_p.
+ (x_supports_face_attributes_p): New function.
+ (Ftty_supports_face_attributes_p): Function deleted.
+ (Fdisplay_supports_face_attributes_p): New function.
+ (syms_of_xfaces): Initialize Sdisplay_supports_face_attributes_p.
+ (face_attr_equal_p): New function.
+ (lface_equal_p): Use it.
+
+2004-06-03 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (Fx_display_grayscale_p, Fw32_send_sys_command)
+ (Vw32_color_map): Fix typo in docstring.
+ (Fx_create_frame, Fw32_find_bdf_fonts, Fx_show_tip)
+ (Fw32_unregister_hot_key, Fw32_reconstruct_hot_key):
+ Make argument names match their use in docstring.
+
+2004-06-02 Juanma Barranquero <[email protected]>
+
+ Work around bugs/problems with MinGW builds of graphics libraries
+ called from MSVC builds of Emacs.
+
+ * image.c (lookup_image): Make pointer to img static.
+ (png_read_from_memory): Disable "global" optimization.
+
+2004-06-01 Stefan Monnier <[email protected]>
+
+ * eval.c (Fcondition_case): Fix usage. Simplify.
+
+ * mem-limits.h (EXCEEDS_LISP_PTR) [USE_LSB_TAG]: Never true.
+
+2004-05-29 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macfns.c: Don't include ccl.h.
+ [MAC_OSX]: Don't include QuickTime/QuickTime.h.
+ [!MAC_OSX]: Don't include alloca.h, Windows.h, Gestalt.h, or
+ TextUtils.h.
+ (Fx_create_frame): Sync with xfns.c. Initialize cursor descriptors.
+ (Fx_display_mm_height, Fx_display_mm_width): Calculate length from
+ display height/width.
+ (compute_tip_xy, Vx_max_tooltip_size): Declare.
+ (unwind_create_tip_frame, compute_tip_xy): New functions.
+ (x_create_tip_frame, Fx_show_tip, Fx_hide_tip): Sync with xfns.c.
+ (syms_of_macfns): Initialize Qcancel_timer, Vx_max_tooltip_size,
+ and last_show_tip_args.
+
+ * macgui.h [!MAC_OSX]: Include Gestalt.h.
+ (Cursor, No_Cursor): New defines.
+ [!TARGET_API_MAC_CARBON] (SetPortWindowPort): New compatibility macro.
+ [!TARGET_API_MAC_CARBON] (arrow_cursor): Declare.
+
+ * macmenu.c (mac_menu_show, mac_dialog): Use SetPortWindowPort.
+
+ * macterm.c: Don't include Gestalt.h.
+ (enum mouse_tracking_type, mouse_tracking_in_progress): Remove.
+ (XDrawLine, XClearArea, XClearWindow, mac_draw_bitmap)
+ (mac_set_clip_rectangle, mac_reset_clipping, XCreatePixmap)
+ (XFillRectangle, mac_draw_rectangle, mac_draw_string_common)
+ (mac_copy_area, mac_copy_area_with_mask, x_update_end)
+ (construct_mouse_click, XTmouse_position)
+ (x_scroll_bar_report_motion, x_calc_absolute_position)
+ (do_mouse_moved, do_zoom_window, mac_do_receive_drag)
+ (XTread_socket, make_mac_frame): Use SetPortWindowPort.
+ (note_mouse_movement): Clear the mouse face and reset the pointer
+ shape when the pointer goes outside the frame without grabbing.
+ (mac_front_window): New function.
+ (mac_window_to_frame): New macro.
+ (XTmouse_position, x_scroll_bar_report_motion, do_window_update)
+ (do_window_activate, do_window_deactivate, do_app_resume)
+ (do_app_suspend, do_mouse_moved, do_menu_choice, do_grow_window)
+ (do_zoom_window, mac_do_receive_drag, XTread_socket)
+ (mac_check_for_quit_char): Use mac_front_window and/or
+ mac_window_to_frame.
+ (x_scroll_bar_handle_click): Set `(PORTION . WHOLE)' part in a
+ scroll-bar click event.
+ (mac_define_frame_cursor): Change the pointer shape.
+ (x_free_frame_resources): Reset tip_window to NULL when it is
+ disposed of.
+ [!TARGET_API_MAC_CARBON] (arrow_cursor): New variable.
+ [!TARGET_API_MAC_CARBON] (do_init_managers): Initialize arrow_cursor.
+ (do_window_update): Don't do anything if the updated window is the
+ tooltip window.
+ (do_mouse_moved): Handle mouse movement events here (previously in
+ XTread_socket). Clear the mouse face if
+ dpyinfo->mouse_face_hidden is set.
+ (do_os_event, do_events): Remove (now in XTread_socket).
+ (XTread_socket): Immediately return if interrupt_input_blocked.
+ Loop until all the events in the queue are processed.
+ Rearrange codes for mouse grabbing. Add tooltip support. Include the
+ contents of do_os_event and do_events. Remove mouse movement
+ handling (now in do_mouse_moved). Add the case where
+ Vmouse_highlight has an integer value.
+ (NewMacWindow): Remove.
+ (make_mac_frame): Do what NewMacWindow previously did. Don't do
+ excess initializations.
+ (make_mac_terminal_frame): Previous initializations in
+ make_mac_frame are moved here.
+ (mac_initialize_display_info):
+ Initialize dpyinfo->mouse_face_overlay and dpyinfo->mouse_face_hidden.
+
+ * xdisp.c [MAC_OS] (No_Cursor): Remove variable.
+ (define_frame_cursor1): Don't treat HAVE_CARBON as a special case.
+
+2004-05-29 Richard M. Stallman <[email protected]>
+
+ * lisp.h (truncate_undo_list): Update decl.
+
+ * alloc.c (undo_outer_limit): New variable.
+ (syms_of_alloc): Defvar it.
+ (Fgarbage_collect): Pass undo_outer_limit to truncate_undo_list.
+
+ * undo.c (truncate_undo_list): New arg LIMITSIZE.
+
+ * alloc.c (lisp_align_malloc): Check for base == 0
+ regardless of HAVE_POSIX_MEMALIGN.
+ Clean up HAVE_POSIX_MEMALIGN handling of `err'.
+
+2004-05-28 Stefan Monnier <[email protected]>
+
+ * alloc.c: Undo Kim's recent changes and fix the same bug differently.
+ (marker_blocks_pending_free): Remove.
+ (Fgarbage_collect): Sweep after cleaning up undo-lists.
+ Mark the undo lists after claning them up.
+ Don't free block in marker_blocks_pending_free.
+ (mark_buffer): Don't mark undo_list.
+ (gc_sweep): Sweep hash-tables and strings first.
+ Do free marker blocks that are empty.
+
+2004-05-28 Jim Blandy <[email protected]>
+
+ * regex.c (print_partial_compiled_pattern): Add missing 'break'
+ after 'case wordend'. For symbeg and symend, print to stderr,
+ like the other cases.
+
+2004-05-28 Noah Friedman <[email protected]>
+
+ * process.c (Fdelete_process): Do not call remove_process.
+
+2004-05-28 Stefan Monnier <[email protected]>
+
+ * alloc.c (struct backtrace): Remove.
+ (Fgarbage_collect): Use the new mark_backtrace.
+
+ * eval.c (mark_backtrace): New function.
+
+ * minibuf.c (run_exit_minibuf_hook): New function.
+ (read_minibuf_unwind): Don't run exit-minibuffer-hook any more.
+ (read_minibuf): Use separate unwind handler to run exit-minibuf-hook.
+
+2004-05-27 Kim F. Storm <[email protected]>
+
+ * xdisp.c (back_to_previous_visible_line_start): Skip backwards
+ over display properties, e.g. images, that replace buffer text.
+
+2004-05-25 Kim F. Storm <[email protected]>
+
+ * alloc.c (marker_blocks_pending_free): New var.
+ (gc_sweep): Store free marker blocks on that list.
+ (Fgarbage_collect): Free them after undo-list cleanup.
+
+ * process.c (wait_reading_process_input): Check connect_wait_mask
+ before actually accepting connection in case it has already been
+ accepted due to recursion.
+
+2004-05-23 K,Aa(Broly L$,1 q(Brentey <[email protected]>
+
+ * coding.c (Fset_safe_terminal_coding_system_internal):
+ Set suppress_error in safe_terminal_coding, not terminal_coding.
+
+2004-05-22 Richard M. Stallman <[email protected]>
+
+ * alloc.c (Fmake_string): Doc fix.
+
+ * buffer.c (clone_per_buffer_values): Copy the alist of local vars,
+ and the alist pairs too.
+
+ * casefiddle.c (casify_object): Return OBJ unchanged if not real char.
+
+ * emacs.c (main): Update copyright year.
+
+ * fileio.c (Fread_file_name): Expand DIR if not absolute.
+
+ * insdel.c (del_range_2, replace_range): Don't write an anchor
+ if the gap is empty.
+
+ * xdisp.c (try_scrolling): If scroll-up-aggressively or
+ scroll-down-aggressively is small but positive, put point
+ near the screen edge.
+
+2004-05-22 Juanma Barranquero <[email protected]>
+
+ * keymap.c (Fdefine_key): Doc fix.
+
+2004-05-22 Kim F. Storm <[email protected]>
+
+ * alloc.c (struct backtrace): Add debug_on_exit member.
+ (Fgarbage_collect): Clear out buffer undo_list markers after gc_sweep.
+ Identify those markers as Lisp_Misc_Free objects. Clear car and cdr of
+ the removed cons cells.
+ (mark_object): Undo previous change - disallow Lisp_Misc_Free objects.
+ (gc_sweep): Clear cons_blocks before sweeping strings, so we don't have
+ any cons cells pointing to unallocated stings.
+ Do not lisp_free any marker blocks, as there may still be pointers
+ to them from buffer undo lists at this stage of GC.
+
+ * keyboard.c (struct backtrace): Add debug_on_exit member.
+ (Fcommand_execute): Clear it.
+
+2004-05-20 Luc Teirlinck <[email protected]>
+
+ * intervals.c (lookup_char_property): Do not prematurely return nil.
+
+2004-05-19 Jim Blandy <[email protected]>
+
+ Add support for new '\_<' and '\_>' regexp operators, matching the
+ beginning and end of symbols.
+
+ * regex.c (enum syntaxcode): Add Ssymbol.
+ (init_syntax_once): Set the syntax for '_' to Ssymbol, not Sword.
+ (re_opcode_t): New opcodes `symbeg' and `symend'.
+ (print_partial_compiled_pattern): Print the new opcodes properly.
+ (regex_compile): Parse the new operators.
+ (analyse_first): Skip sym(beg|end) (they match only the empty string).
+ (mutually_exclusive_p): `symend' is mutually exclusive with \s_ and
+ \sw; `symbeg' is mutually exclusive with \S_ and \Sw.
+ (re_match_2_internal): Match symbeg and symend.
+
+ * search.c (trivial_regexp_p): \_ is no longer a trivial regexp.
+
+2004-05-19 Kim F. Storm <[email protected]>
+
+ * .gdbinit (xsymbol): Fix last change.
+
+2004-05-18 Stefan Monnier <[email protected]>
+
+ * .gdbinit (xprintstr): New fun.
+ (xstring, xprintsym): Use it.
+
+ * w32proc.c (create_child): Use INTMASK.
+
+ * alloc.c (Fgarbage_collect): Do all the marking before flushing
+ unmarked elements of the undo list.
+
+2004-05-18 David Ponce <[email protected]>
+
+ * print.c (print): Reset print_depth before to call print_object.
+
+2004-05-18 Jason Rumney <[email protected]>
+
+ * w32console.c: Prefix RIF functions with w32con_ to avoid
+ namespace clash with functions in term.c and w32term.c.
+
+ * w32menu.c (add_menu_item, w32_menu_display_help)
+ [USE_LISP_UNION_TYPE]: Cast from Lisp_Object using i member.
+
+ * w32term.h (display_x_get_resource, vga_stdcolor_name): Add prototype.
+
+2004-05-18 Eli Zaretskii <[email protected]>
+
+ * lisp.h (DECL_ALIGN): Remove restriction on MS-DOS systems.
+
+ * msdos.c (syms_of_msdos): Initialize dos-unsupported-char-glyph
+ with make_number.
+ (IT_write_glyphs): Extract glyph from dos-unsupported-char-glyph
+ with XINT.
+
+2004-05-18 Kim F. Storm <[email protected]>
+
+ * blockinput.h (INPUT_BLOCKED_P): New macros.
+
+ * keyboard.c (Frecursive_edit): Return immediately if input blocked.
+ (Ftop_level): Unblock input if blocked.
+
+ * buffer.h (GET_OVERLAYS_AT): New macro.
+ * msdos.c (IT_note_mouse_highlight): Use it.
+ * textprop.c (get_char_property_and_overlay): Use it.
+ * xdisp.c (next_overlay_change, note_mouse_highlight): Use it.
+ * xfaces.c (face_at_buffer_position): Use it.
+
+ * print.c (print_object): Increase buf size.
+
+2004-05-17 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fw32_register_hot_key, Fw32_unregister_hot_key)
+ (Fw32_toggle_lock_key) [USE_LISP_UNION_TYPE]: Cast from
+ Lisp_Object using i member.
+ (w32_quit_key): Rename from Vw32_quit_key, and make an int.
+ (syms_of_w32fns, globals_of_w32fns): Use Lisp_Object and int
+ consistently.
+
+ * w32proc.c (create_child): Use make_number instead of masking pid.
+
+ * w32fns.c (w32_color_map_lookup): Return a Lisp_Object.
+ (x_to_w32_charset, w32_to_x_charset, w32_to_all_x_charsets):
+ Use EQ to compare Lisp_Objects.
+ (w32_parse_hot_key): Use int for lisp_modifiers consistently.
+
+ * w32term.c (w32_num_mouse_buttons): Rename from
+ Vw32_num_mouse_buttons and make it an int.
+
+ * w32.c (init_environment): Use it.
+
+ * w32fns.c (w32_wnd_proc): Likewise.
+
+ * w32proc.c (w32_pipe_read_delay): Rename from
+ Vw32_pipe_read_delay and make it an int.
+
+ * w32.c (_sys_read_ahead): Use it.
+
+ * lisp.h (egetenv) [USE_CRT_DLL]: Remove condition.
+
+ * w32proc.c (create_child) [USE_LSB_TAG]: Don't try to mask pid.
+
+ * w32inevt.c (w32_console_mouse_position, do_mouse_event)
+ (key_event): Don't mix Lisp_Object and int.
+
+ * w32heap.c (init_heap) [USE_LSB_TAG]: Don't check heap location.
+
+ * keyboard.c (kbd_buffer_get_event): Don't use event->code and
+ modifiers in language change event.
+
+2004-05-17 Kim F. Storm <[email protected]>
+
+ * alloc.c (mark_object): Ignore Lisp_Misc_Free objects.
+ Such objects may be freed markers which still exist on an undo list.
+
+2004-05-16 Juanma Barranquero <[email protected]>
+
+ * data.c (Fset_default): Make argument names match their use in
+ docstring.
+
+2004-05-15 Andreas Schwab <[email protected]>
+
+ * emacs.c (gdb_array_mark_flag): Define.
+ * .gdbinit: Mask off gdb_array_mark_flag from vector sizes.
+
+2004-05-15 Eli Zaretskii <[email protected]>
+
+ * lisp.h (DECL_ALIGN) [MSDOS]: Don't define DECL_ALIGN to use
+ __attribute__((__aligned__)), so that USE_LSB_TAG would not become
+ defined for the MS-DOS build.
+
+2004-05-14 Stefan Monnier <[email protected]>
+
+ * w32fns.c (Fw32_define_rgb_color): Avoid XSET.
+
+2004-05-14 Kenichi Handa <[email protected]>
+
+ * ccl.c (Fccl_execute_on_string): Fix setting elements of STATUS.
+
+2004-05-14 YAMAMOTO Mitsuharu <[email protected]>
+
+ * lisp.h (Vx_resource_name, Vx_resource_class): Move from xfns.c
+ section to frame.c section.
+ (Fxw_display_color_p, Fx_file_dialog): Declare if
+ HAVE_WINDOW_SYSTEM defined.
+
+ * macfns.c (Fx_create_frame): Fix int/Lisp_Object mixup.
+
+ * macmenu.c (set_frame_menubar): Use NILP to test a lisp value.
+
+ * macterm.c (mac_get_emulated_btn, mac_event_to_emacs_modifiers)
+ (mac_get_mouse_btn): Use NILP and EQ to test/compare lisp values.
+ (XTread_socket): Fix int/Lisp_Object mixup.
+ (mac_check_for_quit_char): Fix pointer/Lisp_Object mixup.
+
+ * macterm.h (struct frame, struct face, struct image)
+ (display_x_get_resource, Fx_display_color_p)
+ (Fx_display_grayscale_p, Fx_display_planes, x_free_gcs):
+ Add prototypes.
+
+2004-05-14 Kim F. Storm <[email protected]>
+
+ * process.c (wait_reading_process_input): Make reentrant.
+ Make Available and Connecting non-static. Save and restore value
+ of waiting_for_user_input_p.
+
+2004-05-13 Kim F. Storm <[email protected]>
+
+ * keyboard.c (mark_kboards): Don't mark x and y members
+ that are overloaded in selection request events.
+
+2004-05-13 Stefan Monnier <[email protected]>
+
+ * lisp.h (USE_LSB_TAG): Make it the default when it is known to work.
+
+2004-05-13 Glenn Morris <[email protected]>
+
+ * window.c (Fdisplay_buffer, Fsplit_window)
+ (split-height-threshold): Doc fix.
+
+2004-05-13 Juanma Barranquero <[email protected]>
+
+ * xfaces.c (Ftty_supports_face_attributes_p)
+ (Finternal_copy_lisp_face): Fix typo in docstring.
+ (Finternal_get_lisp_face_attribute): Fix docstring.
+
+2004-05-12 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (syms_of_xfns): Provide x-toolkit also for GTK.
+
+2004-05-11 Steven Tamm <[email protected]>
+
+ * macfns.c (Fx_create_frame): Default to using tool-bar by
+ setting tool-bar-lines to 1 in default-frame-alist.
+
+2004-05-11 YAMAMOTO Mitsuharu <[email protected]>
+
+ * image.c (xpm_scan, xpm_make_color_table_v, xpm_put_color_table_v)
+ (xpm_get_color_table_v, xpm_make_color_table_h)
+ (xpm_put_color_table_h, xpm_get_color_table_h)
+ (xpm_str_to_color_key, xpm_load_image, xpm_load)
+ (syms_of_image): Support XPM on Carbon Emacs. Does not
+ depend on libXpm, but only supports XPM version 3 without extensions.
+
+2004-05-11 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (x_flush, XTframe_up_to_date): Use FRAME_MAC_P
+ instead of FRAME_X_P.
+
+2004-05-11 Kim F. Storm <[email protected]>
+
+ * process.c (read_process_output): Grow decoding_buf when needed;
+ this could cause a crash in allocate_string and compact_small_strings.
+
+2004-04-29 Jim Blandy <[email protected]>
+
+ * regex.c (mutually_exclusive_p): In 'case wordbeg', compare op2
+ against proper opcode.
+
+2004-05-10 Juanma Barranquero <[email protected]>
+
+ * process.c (Fstart_process): Fix docstring.
+
+ * charset.c (Fget_unused_iso_final_char): Fix typos in docstring.
+ (Fchar_bytes, Fchar_width, Fstring_width, Fchar_direction)
+ (Fsplit_char, Fchar_charset): Make argument names match their use
+ in docstring.
+
+2004-05-10 Richard M. Stallman <[email protected]>
+
+ * print.c (print_preprocess): Use being_printed, loop_count and
+ halftail to detect overdeep nesting and cyclic cdr chains.
+
+2004-05-10 Andreas Schwab <[email protected]>
+
+ * lisp.h (Fmake_symbolic_link): Declare.
+
+ * fileio.c (Frename_file): Remove extra argument in call to
+ Fmake_symbolic_link.
+
+2004-05-10 Kim F. Storm <[email protected]>
+
+ * xdisp.c (calc_line_height_property): Use string position when
+ object is a string.
+
+2004-05-10 Kenichi Handa <[email protected]>
+
+ * print.c (temp_output_buffer_setup): Bind inhibit-read-only and
+ inhibit-modification-hooks to t temporarily before calling
+ Ferase_buffer.
+
+ * xfns.c (x_create_tip_frame): Bind inhibit-read-only and
+ inhibit-modification-hooks to t temporarily before calling
+ Ferase_buffer.
+
+ * w32fns.c (x_create_tip_frame): Bind inhibit-read-only and
+ inhibit-modification-hooks to t temporarily before calling
+ Ferase_buffer.
+
+ * fns.c (count_combining): Delete it.
+ (concat): Don't check combining bytes.
+
+2004-05-09 Jason Rumney <[email protected]>
+
+ * w32fns.c (Vw32_ansi_code_page): New Lisp variable.
+ (globals_of_w32fns): Set it.
+
+2004-05-09 Piet van Oostrum <[email protected]>
+
+ * data.c (Fquo): Simplify.
+
+2004-05-08 Peter Whaite <[email protected]> (tiny change)
+
+ * data.c (Fquo): If any argument is float, do the computation in
+ floating point.
+
+2004-05-08 Juanma Barranquero <[email protected]>
+
+ * process.c (Fwaiting_for_user_input_p, Fmake_network_process)
+ (Fset_process_query_on_exit_flag, Vprocess_adaptive_read_buffering):
+ Fix spelling of Emacs on docstring.
+ (Fset_process_coding_system, Fprocess_coding_system)
+ (Fset_process_filter_multibyte, Fprocess_filter_multibyte_p):
+ Make argument names match their use in docstring.
+ (Fprocess_id, Fprocess_query_on_exit_flag, Finterrupt_process):
+ Fix docstring.
+
+ * editfns.c (Finsert_buffer_substring): Make argument names match their
+ use in docstring.
+
+ * syntax.c (Fmodify_syntax_entry): Fix docstring.
+
+2004-05-07 Steven Tamm <[email protected]>
+
+ * macterm.c (mac_check_for_quit_char): Adding BLOCK_INPUT
+ around call to ReceiveEvent to avoid certain crashes.
+
+2004-05-07 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (mac_draw_line_to_pixmap, XCreatePixmapFromBitmapData)
+ (mac_fill_rectangle_to_pixmap, mac_draw_rectangle_to_pixmap)
+ (mac_copy_area_to_pixmap, mac_copy_area_with_mask_to_pixmap):
+ Save/restore the current graphics port and device handle when
+ drawing into an offscreen graphics world.
+
+ * image.c [MAC_OS] (XPutPixel, XGetPixel, image_load_qt_1)
+ (gif_load): Likewise.
+
+2004-05-07 Juanma Barranquero <[email protected]>
+
+ * window.c (Fset_window_buffer): Fix docstring.
+
+2004-05-06 Thien-Thi Nguyen <[email protected]>
+
+ * emacs.c (main) [VMS]: Fix var ref.
+
+2004-05-06 Romain Francoise <[email protected]>
+
+ * data.c (Fsetq_default): Fix docstring.
+
+2004-05-06 Jason Rumney <[email protected]>
+
+ * image.c (Display) [HAVE_NTGUI]: Redefine while loading xpm.h
+ to avoid name clash.
+
+2004-05-04 Jan Dj,Ad(Brv <[email protected]>
+
+ * fileio.c (barf_or_query_if_file_exists): Use lstat.
+ (Frename_file): Handle renaming of symlinks across file systems.
+ (Frename_file): Put symlink handling inside #ifdef S_IFLNK.
+
+2004-05-04 Kim F. Storm <[email protected]>
+
+ * xdisp.c (Qtotal): New var.
+ (syms_of_xdisp): Intern and staticpro it.
+ (calc_line_height_property): New arg total. Set it if
+ line-spacing property has format (total . VALUE).
+ (x_produce_glyphs): Ignore line-spacing if line-height is 0.
+ Handle total line-spacing property.
+
+2004-05-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_update_scrollbar_pos): Call XClearWindow to clear
+ "under" scroll bar when size/position changes.
+
+2004-05-03 Jason Rumney <[email protected]>
+
+ * makefile.nt: Remove.
+
+2004-05-02 Eli Zaretskii <[email protected]>
+
+ * syntax.h (SET_RAW_SYNTAX_ENTRY, SYNTAX_ENTRY_INT):
+ Avoid compiler warnings.
+
+ * Makefile.in (region-cache.o): Depend on config.h.
+
+2004-05-02 Romain Francoise <[email protected]>
+
+ * indent.c (compute_motion): Save vpos in prev_vpos when dealing
+ with continuation lines, too.
+
+2004-05-02 Thien-Thi Nguyen <[email protected]>
+
+ * syssignal.h (init_signals): Move decl outside `#ifdef POSIX_SIGNALS'.
+
+2004-05-01 Stefan Monnier <[email protected]>
+
+ * xdisp.c (calc_line_height_property): YAILOM (yet another
+ int/Lisp_Object mixup).
+
+2004-05-01 Eli Zaretskii <[email protected]>
+
+ * msdos.c (top-level): Add "#pragma pack(0)" after <dir.h>, to
+ undo bad effect of pack(4) in some versions of system headers.
+
+2004-05-01 Jason Rumney <[email protected]>
+
+ * w32term.c (x_draw_hollow_cursor): Sync with xterm.c.
+
+2004-04-30 Kim F. Storm <[email protected]>
+
+ * buffer.c (syms_of_buffer) <line-spacing>: Allow float value.
+ (syms_of_buffer) <cursor-type>: Doc fix.
+
+ * dispextern.h (struct it): Remove member use_default_face.
+ Add members override_ascent, override_descent, override_boff.
+
+ * xdisp.c (init_iterator): Handle line-spacing float value.
+ Initialize override_ascent member.
+ (append_space_for_newline): Reset override_ascent.
+ Remove use_default_face.
+ (calc_line_height_property): New function to calculate value of
+ line-height and line-spacing properties. Look at overlays, too.
+ Set override_ascent, override_descent, override_boff members when
+ using another face than the current face. Float values are now
+ relative to the frame default font, by default; accept a cons
+ of ratio and face name to specify value relative to a specific face.
+ (x_produce_glyphs): Use calc_line_height_property.
+ Use override_ascent etc. when set to handle different face heights.
+ A negative line-spacing property value is interpreted as a total
+ line height, rather than inter-line spacing.
+ (note_mouse_highlight): Allocate room for 40 overlays initially.
+
+2004-04-29 Stefan Monnier <[email protected]>
+
+ * data.c (Fsubr_name): New fun.
+ (syms_of_data): Defsubr it.
+
+2004-04-29 Kim F. Storm <[email protected]>
+
+ * xdisp.c (null_glyph_slice): New var.
+ (append_glyph, append_composite_glyph, append_stretch_glyph):
+ Use it to initialize glyph slice.
+
+2004-04-27 Stefan Monnier <[email protected]>
+
+ * xdisp.c (x_produce_glyphs): Fix the proverbial int/Lisp_Object mixup.
+ (on_hot_spot_p): Make sure we always return a value.
+ (Flookup_image_map): Remove unused var ix and iy.
+ (note_mode_line_or_margin_highlight): Remove unused var `image'.
+
+2004-04-27 Eli Zaretskii <[email protected]>
+
+ * msdos.c (init_environment): If one of the TMP... environment
+ variables is set to a drive letter without a trailing slash,
+ append a slash.
+
+2004-04-27 Matthew Mundell <[email protected]>
+
+ * editfns.c (lisp_time_argument): Provide externally.
+
+ * fileio.c (Fset_file_times): New function.
+ (syms_of_fileio): Intern and staticpro it.
+
+2004-04-27 Kim F. Storm <[email protected]>
+
+ * xdisp.c (x_produce_glyphs): Fix last change; handle newline in
+ header line strings.
+
+ * dispextern.h (struct it): New member use_default_face.
+
+ * xdisp.c (Qline_height): New variable.
+ (syms_of_xdisp): Intern and staticpro it.
+ (append_space_for_newline): Partially undo 2004-04-25 change;
+ add default_face_p arg, and restore callers.
+ Clear it->use_default_face after use.
+ (x_produce_glyphs): Set default font for ascii char if
+ it->use_default_font is set. Change line-spacing property to set
+ just extra line spacing. Handle new line-height property.
+
+2004-04-26 Andreas Schwab <[email protected]>
+
+ * print.c (print_object): Print non-ascii characters in bool
+ vector representation as octal escapes.
+
+ * lisp.h (BOOL_VECTOR_BITS_PER_CHAR): Define.
+ * print.c (print_object): Use it instead of BITS_PER_CHAR for
+ bool vectors.
+ * lread.c (read1): Likewise.
+ * alloc.c (Fmake_bool_vector): Likewise.
+ * data.c (Faref, Faset): Likewise.
+ * fns.c (Fcopy_sequence, concat, internal_equal, Ffillarray)
+ (mapcar1): Likewise.
+
+2004-04-26 Steven Tamm <[email protected]>
+
+ * lread.c (init_lread): Fix typo in HAVE_CARBON test logic.
+
+2004-04-26 Miles Bader <[email protected]>
+
+ * lisp.h (CYCLE_CHECK): Macro moved from xfaces.c.
+
+2004-04-26 Juanma Barranquero <[email protected]>
+
+ * buffer.c (Fpop_to_buffer): Fix docstring.
+
+2004-04-26 Steven Tamm <[email protected]>
+
+ * lread.c (init_lread): Don't display missing lisp directory
+ warnings with Carbon Emacs because self-contained bundled Emacs
+ may be built without correct installation path.
+
+2004-04-25 Kim F. Storm <[email protected]>
+
+ * macterm.c (x_draw_hollow_cursor): Fix height of box for narrow lines.
+
+ * xterm.c (x_draw_hollow_cursor): Fix height of box for narrow lines.
+
+ * xdisp.c (append_space_for_newline): Rename from append_space.
+ Remove DEFAULT_FACE_P arg; always use current face. Callers changed.
+ (x_produce_glyphs): Handle line-spacing property on newline char.
+ If value is t, adjust ascent and descent to fit current row height.
+ If value is an integer or float, set extra_line_spacing to integer
+ value, or to float value x current line height.
+
+2004-04-23 Kenichi Handa <[email protected]>
+
+ * fontset.c (Finternal_char_font): If POSITION is nil, return
+ font for displaying CH with the default face.
+
+2004-04-23 Juanma Barranquero <[email protected]>
+
+ * makefile.w32-in: Add "-*- makefile -*-" mode tag.
+
+2004-04-21 Stefan Monnier <[email protected]>
+
+ * lisp.h (XINT) [EXPLICIT_SIGN_EXTEND && !NO_UNION_TYPE]:
+ Don't make assumptions about the relative place of i and val.
+ (EQ) [!NO_UNION_TYPE]: Don't forget to check the type match as well.
+
+2004-04-21 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct glyph_slice): New struct.
+ (struct glyph): New member slice.
+ (GLYPH_SLICE_EQUAL_P): New macro.
+ (GLYPH_EQUAL_P): Use it.
+ (struct glyph_string): New member slice.
+ (struct it_slice): New struct.
+ (struct it): New member slice, add member to stack too.
+ New member constrain_row_ascent_descent_p.
+ (image_ascent): Add prototype.
+
+ * dispnew.c (buffer_posn_from_coords): Return full image width
+ and height even for image slices (posn is relative to full image).
+ (marginal_area_string): Adjust x0,y0 for image slice.
+
+ * image.c (image_ascent): Add slice arg; calculate ascent for
+ image slice (or full image).
+
+ * keyboard.c (Fposn_at_x_y, Fposn_at_point): New defuns.
+ (syms_of_keyboard): Defsubr them.
+
+ * lisp.h (pos_visible_p): Fix prototype.
+
+ * macterm.c (x_draw_relief_rect): Add top_p and bot_p args.
+ (x_draw_glyph_string_box): Fix call to x_draw_relief_rect.
+ (x_draw_image_foreground, x_draw_image_relief)
+ (x_draw_image_foreground_1, x_draw_image_glyph_string):
+ Draw sliced images.
+
+ * w32term.c (w32_draw_relief_rect): Add top_p and bot_p args.
+ (x_draw_glyph_string_box): Fix call to x_draw_relief_rect.
+ (x_draw_image_foreground, x_draw_image_relief)
+ (w32_draw_image_foreground_1, x_draw_image_glyph_string):
+ Draw sliced images.
+
+ * w32term.h (image_ascent): Remove prototype.
+
+ * window.c (Fpos_visible_in_window_p): Return pixel position if
+ PARTIALLY arg is non-nil. Simplify. Doc fix.
+ (Fwindow_vscroll, Fset_window_vscroll): Add optional PIXEL_P arg
+ to return/set vscroll in pixels.
+
+ * window.h (Fwindow_vscroll, Fset_window_vscroll): Fix EXFUN.
+
+ * xdisp.c (Qslice): New variable.
+ (syms_of_xdisp): Intern and staticpro it.
+ (pos_visible_p): Return pixel position in new x and y args.
+ (init_iterator): Reset it->slice info.
+ (handle_display_prop): Parse (slice ...) property.
+ (push_it, pop_it): Save/restore slice info.
+ (make_cursor_line_fully_visible): Fix 2004-04-14 change. Do not
+ force repositioning of tall row if window is vscrolled, as that
+ would reset vscroll.
+ (append_space): Set it->constrain_row_ascent_descent_p to avoid
+ increasing row height if row is non-empty.
+ (fill_image_glyph_string): Copy slice info.
+ (take_vertical_position_into_account): Simplify.
+ (produce_image_glyph): Handle iterator slice info, setup glyph
+ slice info. Do not force minimum line height.
+ (x_produce_glyphs): If it->constrain_row_ascent_descent_p is set,
+ do not increase height (ascent/descent) of non-empty row when
+ adding normal character glyph; instead reduce glyph ascent/descent
+ appropriately; if row is higher than current glyph, adjust glyph
+ descent/ascent to reposition glyph within the existing row.
+ Likewise, when char is newline, only set ascent/descent if row is
+ currently empty.
+ (note_mouse_highlight): Handle hotspots with sliced image.
+
+ * xterm.c (x_draw_relief_rect): Add top_p and bot_p args.
+ (x_draw_glyph_string_box): Fix call to x_draw_relief_rect.
+ (x_draw_image_foreground, x_draw_image_relief)
+ (x_draw_image_foreground_1, x_draw_image_glyph_string):
+ Draw sliced images.
+
+ * xterm.h (image_ascent): Remove prototype.
+
+2004-04-20 Stefan Monnier <[email protected]>
+
+ * keymap.c (Fkey_description): Fix the usual int/Lisp_Object mixup.
+
+2004-04-20 John Paul Wallington <[email protected]>
+
+ * fns.c (Fassoc, Feql): Fix indentation.
+
+ * fontset.c (regularize_fontname): Rename from regulalize_fontname.
+
+2004-04-19 John Paul Wallington <[email protected]>
+
+ * fns.c (Feql): New function.
+ (syms_of_fns): Defsubr it.
+
+2004-04-18 Jason Rumney <[email protected]>
+
+ * w32select.c (Fw32_set_clipboard_data): Get sequence number
+ after closing the clipboard.
+
+2004-04-16 Luc Teirlinck <[email protected]>
+
+ * buffer.c (Fbuffer_base_buffer): Doc fix.
+
+2004-04-17 Kim F. Storm <[email protected]>
+
+ * keymap.c (Fkey_description): Add optional PREFIX arg.
+ Combine prefix with KEYS to make up the full key sequence to describe.
+ Correlate meta_prefix_char and following (simple) key to describe
+ as meta modifier. All callers changed.
+ (describe_map): Rename arg `keys' to `prefix'. Remove local
+ `elt_prefix' var. Use Fkey_description with prefix instead of
+ elt_prefix combined with Fsingle_key_description.
+ (describe_vector): Declare static. Replace arg `elt_prefix' with
+ `prefix'. Add KEYMAP_P arg. Add local var `elt_prefix'; use it
+ if !KEYMAP_P. Use Fkey_description with prefix instead of
+ Fsingle_key_description.
+
+ * keymap.h (Fkey_description): Fix prototype.
+ (describe_vector): Remove prototype.
+
+ * xdisp.c (update_overlay_arrows): Fix handling of up_to_date < 0.
+
+ * image.c (PNG_BG_COLOR_SHIFT): Remove.
+ (png_load): Fix calculation of transparent background color on X
+ and W32 platforms.
+
+2004-04-16 Juanma Barranquero <[email protected]>
+
+ * xdisp.c (try_scrolling): Make sure `scroll-conservatively' is
+ not too large before computing how much to scroll.
+
+2004-04-15 Stefan Monnier <[email protected]>
+
+ * dired.c (Ffile_attributes): Don't pass extra nil arg to file-handler.
+
+2004-04-14 Luc Teirlinck <[email protected]>
+
+ * fileio.c (Fverify_visited_file_modtime, Fvisited_file_modtime):
+ Add hyperlink to Elisp manual to the docstring.
+
+2004-04-14 Stefan Monnier <[email protected]>
+
+ * callint.c (fix_command): Use XDCR.
+
+2004-04-14 Nick Roberts <[email protected]>
+
+ * window.c (Fget_lru_window): Doc fix.
+
+2004-04-14 Kim F. Storm <[email protected]>
+
+ * editfns.c (Fformat): Fix allocation size of precision array.
+
+ * dispnew.c (update_window): Only set changed_p if
+ scrolling_window actually did scroll.
+ (scrolling_window): Only return 1 if we actually did scroll.
+
+ * xdisp.c (get_glyph_string_clip_rect): Fix reduction of cursor
+ height to glyph height when cursor row is not fully visible.
+ (make_cursor_line_fully_visible): Add FORCE_P arg to return
+ failure in case row is higher than window. Callers changed.
+ (try_scrolling): Fix loop in scrolling if last_line_misfit (from Gerd).
+ Try to scroll partially visible, higher-than-window cursor row.
+ (redisplay_window): Always try to scroll partially visible,
+ higher-than-window cursor row - both initially and again with
+ centering_position = 0.
+ Clear desired matrix before retrying with centering_position = 0.
+
+2004-04-13 Stefan Monnier <[email protected]>
+
+ * syntax.c (scan_lists): Simplify backward string scan.
+ Fix off-by-one boundary check for string and comment fences.
+
+2004-04-13 Joe Buehler <[email protected]>
+
+ * sheap.c, unexcw.c: New files.
+
+2004-04-12 Luc Teirlinck <[email protected]>
+
+ * buffer.c (Fmake_indirect_buffer): Throw an error if the intended
+ base buffer has been killed. Correct the error message if the
+ base buffer does not exist.
+
+2004-04-12 Joe Buehler <[email protected]>
+
+ * s/cygwin.h: Changes for Cygwin unexec() support, changes in
+ Cygwin itself. Add support for Xaw3d scrollbars.
+
+ * puresize.h: Set up PURE_P() for Cygwin unexec() support.
+
+ * lastfile.c: Define my_endbss[] for Cygwin unexec() support.
+
+ * gmalloc.c (__default_morecore): Use bss_sbrk(), not __sbrk(),
+ before Cygwin unexec.
+
+ * Makefile.in: Link changes for Cygwin unexec() support.
+
+2004-04-12 Andreas Schwab <[email protected]>
+
+ * buffer.c (Fmake_indirect_buffer): Check that NAME is a string.
+
+2004-04-11 Luc Teirlinck <[email protected]>
+
+ * buffer.c (Fgenerate_new_buffer_name): Return NAME argument if
+ IGNORE argument equals NAME. Doc fix.
+
+2004-04-11 Masatake YAMATO <[email protected]>
+
+ * buffer.c (fix_start_end_in_overlays): Make overlays
+ empty if they are backwards.
+
+2004-04-09 Stefan Monnier <[email protected]>
+
+ * xfaces.c (face_color_supported_p): Fix compilation without X11.
+
+2004-04-07 Stefan Monnier <[email protected]>
+
+ * doc.c (Fsnarf_documentation): Ignore new file name entries.
+
+2004-04-06 Kim F. Storm <[email protected]>
+
+ * msdos.c (clear_mouse_face): Only clear mouse highlight if not hidden.
+ (dos_rawgetc): Set mouse_face_hidden after clearing highlight.
+
+ * w32term.c (w32_read_socket): Set mouse_face_hidden after
+ clearing highlight.
+
+ * xdisp.c (clear_mouse_face): Only clear mouse highlight if not hidden.
+
+ * xterm.c (handle_one_xevent): Set mouse_face_hidden after
+ clearing highlight.
+
+ * indent.c (vmotion): Do not reserve one column for continuation
+ marks on window frames.
+
+2004-04-04 Eli Zaretskii <[email protected]>
+
+ * charset.h (SINGLE_BYTE_CHAR_P): Fix macro to avoid warnings
+ from GCC.
+
+2004-04-03 Stefan Monnier <[email protected]>
+
+ * .gdbinit-union: Remove.
+
+ * .gdbinit: Make it work for USE_LSB_TAG and !NO_LISP_UNION.
+ (xgetptr, xgetint, xgettype): New funs. Use them everywhere.
+ ($nonvalbits): Remove.
+ ($valmask): Set it by calling xreload to avoid redundancy.
+
+ * emacs.c (gdb_use_union, gdb_use_lsb): New vars.
+ (gdb_emacs_intbits): Remove.
+
+2004-03-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * data.c (Fbyteorder): Make test work even if unsigned is not 4 bytes.
+
+2004-03-30 Kenichi Handa <[email protected]>
+
+ * editfns.c (Fformat): Fix initialization of the array info.
+
+2004-03-30 Kim F. Storm <[email protected]>
+
+ * xterm.c (x_mouse_click_focus_ignore_position): New var.
+ (syms_of_xterm): DEFVAR_BOOL it.
+ (ignore_next_mouse_click_timeout): New var.
+ (handle_one_xevent): Clear it on KeyPress, set it on EnterNotify.
+ Use it to filter mouse clicks following focus event.
+
+2004-03-29 David Ponce <[email protected]>
+
+ * callint.c (Fcall_interactively): Fix last change.
+
+2004-03-28 Stefan Monnier <[email protected]>
+
+ * eval.c (Fcommandp): Simplify.
+
+ * data.c (Finteractive_form): Rename from Fsubr_interactive_form.
+ Extend to handle all kinds of functions.
+
+ * lisp.h (Finteractive_form): Declare.
+
+ * callint.c (Fcall_interactively): Use it.
+
+2004-03-26 Kim F. Storm <[email protected]>
+
+ * xdisp.c (syms_of_xdisp): Include `void-variable' in list_of_error
+ to catch errors in calc_pixel_width_or_height during redisplay.
+
+2004-03-26 Masatake YAMATO <[email protected]>
+
+ * buffer.c (fix_start_end_in_overlays): Rename fix_overlays_in_range.
+
+ * lisp.h (fix_start_end_in_overlays): Likewise.
+
+ * insdel.c (adjust_markers_for_insert): Call fix_start_end_in_overlays.
+
+ * editfns.c (Ftranspose_regions): Likewise.
+
+2004-03-20 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): Do not pass key press events to GTK.
+
+2004-03-19 Richard M. Stallman <[email protected]>
+
+ * s/sol2-6.h: Delete previous change.
+
+2004-03-19 Kim F. Storm <[email protected]>
+
+ * xdisp.c (move_it_in_display_line_to): Fix MOVE_TO_POS case when
+ to_charpos corresponds to newline in right fringe. Use local
+ BUFFER_POS_REACHED_P macro.
+
+2004-03-19 Jan Dj,Ad(Brv <[email protected]>
+
+ * xdisp.c (calc_pixel_width_or_height): Add ifdef HAVE_WINDOW_SYSTEM
+ to compile on non-window system.
+
+2004-03-19 Kim F. Storm <[email protected]>
+
+ * dispextern.h (calc_pixel_width_or_height): Add prototype.
+
+ * image.c (Qcenter): Move to xdisp.c.
+
+ * xdisp.c (Qcenter): Declare here.
+ (syms_of_xdisp): Intern and staticpro it.
+ (handle_single_display_prop): Allow space display property on all
+ platforms.
+ (display_mode_line): Set mode_line_p before displaying line.
+ (calc_pixel_width_or_height): Declare extern. Add separate :align-to
+ handling. Remove complex cases for fringes and scroll-bars.
+ Add left, right, and center alignment positions. Add text (area)
+ width/height. Return width or height for image specs.
+ (produce_stretch_glyph): Improve handling of :align-to. Is now
+ relative to left of text area by default, but other base offsets
+ can be specified -- also for text lines.
+
+ * term.c (produce_glyphs): Handle IT_STRETCH.
+ (produce_stretch_glyph): New function to handle space width and
+ align-to display properties on non-window systems.
+
+2004-03-17 Stefan Monnier <[email protected]>
+
+ * fileio.c (Fread_file_name): Set completion-ignore-case for
+ case-insensitive systems.
+
+2004-03-14 Masatake YAMATO <[email protected]>
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Accept HEADER_LINE
+ when keymap and cursor are setup.
+
+2004-03-14 Steven Tamm <[email protected]>
+
+ * Makefile.in (XMENU_OBJ) [HAVE_CARBON]: Do not include xmenu.o.
+
+2004-03-14 Kim F. Storm <[email protected]>
+
+ * dispextern.h (x_find_image_file): Add prototype.
+
+ * image.c (x_find_image_file): Make extern.
+
+ * xfns.c (x_find_image_file): Remove prototype.
+
+2004-03-13 Eli Zaretskii <[email protected]>
+
+ * Makefile.in (XMENU_OBJ): Include xmenu.o if HAVE_MENUS is defined.
+
+ * emacs.c (main): Call syms_of_xmenu only if HAVE_MENUS is defined.
+
+2004-03-12 Richard M. Stallman <[email protected]>
+
+ * fns.c (internal_equal): New arg PROPS controls comparing
+ text properties. All callers changed.
+ (Fequal_including_properties): New function.
+ (syms_of_fns): defsubr it.
+
+2004-03-12 Kim F. Storm <[email protected]>
+
+ Fix image support on MAC. From YAMAMOTO Mitsuharu.
+
+ * dispextern.h (XImagePtr, XImagePtr_or_DC): Add typedefs.
+ (image_background, image_background_transparent): Fix prototypes.
+
+ * image.c (XImagePtr, XImagePtr_or_DC): Move typedefs to dispextern.h.
+
+ * macfns.c (x_list_fonts, x_get_font_info, x_load_font)
+ (x_query_font, x_find_ccl_program, x_set_window_size)
+ (x_make_frame_visible, mac_initialize, XCreatePixmap)
+ (XCreatePixmapFromBitmapData, XFreePixmap, XSetForeground)
+ (mac_draw_line_to_pixmap): Move prototypes to macterm.h.
+
+ * macterm.h (x_list_fonts, x_get_font_info, x_load_font)
+ (x_query_font, x_find_ccl_program, x_set_window_size)
+ (x_make_frame_visible, mac_initialize, XCreatePixmap)
+ (XCreatePixmapFromBitmapData, XFreePixmap, XSetForeground)
+ (mac_draw_line_to_pixmap): Add prototypes.
+
+2004-03-12 YAMAMOTO Mitsuharu <[email protected]>
+
+ * macterm.c (XTread_socket): Fix mouse click on tool bar.
+
+2004-03-11 Kim F. Storm <[email protected]>
+
+ * dispextern.h: Move image related prototypes from xfns.c section
+ to image.c. Condition them by HAVE_WINDOW_SYSTEM rather than
+ HAVE_X_WINDOWS.
+
+ * Makefile.in (XOBJ): Consolidate into one list. Add image.o.
+ Move gtkutil.o to new GTK_OBJ list.
+ (XMENU_OBJ) [HAVE_MENUS]: Move declaration to proper place.
+ (GTK_OBJ) [USE_GTK]: New declaration.
+ (obj): Add $(GTK_OBJ) to list.
+
+2004-03-11 Steven Tamm <[email protected]>
+
+ * image.c [MAC_OSX]: Include sys/stat.h.
+
+ * macfns.c (syms_of_macfns): Remove definitions of things now
+ defined in image.c.
+
+2004-03-11 Kim F. Storm <[email protected]>
+
+ The following changes consolidates the identical/similar image
+ support code previously found in xfns.c, w32fns.c, and macfns.c
+ into a new file image.c.
+
+ * makefile.w32-in (OBJ1): Add image.o.
+ ($(BLD)/image.$(O)): Add dependencies.
+
+ * Makefile.in (XOBJ, MAC_OBJ): Add image.o.
+ (image.o): Add dependencies.
+
+ * image.c: New file with consolidated image support code.
+ (COLOR_TABLE_SUPPORT): New define to control whether
+ color table support is available (X only).
+ (Bitmap_Record): Common name for x_bitmap_record,
+ w32_bitmap_record, and mac_bitmap_record.
+ (XImagePtr): Common name for pointer to XImage or equivalent.
+ (XImagePtr_or_DC): New type to simplify code sharing; equivalent
+ to XImagePtr on X+MAC, and to HDC on W32.
+ (GET_PIXEL): Wrapper for XGetPixel or equivalent.
+ (NO_PIXMAP): Common name for "None" or equivalent.
+ (PNG_BG_COLOR_SHIFT): Bits to shift PNG background colors.
+ (RGB_PIXEL_COLOR): Common type for an integer "pixel color" value.
+ (PIX_MASK_RETAIN, PIX_MASK_DRAW): Portability macros (from macfns.c).
+ (FRAME_X_VISUAL, x_defined_color, DefaultDepthOfScreen):
+ Define with suitable equivalents on W32 and MAC for code sharing.
+ (XDrawLine): Define on MAC for code sharing.
+ (Destroy_Image, Free_Pixmap): Wrappers for code sharing.
+ (IF_LIB_AVAILABLE): Macro to simplify code sharing.
+ (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
+ (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
+ (x_reference_bitmap, x_create_bitmap_from_data)
+ (x_create_bitmap_from_file, x_destroy_bitmap)
+ (x_destroy_all_bitmaps, x_create_bitmap_mask)
+ (XGetImage, XPutPixel, XGetPixel, XDestroyImage)
+ (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
+ (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
+ (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
+ (define_image_type, lookup_image_type, valid_image_p)
+ (image_error, enum image_value_type, struct image_keyword)
+ (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
+ (make_image, free_image, prepare_image_for_display, image_ascent)
+ (four_corners_best, image_background, image_background_transparent)
+ (x_clear_image_1, x_clear_image, x_alloc_image_color)
+ (make_image_cache, free_image_cache, clear_image_cache)
+ (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
+ (forall_images_in_image_cache, x_create_x_image_and_pixmap)
+ (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
+ (find_image_fsspec, image_load_qt_1, image_load_quicktime)
+ (init_image_func_pointer, image_load_quartz2d)
+ (struct ct_color, init_color_table, free_color_table)
+ (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
+ (cross_disabled_images, x_to_xcolors, x_from_xcolors)
+ (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
+ (x_disable_image, x_build_heuristic_mask)
+ (XBM support, XPM support, PBM support, PNG support, JPEG support)
+ (TIFF support, GIF support, Ghostscript support): Consolidate image
+ code from xfns.c, w32fns.c, and macfns.c.
+ (syms_of_image): Consolidate image related symbol setup here.
+ (init_image): Consolidate image related initializations here.
+
+ * emacs.c (main) [HAVE_WINDOW_SYSTEM]: Add calls to syms_of_image
+ and init_image. Remove call to init_xfns.
+
+ * macterm.h (struct mac_bitmap_record): Add file member.
+ Not currently used, but simplifies code sharing.
+
+ * macfns.c (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
+ (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
+ (x_reference_bitmap, x_create_bitmap_from_data)
+ (x_create_bitmap_from_file, x_destroy_bitmap)
+ (x_destroy_all_bitmaps, x_create_bitmap_mask)
+ (XGetImage, XPutPixel, XGetPixel, XDestroyImage)
+ (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
+ (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
+ (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
+ (define_image_type, lookup_image_type, valid_image_p)
+ (image_error, enum image_value_type, struct image_keyword)
+ (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
+ (make_image, free_image, prepare_image_for_display, image_ascent)
+ (four_corners_best, image_background, image_background_transparent)
+ (x_clear_image_1, x_clear_image, x_alloc_image_color)
+ (make_image_cache, free_image_cache, clear_image_cache)
+ (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
+ (forall_images_in_image_cache, x_create_x_image_and_pixmap)
+ (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
+ (find_image_fsspec, image_load_qt_1, image_load_quicktime)
+ (init_image_func_pointer, image_load_quartz2d)
+ (struct ct_color, init_color_table, free_color_table)
+ (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
+ (cross_disabled_images, x_to_xcolors, x_from_xcolors)
+ (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
+ (x_disable_image, x_build_heuristic_mask)
+ (XBM support, XPM support, PBM support, PNG support, JPEG support)
+ (TIFF support, GIF support, Ghostscript support): Merge with image
+ code from xfns.c and macfns.c into image.c.
+ (syms_of_xfns): Move image related symbols to image.c.
+ (init_external_image_libraries, init_xfns): Remove; initialization
+ moved to init_image in image.c.
+
+ * w32fns.c (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
+ (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
+ (x_reference_bitmap, x_create_bitmap_from_data)
+ (x_create_bitmap_from_file, x_destroy_bitmap)
+ (x_destroy_all_bitmaps, x_create_bitmap_mask)
+ (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
+ (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
+ (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
+ (define_image_type, lookup_image_type, valid_image_p)
+ (image_error, enum image_value_type, struct image_keyword)
+ (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
+ (make_image, free_image, prepare_image_for_display, image_ascent)
+ (four_corners_best, image_background, image_background_transparent)
+ (x_clear_image_1, x_clear_image, x_alloc_image_color)
+ (make_image_cache, free_image_cache, clear_image_cache)
+ (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
+ (forall_images_in_image_cache, x_create_x_image_and_pixmap)
+ (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
+ (struct ct_color, init_color_table, free_color_table)
+ (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
+ (cross_disabled_images, x_to_xcolors, x_from_xcolors)
+ (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
+ (x_disable_image, x_build_heuristic_mask)
+ (XBM support, XPM support, PBM support, PNG support, JPEG support)
+ (TIFF support, GIF support, Ghostscript support): Merge with image
+ code from xfns.c and macfns.c into image.c.
+ (syms_of_xfns): Move image related symbols to image.c.
+ (init_external_image_libraries, init_xfns): Remove; initialization
+ moved to init_image in image.c.
+
+ * xfns.c (Vx_bitmap_file_path, Vimage_cache_eviction_delay)
+ (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
+ (x_reference_bitmap, x_create_bitmap_from_data)
+ (x_create_bitmap_from_file, x_destroy_bitmap)
+ (x_destroy_all_bitmaps, x_create_bitmap_mask)
+ (QCascent, QCmargin, QCrelief, QCconversion, QCcolor_symbols)
+ (QCheuristic_mask, QCindex, QCmatrix, QCcolor_adjustment, QCmask)
+ (Qlaplace, Qemboss, Qedge_detection, Qheuristic, Qcenter)
+ (define_image_type, lookup_image_type, valid_image_p)
+ (image_error, enum image_value_type, struct image_keyword)
+ (parse_image_spec, image_spec_value, Fimage_size, Fimage_mask_p)
+ (make_image, free_image, prepare_image_for_display, image_ascent)
+ (four_corners_best, image_background, image_background_transparent)
+ (x_clear_image_1, x_clear_image, x_alloc_image_color)
+ (make_image_cache, free_image_cache, clear_image_cache)
+ (Fclear_image_cache, postprocess_image, lookup_image, cache_image)
+ (forall_images_in_image_cache, x_create_x_image_and_pixmap)
+ (x_destroy_x_image, x_put_x_image, x_find_image_file, slurp_file)
+ (struct ct_color, init_color_table, free_color_table)
+ (lookup_rgb_color, lookup_pixel_color, colors_in_color_table)
+ (cross_disabled_images, x_to_xcolors, x_from_xcolors)
+ (x_detect_edges, x_emboss, x_laplace, x_edge_detection)
+ (x_disable_image, x_build_heuristic_mask)
+ (XBM support, XPM support, PBM support, PNG support, JPEG support)
+ (TIFF support, GIF support, Ghostscript support): Merge with
+ w32fns.c and macfns.c image code into image.c.
+ (syms_of_xfns): Move image related symbols to image.c.
+ (init_xfns): Remove; initialization moved to init_image in image.c.
+
+ * lisp.h (syms_of_image, init_image): Add protoypes.
+ (init_xfns): Remove prototype.
+
+ * dispextern.h (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
+ (x_reference_bitmap, x_create_bitmap_from_data)
+ (x_create_bitmap_from_file, x_destroy_bitmap)
+ (x_create_bitmap_mask): Move prototypes from dispextern.h.
+ (gamma_correct) [MAC_OS]: Add prototype.
+
+ * xterm.h (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
+ (x_reference_bitmap, x_create_bitmap_from_data)
+ (x_create_bitmap_from_file, x_destroy_bitmap)
+ (x_create_bitmap_mask): Move prototypes to dispextern.h.
+
+2004-03-09 Kenichi Handa <handa@etlken2>
+
+ * coding.c (decode_coding_emacs_mule): Handle insufficent source
+ correctly.
+
+2004-03-04 Richard M. Stallman <[email protected]>
+
+ * s/sol2-6.h (LD_SWITCH_SYSTEM_TEMACS): New definition.
+
+ * window.c (Fdisplay_buffer): Doc fix.
+
+ * buffer.c (Fpop_to_buffer): Doc fix.
+
+2004-03-03 Kim F. Storm <[email protected]>
+
+ * xdisp.c (display_line): Fix call to get_overlay_arrow_glyph_row.
+
+2004-03-02 Stefan Monnier <[email protected]>
+
+ * editfns.c (Ftranslate_region): Lisp_Object/int mixup.
+
+2004-03-02 Richard M. Stallman <[email protected]>
+
+ * indent.c (compute_motion): Save vpos in prev_vpos, like hpos etc.
+
+2004-03-02 Kenichi Handa <[email protected]>
+
+ * doc.c (Fsubstitute_command_keys): Fix counding bytes.
+
+2004-03-02 Kim F. Storm <[email protected]>
+
+ * window.h (struct window): New member overlay_arrow_bitmap.
+
+ * window.c (make_window): Initialize overlay_arrow_bitmap.
+
+ * xdisp.c (Voverlay_arrow_variable_list): New variable to properly
+ implement and integrate multiple overlay arrows with redisplay.
+ (syms_of_xdisp): DEFVAR_LISP and initialize it.
+ (last_arrow_position, last_arrow_string): Replace by properties.
+ (Qlast_arrow_position, Qlast_arrow_string)
+ (Qoverlay_arrow_string, Qoverlay_arrow_bitmap): New variables.
+ (syms_of_xdisp): Intern and staticpro them.
+ (overlay_arrow_string_or_property, update_overlay_arrows)
+ (overlay_arrow_in_current_buffer_p, overlay_arrows_changed_p)
+ (overlay_arrow_at_row): New functions for multiple overlay arrows.
+ (redisplay_internal): Use them instead of directly accessing
+ Voverlay_arrow_position etc. for multiple overlay arrows.
+ (mark_window_display_accurate): Use update_overlay_arrows.
+ (try_cursor_movement): Use overlay_arrow_in_current_buffer_p.
+ (try_window_id): Use overlay_arrows_changed_p.
+ (get_overlay_arrow_glyph_row): Add overlay_arrow_string arg.
+ (display_line): Use overlay_arrow_at_row to check multiple
+ overlay arrows, and get relevant overlay-arrow-string and
+ overlay-arrow-bitmap. Set w->overlay_arrow_bitmap accordingly.
+ (produce_image_glyph): Set pixel_width = 0 for fringe bitmap.
+ (syms_of_xdisp): Remove last_arrow_position and last_arrow_string.
+
+ * fringe.c (draw_fringe_bitmap): Use w->overlay_arrow_bitmap if set.
+ (update_window_fringes): Remove unused code.
+
+2004-03-01 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_read_socket): Fix last change to ButtonPress handling.
+
+2004-03-01 Juanma Barranquero <[email protected]>
+
+ * fringe.c (Fdefine_fringe_bitmap): Fix typo in docstring.
+
+ * makefile.w32-in ($(BLD)/fringe.$(O)): Add dependencies.
+
+2004-03-01 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (Fx_display_color_cells): Use number of planes to calculate
+ how many colors can be displayed.
+
+2004-03-01 Kenichi Handa <[email protected]>
+
+ * editfns.c (Ftranslate_region): Handle multibyte chars in TABLE
+ correctly.
+
+2004-02-28 Kim F. Storm <[email protected]>
+
+ * dispnew.c (update_window): Update header line also if there are
+ no other changes in window (move code after set_cursor label).
+
+ * lisp.h (mark_window_display_accurate): Remove prototype.
+
+ * window.c (window_loop, Fforce_window_update): Force mode line
+ updates by setting prevent_redisplay_optimizations_p and
+ update_mode_lines.
+
+2004-02-28 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_window): Fix indentation.
+
+ * xterm.c (x_calc_absolute_position): Call x_real_positions
+ to get WM window sizes and use those to calculate position.
+ (x_set_offset): Remove code commented out.
+
+2004-02-28 Miles Bader <[email protected]>
+
+ * keyboard.c (adjust_point_for_property): #ifdef-out dodgy xassert.
+
+2004-02-28 Kim F. Storm <[email protected]>
+
+ * keyboard.c (kbd_buffer_store_event_hold): New function to store
+ an event into kbd fifo, but with special handling of quit event;
+ a quit event is saved for later, and further events are discarded
+ until the saved quit event has been processed.
+ (kbd_buffer_store_event): Use kbd_buffer_store_event_hold.
+ (gen_help_event): Store help event in kbd fifo.
+ (NREAD_INPUT_EVENTS): Remove.
+ (read_avail_input): Adapt to new read_socket_hook interface.
+ Remove allocation and initialization of local input_event buffer,
+ as read_socket_hook stores events directly in fifo. Allocate and
+ initialize local hold_quit event to handle postponed quit event
+ (and store it if set by kbd_buffer_store_event_hold).
+
+ * keyboard.h (kbd_buffer_store_event_hold): Add prototype.
+ (gen_help_event): Fix prototype.
+
+ * macterm.c (XTread_socket): Remove bufp_r and
+ numcharsp args. Add hold_quit arg.
+ Rework to use just one, local, inev input_event. Store inev
+ directly in fifo using kbd_buffer_store_event_hold.
+
+ * sysdep.c (BUFFER_SIZE_FACTOR): Remove.
+ (read_input_waiting): Adapt to new read_socket_hook interface.
+ Remove allocation and initialization of local input_event buffer,
+ as read_socket_hook stores events directly in fifo. Allocate and
+ initialize local hold_quit event to handle postponed quit event
+ (and store it if set by kbd_buffer_store_event_hold).
+
+ * term.c (read_socket_hook): Fix arg list.
+
+ * termhooks.h (read_socket_hook): Fix prototype.
+
+ * w32inevt.c (w32_console_read_socket): Remove bufp_r and
+ numcharsp args. Add hold_quit arg.
+ Rework to use just one, local, inev input_event. Store inev
+ directly in fifo using kbd_buffer_store_event_hold.
+
+ * w32inevt.h (w32_console_mouse_position): Fix prototype.
+
+ * w32term.c (w32_read_socket): Remove bufp_r and numcharsp args.
+ Add hold_quit arg. Rework to use just one, local, inev
+ input_event. Store inev directly in fifo using
+ kbd_buffer_store_event_hold. Update count in one place.
+ Postpone call to gen_help_event until inev is stored; use new
+ local do_help for this.
+ Remove local emacs_event in handing of ButtonPress event; just use
+ inev instead (so no reason to copy it later).
+
+ * xsmfns.c (x_session_check_input): Remove numchars arg.
+
+ * xterm.c (x_focus_changed, x_detect_focus_change):
+ Remove numchars arg. Always store event into bufp arg.
+ Return nothing. Callers changed accordingly.
+ (glyph_rect): Simplify.
+ (STORE_KEYSYM_FOR_DEBUG): New macro.
+ (SET_SAVED_MENU_EVENT): Use inev instead of bufp, etc.
+ (current_bufp, current_numcharsp) [USE_GTK]: Remove.
+ (current_hold_quit) [USE_GTK]: Add.
+ (event_handler_gdk): Adapt to new handle_one_xevent.
+ (handle_one_xevent): Remove bufp_r and numcharsp args.
+ Add hold_quit arg. Rework to use just one, local, inev
+ input_event. Store inev directly in fifo using
+ kbd_buffer_store_event_hold. Update count in one place.
+ Postpone call to gen_help_event until inev is stored; use new
+ local do_help for this.
+ Simplify handling of keysyms (consolidate common code). Fix bug
+ where count was updated with nchars instead of nbytes.
+ Remove local emacs_event in handing of ButtonPress event; just use
+ inev instead (so no reason to copy it later).
+ Remove `out' label. Rename label `ret' to `done'; add various
+ `goto done' to clarify code flow in deeply nested blocks.
+ (x_dispatch_event): Simplify as handle_one_xevent now calls
+ kbd_buffer_store_event itself.
+ (XTread_socket): Remove bufp_r and numcharsp args. Add hold_quit
+ arg. Call handle_one_xevent with new arglist. Store event from
+ x_session_check_input in fifo.
+ [USE_GTK]: Setup current_hold_quit.
+ Decrement handling_signal before unblocking input.
+ (x_initialize) [USE_GTK]: Initialize current_count.
+
+ * xterm.h (x_session_check_input): Fix prototype.
+
+2004-02-26 YAMAMOTO Mitsuharu <[email protected]>
+
+ * s/darwin.h (LD_SWITCH_SYSTEM_TEMACS): Add `-framework QuickTime'.
+
+ * dispextern.h [MAC_OSX]: Do not include Carbon/Carbon.h (now in
+ macgui.h).
+
+ * emacs.c (main) [HAVE_CARBON]: Call init_xfns.
+
+ * macgui.h [MAC_OSX]: Include Carbon/Carbon.h.
+ (mktime, DEBUG, Z, free, malloc, realloc, max, min)
+ (init_process) [MAC_OSX]: Avoid conflicts with Carbon/Carbon.h.
+ [!MAC_OSX]: Include QDOffscreen.h and Controls.h.
+ (INFINITY) [MAC_OSX]: Avoid conflict with definition in math.h.
+ (Bitmap): Remove typedef.
+ (Pixmap): Change int to GWorldPtr.
+
+ * macmenu.c [MAC_OSX]: Don't include Carbon/Carbon.h (now in macgui.h).
+
+ * macterm.h [MAC_OSX]: Don't include Carbon/Carbon.h (now in macgui.h).
+ (RED16_FROM_ULONG, GREEN16_FROM_ULONG, BLUE16_FROM_ULONG):
+ New #define to extract 16-bit depth color components from unsigned
+ long representation.
+ (PIX_MASK_DRAW, PIX_MASK_RETAIN): New #define to represent pixel
+ colors used for masks.
+ (struct mac_display_info): Add color_p. Remove n_cbits.
+
+ * macfns.c: Include sys/types.h and sys/stat.h.
+ [MAC_OSX]: Do not include Carbon/Carbon.h (now in macgui.h).
+ Include QuickTime/QuickTime.h.
+ (XCreatePixmap, XCreatePixmapFromBitmapData, XFreePixmap)
+ (XSetForeground, mac_draw_line_to_pixmap): Add externs for
+ functions defined in macterm.c.
+ (XImagePtr): New typedef. Corresponds to XImage * in xfns.c.
+ (ZPixmap): New #define for compatibility with xfns.c.
+ (XGetImage, XPutPixel, XGetPixel, XDestroyImage)
+ (x_create_x_image_and_pixmap, x_destroy_x_image, x_put_x_image)
+ (find_image_fsspec, image_load_qt_1, image_load_quicktime):
+ New functions.
+ (four_corners_best, x_create_x_image_and_pixmap)
+ (x_destroy_x_image, unwind_create_frame, x_disable_image)
+ (x_edge_detection, init_color_table, colors_in_color_table)
+ (lookup_rgb_color, lookup_pixel_color, postprocess_image)
+ (x_put_x_image, slurp_file, xbm_scan, xbm_load, xbm_load_image)
+ (xbm_image_p, xbm_read_bitmap_data, xbm_file_p, x_to_xcolors)
+ (x_from_xcolors, x_detect_edges): New declarations (from xfns.c).
+ (mac_color_map_lookup, x_to_mac_color): Fix Lisp_Object/unsigned
+ long mixup.
+ (mac_defined_color, x_to_x_colors): Use RED16_FROM_ULONG etc.
+ (x_decode_color): Don't use n_cbits (in struct mac_display_info).
+ (x_set_foreground_color, x_set_cursor_color): Sync with w32fns.c.
+ (x_set_cursor_type, Fxw_color_values, valid_image_p)
+ (image_value_type, parse_image_spec, image_ascent, x_clear_image)
+ (x_alloc_image_color, clear_image_cache, lookup_image)
+ (x_find_image_file, xbm_read_bitmap_file_data)
+ (enum xbm_keyword_index, xbm_format, xbm_image_p, xbm_scan)
+ (xbm_read_bitmap_data, xbm_load, pbm_image_p, pbm_scan_number)
+ (enum pbm_keyword_index, pbm_format, enum png_keyword_index)
+ (png_format, png_image_p, enum jpeg_keyword_index, jpeg_format)
+ (jpeg_image_p, enum tiff_keyword_index, tiff_format, tiff_image_p)
+ (enum gif_keyword_index, gif_format, gif_image_p): Sync with xfns.c.
+ (x_make_gc): Sync with xfns.c. Enclose unused `border_tile' with
+ #if 0.
+ (x_free_gcs): Sync with xfns.c. Enclose unused `border_tile' with
+ #if 0. Free white_relief.gc and black_relief.gc.
+ (unwind_create_frame, x_emboss, x_laplace, x_edge_detection):
+ New functions (from xfns.c).
+ (Fx_create_frame): Record unwind_create_frame.
+ (Fxw_display_color_p): Use dpyinfo->color_p.
+ (Fx_display_grayscale_p, Fx_display_planes): Don't use
+ dpyinfo->n_cbits.
+ (Fx_display_color_cells): Use dpyinfo->n_planes;
+ (QCmatrix, QCcolor_adjustment, QCmask, Qemboss, Qedge_detection)
+ (Qheuristic, cross_disabled_images, emboss_matrix)
+ (laplace_matrix): New variables (from xfns.c).
+ (Fimage_size, Fimage_mask_p, four_corners_best, image_background)
+ (x_clear_image_1, postprocess_image, slurp_file, xbm_load_image)
+ (xbm_file_p, x_to_xcolors, x_from_xcolors, x_detect_edges)
+ (image_background_transparent): New function (from xfns.c).
+ Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
+ (image_load_quicktime): Add declaration.
+ [MAC_OSX] (image_load_quartz2d): Likewise.
+ [MAC_OSX] (CGImageCreateWithPNGDataProviderProcType): New typedef.
+ [MAC_OSX] (MyCGImageCreateWithPNGDataProvider): New variable.
+ [MAC_OSX] (init_image_func_pointer, image_load_quartz2d): New funs.
+ (xbm_load_image_from_file, x_laplace_read_row)
+ (x_laplace_write_row, pbm_read_file): Remove functions.
+ [HAVE_XPM] (enum xpm_keyword_index, xpm_format, xpm_image_p)
+ (xpm_load): Sync with xfns.c (although XPM is not supported yet).
+ (colors_in_color_table): Sync with xfns.c (although not used).
+ (lookup_rgb_color): Don't lookup color table. Just do gamma
+ correction.
+ (COLOR_INTENSITY): New #define (from xfns.c).
+ (x_disable_image): New function (from xfns.c).
+ Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
+ (x_build_heuristic_mask): Sync with xfns.c.
+ Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
+ (HAVE_PBM): Remove #ifdef.
+ (pbm_load): Sync with xfns.c. Set img->width and img->height
+ before IMAGE_BACKGROUND.
+ (png_image_p, png_load): Don't enclose declarations with #if HAVE_PNG.
+ (Qpng, enum png_keyword_index, png_format, png_type, png_image_p):
+ Don't enclose with #if HAVE_PNG.
+ [!HAVE_PNG] (png_load) [MAC_OSX]: Use image_load_quartz2d if a
+ symbol _CGImageCreateWithPNGDataProvider is defined.
+ Otherwise use image_load_quicktime.
+ [!HAVE_PNG] (png_load) [!MAC_OSX]: Use image_load_quicktime.
+ [HAVE_PNG] (png_load): Sync with xfns.c.
+ Use PIX_MASK_DRAW/PIX_MASK_RETAIN.
+ (jpeg_image_p, jpeg_load): Don't enclose declarations with #if
+ HAVE_JPEG.
+ (Qjpeg, enum jpeg_keyword_index, jpeg_format, jpeg_type)
+ (jpeg_image_p): Don't enclose with #if HAVE_JPEG.
+ [!HAVE_JPEG] (jpeg_load) [MAC_OSX]: Use image_load_quartz2d.
+ [!HAVE_JPEG] (jpeg_load) [!MAC_OSX]: Use image_load_quicktime.
+ [HAVE_JPEG] (jpeg_load): Sync with xfns.c.
+ (tiff_image_p, tiff_load): Don't enclose declarations with #if
+ HAVE_TIFF.
+ (Qtiff, enum tiff_keyword_index, tiff_format, tiff_type)
+ (tiff_image_p): Don't enclose with #if HAVE_TIFF.
+ [!HAVE_TIFF] (tiff_load): Use image_load_quicktime.
+ [HAVE_TIFF] (tiff_error_handler, tiff_warning_handler):
+ New functions (from xfns.c).
+ [HAVE_TIFF] (tiff_load): Sync with xfns.c.
+ (gif_image_p, gif_load): Don't enclose declarations with #if HAVE_GIF.
+ (Qgif, enum gif_keyword_index, gif_format, gif_type, gif_image_p):
+ Don't enclose with #if HAVE_GIF.
+ [!HAVE_GIF] (gif_load): Use Quicktime Movie Toolbox if it is
+ animated gif. Otherwise use image_load_quicktime.
+ [HAVE_GIF] (gif_lib.h): Temporarily define DrawText as
+ gif_DrawText to avoid conflict with QuickdrawText.h.
+ [HAVE_GIF] (gif_load): Sync with xfns.c.
+ (enum gs_keyword_index, gs_format, gs_image_p, gs_load)
+ [HAVE_GHOSTSCRIPT] (x_kill_gs_process): Sync with xfns.c (although
+ Ghostscript is not supported yet).
+ (syms_of_macfns): Initialize Qemboss, Qedge_detection, Qheuristic,
+ QCmatrix, QCcolor_adjustment, and QCmask. Add DEFVAR_BOOL
+ cross_disabled_images (from xfns.c). Remove #if 0 for supported
+ image types. Remove #if HAVE_JPEG, HAVE_TIFF, HAVE_GIF, and
+ HAVE_PNG. Add defsubr for Simage_size and Simage_mask_p.
+ (init_xfns): Remove #if HAVE_JPEG, HAVE_TIFF, HAVE_GIF, and
+ HAVE_PNG. Call EnterMovies to support animated gifs.
+ Call init_image_func_pointer to bind a symbol
+ _CGImageCreateWithPNGDataProvider if it is defined.
+
+ * macterm.c [MAC_OSX]: Don't include Carbon/Carbon.h (now in macgui.h).
+ (x_draw_bar_cursor): Sync declaration with xterm.c.
+ (XFreePixmap, mac_draw_rectangle_to_pixmap, mac_copy_area)
+ (mac_copy_area_to_pixmap): Implementation with GWorld (offscreen
+ graphics).
+ (mac_set_forecolor, mac_set_backcolor): Use RED16_FROM_ULONG etc.
+ (mac_draw_line_to_pixmap, XCreatePixmap)
+ (XCreatePixmapFromBitmapData, mac_fill_rectangle_to_pixmap)
+ (mac_copy_area_with_mask, mac_copy_area_with_mask_to_pixmap):
+ New functions.
+ (mac_draw_bitmap) [TARGET_API_MAC_CARBON]:
+ Use GetPortBitMapForCopyBits instead of the cast to Bitmap *.
+ Cast bits to char *.
+ (reflect_byte): New function (from w32fns.c).
+ (mac_create_bitmap_from_bitmap_data): Use it and don't stuff bits
+ due to byte alignment.
+ (mac_scroll_area) [TARGET_API_MAC_CARBON]:
+ Use GetPortBitMapForCopyBits instead of the cast to Bitmap *.
+ (XSetForeground): Remove static (now used in macfns.c).
+ (HIGHLIGHT_COLOR_DARK_BOOST_LIMIT): New #define (from w32term.c).
+ (mac_alloc_lighter_color, x_destroy_window): Sync with w32term.c.
+ (x_setup_relief_color, x_setup_relief_colors, x_draw_box_rect)
+ (x_draw_glyph_string_box, x_draw_image_foreground)
+ (x_draw_image_foreground_1, x_draw_image_glyph_string)
+ (x_draw_stretch_glyph_string, x_draw_glyph_string)
+ (x_draw_hollow_cursor, x_draw_bar_cursor, mac_draw_window_cursor):
+ Sync with xterm.c.
+ (x_draw_relief_rect): Sync with xterm.c. Make 1 pixel shorter
+ than the xterm.c version when a strictly horizontal or vertical
+ line is drawn.
+ (XTset_terminal_window): Add static.
+ (x_make_frame_visible): Add UNBLOCK_INPUT.
+ (x_free_frame_resources): New funcion (from xterm.c).
+ (XTread_socket): Call handle_tool_bar_click if mouse up/down event
+ occurs in tool bar area.
+ (mac_initialize_display_info): Remove dpyinfo->n_cbits.
+ Set dpyinfo->color_p. Determine dpyinfo->n_planes using HasDepth.
+ Initialize image cache.
+ (stricmp, wildstrieq, mac_font_pattern_match, mac_font_match):
+ Enclose unused functions with #if 0.
+ (Qbig5, Qcn_gb, Qsjis, Qeuc_kr): New variables.
+ (decode_mac_font_name): New function to apply code conversions
+ from a mac font name to an XLFD font name according to its script code.
+ (x_font_name_to_mac_font_name): Apply code conversion from an XLFD
+ font name to a mac font name according to REGISTRY and ENCODING fields.
+ (init_font_name_table) [TARGET_API_MAC_CARBON]: Don't use a font
+ whose name starts with `.'.
+ (init_font_name_table): Use decode_mac_font_name. Add both
+ jisx0208.1983-sjis and jisx0201.1976-0 entries if the script code
+ of a font is smJapanese.
+ (mac_do_list_fonts): New function to list fonts that match a given
+ pattern.
+ (x_list_fonts, XLoadQueryFont): Use it.
+ (XLoadQueryFont): Set rbearing field for each variable width
+ character to avoid needless redraw.
+ (syms_of_macterm): Initialize Qbig5, Qcn_gb, Qsjis, and Qeuc_kr.
+
+2004-02-26 Kim F. Storm <[email protected]>
+
+ * keyboard.c (NREAD_INPUT_EVENTS): Temporarily increase to 512
+ as read_socket_hook handler on X aborts if buffer is too small
+ and W32 handler doesn't always check buffer limit.
+
+ * xdisp.c (handle_single_display_prop): Handle left-fringe and
+ right-fringe similar to a display margin image. Specifically,
+ the characters having the fringe prop are no longer shown, and
+ we use IT_IMAGE/next_element_from_image with image_id = -1 to
+ do this. Set fringe bitmap face_id in it->face_id.
+ (produce_image_glyph): Handle image_id < 0 as "no image" case, but
+ still realize it->face (i.e. the fringe bitmap face).
+
+2004-02-25 Miles Bader <[email protected]>
+
+ * xdisp.c (check_it): Check string/string_pos consistency.
+ (init_iterator): Initialize string-related fields properly.
+
+2004-02-11 Miles Bader <[email protected]>
+
+ * xdisp.c (produce_image_glyph): Force negative descents to zero.
+
+2004-02-10 Miles Bader <[email protected]>
+
+ * xfns.c (lookup_image): Remove xassert(!interrupt_input_blocked);
+ BLOCK_INPUT can be nested, so it doesn't make much sense.
+
+2004-02-24 Michael Mauger <[email protected]>
+
+ * w32fns.c (slurp_file, xbm_scan, xbm_load_image)
+ (xbm_read_bitmap_data): Use unsigned char for image data.
+
+2004-02-23 Luc Teirlinck <[email protected]>
+
+ * abbrev.c (Finsert_abbrev_table_description): Doc fix.
+
+2004-02-22 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_draw_fringe_bitmap): Draw overlaid bitmaps
+ correctly over other bitmaps.
+
+2004-02-21 Eli Zaretskii <[email protected]>
+
+ * emacs.c (USAGE1): Split into two halves.
+ (USAGE2): Second half of the old USAGE1.
+ (USAGE3): Rename from USAGE2.
+ (USAGE4): Rename from USAGE3.
+
+2004-02-21 Juri Linkov <[email protected]>
+
+ * emacs.c (USAGE1): Add --no-desktop. Move --display from USAGE2.
+ Fix --multibyte. Move --help, --version to USAGE2. Add alias
+ --file. Fix -f, -l. Sort options. Untabify.
+ (USAGE2): Add -hb. Fix --name, --title. Sort options. Untabify.
+
+2004-02-19 Luc Teirlinck <[email protected]>
+
+ * category.c (Fdefine_category, Fcategory_docstring)
+ (Fget_unused_category, Fset_category_table)
+ (Fcategory_set_mnemonics): Doc fixes.
+
+2004-02-20 Kim F. Storm <[email protected]>
+
+ * keyboard.c: Undo 2004-02-16 and 2004-02-17 changes.
+ The following changes are relative to the 2004-01-21 revision.
+ (NREAD_INPUT_EVENTS): Define as max number of input events to read
+ in one call to read_socket_hook. Value is 8.
+ (read_avail_input): Separate and rework handling of read_socket_hook
+ and non-read_socket_hook cases. Use smaller input_event buffer
+ in read_socket_hook case, and repeat if full buffer is read.
+ Use new local variable 'discard' to skip input after C-g.
+ In non-read_socket_hook case, just use a single input_event, and
+ call kbd_buffer_store_event on the fly for each character.
+
+2004-02-19 Stefan Monnier <[email protected]>
+
+ * lisp.h (union Lisp_Object): Give a more precise type for `type'.
+ Remove unused `gu' alternative.
+
+2004-02-19 Andreas Schwab <[email protected]>
+
+ * fringe.c (Fdefine_fringe_bitmap): Use && instead of & to avoid
+ warning.
+
+2004-02-18 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_window_cursor_type, display_and_set_cursor):
+ Fix last change.
+
+2004-02-17 Kim F. Storm <[email protected]>
+
+ * xdisp.c (fast_find_position): Fix return value of new version;
+ it was inverted compared to the 21.1 version.
+ (get_window_cursor_type): Don't look at glyph if NULL.
+ (display_and_set_cursor): Set glyph to NULL if cursor in fringe.
+
+ * keyboard.c: Rework previous change; it didn't consider that the
+ buf array was allocated on the stack.
+ (prev_read): Remove variable.
+ (read_avail_input_buf): New static event buffer array.
+ (in_read_avail_input): New static variable to handle re-entrancy.
+ (read_avail_input): Change buf to pinter to read_avail_input_buf.
+ Use in_read_avail_input to handle re-entrance; when re-entered,
+ fully initialize and use tmp_buf array instead of read_avail_input_buf.
+ Do not initialize read_avail_input_buf in full here; instead assume it
+ is always cleared on entry. To ensure that, we clear (just) the
+ entries that were used before we return.
+ (init_keyboard): Initialize read_avail_input_buf here.
+
+2004-02-16 Jesper Harder <[email protected]>
+
+ * cmds.c (Fend_of_line): Doc fix.
+
+2004-02-16 Dmitry Antipov <[email protected]> (tiny change)
+
+ * keyboard.c (prev_read): New static variable.
+ (read_avail_input): Use it to zero out only those slots in buf[]
+ that were used last time we were called.
+
+2004-02-16 Eli Zaretskii <[email protected]>
+
+ * Makefile.in (obj): Move fringe.o from here...
+ (XOBJ, MAC_OBJ): ...to here.
+
+2004-02-16 Stephen Eglen <[email protected]>
+
+ * fringe.c (init_fringe_bitmap): Define j in MAC_OS code.
+
+2004-02-15 Stefan Monnier <[email protected]>
+
+ * data.c (Fbyteorder):
+ * fringe.c (Fdefine_fringe_bitmap):
+ * xdisp.c (handle_single_display_prop):
+ * xselect.c (x_handle_dnd_message): Lisp_Object/int mixup.
+
+2004-02-16 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_draw_fringe_bitmap): Handle overlay fringe bitmaps.
+
+2004-02-15 Steven Tamm <[email protected]>
+
+ * macterm.c (Vmac_emulate_three_button_mouse): New variable for
+ controlling emulation of a three button mouse with option and
+ command keys.
+ (Qreverse, mac_get_enumlated_btn): Handle the emulation.
+ (mac_event_to_emacs_modifiers, XTread_socket): Ditto.
+
+2004-02-15 Kim F. Storm <[email protected]>
+
+ * buffer.c (syms_of_buffer): Doc fix for indicate-buffer-boundaries.
+
+ * fringe.c (init_fringe_bitmap) [MAC_OS, WORDS_BIG_ENDIAN]:
+ Perform byte-swapping.
+
+2004-02-14 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct draw_fringe_bitmap_params): Change member
+ bits from char to short to facilitate wider bitmaps.
+ (struct redisplay_interface): Fix prototype of define_fringe_bitmap
+ member.
+
+ * fringe.c (struct fringe_bitmap): Change member bits from char to
+ short to facilitate 16 bits wide bitmaps. Modify all standard
+ bitmaps accordingly.
+ (BYTES_PER_BITMAP_ROW, STANDARD_BITMAP_HEIGHT): New macros.
+ (FRBITS): Use STANDARD_BITMAP_HEIGHT instead of just sizeof.
+ (draw_fringe_bitmap): Ditto.
+ (init_fringe_bitmap) [MAC_OS]: Don't bitswap.
+ (init_fringe_bitmap) [HAVE_X_WINDOWS]: Enhance bitswapping to
+ handle up to 16 bits wide bitmaps.
+ (Fdefine_fringe_bitmap): Doc fix. Handle wider bitmaps.
+ (Ffringe_bitmaps_at_pos): Add missing arg declarations.
+
+ * macterm.c (mac_draw_bitmap): Handle 16 bits wide bitmaps directly.
+ (x_draw_fringe_bitmap): Use enhanced mac_draw_bitmap, so we no longer
+ need to call mac_create_bitmap_from_bitmap_data and mac_free_bitmap.
+
+ * w32term.c (w32_define_fringe_bitmap): Bitmaps are now 16 bits wide,
+ so it is no longer necessary to expand them here.
+
+ * xterm.c (x_draw_fringe_bitmap): Handle wider bitmaps (max 16 bits).
+
+2004-02-12 Kim F. Storm <[email protected]>
+
+ * window.c (Fwindow_fringes): Doc fix.
+
+2004-02-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * xselect.c (x_get_foreign_selection): Add new optional parameter
+ time_stamp.
+ (Fx_get_selection_internal): Ditto, pass time_stamp to
+ x_get_foreign_selection.
+
+ * data.c (Fbyteorder): New function.
+
+2004-02-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * atimer.c: Move include stdio.h to same place as in other files.
+
+ * region-cache.c: Ditto.
+
+ * sysdep.c: Ditto.
+
+ * xfaces.c: Ditto.
+
+2004-02-09 Sam Steingold <[email protected]>
+
+ * w32term.c (w32_draw_fringe_bitmap): Fix a typo in the last patch.
+
+2004-02-09 Kim F. Storm <[email protected]>
+
+ * fringe.c: New file. Move original fringe related declarations
+ and code from dispextern.h and xdisp.c here.
+ Rework code to support user defined fringe bitmaps, redefining
+ standard bitmaps, ability to overlay user defined bitmap with
+ overlay arrow bitmap, and add faces to bitmaps.
+ (Voverflow_newline_into_fringe): Declare here.
+ (enum fringe_bitmap_align): New enum.
+ (..._bits): All bitmaps are now defined without bitswapping; that
+ is now done in init_fringe_once (if necessary).
+ (standard_bitmaps): New array with specifications for the
+ standard fringe bitmaps.
+ (fringe_faces): New array.
+ (valid_fringe_bitmap_id_p): New function.
+ (draw_fringe_bitmap_1): Rename from draw_fringe_bitmap.
+ (draw_fringe_bitmap): New function which draws fringe bitmap,
+ possibly overlaying bitmap with cursor in right fringe or the
+ overlay arrow in the left fringe.
+ (update_window_fringes): Do not handle overlay arrow here.
+ Compare and copy fringe bitmap faces.
+ (init_fringe_bitmap): New function.
+ (Fdefine_fringe_bitmap, Fdestroy_fringe_bitmap): New DEFUNs to
+ define and destroy user defined fringe bitmaps.
+ (Fset_fringe_bitmap_face): New DEFUN to set face for a fringe bitmap.
+ (Ffringe_bitmaps_at_pos): New DEFUN to read current fringe bitmaps.
+ (syms_of_fringe): New function. Defsubr new DEFUNs.
+ DEFVAR_LISP Voverflow_newline_into_fringe.
+ (init_fringe_once, init_fringe): New functions.
+ (w32_init_fringe, w32_reset_fringes) [WINDOWS_NT]: New functions.
+
+ * Makefile.in (obj): Add fringe.o.
+ (fringe.o): New dependencies.
+
+ * dispextern.h (FRINGE_ID_BITS): New definition for number of
+ bits allocated to hold a fringe number. Increase number of bits
+ from 4 to 8 to allow user defined fringe bitmaps.
+ (struct glyph_row, struct it): New members left_user_fringe_bitmap,
+ left_user_fringe_face_id, right_user_fringe_bitmap,
+ right_user_fringe_face_id.
+ (enum fringe_bitmap_type, struct fringe_bitmap, fringe_bitmaps):
+ Move to new file fringe.c.
+ (MAX_FRINGE_BITMAPS): Define here.
+ (struct draw_fringe_bitmap_params): New members bits, cursor_p,
+ and overlay_p. Change member which to int.
+ (struct redisplay_interface): New members define_fringe_bitmap
+ and destroy_fringe_bitmap.
+ (valid_fringe_bitmap_id_p): Add prototype.
+ (w32_init_fringe, w32_reset_fringes) [WINDOWS_NT]: Add prototypes.
+
+ * dispnew.c (row_equal_p): Compare fringe bitmap faces and overlay
+ arrows.
+ (update_frame): Do flush_display if force_flush_display_p to
+ ensure display (specifically fringes) are updated in a timely
+ manner when resizing the frame by dragging the mouse.
+ (update_window_line): Update row if overlay arrow changed.
+ (scrolling_window): Redraw fringe bitmaps if fringe bitmap faces
+ or overlay arrow changed.
+
+ * emacs.c (main) [HAVE_WINDOW_SYSTEM]: Call init_fringe_once,
+ syms_of_fringe, and init_fringe.
+
+ * frame.h (struct frame): New member force_flush_display_p.
+
+ * lisp.h (syms_of_fringe, init_fringe, init_fringe_once):
+ Add prototypes.
+
+ * macterm.c (mac_draw_bitmap): Add overlay_p arg.
+ (x_draw_fringe_bitmap): Handle overlayed fringe bitmaps;
+ thanks to YAMAMOTO Mitsuharu for advice on how to do this.
+ Use cursor color for displaying cursor in fringe.
+ (x_redisplay_interface): Add null handlers for
+ define_fringe_bitmap and destroy_fringe_bitmap functions.
+
+ * w32term.c (w32_draw_fringe_bitmap): Copy unadapted code from
+ xterm.c to handle overlayed fringe bitmaps and to use cursor color
+ for displaying cursor in fringe.
+ (w32_define_fringe_bitmap, w32_destroy_fringe_bitmap): New W32
+ specific functions to define and destroy fringe bitmaps in fringe_bmp.
+ (w32_redisplay_interface): Add them to redisplay_interface.
+ (w32_term_init): Call w32_init_fringe instead of explicitly
+ defining fringe bitmaps in fringe_bmp array.
+ (x_delete_display): Call w32_reset_fringes instead of explicitly
+ destroying fringe bitmaps in fringe_bmp array.
+
+ * xdisp.c (Voverflow_newline_into_fringe, syms_of_xdisp)
+ (left_bits, right_bits, up_arrow_bits, down_arrow_bits)
+ (continued_bits, continuation_bits, ov_bits, first_line_bits)
+ (last_line_bits, filled_box_cursor_bits, hollow_box_cursor_bits)
+ (bar_cursor_bits, hbar_cursor_bits, zv_bits, hollow_square_bits)
+ (fringe_bitmaps, draw_fringe_bitmap, draw_row_fringe_bitmaps)
+ (draw_window_fringes, compute_fringe_widths, update_window_fringes):
+ Move fringe handling vars and code to new file fringe.c.
+ (handle_display_prop): Handle left-fringe and right-fringe
+ display properties; store user fringe bitmaps in iterator.
+ (move_it_in_display_line_to): Handle cursor in fringe at eob.
+ (clear_garbaged_frames): Set force_flush_display_p if resized.
+ (redisplay_window): Redraw fringe bitmaps if not just_this_one_p.
+ (display_line): Handle cursor in fringe at eob.
+ (display_line): Set row user fringe bitmaps from iterator.
+
+ * xterm.c (x_draw_fringe_bitmap): Handle overlayed fringe bitmaps.
+ Use cursor color for displaying cursor in fringe.
+ (x_redisplay_interface): Add null handlers for
+ define_fringe_bitmap and destroy_fringe_bitmap functions.
+
+2004-02-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * macfns.c (Fx_change_window_property): Make doc string and
+ parameters same as for X version.
+
+ * w32fns.c (Fx_change_window_property): Ditto.
+
+2004-02-07 Kim F. Storm <[email protected]>
+
+ * xdisp.c (hscroll_window_tree): Position cursor near to right
+ margin in hscrolled window when jumping to end of line (rather
+ than centering cursor).
+
+ * process.c (wait_reading_process_input): Don't do adaptive read
+ buffering if waiting for a specific process.
+
+2004-02-05 Luc Teirlinck <[email protected]>
+
+ * minibuf.c (Fminibufferp, Fread_from_minibuffer)
+ (Fread_minibuffer, Feval_minibuffer)
+ (Fread_string, Fread_no_blanks_input)
+ (Fcompleting_read): Doc fixes.
+ (syms_of_minibuf): Doc fixes for minibuffer-completion-table and
+ completion-regexp-list. Define Qcase_fold_search and staticpro it.
+ (read_minibuf): Fix initial comment.
+ (Ftry_completion, Fall_completions, Ftest_completion): Bind
+ case-fold-search to the value of completion-ignore-case when
+ checking completion-regexp-list.
+ (Fdisplay_completion_list): Make it handle arguments that are
+ symbols. Doc fix.
+
+2004-02-05 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h: Add declaration of free_frame_menubar.
+
+ * xfns.c (x_create_bitmap_mask): Removed unused variable depth.
+ (x_set_menu_bar_lines): Added ! defined USE_GTK for olines.
+ (Fx_change_window_property): Add declaration of parameters type and
+ format. Remove unused variable cons.
+
+ * xselect.c: Include stdio.h.
+
+2004-02-05 Kenichi Handa <[email protected]>
+
+ * fns.c (Fset_char_table_range): Fix previous change.
+
+ * buffer.c (Fset_buffer_multibyte): Fix docstring.
+
+2004-02-04 Luc Teirlinck <[email protected]>
+
+ * editfns.c (Fchar_after, Fchar_before): Doc fixes.
+
+2004-02-04 Stefan Monnier <[email protected]>
+
+ * keymap.c (Vmouse_events): Rename from Vmenu_events.
+ (syms_of_keymap): Add mouse-[45], header-line, and mode-line to it.
+
+2004-02-04 Kenichi Handa <[email protected]>
+
+ * fns.c (Fset_char_table_range): Handle charsets ascii,
+ eight-bit-control, and eight-bit-graphic correctly.
+
+2004-02-03 Jason Rumney <[email protected]>
+
+ * w32select.c (Fw32_set_clipboard_data): Make coding iso2022 safe.
+
+ * w32fns.c (x_to_w32_font): Likewise.
+
+2004-02-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h: Add x_handle_dnd_message, x_check_property_data,
+ x_fill_property_data, x_property_data_to_lisp and check_x_display_info.
+
+ * xterm.c (handle_one_xevent): Call x_handle_dnd_message for
+ ClientMessages.
+
+ * xselect.c: Include termhooks.h and X11/Xproto.h.
+ (x_check_property_data, x_fill_property_data)
+ (x_property_data_to_lisp, mouse_position_for_drop)
+ (Fx_get_atom_name, x_handle_dnd_message): New functions for DND support.
+ (Fx_send_client_event): Move here from xfns.c.
+ (syms_of_xselect): Add Sx_get_atom_name and Sx_send_client_message.
+
+ * xfns.c (x-send-client-message): Move to xselect.c.
+ (Fx_change_window_property): Add optional arguments TYPE, FORMAT and
+ OUTER_P.
+ (Fx_window_property): Add optional arguments TYPE, SOURCE, DELETE_P,
+ VECTOR_RET_P. Handle AnyPropertyType. Call x_property_data_to_lisp
+ if vector_ret_p is true.
+ (syms_of_xfns): Sx_send_client_message moved to xselect.c.
+
+2004-02-02 Eli Zaretskii <[email protected]>
+
+ * fileio.c (Fcopy_file): If NEWNAME is a directory, expand the
+ basename of FILE relative to it, not FILE itself.
+
+2004-02-02 Kenichi Handa <[email protected]>
+
+ * coding.c (coding_restore_composition): Check invalid
+ composition data more rigidly.
+
+2004-01-30 Luc Teirlinck <[email protected]>
+
+ * fileio.c (Fread_file_name_internal): Correctly handle the case
+ where insert-default-directory is nil.
+ (Fread_file_name): Always return an empty string if the user exits
+ with an empty minibuffer. Adapt the docstring accordingly.
+ (syms_of_fileio): Adapt the docstring of insert-default-directory
+ to the change in Fread_file_name.
+
+2004-01-29 Eli Zaretskii <[email protected]>
+
+ * alloca.c [!alloca]: Fix the prototype for xfree.
+
+2004-01-29 Kenichi Handa <[email protected]>
+
+ * fns.c (string_char_to_byte): Optimize for ASCII only string.
+ (string_byte_to_char): Likewise.
+
+2004-01-28 Peter Runestig <[email protected]>
+
+ * makefile.w32-in, w32fns.c: Add `default-printer-name' function.
+
+2004-01-27 Steven Tamm <[email protected]>
+
+ * unexmacosx.c (unexec_copy): Do not copy more than was
+ requested to prevent overwriting during unexec.
+
+2004-01-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * process.c (sigchld_handler): Add comment about not calling malloc.
+
+ * process.h: Add extern to synch_process_termsig.
+
+2004-01-27 Steven Tamm <[email protected]>
+
+ * macterm.c (make_mac_frame, make_mac_terminal_frame):
+ Move setting of scroll bars from make_mac_frame to
+ make_mac_terminal_frame to prevent clobbering of scroll-bar-mode.
+
+2004-01-26 Richard M. Stallman <[email protected]>
+
+ * search.c (Freplace_match): Handle nonexistent
+ back-references properly.
+
+2004-01-03 Richard M. Stallman <[email protected]>
+
+ * window.c (decode_any_window): New function.
+ (Fwindow_height, Fwindow_width, Fwindow_edges)
+ (Fwindow_pixel_edges, Fwindow_inside_edges)
+ (Fwindow_inside_pixel_edges): Use decode_any_window.
+
+2004-01-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * process.h: synch_process_termsig new variable.
+
+ * callproc.c: Define synch_process_termsig.
+ (Fcall_process): Initiate synch_process_termsig to zero and
+ check if non-zero and get signal name after subprocess has ended.
+
+ * process.c (sigchld_handler): Set synch_process_termsig
+ if terminated by a signal. synch_process_death setting removed.
+
+ * sysdep.c (mkdir, rmdir): Also check synch_process_termsig.
+
+2004-01-26 Andreas Schwab <[email protected]>
+
+ * print.c (print_preprocess): Declare size as EMACS_INT to not
+ lose bits.
+ (print_object): Likewise.
+ * alloc.c (Fpurecopy): Likewise.
+
+2004-01-25 Luc Teirlinck <[email protected]>
+
+ * window.c (Fwindow_minibuffer_p): Doc fix.
+
+2004-01-24 Jonathan Yavner <[email protected]>
+
+ * editfns.c (Fformat): Make both passes accept the same set of flags.
+
+2004-01-23 Kenichi Handa <[email protected]>
+
+ * fns.c (Fmd5): If OBJECT is a buffer different from the current
+ one, set buffer to OBJECT temporarily.
+
+2004-01-21 Stefan Monnier <[email protected]>
+
+ * keyboard.c (kbd_buffer_gcpro): Remove.
+ (kbd_buffer_store_event, clear_event, Fdiscard_input)
+ (stuff_buffered_input, init_keyboard, syms_of_keyboard):
+ Don't initialize and/or maintain the variable any more. It was made
+ redundant by my commit of 2003-06-15.
+
+ * lisp.h [USE_LSB_TAG && !DECL_ALIGN]: Signal an error.
+
+2004-01-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * lisp.h: Add undef DECL_ALIGN.
+
+2004-01-21 Stefan Monnier <[email protected]>
+
+ * process.c (wait_reading_process_input) [SYNC_INPUT]:
+ Check interrupt_input_pending explicitly.
+
+ * lisp.h (QUIT) [SYNC_INPUT]: Check interrupt_input_pending as well.
+
+ * keyboard.c (handle_async_input): New fun,
+ extracted from input_available_signal.
+ (input_available_signal, reinvoke_input_signal): Use it.
+
+2004-01-20 Stefan Monnier <[email protected]>
+
+ * buffer.c (buffer_defaults, buffer_local_symbols): Use DECL_ALIGN.
+
+ * lisp.h [USE_LSB_TAG]: Add definitions for Lisp_Object value
+ manipulation macros for when tags are in the lower bits.
+ (struct Lisp_Free) [USE_LSB_TAG]: Add padding.
+ (DECL_ALIGN): New macro.
+ (DEFUN): Use it.
+
+ * lisp.h [ENABLE_CHECKING]: Don't force union type.
+
+ * s/darwin.h (__attribute__): Remove outdated workaround.
+
+ * macterm.c (main) [USE_LSB_TAG]: Don't range check the ram.
+
+ * alloc.c (lisp_malloc, lisp_align_malloc) [USE_LSB_TAG]:
+ Don't check range of malloc address.
+ (pure_alloc) [USE_LSB_TAG]: Enforce alignment.
+
+ * process.c (wait_reading_process_input): Lisp_Object/int mixup.
+
+ * dired.c (Ffile_attributes): Lisp_Object/int mixup.
+
+2004-01-19 Kenichi Handa <[email protected]>
+
+ * fontset.c (fontset_font_pattern): Fix previous change.
+
+2004-01-16 Miles Bader <[email protected]>
+
+ * xdisp.c (Voverflow_newline_into_fringe)
+ (move_it_in_display_line_to, redisplay_internal)
+ (update_window_fringes, redisplay_window, display_line, window):
+ Add `#ifdef HAVE_WINDOW_SYSTEM' around fringe-drawing stuff, so
+ that it compiles without a window-system.
+ * dispnew.c (direct_output_for_insert, update_window): Likewise.
+
+2004-01-16 Kim F. Storm <[email protected]>
+
+ * buffer.h (struct buffer): New member indicate_buffer_boundaries.
+
+ * buffer.c (init_buffer_once): Set buffer_defaults and
+ buffer_local_flags for indicate_buffer_boundaries.
+ (syms_of_buffer): Defvar_per_buffer it, and defvar_lisp_nopro
+ default- variable for it.
+
+ * dispextern.h (struct glyph_row): New members left_fringe_bitmap,
+ right_fringe_bitmap, redraw_fringe_bitmaps_p for new fringe handling.
+ New members exact_window_width_line_p and cursor_in_fringe_p for
+ overflowing newlines into right fringe.
+ New members indicate_bob_p, indicate_top_line_p, indicate_eob_p,
+ and indicate_bottom_line_p for buffer boundaries and scrolling.
+ (enum fringe_bitmap_type): Add UP_ARROW_BITMAP, DOWN_ARROW_BITMAP,
+ FIRST_LINE_BITMAP, LAST_LINE_BITMAP, FILLED_BOX_CURSOR_BITMAP,
+ HOLLOW_BOX_CURSOR_BITMAP, BAR_CURSOR_BITMAP, HBAR_CURSOR_BITMAP,
+ and HOLLOW_SQUARE_BITMAP.
+ (draw_fringe_bitmap, draw_window_fringes, update_window_fringes):
+ Add prototypes.
+
+ * dispnew.c (row_equal_p, update_window_line): Compare fringe bitmaps
+ instead of related indicator fields.
+ Compare exact_window_width_line_p and cursor_in_mouse_face_p indicators.
+ (direct_output_for_insert): Handle exact width lines like
+ contined lines. Call update_window_fringes.
+ (update_window): Call update_window_fringes.
+ (scrolling_window): Don't skip desired rows with changed bitmaps.
+ Check if fringe bitmaps changes when assigning scrolled rows.
+
+ * xdisp.c (Voverflow_newline_into_fringe): New variable.
+ (IT_OVERFLOW_NEWLINE_INTO_FRINGE): New macro.
+ (move_it_in_display_line_to): Overflow newline into fringe for
+ rows that are exactly as wide as the window.
+ (up_arrow_bits, down_arrow_bits, first_line_bits, last_line_bits)
+ (filled_box_cursor_bits, hollow_box_cursor_bits, bar_cursor_bits)
+ (hbar_cursor_bits, hollow_square_bits): New fringe bitmaps.
+ (fringe_bitmaps): Add new bitmaps.
+ (draw_fringe_bitmap): Make extern. Remove WHICH arg.
+ Select proper bitmap for cursor in fringe when appropriate.
+ Handle alignment of bitmap to top or bottom of row.
+ (draw_row_fringe_bitmaps): Don't select bitmaps here; that is now
+ done by update_window_fringes.
+ (update_window_fringes, draw_window_fringes): New functions.
+ (redisplay_internal): Call update_window_fringes in case only
+ cursor row is updated.
+ (redisplay_window): Call update_window_fringes.
+ Explicitly call draw_window_fringes if redisplay was done using
+ the current matrix or the overlay arrow is in the window.
+ (try_window_reusing_current_matrix): Mark scrolled rows for
+ fringe update (to update buffer-boundaries / scrolling icons).
+ (find_last_unchanged_at_beg_row): Handle exact width lines line
+ continued lines.
+ (display_line): Overflow newline into fringe for rows that are
+ exactly as wide as the window. Don't append space for newline
+ in this case.
+ (notice_overwritten_cursor): Explicitly clear cursor bitmap
+ in fringe as if it had been overwritten.
+ (erase_phys_cursor): Erase cursor bitmap in fringe.
+ (syms_of_xdisp): Mark show-trailing-whitespace and
+ void-text-area-pointer as user options.
+ DEFVAR_LISP Voverflow_newline_into_fringe. Enable by default.
+
+ * xterm.c (x_update_window_end): Call draw_window_fringes.
+ (x_after_update_window_line): Just set redraw_fringe_bitmaps_p
+ in row instead of actually drawing fringe bitmaps.
+ (x_draw_fringe_bitmap): Handle bottom aligned bitmaps.
+ (x_draw_window_cursor): Draw cursor in fringe.
+
+ * w32term.c (x_update_window_end): Call draw_window_fringes.
+ (x_after_update_window_line): Just set redraw_fringe_bitmaps_p
+ in row instead of actually drawing fringe bitmaps.
+ (w32_draw_fringe_bitmap): Handle bottom aligned bitmaps.
+ (w32_draw_window_cursor): Draw cursor in fringe.
+
+ * macterm.c (x_update_window_end): Call draw_window_fringes.
+ (x_after_update_window_line): Just set redraw_fringe_bitmaps_p
+ in row instead of actually drawing fringe bitmaps.
+ (x_draw_fringe_bitmap): Handle bottom aligned bitmaps.
+ (mac_draw_window_cursor): Draw cursor in fringe.
+
+2004-01-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): Don't handle characters that are part
+ of an old style (XLookupString) compose sequence.
+
+2004-01-15 Kenichi Handa <[email protected]>
+
+ * search.c (Freplace_match): Use make_multibyte_string or
+ make_unibyte_string according to the buffer multibyteness.
+
+2004-01-14 Stefan Monnier <[email protected]>
+
+ * alloc.c (struct interval_block, struct string_block)
+ (struct symbol_block, struct marker_block, live_string_p)
+ (live_cons_p, live_symbol_p, live_float_p, live_misc_p):
+ Better preserve alignment for objects in blocks.
+ (FLOAT_BLOCK_SIZE): Adjust for possible alignment padding.
+
+ * lread.c (defvar_per_buffer): Remove dead declaration.
+
+ * macterm.c (do_check_ram_size): Don't hardcode the lisp address
+ space size.
+
+2004-01-12 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (popup_get_selection): Check new parameter down_on_keypress
+ if a key press should pop down. Only pop down if a key is pressed
+ outside the menu/dialog.
+ (create_and_show_popup_menu): Pass 0 for down_on_keypress to
+ popup_get_selection.
+ (create_and_show_dialog): Pass 1 for down_on_keypress to
+ popup_get_selection.
+
+2004-01-11 Jan Dj,Ad(Brv <[email protected]>
+
+ * alloc.c (allocate_vectorlike): Surround calls to mallopt with
+ BLOCK/UNBLOCK_INPUT.
+
+2004-01-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (Fx_popup_dialog): Add an Ok button if no buttons are
+ specified.
+
+2004-01-08 Kenichi Handa <[email protected]>
+
+ * editfns.c (Fformat): Fix '&' to '&&'.
+
+2004-01-08 Andreas Schwab <[email protected]>
+
+ * print.c (print_preprocess) <case Lisp_Vectorlike>: Only mask
+ size if PSEUDOVECTOR_FLAG is set.
+
+2004-01-07 Kenichi Handa <[email protected]>
+
+ * charset.c (Fdeclare_equiv_charset): Fix docstring.
+
+ * fontset.c (fontset_ref_via_base): Fix previous change.
+
+2004-01-07 Kim F. Storm <[email protected]>
+
+ * process.c (read_process_output): Only activate adaptive
+ buffering if we read less than 256 bytes at a time.
+
+2004-01-06 Kim F. Storm <[email protected]>
+
+ * dispnew.c (buffer_posn_from_coords): Return both buffer/string
+ object and image object. Return glyph width and height.
+ (mode_line_string, marginal_area_string): Ditto.
+
+ * dispextern.h (buffer_posn_from_coords, mode_line_string)
+ (marginal_area_string): Fix prototypes.
+
+ * keyboard.h (POSN_POSN, POSN_SET_POSN): Rename macros from
+ POSN_BUFFER_POSN and POSN_SET_BUFFER_POSN. All uses changed.
+ (POSN_INBUFFER_P, POSN_BUFFER_POSN): New macros.
+
+ * keyboard.c (make_lispy_position): Use modified mode_line_string,
+ buffer_posn_from_coords, and marginal_area_string functions to
+ include both string object and image object in the lispy position.
+ Also add actual glyph width and height to position.
+ (read_key_sequence): Use real buffer position from mouse
+ event to find keymap property even when click is in marginal area.
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Use modified
+ mode_line_string and marginal_area_string functions to handle
+ both string object and image object properties.
+
+2004-01-06 Andreas Schwab <[email protected]>
+
+ * syntax.c (skip_chars): Treat '-' at end of string as ordinary
+ character.
+
+2004-01-02 Andreas Schwab <[email protected]>
+
+ * macterm.c (emacs_options, x_initialized, same_x_server):
+ Remove unused (and duplicated) definitions.
+
+2004-01-02 Kim F. Storm <[email protected]>
+
+ * process.h (struct Lisp_Process): New members for adaptive read
+ buffering: adaptive_read_buffering, read_output_delay, and
+ read_output_skip.
+
+ * process.c (ADAPTIVE_READ_BUFFERING): New conditional.
+ (READ_OUTPUT_DELAY_INCREMENT, READ_OUTPUT_DELAY_MAX)
+ (READ_OUTPUT_DELAY_MAX_MAX): New constants.
+ (process_output_delay_count, process_output_skip): New vars.
+ (Vprocess_adaptive_read_buffering): New variable.
+ (make_process): Initialize adaptive read buffering members.
+ (Fstart_process): Set adaptive_read_buffering member.
+ (deactivate_process): Cleanup adaptive read buffering.
+ (wait_reading_process_input): Temporarily omit delayed
+ subprocesses from the set of file descriptors to read from;
+ adjust the select timeout if we skipped any subprocesses.
+ (read_process_output): Increase adaptive read buffering delay if
+ we read less than a full buffer; reduce delay when we read a
+ full buffer.
+ (send_process): Simplify using local Lisp_Process var.
+ Reset adaptive read buffering delay after write.
+ (init_process): Initialize process_output_delay_count and
+ process_output_skip.
+ (syms_of_process): DEFVAR_LISP Vprocess_adaptive_read_buffering.
+
+2004-01-01 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_text_out): Use s->font, for consistency with callers.
+
+2003-12-30 Luc Teirlinck <[email protected]>
+
+ * print.c (Ferror_message_string): Add hyperlink in the docstring
+ to the definition of `signal' in the Elisp manual.
+ * eval.c (Fsignal): Ditto.
+
+2003-12-29 James Clark <[email protected]>
+
+ * fns.c (internal_equal): Return t for two NaN arguments.
+
+2003-12-29 Richard M. Stallman <[email protected]>
+
+ * data.c (store_symval_forwarding): Handle setting
+ default-fill-column, etc., by changing the value in
+ buffers that use the default.
+
+ * minibuf.c (Fset_minibuffer_window): Doc fix.
+
+ * fileio.c (choose_write_coding_system): Ignore auto_saving
+ if using the visited file for auto saves.
+ (Fwrite_region): Don't update SAVE_MODIFF
+ if auto-saving in visited file.
+
+2003-12-29 Kenichi Handa <[email protected]>
+
+ * dispextern.h (face_font_available_p): Extern it.
+
+ * fontset.c (Voverriding_fontspec_alist): New variable.
+ (lookup_overriding_fontspec): New function.
+ (fontset_ref_via_base): Call lookup_overriding_fontspec if necessary.
+ (fontset_font_pattern): Likewise.
+ (regulalize_fontname): New function.
+ (Fset_fontset_font): Call regulalize_fontname.
+ (Fset_overriding_fontspec_internal): New function.
+ (syms_of_fontset): Initialize and staticpro Voverriding_fontspec_alist.
+ Defsubr Sset_overriding_fontspec_internal.
+
+ * xfaces.c (face_font_available_p): New function.
+
+2003-12-28 Richard M. Stallman <[email protected]>
+
+ * buffer.c (Fother_buffer): Don't crash if BUF is nil
+ or if its name is nil.
+
+ * buffer.c (Fkill_buffer): Don't delete auto-save file
+ if it's the same as the visited file.
+
+2003-12-28 Luc Teirlinck <[email protected]>
+
+ * coding.c (Fcheck_coding_system): Doc fix.
+
+2003-12-28 Kim F. Storm <[email protected]>
+
+ * Makefile.in (eval.o): Depend on dispextern.h.
+
+ * dispnew.c (buffer_posn_from_coords): Fix calculation of dy for
+ image glyph using image's ascent.
+ (mode_line_string): Return image glyph as object clicked on.
+ Adjust y0 for image glyph using image's ascent.
+
+ * dispextern.h (FACE_ID_BITS, MAX_FACE_ID): New defines.
+ (struct glyph): New members, ascent and descent. Used to save
+ this glyph's ascent and descent, instead of having.
+ (struct glyph): Declare member face_id using FACE_ID_BITS.
+ (find_hot_spot): Add prototype.
+
+ * keyboard.c (Qimage): Remove extern (now in lisp.h).
+ (QCmap): Declare extern.
+ (make_lispy_position): When position is inside image hot-spot,
+ use hot-spot element's id as posn element.
+
+ * lisp.h (IMAGEP): New macro to test for image object type.
+ (Qimage): Declare extern.
+
+ * macfns.c (Qimage): Remove extern (now in lisp.h).
+ (valid_image_p, parse_image_spec): Use IMAGEP macro.
+
+ * macterm.c (Qface, Qmouse_face): Remove unused externs.
+
+ * w32fns.c (Qimage): Remove extern (now in lisp.h).
+ (valid_image_p, parse_image_spec): Use IMAGEP macro.
+
+ * w32menu.c (Qmouse_click, Qevent_kind): Remove unused externs.
+
+ * w32term.c (Qface, Qmouse_face): Remove unused externs.
+
+ * xdisp.c (Qarrow, Qhand, Qtext, Qpointer): New variables for
+ pointer types.
+ (Qrelative_width, Qalign_to): Remove unused variables.
+ (Vvoid_text_area_pointer): Replace Vshow_text_cursor_in_void.
+ (QCmap, QCpointer, Qrect, Qcircle, Qpoly): New variables for image
+ maps.
+ (x_y_to_hpos_vpos): Return glyph relative coordinates through new
+ dx and dy args. Remove buffer_only_p arg (always 0). Simplify
+ code accordingly.
+ (get_glyph_string_clip_rect): Draw cursor using glyph's rather
+ than row's ascent and height, to get sensible height on tall rows.
+ (build_desired_tool_bar_string): Remove Qimage extern.
+ (get_tool_bar_item): Fix call to x_y_to_hpos_vpos.
+ (produce_image_glyph): Adjust it.ascent to minimum row ascent if
+ image glyph is alone on the last line.
+ (append_glyph, append_composite_glyph, produce_image_glyph)
+ (append_stretch_glyph): Set glyph's ascent and descent.
+ (on_hot_spot_p): New function to check if position is inside an
+ rectangular, circular, or polygon-shaped image hot-spot,
+ (find_hot_spot): New function to search for image hot-spot.
+ (Flookup_image_map): New defun to search for image hot-spot.
+ (define_frame_cursor1): New aux function to determine frame
+ pointer.
+ (note_mode_line_or_margin_highlight, note_mouse_highlight): Handle
+ `pointer' text property and :pointer image property to control
+ frame pointer shape. Detect image hot-spots for pointer and
+ help_echo properties. Use define_frame_cursor1.
+ (note_mouse_highlight): Use Vvoid_text_area_pointer.
+ (syms_of_xdisp): Defsubr new defun. Intern and staticpro new
+ variables. DEFVAR_LISP Vvoid_text_area_pointer instead of
+ Vshow_text_cursor_in_void.
+
+ * xfaces.c (cache_face): Abort if c->size exceeds MAX_FACE_ID.
+
+ * xfns.c (x_set_mouse_color): Remove bogus x_check_errors call.
+ (Qimage): Remove extern (now in lisp.h).
+ (valid_image_p, parse_image_spec): Use IMAGEP macro.
+
+ * xmenu.c (show_help_event): Remove unused code.
+
+ * xterm.c (Qface, Qmouse_face): Remove unused externs.
+ (x_draw_hollow_cursor): Draw cursor using glyph's rather than
+ row's ascent and descent, to get a sensible height on tall rows.
+
+2003-12-25 Luc Teirlinck <[email protected]>
+
+ * minibuf.c (Fcompleting_read): Undo previous change.
+
+2003-12-25 Lars Hansen <[email protected]>
+
+ * dired.c (Fdirectory_files, Fdirectory_files_and_attributes):
+ Arguments GCPRO'ed in call to file name handler.
+
+2003-12-25 Thien-Thi Nguyen <[email protected]>
+
+ * termcap.c (tgetst1): Scan for "%pN"; if all
+ N are continuous in [1,9], remove all "%pN".
+
+2003-12-24 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_frame_set_char_size): Call x_wm_set_size_hint.
+
+ * xfaces.c (lface_fully_specified_p): Take into account that
+ MAC OS always have unspecified stipple.
+
+2003-12-24 Thien-Thi Nguyen <[email protected]>
+
+ * tparam.c (tparam1): Add handling for `%pN', which
+ means use param N for the next substitution.
+
+2003-12-24 Thien-Thi Nguyen <[email protected]>
+
+ * xfaces.c (Fcolor_gray_p): Fix omission bug:
+ In case `frame' is nil, consult the selected frame.
+ (Fcolor_supported_p): Likewise.
+
+2003-12-23 Luc Teirlinck <[email protected]>
+
+ * fns.c (Frandom, Fstring_make_multibyte, Fset_char_table_range):
+ Doc fixes.
+
+ * minibuf.c (read_minibuf): Allow INITIAL to be a cons of a string
+ and an integer. Adapt the introductory comment accordingly.
+ (Fread_from_minibuffer): Delete code moved into read_minibuf.
+ Doc fix.
+ (Fread_minibuffer, Fread_no_blanks_input): Adapt to changes in
+ read_minibuf.
+ (Fcompleting_read): Delete code moved into read_minibuf.
+ (Ftest_completion): Make it handle obarrays and hash tables correctly.
+
+2003-12-03 Kenichi Handa <[email protected]>
+
+ * coding.c (decode_coding_iso2022): Fix for preserving UTF-8
+ encoding sequence.
+
+2003-12-01 Kenichi Handa <[email protected]>
+
+ * composite.c (syms_of_composite): Don't make the compostion hash
+ table week.
+
+2003-11-30 Luc Teirlinck <[email protected]>
+
+ * intervals.h: Add EXFUN for Fget_char_property_and_overlay.
+ * textprop.c (Fget_char_property_and_overlay): New function.
+ (syms_of_textprop): Defsubr it.
+
+2003-11-29 Jan Dj,Ad(Brv <[email protected]>
+
+ * dispnew.c (buffer_posn_from_coords): Add ifdef HAVE_WINDOW_SYSTEM
+ to compile on terminal configuration.
+
+ * fileio.c (Fread_file_name): Check use_file_dialog also before
+ calling Fx_file_dialog.
+
+ * fns.c (use_file_dialog): New variable.
+ (syms_of_fns): DEFVAR_BOOL use-file-dialog.
+
+2003-11-29 Kim F. Storm <[email protected]>
+
+ * msdos.c (Qcursor_type, Qbar, Qhbar): Declare extern.
+ (syms_of_msdos): Don't intern and staticpro them.
+
+2003-11-27 Kim F. Storm <[email protected]>
+
+ * dispnew.c (buffer_posn_from_coords): Calculate and return pixel
+ coordinates relative to glyph at posn. If glyph is an image,
+ return that as object at posn. Callers changed.
+ (mode_line_string, marginal_area_string): Calculate and return
+ pixel coordinates relative to glyph. Callers changed.
+
+ * dispextern.h (buffer_posn_from_coords, mode_line_string)
+ (marginal_area_string): Fix prototypes.
+ (window_box_left_offset, window_box_right_offset): Add prototypes.
+
+ * frame.h (get_specified_cursor_type, get_window_cursor_type):
+ Remove prototypes.
+
+ * keyboard.h (EVENT_CLICK_COUNT, POSN_SCROLLBAR_PART): Fix defines.
+
+ * keyboard.c (make_lispy_position): Add x and y coordinates
+ relative to the current glyph as 7th element of position.
+ If glyph is an image, return it in the object element.
+ (read_key_sequence): Skip checks for keymap property in cases
+ where POSN_STRING is not a string (e.g. an image).
+
+ * xdisp.c (Vdisplay_pixels_per_inch): New variable.
+ (Vshow_text_cursor_in_void): New variable.
+ (glyph_to_pixel_coords): Don't use negative hpos.
+ (x_y_to_hpos_vpos): Fix for partially visible first glyph.
+ (append_stretch_glyph): Change ascent arg to be actual value
+ in pixels rather than ratio to height. Callers changed.
+ (calc_pixel_width_or_height): New aux function, implementing
+ pixel based artihmetic for glyph widths and heights.
+ (produce_stretch_glyph): Use calc_pixel_width_or_height for
+ :width, :height, :align-to, and :ascent, thus allowing these to
+ be specified in pixels as well as multiples of characters.
+ Don't produce stretch glyphs with zero width or height.
+ (get_specified_cursor_type): Declare static.
+ (get_window_cursor_type): Declare static. Add glyph arg to be
+ able to know when cursor is on an image; always substitute
+ hollow-box cursor for filled-box cursor on images, to avoid
+ negative images and flicker when blinking the cursor.
+ (display_and_set_cursor): Pass glyph to get_window_cursor_type.
+ (note_mode_line_or_margin_highlight): Use non-text cursor rather
+ than vertical scroll-bar cursor in display margins.
+ (note_mouse_highlight): Use non-text cursor rather than text
+ cursor in fringes and over images in the text area.
+ Use non-text cursor when mouse pointer is outside editable text,
+ i.e. in the void after end-of-line or end-of-buffer; this was
+ already done for W32, but is now standard for all systems --
+ user can toggle show-text-cursor-in-void to get old behaviour.
+ (syms_of_xdisp): DEFVAR_LISP Vshow_text_cursor_in_void and
+ Vdisplay_pixels_per_inch.
+
+2003-11-25 Andreas Schwab <[email protected]>
+
+ * fns.c (internal_equal) <case Lisp_Vectorlike>: Declare size as
+ EMACS_INT to not lose bits.
+ (Ffillarray): Don't set bits beyond the size of a bool vector.
+
+2003-11-25 Kim F. Storm <[email protected]>
+
+ * print.c (Fredirect_debugging_output) [!GNU_LINUX]: Do not
+ define this defun on systems that cannot use stderr as lvalue.
+
+2003-11-24 Gerd Moellmann <[email protected]>
+
+ * s/freebsd.h (LD_SWITCH_SYSTEM_TEMACS)
+ [__FreeBSD_version >= 500042]: Define as -znocombreloc because
+ ld's default is incompatible with unexec.
+
+2003-11-23 Kim F. Storm <[email protected]>
+
+ * window.c (enum window_loop): Add REDISPLAY_BUFFER_WINDOWS.
+ (window_loop): Handle REDISPLAY_BUFFER_WINDOWS.
+ (Fforce_window_update): New defun.
+ (syms_of_window): Defsubr it.
+ (Fset_window_margins, Fset_window_fringes): Doc fix.
+
+ * print.c (Fredirect_debugging_output): New defun.
+ (syms_of_print): Defsubr it.
+
+2003-11-22 Luc Teirlinck <[email protected]>
+
+ * fns.c (Fset_char_table_parent): Doc fix.
+
+2003-11-22 Kim F. Storm <[email protected]>
+
+ * dispnew.c (buffer_posn_from_coords): Return actual row/column
+ for glyph clicked on, rather than (unused) pixel positions.
+ (mode_line_string, marginal_area_string): Change X and Y args to
+ pointers for returning actual row/column for glyph clicked on.
+ Simplify and optimize loops.
+
+ * dispextern.h (mode_line_string, marginal_area_string):
+ Update prototypes.
+
+ * keyboard.c (make_lispy_position): New function for generating
+ mouse click positions from frame and pixel coordinates.
+ Enhanced to return buffer position and actual row/column for
+ events outside the text area using updated mode_line_string and
+ marginal_area_string functions.
+ Return left-fringe and right-fringe clicks as such, rather than
+ clicks in text area.
+ (make_lispy_event) [USE_X_TOOLKIT, USE_GTK]: Don't call
+ pixel_to_glyph_coords, as we never use the results.
+ (make_lispy_event): Use make_lispy_position for MOUSE_CLICK_EVENT,
+ WHEEL_EVENT, and DRAG_N_DROP_EVENT to replace redundant code.
+ Eliminate unused code in WHEEL_EVENT handling.
+ (make_lispy_movement): Use make_lispy_position.
+
+ * window.c (coordinates_in_window): Remove redundant tests.
+ Fix returned X pixel value for left-margin.
+
+ * xdisp.c (note_mode_line_or_margin_highlight): Adapt to new
+ mode_line_string and marginal_area_string parameters.
+
+2003-11-22 Lars Hansen <[email protected]>
+
+ * w32.c (struct the_group, getgrgid): Add.
+ * mac.c (struct my_group, getgrgid): Add.
+
+2003-11-21 Luc Teirlinck <[email protected]>
+
+ * fns.c (Fassq, Fassoc, Frassq, Frassoc): Doc fixes.
+
+2003-11-21 Lars Hansen <[email protected]>
+
+ * dired.c (Ffile_attributes): Add parameter ID-FORMAT and
+ include in call to file name handler. Optionally translate numeric
+ UID and GID to strings. Update docstring.
+ (directory_files_internal): Add parameter ID-FORMAT.
+ (Fdirectory_files_and_attributes): Add parameter ID-FORMAT and
+ include in call to file name handler and call to
+ directory_files_internal. Update Docstring.
+ (Fdirectory_files): Add dummy parameter in call to
+ directory_files_internal.
+ * lisp.h (Qinteger): Add.
+ (Qinteger_or_floatp, Qinteger_or_float_or_marker_p): Remove.
+ (Ffile_attributes): Add parameter.
+ * data.c (Qinteger): Export.
+
+2003-11-21 Luc Teirlinck <[email protected]>
+
+ * fns.c (Freverse, Fnreverse): Doc fixes.
+
+2003-11-19 Kim F. Storm <[email protected]>
+
+ * xdisp.c (init_iterator): Initialize it->start to position
+ before reseating (in case start position is invisible).
+ (init_to_row_start): Set it->start to row-start.
+ (redisplay_window): Accept optional_new_start if start position
+ is invisible (in which case IT_CHARPOS overshoots PT).
+ (display_line): Setup row->start from it->start (rather than
+ it->current which is wrong if first char on line is invisible).
+ When done, reseat it->start to it->current (= start of next row).
+ (expose_area): Fix exposure of text area when first char (e.g. TAB)
+ is only partially visible.
+
+ * dispextern.h (struct it): New member start.
+
+2003-11-17 Stefan Monnier <[email protected]>
+
+ * alloc.c (make_float, Fcons): Clear the markbit at init time.
+ (make_float, Fcons, Fmake_symbol, allocate_misc): Move the increment
+ of block_index outside of the macro call.
+ (Fgarbage_collect): Remove null code.
+
+ * m/amdx86-64.h: Don't redefine XPNTR.
+
+ * keyboard.c (parse_modifiers, apply_modifiers): Use INTMASK instead
+ of VALMASK.
+
+ * fns.c (hashfn_eq, hashfn_eql, hashfn_equal, hash_put)
+ (sxhash_string, sxhash): Use INTMASK instead of VALMASK.
+ (maybe_resize_hash_table): Use MOST_POSITIVE_FIXNUM.
+
+ * lisp.h (VALMASK): Only define for non-union type.
+ (MARKBIT): Remove.
+ (ARRAY_MARK_FLAG): Use previous value of MARKBIT.
+ (XTYPE): Define unconditionally.
+ (XSETTYPE): Remove one more remnant.
+ (EQ): Define differently for the union and non-union cases.
+ (INTMASK): New bit mask.
+ (struct Lisp_Marker): Move down to prepare for upcoming patch.
+ (GC_EQ): Delegate to EQ.
+
+ * coding.c (coding_restore_composition): Lisp_Object/int mixup.
+
+2003-11-17 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_window_to_scroll_bar): Move check of display to
+ where window_id is compared.
+
+2003-11-17 Kim F. Storm <[email protected]>
+
+ * dispextern.h (struct it): New member first_vpos.
+
+ * xdisp.c (start_display): Set it->first_vpos.
+ (try_window_id): Use first_vpos to start display in first _text_
+ line if no reusable lines at start of window with header line.
+
+2003-11-16 Jan Dj,Ad(Brv <[email protected]>
+
+ * w32fns.c (XPutPixel):
+ * w32bdf.c (w32_init_bdf_font):
+ * sunfns.c (sel_read):
+ * process.c (Fmake_network_process):
+ * frame.c (store_frame_param):
+ * fontset.c (Fset_fontset_font):
+ * emacs.c (shut_down_emacs):
+ * ccl.c (ccl_driver): Remove period at end of error message.
+
+ * config.in: Regenerate.
+
+ * xfns.c (x_window_to_frame, x_any_window_to_frame)
+ (x_non_menubar_window_to_frame, x_menubar_window_to_frame)
+ (x_top_window_to_frame): Add Display* argument to xg_win_to_widget.
+ (x_create_bitmap_mask, xg_set_icon, create_frame_xic)
+ (xic_set_statusarea, x_window, gif_load): Formatting adjustments.
+
+ * xterm.h (struct x_display_info): New field xg_cursor for GTK.
+
+ * xterm.c: Add Display * to x_window_to_scroll_bar declaration.
+ (XTmouse_position, handle_one_xevent): Pass Display* to
+ x_window_to_scroll_bar.
+ (x_window_to_scroll_bar): Take a Display* argument.
+ Check that display for frame is equal to Display* argument.
+ (event_handler_gdk): Remove current_dpyinfo. Get dpyinfo from
+ x_display_info_for_display instead. Use Display in xev instead
+ of GDK_DISPLAY.
+ (x_dispatch_event): Call x_display_info_for_display.
+ (XTread_socket): Move GTK part out of loop. current_dpyinfo removed.
+ (x_connection_closed): Call xg_display_close for GTK.
+ (x_term_init): Call xg_display_open for additional displays.
+ Initiate dpyinfo->xg_cursor with call to xg_create_default_cursor
+ for GTK.
+
+ * xmenu.c (single_menu_item, mouse_position_for_popup)
+ (x_activate_menubar): Formatting adjustments.
+
+ * xdisp.c (update_tool_bar, redisplay_tool_bar): Formatting
+ adjustments.
+
+ * gtkutil.c (xg_get_gdk_display, xg_set_screen, xg_display_open)
+ (xg_display_close, xg_create_default_cursor)
+ (xg_get_gdk_pixmap_and_mask): New functions for multiple display
+ handling.
+ (xg_left_ptr_cursor): Remove.
+ (xg_set_cursor): Change cursor to GdkCursor*. Do not create
+ cursor here.
+ (xg_win_to_widget): Take Display* argument, call
+ gdk_xid_table_lookup_for_display.
+ (xg_create_frame_widgets, xg_get_file_name, create_menus)
+ (xg_create_widget, xg_modify_menubar_widgets): Call xg_set_screen.
+ (xg_create_widget, xg_create_scroll_bar): Use xg_cursor
+ in FRAME_X_DISPLAY_INFO.
+ (xg_get_scroll_id_for_window): Take Display* argument.
+ (update_frame_tool_bar): Call xg_get_gdk_pixmap_and_mask.
+ (xg_initialize): Remove xg_left_ptr_cursor.
+
+ * gtkutil.h (xg_get_scroll_id_for_window, xg_win_to_widget): Add
+ Display* argument.
+ (xg_display_open, xg_display_close, xg_create_default_cursor): Declare.
+
+2003-11-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_detect_focus_change): Do not change focus frame for
+ Enter/LeaveNotify if the current focus frame has explicit focus.
+
+2003-11-14 Kim F. Storm <[email protected]>
+
+ * dispnew.c (update_text_area): Fix redisplay error when hscroll
+ is active and first glyph is only partially visible.
+
+2003-11-13 Kenichi Handa <[email protected]>
+
+ * xdisp.c (select_frame_for_redisplay): New function.
+ (redisplay_internal): Record also selected_frame for
+ unwind_redisplay. Call select_frame_for_redisplay before
+ redrawing each frame.
+ (unwind_redisplay): Argument changed to a cons.
+
+2003-11-12 Luc Teirlinck <[email protected]>
+
+ * fns.c (Fstring_to_multibyte): Doc fix.
+
+2003-11-11 Kenichi Handa <[email protected]>
+
+ * xterm.c (x_list_fonts): Fix excluding of auto-scaled fonts.
+
+2003-11-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_window): Set XtNx and XtNy in shell widget for
+ program specified positions.
+
+2003-11-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (XAW_ARROW_SCROLLBARS): Define it for Xaw 1.5E.
+
+2003-11-08 Kenichi Handa <[email protected]>
+
+ * Makefile.in (lisp): Add kannada.el.
+ (shortlisp): Likewise.
+
+2003-11-07 Kenichi Handa <[email protected]>
+
+ * coding.c (coding_allocate_composition_data):
+ Reset coding->composing to COMPOSITION_NO.
+ (coding_restore_composition): Detect invalid composition data.
+ Give Fstring and Fvector a Lispy integer, not C int.
+
+2003-11-05 Stefan Monnier <[email protected]>
+
+ * floatfns.c (Flogb): Don't use VALMASK.
+
+ * m/amdx86-64.h (VALBITS, XINT, XUINT): Remove.
+ * m/ia64.h (VALBITS, XINT, XUINT): Remove.
+
+ * lisp.h (XINT): Move the cast to clarify what is going on.
+ (GCTYPEMASK, XSETTYPE): Remove.
+ (XGCTYPE): Make it an alias of XTYPE.
+
+2003-11-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_term_init): Fix formatting.
+
+2003-11-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.h (xg_have_tear_offs): Declare.
+ (xg_keep_popup, xg_did_tearoff): Remove.
+
+ * gtkutil.c: Remove variable xg_did_tearoff.
+ (xg_have_tear_offs): New function.
+ (tearoff_remove): Just decrease xg_detached_menus.
+ (tearoff_activate): Increase xg_detached_menus and call
+ tearoff_remove when tearoff is removed.
+ (xg_keep_popup): Remove function.
+ (create_menus): Give add_tearoff_p as argument to recursive
+ call to create_menus.
+ (xg_create_widget): Use variables instead of multiple
+ strcmp. Tell create_menus to create tear off only for
+ menu bar menus.
+ (xg_update_menubar): Change title for a detached menu also.
+ (xg_modify_menubar_widgets): Always call xg_update_menubar, regardless
+ of deep_p.
+ (xg_initialize): Initialize xg_detached_menus, remove
+ initialization of xg_did_tearoff.
+
+ * xmenu.c (set_frame_menubar): For GTK, set deep_p if
+ xg_have_tear_offs returns non-zero.
+ (create_and_show_popup_menu): Remove setting of xg_did_tearoff and
+ call to xg_keep_popup.
+
+2003-11-01 Andrew Choi <[email protected]>
+
+ * macterm.c (XTread_socket): Handle menubar selection and grow
+ window only for mouseDown events.
+
+2003-10-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_term_init): For GTK part, increase x_initialized
+ to check for more than one display. Use error instead of return 0.
+
+2003-10-31 Andrew Choi <[email protected]>
+
+ * unexmacosx.c (unrelocate): New function (contributed by Nozomu Ando).
+ (copy_dysymtab): Call it.
+
+2003-10-31 Luc Teirlinck <[email protected]>
+
+ * eval.c (Fdefvaralias): Doc fix.
+
+2003-10-26 Luc Teirlinck <[email protected]>
+
+ * data.c (Fsetplist): Doc fix.
+
+2003-10-14 Lute Kamstra <[email protected]>
+
+ * window.c (Fset_window_fringes): Clarify docstring.
+
+2003-10-14 Kim F. Storm <[email protected]>
+
+ * window.c (Fset_window_margins): Simplify arg checking.
+
+2003-10-13 Richard M. Stallman <[email protected]>
+
+ * regex.c (MAX_BUF_SIZE): Reduce to 2**15.
+ (print_partial_compiled_pattern): Replace assert with a printout.
+ (skip_noops, mutually_exclusive_p): Change args, values to re_char *.
+
+ * alloc.c (lisp_align_malloc): If BASE is 0, call memory_full.
+
+ * window.c (Fset_window_margins): Allow only integers as args.
+ (syms_of_window) <special-display-buffer-names,
+ special-display-regexps>: Doc fixes.
+
+2003-10-13 Lute Kamstra <[email protected]>
+
+ * window.c (Fset_window_fringes): Elaborate docstring.
+
+2003-10-12 Andrew Choi <[email protected]>
+
+ * macterm.c (XTread_socket): Call DragWindow only for mouseDown events.
+
+ * s/darwin.h (GC_MARK_STACK): Define.
+
+2003-10-12 Jan Dj,Ad(Brv <[email protected]>
+
+ * window.c (shrink_windows): New function.
+ (size_window): Call shrink_windows to calculate window sizes when
+ shrinking frame with more than one window.
+
+2003-10-12 Kim F. Storm <[email protected]>
+
+ * xdisp.c (compute_fringe_widths): Doc fix.
+
+2003-10-08 Kenichi Handa <[email protected]>
+
+ * coding.c (Fcoding_system_p): Return t for auto-loading coding system.
+
+2003-10-07 Kenichi Handa <[email protected]>
+
+ * coding.c (Qcoding_system_define_form): New variable.
+ (syms_of_coding): Intern and staticpro it.
+ (Fcheck_coding_system): Try to autoload the definition of
+ CODING-SYSTEM.
+
+2003-10-05 Luc Teirlinck <[email protected]>
+
+ * fns.c (Frequire): Doc fix.
+
+2003-10-05 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (Fx_send_client_event): New function as a base for
+ manipulating extended window manager hints.
+ (Fx_send_client_event): Remove unused variable s.
+
+ * w32term.c (w32_read_socket): Remove call to x_check_fullscreen_move,
+ that function is removed.
+
+ * xterm.c (x_set_offset): Use move_offset_left/top instead of
+ x/y_pixels_outer_diff.
+ (x_check_expected_move): Calculate move_offset_left/top.
+
+ * xterm.h (struct x_output): New members: move_offset_top/left.
+
+ * frame.c (x_set_frame_parameters): Remove x_fullscreen_move,
+ call x_set_offset directly.
+
+ * frame.h (enum): FULLSCREEN_MOVE_WAIT removed.
+
+ * frame.c (Fdelete_frame): Free decode_mode_spec_buffer.
+
+ * xterm.c (x_delete_display): Free font names and font_encoder
+ in dpyinfo->font_table.
+
+ * xfns.c (Fx_close_connection): Only call XFreeFont here.
+ Move xfree of font names to x_delete_display.
+
+ * xterm.h (struct x_display_info): New member, wm_type.
+ (struct x_output): New members, expected_top/left and
+ check_expected_move.
+
+ * xterm.c (handle_one_xevent): Reset wm_type when ReparentNotify
+ is received.
+ (handle_one_xevent): Rename x_check_expected_move from
+ x_check_fullscreen_move.
+ (x_set_offset): Only add WM decoration sizes to modified_top/left
+ for X_WMTYPE_A. Set check_expected_move when WM type is unknown.
+ (x_check_expected_move): Rename from x_check_fullscreen_move.
+ Removed fullscreen specific code. Use check_expected_move,
+ expected_left/top instead. Also, set wm_type.
+ (x_term_init): Initialize wm_type to unknown.
+
+ * frame.c (x_fullscreen_move): Remove addition of WM decoration
+ sizes to move_x/y.
+
+2003-10-03 Kenichi Handa <[email protected]>
+
+ * macterm.c (x_load_font): Clear all members of FONTP before start
+ filling them.
+
+2003-10-02 Kenichi Handa <[email protected]>
+
+ * fontset.c (fs_load_font): Don't set fontp->font_encoder to NULL
+ before calling find_ccl_program_func. Call find_ccl_program_func
+ only when fontp->font_encoder is not NULL.
+
+ * xterm.c (x_load_font): Clear all members of FONTP before start
+ filling them.
+
+2003-10-03 John Paul Wallington <[email protected]>
+
+ * keymap.c (map_keymap): Don't abort when binding is a vector.
+
+2003-10-02 Jason Rumney <[email protected]>
+
+ * makefile.w32-in (emacs.o, coding.o, bytecode.o):
+ Sync dependencies with Makefile.in.
+ (alloca.o): Remove.
+
+ * w32fns.c (w32_load_system_font): Clear all members of FONTP before
+ filling them.
+
+ * w32bdf.c (w32_load_bdf_font): Likewise.
+
+2003-09-30 Richard M. Stallman <[email protected]>
+
+ * term.c (set_tty_color_mode): Calculate current_mode_spec
+ regardless of value of VAL.
+
+ * intervals.c (graft_intervals_into_buffer):
+ Set BUF_INTERVALS (buffer)->up_obj when appropriate.
+ Handle over_used when splitting UNDER.
+
+2003-09-30 YAMAMOTO Mitsuharu <[email protected]>
+
+ * regex.c (regex_compile): Free the stack when returning from function.
+
+2003-09-28 Kenichi Handa <[email protected]>
+
+ * fontset.c (Finternal_char_font): Change return value to
+ cons (FONT-NAME . GLYPH-CODE).
+
+2003-09-28 Eli Zaretskii <[email protected]>
+
+ * term.c (tty_setup_colors): Treat any negative argument as -1.
+
+2003-09-27 Gaute B Strokkenes <[email protected]> (tiny change)
+
+ * process.c (send_process): Delete unused temp_buf.
+
+2003-09-26 Dave Love <[email protected]>
+
+ * xterm.c (x_bitmap_mask): Declare.
+
+2003-09-25 Dave Love <[email protected]>
+
+ * Makefile.in (fns.o): Depend on md5.h.
+
+2003-09-25 Kim F. Storm <[email protected]>
+
+ * window.c (set_window_buffer): Fix redisplay problems when
+ switching between buffers with different display margin widths.
+
+2003-09-23 Kim F. Storm <[email protected]>
+
+ * process.c (set_socket_option): Fix :bindtodevice option.
+ (Fset_network_process_option): Update process contact list when
+ setting option succeeds.
+ (Fmake_network_process): Doc fix.
+
+2003-09-23 Dave Love <[email protected]>
+
+ * process.c (Fnetwork_interface_info): Use HAVE_STRUCT_IFREQ... macros.
+
+2003-09-22 Eli Zaretskii <[email protected]>
+
+ * term.c (set_tty_color_mode): Use INTEGERP to test whether a
+ color mode is an integer number (it could be -1).
+
+2003-09-22 Richard M. Stallman <[email protected]>
+
+ * intervals.c (graft_intervals_into_buffer): Correct the main loop
+ in the case where OVER is longer than UNDER.
+
+2003-09-22 Masatake YAMATO <[email protected]>
+
+ * window.c (Fset_window_scroll_bars): Validate the value of
+ `vertical_type'.
+
+2003-09-21 Kim F. Storm <[email protected]>
+
+ * frame.c (Vdefault_frame_scroll_bars): New variable.
+ (x_set_vertical_scroll_bars): Use it instead of hardcoded values.
+ (syms_of_frame): DEFVAR_LISP it, and initialize according to
+ window-system default scroll bar position.
+
+ * window.c (Fwindow_scroll_bars): Doc fix.
+
+2003-09-19 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_set_offset): Take window manager decorations into account.
+
+2003-09-19 Richard M. Stallman <[email protected]>
+
+ * atimer.h: Don't include lisp.h.
+ (P_): Define it here (as well as elsewhere).
+
+ * print.c (Fprin1_to_string): Move the PRINTPREPARE
+ later, so that PRINTFINISH won't unbind Qinhibit_modification_hooks.
+
+ * data.c (Fvariable_binding_locus): New function.
+ (syms_of_data): defsubr it.
+ (Flocal_variable_p): Delete duplicate call to indirect_variable.
+
+2003-09-18 Dave Love <[email protected]>
+
+ * alloc.c (GC_MALLOC_CHECK): Move conditional undef after lisp.h.
+
+ * process.c (Fnetwork_interface_info): Fix type error.
+ (Fnetwork_interface_list): Doc fix.
+ (read_process_output, read_process_output): Delete unused var.
+
+2003-09-17 Kim F. Storm <[email protected]>
+
+ * process.c (Fnetwork_interface_list, Fnetwork_interface_info):
+ Require HAVE_NET_IF_H and HAVE_SYS_IOCTL_H to include these fns.
+ (Fnetwork_interface_info): Check that ifreq struct has required
+ fields before accessing them; this requires that those fields are
+ defined as macros, which may be too restrictive on some platforms,
+ but it is better than failing on other platforms.
+ (syms_of_process): Only defsubr above fns when included.
+
+2003-09-17 Dave Love <[email protected]>
+
+ * unexalpha.c: Don't include varargs.h.
+
+2003-09-17 Kim F. Storm <[email protected]>
+
+ * process.c (Fset_process_sentinel): Add sentinel to childp plist
+ for network process.
+ (socket_options): Add `:' prefix to option names. Add optbit field.
+ (set_socket_option): Remove no_error arg and special handling of s < 0.
+ Return 1<<optbit for known option, 0 for unknown.
+ Do not interpret 0 as false for boolean option (only nil).
+ Pass failed option and value to report_file_error.
+ (Fset_network_process_options): Replace by Fset_network_process_option.
+ (Fset_network_process_option): New function to set just one option.
+ (Fmake_network_process): Allow :coding arg to be a cons.
+ Allow :server arg to be an integer specifying backlog size.
+ Remove :options arg, and allow options to be specified directly
+ as :KEY, VALUE pairs. Parse these options before binding socket.
+ As before, :reuseaddr t is default for a server process, but this
+ can now be disabled by specifying :reuseaddr nil.
+ (Fnetwork_interface_info): Rename from Fget_network_interface_info.
+ (init_process): Availability of network options is now checked with
+ simpler syntax (featurep 'make-network-process :OPTION); use loop to
+ setup features.
+ (syms_of_process): Fix defsubr's for the replaced functions.
+
+2003-09-16 Dave Love <[email protected]>
+
+ * Makefile.in: Depend on coding.h.
+
+2003-09-14 Kim F. Storm <[email protected]>
+
+ * process.c [HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
+ (Fnetwork_interface_list, Fget_network_interface_info): New defuns.
+ (syms_of_process): Defsubr them.
+
+ * config.in: Regenerate.
+
+2003-09-12 Stefan Monnier <[email protected]>
+
+ * m/sr2k.h (XMARKBIT, XUNMARK): Remove.
+ * m/news-r6.h (XUNMARK): Remove.
+ * m/mips.h (XUNMARK): Remove.
+ * m/mips-siemens.h (XUNMARK): Remove.
+ * m/iris4d.h (XUNMARK): Remove.
+ * m/hp800.h (XMARKBIT, XUNMARK): Remove.
+
+2003-09-11 Stefan Monnier <[email protected]>
+
+ * lisp.h (VALBITS): Don't remove 1 for the markbit.
+ (union Lisp_Object): Use unsigned int for types. Remove markbit.
+ (MARKBIT): Remove 1 from VALBITS so we still use same old val.
+ (XTYPE): Use unsigned right-shift.
+ (XMARKBIT, XMARK, XUNMARK): Remove.
+
+ * alloc.c (init_intervals, init_symbol, init_marker):
+ Don't preallocate anything.
+ (Fgarbage_collect, mark_object): Ignore the markbit.
+
+ * bytecode.c (mark_byte_stack, unmark_byte_stack): Ignore the markbit.
+
+2003-09-08 Lute Kamstra <[email protected]>
+
+ * xdisp.c (pint2hrstr): New function.
+ (decode_mode_spec): Add `%i' and `%I' specs.
+ * buffer.c (syms_of_buffer): Document `%i' and `%I' constructs
+ for `mode-line-format'.
+
+2003-09-07 Andreas Schwab <[email protected]>
+
+ * alloc.c: Use long instead of int when casting ABLOCKS_BUSY to
+ avoid warning.
+
+2003-09-07 Eli Zaretskii <[email protected]>
+
+ * editfns.c (region_limit): Support any non-zero value of BEGINNINGP.
+
+2003-09-03 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): Partially undo 2002-03-01
+ change (superseded by 2002-08-30 change); the default blink-off
+ cursor is now again "no cursor".
+
+2003-09-01 Jason Rumney <[email protected]>
+
+ * makefile.w32-in (alloca.o): Remove.
+ (coding.o): Depend on intervals.h
+ (emacs.o, bytecode.o): Depend on window.h.
+
+2003-09-01 Dave Love <[email protected]>
+
+ * Makefile.in (alloca.o): Remove commands.
+ (coding.o): Depend on intervals.h composite.h window.h.
+ (emacs.o): Depend on window.h keyboard.h keymap.h.
+ (gtkutil.o): Depend on keyboard.h charset.h coding.h.
+ (bytecode.o): Depend on window.h.
+
+2003-08-31 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_per_char_metric): Allow cached metrics to be
+ returned even when font_type is unknown.
+
+ * xdisp.c (init_iterator): Remove old WINDOWSNT conditional.
+
+2003-08-30 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_term_init): Initialize new fields in x_display_info.
+
+ * xterm.h (struct x_display_info): Add red/green/blue_bits and
+ *_offset.
+
+ * xfns.c (lookup_rgb_color): Use new fields in x_display_info to
+ calculate pixel value.
+
+2003-08-29 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (redisplay_internal): Fix change of 2003-04-30.
+ Don't tell redisplay display is accurate when it's actually been
+ paused for pending input.
+
+2003-08-29 Richard M. Stallman <[email protected]>
+
+ * dispnew.c (adjust_glyph_matrix): Call window_box
+ whenever W is nonzero.
+
+ * data.c (Fmake_variable_buffer_local, Fmake_local_variable)
+ (Fkill_local_variable, Fmake_variable_frame_local)
+ (Flocal_variable_p, Flocal_variable_if_set_p):
+ Use indirect_variable to trace thru variable aliases.
+
+ * config.in: Updated.
+
+ * callint.c (Fcall_interactively): Save and restore
+ Vthis_command, Vthis_original_command, real_this_command,
+ and current_kboard->Vlast_command.
+
+ * abbrev.c (Fexpand_abbrev): Insert before deleting.
+
+2003-08-29 Gerd Moellmann <[email protected]>
+
+ * xfns.c (lookup_rgb_color): Handle TrueColor visuals specially.
+
+2003-08-28 David Abrahams <[email protected]> (tiny change)
+
+ * coding.c (decode_coding_iso2022): Initialize local variable c2.
+ (decode_coding_sjis_big5): Likewise.
+
+2003-08-27 Jason Rumney <[email protected]>
+
+ * w32.c (sys_pipe): Protect against file descriptor overflow.
+
+ * w32fns.c (syms_of_w32fns): Remove non-existent functions.
+
+ * w32term.c (w32_read_socket): Fix WM_MOUSEWHEEL assignment.
+
+2003-08-26 Terje Rosten <[email protected]>
+
+ * xfns.c (Vgtk_version_string): New variable.
+ (syms_of_xfns): DEFVAR_LISP it. Provide gtk.
+
+2003-08-24 Eli Zaretskii <[email protected]>
+
+ * term.c (term_init): Remove `const' from buffer_size's declaration.
+
+ * Makefile.in (msdos.o): Depend on intervals.h.
+
+ * msdos.c: Include intervals.h, since STRING_INTERVALS requires that.
+
+2003-08-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h (struct x_display_info): New fields: client_leader_window
+ and Xatom_wm_client_leader.
+
+ * xterm.c (x_initialize): Move call to x_session_initialize to ...
+ (x_term_init): ... here. Initialize client_leader fields in dpyinfo.
+
+ * xsmfns.c (create_client_leader_window): New function.
+ (x_session_initialize): Call create_client_leader_window, take
+ dpyinfo as argument.
+
+ * xfns.c (Fx_create_frame): Set property WM_CLIENT_LEADER.
+
+ * Makefile.in (xsmfns.o): Add more depenedencies.
+
+2003-08-21 Dave Love <[email protected]>
+
+ * m/iris4d.h: Use _MIPS_SZLONG, not _LP64.
+
+2003-08-21 Kenichi Handa <[email protected]>
+
+ * term.c (term_init): Fix previous change; don't rely on the
+ length of `buffer' if TERMINFO is defined.
+
+2003-08-20 Dave Love <[email protected]>
+
+ * atimer.h: Include lisp.h.
+
+ * lisp.h (EMACS_LISP_H): New.
+ (popup_activated_flag): Don't declare.
+
+ * alloca.c: Some merging with gnulib. Change logic and doc
+ concerning (x)malloc/(x)free -- no longer Emacs-specific.
+ [DO_BLOCK_INPUT]: Don't include lisp.h.
+ (xmalloc, xfree): Declare.
+ (malloc): Don't declare.
+
+ * Makefile.in (LWLIB_OPTIONS): Remove (unused).
+ (alloca.o): Remove obsolete stuff concerning alloca.s. Depend on
+ atimer.h, blockinput.h.
+
+ * alloc.c (lisp_align_malloc): Change type of `aligned'.
+
+ * alloca.s: Remove.
+
+2003-08-19 Gerd Moellmann <[email protected]>
+
+ * s/freebsd.h [__FreeBSD_version >= 400000]: Define TERMINFO,
+ use -lncurses.
+
+ * term.c (term_init): Use a buffer of size 4096 for tgetent since
+ FreeBSD returns something longer than 2044. Abort if the end of
+ the buffer is overwritten.
+
+2003-08-19 Miles Bader <[email protected]>
+
+ * xterm.c (x_term_init): Correctly use result of Ffile_readable_p.
+
+2003-08-19 Gerd Moellmann <[email protected]>
+
+ * alloc.c (lisp_align_malloc): Check for memory full when
+ allocating ablocks, which also avoids freeing a pointer into an
+ ablocks structure.
+
+ * puresize.h (BASE_PURESIZE): Increase to 1100000.
+
+ * buffer.c (Fmove_overlay): Set overlay's next pointer unconditionally.
+
+2003-08-16 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fencode_time): Doc fix.
+
+2003-08-16 David Ponce <[email protected]>
+
+ * fileio.c (Fwrite_region): Fix conditional expression to issue
+ the right message.
+
+2003-08-16 Juri Linkov <[email protected]>
+
+ * syntax.c (Fforward_word): Argument changed to optional.
+ Set default value to 1.
+
+2003-08-15 Kenichi Handa <[email protected]>
+
+ * xfaces.c (better_font_p): Prefer a real scalable font; i.e. not
+ what autoscaled.
+ (best_matching_font): Once we find a better scalable font, set
+ non_scalable_has_exact_height_p to 1.
+ (try_font_list): Call try_alternative_families to try any family
+ with the given registry.
+
+2003-08-09 Andreas Schwab <[email protected]>
+
+ * alloc.c (mark_object): Handle Lisp_Misc_Save_Value.
+
+ * print.c (print_string): Fix printing of multibyte string with
+ nontrivial printcharfun.
+
+2003-07-31 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (xg_set_icon): Rewrite to compile with GTK 2.0 and 2.2.
+
+ * xterm.c (x_bitmap_icon): Return if xg_set_icon succeeds.
+
+2003-07-31 Kenichi Handa <[email protected]>
+
+ * process.c (read_process_output): Return the actually read bytes
+ instead of the result of decoding.
+
+2003-07-31 Kenichi Handa <[email protected]>
+
+ * xterm.h (struct x_bitmap_record): New member have_mask.
+
+ * xfns.c (x_create_bitmap_from_data): Initialize have_mask member
+ to 0.
+ (x_create_bitmap_from_file): Likewise.
+ (x_destroy_bitmap): Check have_mask member before freeing a mask.
+ (x_destroy_all_bitmaps): Likewise.
+ (x_create_bitmap_mask): Set have_mask member to 1.
+
+2003-07-30 Richard M. Stallman <[email protected]>
+
+ * Makefile.in (CFLAGS) [!OPTIMIZE]: Undo previous change.
+
+2003-07-29 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_mark_data): Update calls to mark_object.
+
+2003-07-29 Richard M. Stallman <[email protected]>
+
+ * xterm.c (xim_open_dpy, xim_initialize, xim_close_dpy):
+ Conditionalize XIM code on HAVE_XIM.
+
+ * fns.c (Fclear_string): New function.
+ (syms_of_fns): defsubr it.
+
+2003-07-28 KOBAYASHI Yasuhiro <[email protected]>
+
+ * xfns.c (xic_set_preeditarea): Add the left fringe width to spot.x.
+
+2003-07-22 Stefan Monnier <[email protected]>
+
+ * xfns.c: Don't check HAVE_PNG_H: autoconf doesn't seem to find it.
+
+ * buffer.c (delete_all_overlays): New function.
+ * buffer.h (delete_all_overlays): Declare.
+ * coding.c (run_pre_post_conversion_on_str):
+ * print.c (temp_output_buffer_setup):
+ * fileio.c (Finsert_file_contents):
+ * minibuf.c (get_minibuffer): Use it.
+
+2003-07-22 Andrew Choi <[email protected]>
+
+ * unexmacosx.c (unexec_regions_sort_compare):
+ (unexec_regions_merge): New functions. Sort and merge unexec
+ regions before dumping them.
+
+2003-07-22 Dave Love <[email protected]>
+
+ * xfns.c [HAVE_PNG]: Consider both png.h and libpng/png.h.
+
+2003-07-21 Stefan Monnier <[email protected]>
+
+ * alloc.c (MARK_STRING, UNMARK_STRING, STRING_MARKED_P)
+ (GC_STRING_CHARS, string_bytes): Use ARRAY_MARK_FLAG rather than
+ MARKBIT as the gcmarkbit for strings.
+
+2003-07-21 Richard M. Stallman <[email protected]>
+
+ * s/openbsd.h (LD_SWITCH_SYSTEM_TEMACS): Add undef.
+
+ * fns.c (Flocale_info): Rename from Flanginfo. Doc fixes.
+ (syms_of_fns): Corresponding change.
+
+ * alloc.c (syms_of_alloc): Doc fixes.
+
+2003-07-20 Han Boetes <[email protected]> (tiny change)
+
+ * s/netbsd.h: Use -Wl syntax.
+
+2003-07-17 Richard M. Stallman <[email protected]>
+
+ * xterm.c (xim_initialize): Redo 6/24 change.
+
+2003-07-15 Stefan Monnier <[email protected]>
+
+ * buffer.c (copy_overlays): Use EMACS_INT for positions.
+ (Fswitch_to_buffer): Don't signal an error when switching to the same
+ buffer in a dedicated window.
+
+ * alloc.c: Use bitmaps for cons, as was done for floats.
+ (init_float, init_cons): Let the normal code allocate the first block.
+ (CONS_BLOCK_SIZE): Redefine based on BLOCK_BYTES and bitmap size.
+ (CONS_BLOCK, CONS_INDEX, CONS_MARKED_P, CONS_MARK, CONS_UNMARK):
+ New macros.
+ (struct cons_block): Move conses to the beginning. Add gcmarkbits.
+ (Fcons): Use lisp_align_malloc and CONS_UNMARK.
+ (live_cons_p): Check the pointer is not past the `conses' array.
+ (mark_maybe_object, mark_maybe_pointer): Use CONS_MARKED_P.
+ (mark_object, mark_buffer): Use CONS_MARKED_P and CONS_MARK.
+ (survives_gc_p): Use CONS_MARKED_P and simplify.
+ (gc_sweep): Use CONS_MARKED_P, CONS_UNMARK, and lisp_align_free.
+
+2003-07-13 Paul Eggert <[email protected]>
+
+ GCC 3.3 (sparc) no longer puts "int foo = 0;" into data; it
+ puts it into BSS instead, at least on Solaris 8 and 9.
+ This is a valid optimization, and it may occur on other platforms,
+ so Emacs should not assume that initializing a static variable to
+ zero puts it into data.
+ * alloc.c (pure, staticvec):
+ Initialize these arrays to nonzero, so that they're not
+ put into BSS by that optimization.
+
+2003-07-13 Stefan Monnier <[email protected]>
+
+ * alloc.c (BLOCK_PADDING): Rename from ABLOCKS_PADDING. Update users.
+ (lisp_align_malloc): Use posix_memalign is available.
+ (ABLOCKS_BASE): Use HAVE_POSIX_MEMALIGN as an optimization.
+ (STRING_BLOCK_SIZE): Rename from STRINGS_IN_STRING_BLOCK
+ for consistency. Update users.
+
+2003-07-13 Richard M. Stallman <[email protected]>
+
+ * s/netbsd.h (START_FILES_1, END_FILES_1): Always define them.
+
+2003-07-13 Terje Rosten <[email protected]>
+
+ * xterm.c (x_bitmap_icon, x_wm_set_icon_pixmap): Modify to add mask,
+ and use the Gtk+ function gtk_window_icon_from_file if available.
+
+ * xfns.c (x_bitmap_mask, x_create_bitmap_mask): New functions to
+ handle mask of bitmaps.
+ (x_allocate_bitmap_record, x_destroy_bitmap): Modify to handle the
+ mask property.
+ (xg_set_icon): New function, wrapper for gtk_window_icon_from_file.
+
+ * xterm.h (xg_set_icon): New function.
+
+2003-07-12 Paul Eggert <[email protected]>
+
+ * unexelf.c (unexec): Consider a section to precede the .bss
+ section if its addresses overlap that of .bss.
+
+2003-07-12 Richard M. Stallman <[email protected]>
+
+ * Makefile.in (CFLAGS) [!OPTIMIZE]: Set CFLAGS to -g.
+
+ * config.in (HAVE_CRTIN): Add #undef.
+ (INLINE): Really inline only if OPTIMIZE is defined.
+
+ * s/netbsd.h (START_FILES, LIB_STANDARD): Use START_FILES_1,
+ END_FILES_1.
+ (START_FILES_1, END_FILES_1): New macros (conditional).
+ (LD_SWITCH_SYSTEM_TEMACS): Define.
+
+ * s/openbsd.h: Don't include bsd4-3.h.
+ (TERMINFO): Define.
+ (LIBS_TERMCAP): Define.
+ (LD_SWITCH_SYSTEM): Define (two definitions).
+
+ * xfns.c: Include libpng/png.h instead of png.h.
+
+2003-07-11 Andreas Schwab <[email protected]>
+
+ * buffer.c (modify_overlay): Update prototype.
+ * lisp.h (adjust_overlays_for_insert, adjust_overlays_for_delete):
+ Likewise.
+
+2003-07-09 Stefan Monnier <[email protected]>
+
+ * lisp.h (VALBITS): Define in terms of GCTYPEBITS.
+ (struct interval): Move to intervals.h.
+ (struct Lisp_Marker): Use EMACS_INT for position info.
+ (forward_point): Remove prototype of defunct function.
+ (Qmodification_hooks, Qrear_nonsticky, Fnext_property_change)
+ (Fget_text_property, Fset_text_properties, Ftext_propertes_not_all)
+ (syms_of_textprop, set_text_properties): Remove prototypes that are
+ already in intervals.h.
+
+ * intervals.h (struct interval): Move from lisp.h.
+ Use EMACS_INT for position and size info.
+
+ * coding.c: Include intervals.h for Fset_text_properties.
+
+ * buffer.h (struct buffer_text, struct buffer): Use EMACS_INT for
+ position and length information.
+
+2003-07-09 Stefan Monnier <[email protected]>
+
+ * buffer.h (struct buffer_text, struct buffer): Use EMACS_INT for
+ position and length information.
+
+2003-07-09 Stefan Monnier <[email protected]>
+
+ Change overlays_after and overlays_before so the overlays themselves
+ are linked into lists, rather than using cons cells. After all each
+ Lisp_Misc already occupies 5 words, so we can add a `next' field to
+ Lisp_Overlay for free and save up one cons cell per overlay (not
+ to mention one indirection when traversing the list of overlay).
+
+ * lisp.h (struct Lisp_Overlay): New field `next'.
+
+ * buffer.h (struct buffer): Change overlays_before and overlays_after
+ from Lisp lists of overlays to pointers to overlays.
+
+ * buffer.c (overlay_strings, recenter_overlay_lists):
+ Fix typo in eassert in last commit.
+ (unchain_overlay): New function.
+ (add_overlay_mod_hooklist): Use AREF.
+ (copy_overlays, reset_buffer, overlays_at, overlays_in)
+ (overlay_touches_p, overlay_strings, recenter_overlay_lists)
+ (fix_overlays_in_range, fix_overlays_before, Fmake_overlay)
+ (Fmove_overlay, Fdelete_overlay, Foverlay_lists)
+ (report_overlay_modification, evaporate_overlays, init_buffer_once):
+ Adjust to new type of overlays_(before|after).
+
+ * alloc.c (mark_object): Mark the new `next' field of overlays.
+ (mark_buffer): Manually mark the overlays_(after|before) fields.
+
+ * coding.c (run_pre_post_conversion_on_str):
+ * editfns.c (overlays_around):
+ * xdisp.c (load_overlay_strings):
+ * fileio.c (Finsert_file_contents):
+ * indent.c (current_column):
+ * insdel.c (signal_before_change, signal_after_change):
+ * intervals.c (set_point_both):
+ * print.c (temp_output_buffer_setup): Use new type for
+ overlays_(before|after).
+
+2003-07-08 Stefan Monnier <[email protected]>
+
+ * buffer.c (report_overlay_modification): Don't run hooks while
+ traversing the list of overlays.
+
+ * buffer.h (struct buffer): Use an int for overlay_center.
+ (overlays_at, evaporate_overlays, recenter_overlay_lists)
+ (overlay_strings, fix_overlays_before): Use EMACS_INT for positions.
+
+ * buffer.c (reset_buffer, recenter_overlay_lists)
+ (adjust_overlays_for_insert, adjust_overlays_for_delete)
+ (fix_overlays_in_range, Fmake_overlay, Fmove_overlay)
+ (evaporate_overlays, init_buffer_once): Update use of overlay_center.
+ (overlays_at, evaporate_overlays, recenter_overlay_lists)
+ (overlay_strings, fix_overlays_before): Use EMACS_INT for positions.
+
+ * xdisp.c (fast_find_position): Remove unused var.
+
+ * cmds.c (Qexpand_abbrev): New sym.
+ (syms_of_cmds): Initialize it.
+ (internal_self_insert): Use it to call expand-abbrev.
+
+2003-07-09 Kim F. Storm <[email protected]>
+
+ * xterm.c (use_xim) [!USE_XIM]: Default to disable XIM if Emacs
+ was configured with --without-xim.
+ (x_term_init) [!USE_XIM]: Use `useXIM' resource to turn on XIM.
+
+2003-07-07 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (reseat_1): Set it->area to TEXT_AREA.
+
+ * alloc.c (Fgarbage_collect): Doc fix.
+
+2003-07-07 Nozomu Ando <[email protected]>
+
+ * buffer.c (Fkill_buffer): Clear charpos cache if necessary.
+
+2003-07-06 Stefan Monnier <[email protected]>
+
+ * minibuf.c (read_minibuf): UNGCPRO before returning.
+ (Ftry_completion, Fall_completions): Doc fix.
+
+ * alloc.c (live_float_p): Check that p is not past the `floats' array,
+ now that `floats' is not the last element of the struct any more.
+
+2003-07-06 Jason Rumney <[email protected]>
+
+ * w32term.h (ClipboardSequence_Proc): New type.
+
+ * w32fns.c (clipboard_sequence_fn): New variable.
+ (globals_of_w32fns): Initialize it.
+
+ * w32select.c (last_clipboard_sequence_number): New variable.
+ (Fw32_set_clipboard_data, Fw32_get_clipboard_data): Use sequence
+ number if possible.
+
+2003-07-06 Stefan Monnier <[email protected]>
+
+ * m/amdx86-64.h (MARKBIT):
+ * m/ia64.h (MARKBIT): Remove definition since lisp.h does not compare
+ MARKBIT and ARRAY_MARK_FLAG any more.
+
+ * m/hp800.h (XSETMARKBIT):
+ * m/sr2k.h (XSETMARKBIT):
+ * lisp.h (XSETMARKBIT): Remove unused macro.
+
+ * lisp.h (mark_object): Change prototype.
+
+ * alloc.c (mark_object): Change arg *Lisp_Object -> Lisp_Object.
+ (last_marked): Change accordingly.
+ (mark_interval, mark_maybe_object, mark_maybe_pointer)
+ (Fgarbage_collect, mark_glyph_matrix, mark_face_cache, mark_image)
+ (mark_buffer): Update calls to mark_object.
+
+ * bytecode.c (mark_byte_stack):
+ * fns.c (sweep_weak_table):
+ * keyboard.c (mark_kboards): Update calls to mark_object.
+
+2003-07-06 Jason Rumney <[email protected]>
+
+ * alloc.c (struct ablock): Only include padding when there is some.
+
+2003-07-04 Stefan Monnier <[email protected]>
+
+ * alloc.c (ALIGN): Add casts to simplify usage.
+ (BLOCK_ALIGN, BLOCK_BYTES, ABLOCKS_PADDING, ABLOCKS_SIZE)
+ (ABLOCKS_BYTES, ABLOCK_ABASE, ABLOCKS_BUSY, ABLOCKS_BASE): New macros.
+ (struct ablock, struct ablocks): New types.
+ (free_ablock): New global var.
+ (lisp_align_malloc, lisp_align_free): New functions.
+ (FLOAT_BLOCK_SIZE): Redefine in terms of BLOCK_BYTES.
+ (struct float_block): Reorder and add gcmarkbits.
+ (GETMARKBIT, SETMARKBIT, UNSETMARKBIT, FLOAT_BLOCK, FLOAT_INDEX)
+ (FLOAT_MARKED_P, FLOAT_MARK, FLOAT_UNMARK): New macros.
+ (init_float, make_float): Use lisp_align_malloc.
+ (free_float, live_float_p): Don't use `type' any more.
+ (make_float): Use FLOAT_UNMARK to access to mark bit.
+ (mark_maybe_object, mark_maybe_pointer, survives_gc_p):
+ Use FLOAT_MARKED_P to access the mark bit.
+ (pure_alloc): Simplify use of ALIGN.
+ (mark_object): Use FLOAT_MARK to access the mark bit.
+ (gc_sweep): Use new macros to access the float's mark bit.
+ (init_alloc_once): Init free_ablock.
+
+ * lisp.h (struct Lisp_Float): Remove unused field `type'.
+
+2003-06-27 Stefan Monnier <[email protected]>
+
+ * alloc.c (VECTOR_MARK, VECTOR_UNMARK, VECTOR_MARKED_P): New macros.
+ (GC_STRING_BYTES): Don't mask markbit (it's only used on `size').
+ (allocate_buffer): Move.
+ (string_bytes): Don't mask markbit of `size_byte'.
+ (mark_maybe_object, mark_maybe_pointer, Fgarbage_collect)
+ (mark_object, mark_buffer, survives_gc_p, gc_sweep):
+ Use the `size' field of buffers (rather than the `name' field) for
+ the mark bit, as is done for all other vectorlike objects.
+ Use the new macros to access the mark bit of vectorlike objects.
+
+2003-06-26 Richard M. Stallman <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increment base size.
+
+ * xdisp.c (fast_find_position): Enable Gerd's new definition.
+
+ * xterm.c (xim_initialize): Undo previous change.
+
+2003-06-26 Stefan Monnier <[email protected]>
+
+ * alloc.c (survives_gc_p): Simplify.
+
+ * buffer.c (set_buffer_internal_1): Test CONSP for lists.
+
+ * window.c (Fset_window_dedicated_p): Simplify.
+ (display_buffer_1): Don't raise the win from which minibuf was entered.
+ (temp_output_buffer_show): Don't assume BEG == 1. Simplify.
+ (Fminibuffer_selected_window): Simplify.
+
+ * buffer.h (struct buffer_text): Lisp_Object `markers' => Lisp_Marker.
+
+ * lisp.h (unchain_marker): Lisp_Object arg => Lisp_Marker.
+ (struct Lisp_Marker): Lisp_Object `chain' => Lisp_Marker `next'.
+
+ * insdel.c (check_markers, adjust_markers_for_delete)
+ (adjust_markers_for_insert, adjust_markers_for_replace)
+ (prepare_to_modify_buffer, RESTORE_VALUE):
+ * marker.c (buf_charpos_to_bytepos, buf_bytepos_to_charpos)
+ (Fset_marker, set_marker_restricted, set_marker_both, unchain_marker)
+ (set_marker_restricted_both, Fbuffer_has_markers_at, count_markers):
+ * alloc.c (Fmake_marker, free_marker, gc_sweep):
+ * buffer.c (Fget_buffer_create, Fkill_buffer, Fset_buffer_multibyte):
+ * editfns.c (save_excursion_restore, transpose_markers):
+ * window.c (delete_window):
+ * xdisp.c (message_dolog): Update for new types.
+
+2003-06-26 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfaces.c (set_font_frame_param): Set default_face_done_p to zero.
+ (realize_default_face): Use default_face_done_p for the force_p
+ argument to set_lface_from_font_name. Set default_face_done_p to one.
+
+ * frame.c (make_frame): Initialize default_face_done_p.
+
+ * frame.h (struct frame): Add default_face_done_p.
+
+ * config.in: Add XRegisterIMInstantiateCallback_arg6 so it
+ will be defined.
+
+2003-06-25 Stefan Monnier <[email protected]>
+
+ * alloc.c (make_interval, Fmake_symbol, allocate_misc):
+ Initialize the new field `gcmarkbit'.
+ (mark_interval, MARK_INTERVAL_TREE): Use the new `gcmarkbit' field.
+ (mark_interval_tree): Don't mark the tree separately from the nodes.
+ (UNMARK_BALANCE_INTERVALS): Don't unmark the tree.
+ (mark_maybe_object, mark_maybe_pointer, Fgarbage_collect)
+ (mark_object, survives_gc_p, gc_sweep): Use new `gcmarkbit' fields.
+
+ * lisp.h (struct interval, struct Lisp_Symbol, struct Lisp_Free)
+ (struct Lisp_Marker, struct Lisp_Intfwd, struct Lisp_Boolfwd)
+ (struct Lisp_Kboard_Objfwd, struct Lisp_Save_Value)
+ (struct Lisp_Buffer_Local_Value, struct Lisp_Overlay)
+ (struct Lisp_Objfwd, struct Lisp_Buffer_Objfwd): Add `gcmarkbit' field.
+
+2003-06-24 Dave Love <[email protected]>
+
+ * xterm.c (xim_initialize): Use XRegisterIMInstantiateCallback_arg6.
+
+ * strftime.c: Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
+ from gnulib.
+
+2003-06-21 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fwrite_region): Alternate messages
+ for append and partial write.
+
+ * keyboard.c (read_key_sequence): When converting upcase fn key to
+ downcase, update fkey and keytran so `backspace' gets translated.
+
+ * keyboard.c (read_avail_input): Don't signal SIGHUP in batch mode.
+
+ * process.c (wait_reading_process_input): Don't signal SIGIO
+ in batch mode.
+
+2003-06-17 Kenichi Handa <[email protected]>
+
+ * Makefile.in (xselect.o): Don't depend on charset.h, coding.h,
+ composite.h.
+
+ * xselect.c: Don't include charset.h, coding.h, composite.h.
+ (Qforeign_selection): New variable.
+ (syms_of_xselect): Intern and static it.
+ (selection_data_to_lisp_data): Return a unibyte string made from
+ data with `foreign-selection' text property.
+
+2003-06-15 Stefan Monnier <[email protected]>
+
+ * termhooks.h (EVENT_INIT): New macro.
+
+ * keyboard.c (mark_kboards): Move from alloc.c. Mark kbd_buffer.
+
+ * alloc.c (mark_kboards): Move to keyboard.c.
+
+ * keyboard.c (record_asynch_buffer_change, read_avail_input):
+ * xterm.c (x_dispatch_event):
+ * xmenu.c (find_and_call_menu_selection):
+ * xdisp.c (handle_tool_bar_click):
+ * w32menu.c (menubar_selection_callback):
+ * sysdep.c (kbd_input_ast, read_input_waiting):
+ * msdos.c (dos_rawgetc):
+ * macterm.c (mac_check_for_quit_char):
+ * macmenu.c (menubar_selection_callback):
+ * gtkutil.c (xg_tool_bar_callback): Don't pass uninitialized
+ data to kbd_buffer_store_event.
+
+2003-06-15 Kim F. Storm <[email protected]>
+
+ * xdisp.c (x_fix_overlapping_area): Always use area relative X
+ to fix redisplay problem with tall characters (such as ,AC(B).
+
+2003-06-13 Kai Gro,A_(Bjohann <[email protected]>
+
+ * fileio.c (Fcopy_file): Doc fix: copies file modes, too.
+
+2003-06-12 Kenichi Handa <[email protected]>
+
+ * fileio.c (Fwrite_region): Save and restore restriction.
+
+2003-06-12 Dave Love <[email protected]>
+
+ * alloca.c (alloca): Declare arg as size_t.
+
+ * sysdep.c: Remove redundant include of unistd.h, stdlib.h.
+ Use HAVE_DECL_SYS_SIGLIST, not SYS_SIGLIST_DECLARED.
+
+2003-06-11 Dave Love <[email protected]>
+
+ * search.c (shrink_regexp_cache): Use xrealloc.
+ (syms_of_search): Use xmalloc.
+
+2003-06-10 Kim F. Storm <[email protected]>
+
+ * xdisp.c (phys_cursor_in_rect_p): Fix 2003-05-24 change.
+ Adjust phys_cursor.x to be relative to window box, rather than
+ text area before checking -- to ensure cursor is redrawn when
+ exposing window.
+ Note: This also fixes a similar (older) bug if display margins
+ are present.
+
+2003-06-06 Kenichi Handa <[email protected]>
+
+ * coding.c (encoding_buffer_size): If coding->type is
+ coding_type_ccl, double magnification on CRLF encoding.
+
+2003-06-06 Jason Rumney <[email protected]>
+
+ * w32reg.c (SYSTEM_DEFAULT_RESOURCES): New constant.
+ (w32_get_string_resource): Try SYSTEM_DEFAULT_RESOURCES last.
+
+ * xfaces.c (Finternal_face_x_get_resource): Do it on Windows and
+ Mac too.
+
+2003-06-05 Dave Love <[email protected]>
+
+ * strftime.c: Merge changes from gnulib.
+
+ * mktime.c (__mktime_internal): Merge changes from gnulib
+ involving year 69 and dst2.
+
+ Changes to merge with gnulib version and be consistent with the
+ autoconf test:
+
+ * getloadavg.c: Set NLIST_STRUCT from HAVE_NLIST_H.
+ Use HAVE_STRUCT_NLIST_N_UN_N_NAME, not NLIST_NAME_UNION.
+ [HAVE_LOCALE_H]: Include locale.h.
+ (getloadavg) [HAVE_SETLOCALE]: Run sscanf in C locale.
+
+2003-06-05 Kim F. Storm <[email protected]>
+
+ * window.c (coordinates_in_window): Convert X and Y to window
+ relative coordinates inside mode-line and header-line parts.
+ Convert X and Y to margin area relative coordinates inside left
+ and right display margin parts.
+
+2003-06-05 Jason Rumney <[email protected]>
+
+ * w32fns.c (add_system_logical_colors_to_map): New function.
+ (Fx_open_connection): Use it.
+
+2003-06-04 Stefan Monnier <[email protected]>
+
+ * process.c (allocate_pty): Revert part of the previous patch.
+ (Faccept_process_output): Simplify.
+
+2003-06-04 Jason Rumney <[email protected]>
+
+ * termhooks.h (enum event_kind): Remove MOUSE_WHEEL_EVENT.
+
+ * keyboard.c (Qmouse_wheel, mouse_wheel_syms)
+ (lispy_mouse_wheel_names): Remove.
+ (syms_of_keyboard): Remove Qmouse_wheel and mouse_wheel_syms.
+ Always define drag_and_drop_syms.
+
+ * macterm.c (XTread_socket): Map mouse wheel events to Emacs
+ WHEEL_EVENT events.
+
+2003-06-03 Stefan Monnier <[email protected]>
+
+ * xdisp.c (update_tool_bar): Add missing UNGCPRO.
+
+ * buffer.c (init_buffer_once): Make kill-buffer-hook permanent-local.
+
+2003-06-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (make_menu_item): Make sure we don't crash on a NULL
+ menu item label.
+
+2003-06-03 Richard M. Stallman <[email protected]>
+
+ * window.c (Fwindow_edges): Doc fix.
+ (Fwindow_pixel_edges, Fwindow_inside_edges)
+ (Fwindow_inside_pixel_edges): New functions.
+ (syms_of_window): defsubr them.
+
+ * window.h (WINDOW_LEFT_FRINGE_COLS, WINDOW_RIGHT_FRINGE_COLS)
+ (WINDOW_MODE_LINE_LINES, WINDOW_HEADER_LINE_LINES): New macros.
+
+2003-06-02 Stefan Monnier <[email protected]>
+
+ * dispnew.c (Fsit_for): Don't lie about the number of args.
+
+2003-06-02 Dave Love <[email protected]>
+
+ * callproc.c: Use HAVE_FCNTL_H, not USG5.
+ (syms_of_callproc) <process-environment>: Doc fix.
+
+ * doc.c: Use HAVE_FCNTL_H, not USG5.
+
+ * xfaces.c (font_rescale_ratio): Fix for K&R.
+
+ * termcap.c: Use HAVE_FCNTL_H, not _POSIX_VERSION.
+
+ * mem-limits.h: Use HAVE_SYS_RESOURCE_H, HAVE_SYS_VLIMIT_H.
+
+ * lread.c [HAVE_FCNTL_H]: Include fcntl.h.
+
+ * gtkutil.c: Include keyboard.h, charset.h, coding.h.
+ (xg_create_frame_widgets): Use ENCODE_UTF_8.
+
+ * xterm.c (Qutf_8): Move to coding.c.
+
+ * xmenu.c (ENCODE_MENU_STRING): New.
+ (list_of_panes, list_of_items, digest_single_submenu, xmenu_show):
+ Use it.
+
+ * coding.h (ENCODE_UTF_8): New.
+ (Qutf_8): Declare.
+
+ * coding.c (Qutf_8): New.
+ (syms_of_coding): Intern it.
+
+ * fns.c: Doc fixes.
+
+2003-06-02 Kenichi Handa <[email protected]>
+
+ * buffer.c (Fset_buffer_multibyte): Fix previous change.
+
+2003-06-01 Stefan Monnier <[email protected]>
+
+ * lread.c (openp): Make sure STR is a string.
+
+2003-06-01 David Ponce <[email protected]>
+
+ * termhooks.h (enum event_kind): Add new WHEEL_EVENT event.
+ Declare MOUSE_WHEEL_EVENT only if MAC_OSX defined.
+
+ * keyboard.c (Qmouse_wheel): Declare only if MAC_OSX defined.
+ (mouse_wheel_syms, lispy_mouse_wheel_names): Likewise.
+ (discard_mouse_events): Discard WHEEL_EVENT events too.
+ (lispy_wheel_names, wheel_syms): New.
+ (syms_of_keyboard): Init and staticpro `wheel_syms'. Init and
+ staticpro `Qmouse_wheel' and `mouse_wheel_syms' only if MAC_OSX defined.
+ (make_lispy_event): Add WHEEL_EVENT handler.
+
+ * w32term.c (construct_mouse_wheel): Construct WHEEL_EVENT.
+ (w32_read_socket): Map w32 WM_MOUSEWHEEL events to Emacs
+ WHEEL_EVENT events.
+
+2003-05-31 John Paul Wallington <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): byte-run, float-sup, map-ynp, and
+ timer are in lisp/emacs-lisp.
+
+2003-05-31 Kenichi Handa <[email protected]>
+
+ * buffer.c (Fset_buffer_multibyte): Correctly recover a narrowed
+ region when a buffer is changed to unibyte.
+
+ * charset.h (VALID_LEADING_CODE_P): New macro.
+ (UNIBYTE_STR_AS_MULTIBYTE_P): Check more rigidly.
+
+ * coding.c (DECODE_EMACS_MULE_COMPOSITION_CHAR): If coding->flags
+ is nonzero, accept multibyte form of eight-bit-control chars.
+ (decode_composition_emacs_mule): Likewise.
+ (decode_coding_emacs_mule): Likewise.
+ (encode_coding_emacs_mule): If coding->flags is nonzero, produce
+ multibyte form of eight-bit-control chars.
+
+ * fileio.c (Qauto_save_coding, auto_save_coding): New variables.
+ (Finsert_file_contents): If coding-system-for-read is bound to
+ Qauto_save_coding, use the coding system emacs-mule with special
+ setting for recovering a file.
+ (choose_write_coding_system): On auto saving, use the coding
+ system emacs-mule with special setting for auto saving.
+ (syms_of_fileio) <Qauto_save_coding>: Intern and staticpro it.
+
+2003-05-30 Kenichi Handa <[email protected]>
+
+ * coding.c (ccl_coding_driver): Set ccl->eight_bit_control
+ properly before calling ccl_driver.
+
+ * ccl.h (struct ccl_program) <eight_bit_control>: Comment fixed.
+
+ * ccl.c (CCL_WRITE_CHAR): Increment extra_bytes only when it is nonzero.
+ (ccl_driver): Initialize extra_bytes to ccl->eight_bit_control.
+ (setup_ccl_program): Initialize ccl->eight_bit_control to zero.
+
+2003-05-29 Glenn Morris <[email protected]>
+
+ * xfaces.c (realize_default_face): Do not abort if lface is
+ non-existent - reverts change from 2003-05-19.
+
+2003-05-29 Kenichi Handa <[email protected]>
+
+ * coding.c (decode_coding_iso2022): Pay attention to the byte
+ sequence of CTEXT extended segment, and retain those bytes as is.
+
+2003-05-28 Kenichi Handa <[email protected]>
+
+ * coding.c (ENCODE_UNSAFE_CHARACTER): Adjust for the name change
+ of CODING_REPLACEMENT_CHARACTER.
+ (decode_coding_iso2022): If CODING_FLAG_ISO_SAFE, set
+ CODING_MODE_INHIBIT_UNENCODABLE_CHAR flag in coding->mode, and
+ check this flag on encoding.
+ (encode_coding_sjis_big5):
+ Check CODING_MODE_INHIBIT_UNENCODABLE_CHAR flag of coding->mode.
+ (Fset_terminal_coding_system_internal):
+ Set CODING_MODE_INHIBIT_UNENCODABLE_CHAR flag in terminal_coding.mode
+ instead of setting CODING_FLAG_ISO_SAFE flag in terminal_coding.flags.
+
+ * coding.h (CODING_REPLACEMENT_CHARACTER): Rename from
+ CODING_INHIBIT_CHARACTER_SUBSTITUTION.
+ (CODING_MODE_INHIBIT_UNENCODABLE_CHAR): New macro.
+
+2003-05-28 Richard M. Stallman <[email protected]>
+
+ * print.c (syms_of_print) <print-escape-nonascii>: Doc fix.
+
+ * eval.c (unbind_to): Move init of this_binding to separate statement.
+
+2003-05-28 Kim F. Storm <[email protected]>
+
+ * xdisp.c (expose_window): Fix error in calculation of
+ window relative coordinates of area to redisplay.
+
+2003-05-27 Jason Rumney <[email protected]>
+
+ * w32term.c (GET_WHEEL_DELTA_WPARAM): New macro.
+
+2003-05-27 David Ponce <[email protected]>
+
+ Handle W32 mouse wheel events as mouse click events, like in X.
+
+ * keyboard.c (make_lispy_event) [WINDOWSNT]: Don't handle
+ MOUSE_WHEEL_EVENT anymore.
+
+ * w32term.c (construct_mouse_wheel): Result is a MOUSE_CLICK_EVENT.
+ Scrolling down/up the mouse wheel is respectively mapped to mouse
+ button 4 and 5.
+ (w32_read_socket): Map w32 WM_MOUSEWHEEL events to Emacs
+ MOUSE_CLICK_EVENT events. Forward w32 MSH_MOUSEWHEEL events as
+ WM_MOUSEWHEEL events.
+
+2003-05-27 Andreas Schwab <[email protected]>
+
+ * buffer.c (syms_of_buffer) <default-direction-reversed>: Doc fix.
+
+ * xdisp.c (try_window_id): Avoid aborting if PT is inside a
+ partially visible line.
+
+ * alloc.c (Fgarbage_collect): Fix last change.
+
+2003-05-26 John Paul Wallington <[email protected]>
+
+ * xfns.c (Fx_create_frame): Don't call Qface_set_after_frame_default.
+
+2003-05-25 Stefan Monnier <[email protected]>
+
+ * window.c (Fset_window_buffer): Add type of `keep_margins'.
+ (Fset_window_fringes, Fset_window_scroll_bars): Declare before use.
+
+ * window.h (window_box_text_cols): Declare.
+
+ * xdisp.c (window_text_bottom_y, draw_row_fringe_bitmaps)
+ (x_draw_vertical_border): Remove unused var `f'.
+
+ * xfaces.c (build_scalable_font_name): Remove `unused var
+ pixel_size' warning.
+
+ * xfns.c (png_load): Remove `unused vars intent, image_gamma' warning.
+
+ * unexelf.c (unexec): Remove `unused var n' warning.
+
+ * strftime.c (my_strftime_localtime_r): Remove `defined but
+ unused' warning.
+
+ * process.c (allocate_pty): Remove `unused var stb' and
+ `cp might be used uninitialized' warnings.
+
+ * dispnew.c (mode_line_string): Remove unused var `f'.
+
+ * coding.c (find_safe_codings): Remove unused var `i'.
+
+ * bytecode.c (Fbyte_code): Remove `unused val' warning.
+
+ * buffer.c (Fkill_buffer): Remove unused var `list'.
+
+ * alloc.c (Fgarbage_collect): Remove `unused var tail' warning.
+
+2003-05-25 Jan Dj,Ad(Brv <[email protected]>
+
+ * frame.c (make_frame): Condition want_fullscreen with
+ HAVE_WINDOW_SYSTEM.
+
+2003-05-25 Juanma Barranquero <[email protected]>
+
+ * window.c (Fset_window_scroll_bars): Fix typo in argument name.
+ (Fwindow_scroll_bars): Fix typo in docstring.
+
+2003-05-24 Kim F. Storm <[email protected]>
+
+ The following changes serve several purposes:
+
+ 1) Swap the position of fringes and display margins in windows, i.e.
+ the fringes are now displayed between the margins and the text area
+ (by default).
+
+ 2) Allow fringe and scroll bar parameters to be set per-buffer and
+ per-window (like display margins). Such settings are now stored
+ in window configurations, preserved when frames are resized, and
+ copied when windows are split vertically or horizontally.
+ Several bugs related to display margins have been fixed.
+
+ 3) Consistently use FRAME_FONT and FRAME_FONTSET macros.
+
+ 4) Use FRAME_COLUMN_WIDTH (f) consistently throughout the code
+ rather than FRAME_WIDTH (FRAME_FONT (f)).
+
+ 5) Introduce a consistent naming of variables, members and macros
+ depending on whether their value is measured in pixels or in
+ canonical columns/lines. Pixel dimensions are named *_width and
+ *_height, while canonical columns/lines are named *_cols and
+ *_lines. Pixel positions are named *_x and *_y, while column/line
+ positions are named *_col and *_line.
+
+ 6) Consolidate more of the X, W32, and MAC gui code by moving
+ common data into struct frame, and generalize it for the non-gui
+ case by using suitable defaults.
+
+ 7) Cleanup and consolidate the macros controlling frame and window
+ layout into frame.h and window.h, and generalize the use of the
+ various window_box_* functions (enhanced to handle the new fringe
+ position and the per-window fringe and scroll bar settings).
+
+ * frame.h (struct frame): Rename members height to text_lines,
+ width to text_cols, window_height to total_lines, window_width to
+ total_cols, new_height to new_text_lines, new_width to
+ new_text_cols. All uses changed.
+ (struct frame): New members which consolidate common members of
+ x_output, w32_output, and mac_output structures: left_pos,
+ top_pos, pixel_height, pixel_width, x_pixels_diff, y_pixels_diff,
+ win_gravity, size_hint_flags, border_width, internal_border_width,
+ line_height, fringe_cols, left_fringe_width, right_fringe_width,
+ want_fullscreen. All uses changed.
+ (struct frame): New member column_width contaning the canonical
+ column width, analogue to line_height. All uses changed.
+ (struct frame): Rename members scroll_bar_pixel_width to
+ config_scroll_bar_width, and scroll_bar_cols to
+ config_scroll_bar_cols. All uses changed.
+ (struct frame): New member scroll_bar_actual_width which
+ consolidates and renames the vertical_scroll_bar_extra member of
+ x_output, w32_output, and mac_output structures. All uses changed.
+ (FRAME_PIXEL_HEIGHT): Rename from PIXEL_HEIGHT and moved
+ from x/w32/macterm.h files. All uses changed. Also change code
+ which referred to f->output_data...->pixel_height.
+ (FRAME_PIXEL_WIDTH): Rename from PIXEL_WIDTH and moved
+ from x/w32/macterm.h files. All uses changed. Also change code
+ which referred to f->output_data...->pixel_width.
+ (FRAME_LINES): Rename from FRAME_HEIGHT. All uses changed.
+ Also change code which referred to f->height.
+ (FRAME_COLS): Rename from FRAME_WIDTH. All uses changed.
+ Also change code which referred to f->width.
+ (FRAME_NEW_HEIGHT, FRAME_NEW_WIDTH): Remove macros; change uses
+ to update new_text_lines and new_text_cols members directly.
+ (FRAME_CONFIG_SCROLL_BAR_WIDTH): Rename from
+ FRAME_SCROLL_BAR_PIXEL_WIDTH. All uses changed.
+ (FRAME_CONFIG_SCROLL_BAR_COLS): Rename from
+ FRAME_SCROLL_BAR_COLS. All uses changed.
+ (FRAME_LEFT_SCROLL_BAR_COLS, FRAME_RIGHT_SCROLL_BAR_COLS):
+ Rename from FRAME_LEFT_SCROLL_BAR_WIDTH and
+ FRAME_RIGHT_SCROLL_BAR_WIDTH, resp. All uses changed.
+ (FRAME_SCROLL_BAR_AREA_WIDTH, FRAME_LEFT_SCROLL_BAR_AREA_WIDTH)
+ (FRAME_RIGHT_SCROLL_BAR_AREA_WIDTH): New macros.
+ (FRAME_TOTAL_COLS): Rename from FRAME_WINDOW_WIDTH.
+ (SET_FRAME_COLS): Rename from SET_FRAME_WIDTH.
+ (FRAME_TOTAL_COLS_ARG): Rename from FRAME_WINDOW_WIDTH_ARG.
+ (WINDOW_VERTICAL_SCROLL_BAR_COLUMN): Remove unused macro.
+ (WINDOW_VERTICAL_SCROLL_BAR_HEIGHT): Remove unused macro.
+ (FRAME_LINE_HEIGHT): Rename from CANON_Y_UNIT.
+ Unconditionally return line_height member (it now has proper value
+ also for non-window frames).
+ (FRAME_COLUMN_WIDTH): Rename from CANON_X_UNIT. Unconditionally
+ return new column_width member (rather than the default font width).
+ (FRAME_FRINGE_COLS, FRAME_LEFT_FRINGE_WIDTH)
+ (FRAME_RIGHT_FRINGE_WIDTH): Rename from FRAME_X_... and moved
+ from x/w32/macterm.h files. Unconditionally return corresponding
+ member of frame structure (they now have proper values also for
+ non-window frames).
+ (FRAME_TOTAL_FRINGE_WIDTH): Rename from FRAME_FRINGE_WIDTH.
+ Calculate return value from left and right widths.
+ (FRAME_INTERNAL_BORDER_WIDTH): Unconditionally return
+ internal_border_width member (has proper value for non-window frame).
+ (FRAME_PIXEL_X_FROM_CANON_X): Rename from PIXEL_X_FROM_CANON_X.
+ (FRAME_PIXEL_Y_FROM_CANON_Y): Rename from PIXEL_Y_FROM_CANON_Y.
+ (FRAME_CANON_X_FROM_PIXEL_X): Rename from CANON_X_FROM_PIXEL_X.
+ (FRAME_CANON_Y_FROM_PIXEL_Y): Rename from CANON_Y_FROM_PIXEL_Y.
+ (FRAME_LINE_TO_PIXEL_Y): Rename from CHAR_TO_PIXEL_ROW,
+ consolidated from xterm.h, macterm.h, and w32term.h.
+ (FRAME_COL_TO_PIXEL_X): Rename from CHAR_TO_PIXEL_COL,
+ consolidated from xterm.h, macterm.h, and w32term.h.
+ (FRAME_TEXT_COLS_TO_PIXEL_WIDTH): Rename from
+ CHAR_TO_PIXEL_WIDTH consolidated from x/mac/w32term.h.
+ (FRAME_TEXT_LINES_TO_PIXEL_HEIGHT): Rename from
+ CHAR_TO_PIXEL_HEIGHT consolidated from x/mac/w32term.h.
+ (FRAME_PIXEL_Y_TO_LINE): Rename from PIXEL_TO_CHAR_ROW
+ consolidated from x/mac/w32term.h.
+ (FRAME_PIXEL_X_TO_COL): Rename from PIXEL_TO_CHAR_COL
+ consolidated from x/mac/w32term.h.
+ (FRAME_PIXEL_WIDTH_TO_TEXT_COLS): Rename from
+ PIXEL_TO_CHAR_WIDTH consolidated from x/mac/w32term.h.
+ (FRAME_PIXEL_HEIGHT_TO_TEXT_LINES): Rename from
+ PIXEL_TO_CHAR_HEIGHT consolidated from x/mac/w32term.h.
+
+ * window.h (struct window): Rename members left to left_col,
+ top to top_line, height to total_lines, width to total_cols,
+ left_margin_width to left_margin_cols, right_margin_width to
+ right_margin_cols, orig_height to orig_total_lines, orig_top to
+ orig_top_line. All uses changed.
+ (struct window): New members left_fringe_width, right_fringe_width,
+ fringes_outside_margins, scroll_bar_width, vertical_scroll_bar_type.
+ (WINDOW_XFRAME, WINDOW_FRAME_COLUMN_WIDTH, WINDOW_FRAME_LINE_HEIGHT):
+ New macros primarily used to simplify other macros.
+ (WINDOW_TOTAL_COLS): New macro. Change relevant code that
+ referred to XINT (w->width).
+ (WINDOW_TOTAL_LINES): New macro. Change relevant code that
+ referred to XINT (w->height).
+ (WINDOW_TOTAL_WIDTH): New macro. Change relevant code that
+ referred to XINT (w->width) * canon_x_unit.
+ (WINDOW_TOTAL_HEIGHT): New macro. Change relevant code that
+ referred to XINT (w->height) * canon_y_unit.
+ (WINDOW_LEFT_EDGE_COL): New macro. Change relevant code that
+ referred to XINT (w->left).
+ (WINDOW_RIGHT_EDGE_COL): Rename from WINDOW_RIGHT_EDGE. Change
+ all uses and code that referred to XINT (w->left) + XINT (w->width).
+ (WINDOW_TOP_EDGE_LINE): New macro. Change relevant code that
+ referred to XINT (w->top).
+ (WINDOW_BOTTOM_EDGE_LINE): New macro. Change relevant code that
+ referred to XINT (w->top) + XINT (w->height).
+ (WINDOW_LEFT_EDGE_X): New macro. Change relevant code that
+ referred to XINT (w->left) * canon_x_unit.
+ (WINDOW_RIGHT_EDGE_X): New macro. Change relevant code that
+ referred to (XINT (w->left) + XINT (w->width)) * canon_x_unit.
+ (WINDOW_TOP_EDGE_Y): New macro. Change relevant code that
+ referred to XINT (w->top) * canon_y_unit.
+ (WINDOW_BOTTOM_EDGE_Y): New macro. Change relevant code that
+ referred to (XINT (w->top) + XINT (w->height)) * canon_y_unit.
+ (WINDOW_LEFTMOST_P): New macro.
+ (WINDOW_BOX_LEFT_EDGE_COL): Rename from WINDOW_LEFT_MARGIN.
+ All uses changed.
+ (WINDOW_BOX_RIGHT_EDGE_COL): Rename from WINDOW_RIGHT_MARGIN.
+ All uses changed.
+ (WINDOW_BOX_LEFT_EDGE_X): Rename from
+ WINDOW_DISPLAY_LEFT_EDGE_PIXEL_X, moved from dispextern.h.
+ Do not exclude left fringe width.
+ (WINDOW_BOX_RIGHT_EDGE_X): Rename from
+ WINDOW_DISPLAY_RIGHT_EDGE_PIXEL_X, moved from dispextern.h.
+ Do not exclude fringe widths.
+ (WINDOW_LEFT_FRINGE_WIDTH, WINDOW_RIGHT_FRINGE_WIDTH)
+ (WINDOW_FRINGE_COLS, WINDOW_TOTAL_FRINGE_WIDTH): New macros.
+ Change relevant code that referred to FRAME_LEFT_FRINGE_WIDTH,
+ FRAME_RIGHT_FRINGE_WIDTH, FRAME_FRINGE_COLS, and
+ FRAME_TOTAL_FRINGE_WIDTH to allow per-window fringe settings.
+ (WINDOW_HAS_FRINGES_OUTSIDE_MARGINS): New macro.
+ (WINDOW_VERTICAL_SCROLL_BAR_TYPE, WINDOW_HAS_VERTICAL_SCROLL_BAR)
+ (WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT)
+ (WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT)
+ (WINDOW_CONFIG_SCROLL_BAR_WIDTH, WINDOW_CONFIG_SCROLL_BAR_COLS):
+ New macros. Change code which referenced corresponding
+ FRAME_VERTICAL_SCROLL_BAR_TYPE, FRAME_HAS_VERTICAL_SCROLL_BARS,
+ FRAME_HAS_VERTICAL_SCROLL_BARS_ON_LEFT,
+ FRAME_HAS_VERTICAL_SCROLL_BARS_ON_RIGHT,
+ FRAME_SCROLL_BAR_PIXEL_WIDTH, and FRAME_SCROLL_BAR_COLS macros to
+ allow per-window scroll-bar settings.
+ (WINDOW_LEFT_SCROLL_BAR_COLS, WINDOW_RIGHT_SCROLL_BAR_COLS): New macros.
+ (WINDOW_LEFT_SCROLL_BAR_AREA_WIDTH): New macro. Change code that
+ referred to FRAME_LEFT_SCROLL_BAR_WIDTH.
+ (WINDOW_RIGHT_SCROLL_BAR_AREA_WIDTH): New macro. Change code
+ that referred to FRAME_HAS_VERTICAL_SCROLL_BARS_ON_RIGHT and
+ FRAME_SCROLL_BAR_WIDTH.
+ (WINDOW_SCROLL_BAR_COLS, WINDOW_SCROLL_BAR_AREA_WIDTH)
+ (WINDOW_SCROLL_BAR_AREA_X): New macros.
+ (WINDOW_HEADER_LINE_HEIGHT): Rename from
+ WINDOW_DISPLAY_HEADER_LINE_HEIGHT, moved from dispextern.h.
+ (WINDOW_BOX_HEIGHT_NO_MODE_LINE): Rename from
+ WINDOW_DISPLAY_HEIGHT_NO_MODE_LINE, moved from dispextern.h.
+ (WINDOW_BOX_TEXT_HEIGHT): Rename from
+ WINDOW_DISPLAY_PIXEL_WIDTH, moved from dispextern.h.
+ (WINDOW_TO_FRAME_PIXEL_X, WINDOW_TO_FRAME_PIXEL_Y)
+ (FRAME_TO_WINDOW_PIXEL_X, FRAME_TO_WINDOW_PIXEL_Y)
+ (WINDOW_TEXT_TO_FRAME_PIXEL_X): Move here from dispextern.h.
+ (WINDOW_LEFT_MARGIN_WIDTH): Rename from
+ WINDOW_DISPLAY_LEFT_AREA_PIXEL_WIDTH, moved from dispextern.h.
+ (WINDOW_RIGHT_MARGIN_WIDTH): Rename from
+ WINDOW_DISPLAY_RIGHT_AREA_PIXEL_WIDTH, moved from dispextern.h.
+ (window_from_coordinates): Update prototype.
+ (Fset_window_buffer): Update EXFUN.
+ (set_window_buffer): Update prototype.
+
+ * dispextern.h (struct glyph_matrix): Rename members window_left_x
+ to window_left_col, window_top_y to window_top_line. All uses
+ changed.
+ (FRAME_INTERNAL_BORDER_WIDTH_SAFE): Remove macro; can now safely
+ use FRAME_INTERNAL_BORDER_WIDTH macro instead as
+ internal_border_width is now set to 0 for non-window frames.
+ (WINDOW_DISPLAY_PIXEL_WIDTH, WINDOW_DISPLAY_PIXEL_HEIGHT)
+ (WINDOW_DISPLAY_MODE_LINE_HEIGHT, WINDOW_DISPLAY_HEADER_LINE_HEIGHT)
+ (WINDOW_DISPLAY_HEIGHT_NO_MODE_LINE, WINDOW_DISPLAY_TEXT_HEIGHT)
+ (WINDOW_DISPLAY_LEFT_EDGE_PIXEL_X, WINDOW_DISPLAY_RIGHT_EDGE_PIXEL_X)
+ (WINDOW_DISPLAY_TOP_EDGE_PIXEL_Y, WINDOW_DISPLAY_BOTTOM_EDGE_PIXEL_Y)
+ (WINDOW_TO_FRAME_PIXEL_X, WINDOW_TO_FRAME_PIXEL_Y)
+ (FRAME_TO_WINDOW_PIXEL_X, FRAME_TO_WINDOW_PIXEL_Y)
+ (WINDOW_DISPLAY_LEFT_AREA_PIXEL_WIDTH)
+ (WINDOW_DISPLAY_RIGHT_AREA_PIXEL_WIDTH, WINDOW_WANTS_MODELINE_P):
+ Move to window.h and renamed [see window.h changes].
+ (WINDOW_AREA_TO_FRAME_PIXEL_X, WINDOW_AREA_PIXEL_WIDTH)
+ (WINDOW_DISPLAY_TEXT_AREA_PIXEL_WIDTH): Remove macros.
+ (WINDOW_WANTS_MODELINE_P, WINDOW_WANTS_HEADER_LINE_P):
+ Use WINDOW_TOTAL_LINES.
+ (frame_update_line_height): Remove prototype.
+
+ * buffer.h (struct buffer): Rename members measured in columns:
+ left_margin_width to left_margin_cols, right_margin_width to
+ right_margin_cols. All uses changed.
+ New members left_fringe_width, right_fringe_width,
+ fringes_outside_margins for per-buffer fringe settings.
+ New members scroll_bar_width and vertical_scroll_bar_type for
+ per-buffer scroll bar settings.
+
+ * buffer.c (init_buffer_once): Set buffer_defaults and
+ buffer_local_flags for new buffer-local variables
+ left_fringe_width, right_fringe_width, fringes_outside_margins,
+ scroll_bar_width, and vertical_scroll_bar_type.
+ (syms_of_buffer): Defvar_per_buffer them, and defvar_lisp_nopro
+ default-* variables for them.
+
+ * dispnew.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (mode_line_string): No need to adjust width for mode lines, as it
+ is already adjusted by the caller.
+ (marginal_area_string): Handle fringes inside/outside margins.
+
+ * frame.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (make_frame): Initialize left_fringe_width, right_fringe_width,
+ fringe_cols, scroll_bar_actual_width, border_width,
+ internal_border_width, column_width, line_height, x_pixels_diff,
+ y_pixels_diff, want_fullscreen, size_hint_flags, and win_gravity
+ members with values suitable for a non-window frames.
+
+ * gtkutil.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * indent.c: Make (few) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * keyboard.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (make_lispy_event): Use window positions returned from
+ window_from_coordinates when constructing the lisp event for
+ MOUSE_CLICK_EVENT and DRAG_N_DROP_EVENT, rather than calculating
+ (incorrect) values locally.
+ (make_lispy_movement): Use window positions returned from
+ window_from_coordinates when constructing the lisp event, rather
+ than calculating (incorrect) values locally.
+
+ * scroll.c: Make (some) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * sunfns.c (Fsun_menu_internal): Adapt to per-window fringes and
+ scroll-bars.
+
+ * sysdep.c: Make (few) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * term.c: Make (some) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * widget.c: Make (few) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * window.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (make_window): Initialize new members
+ left_margin_cols, right_margin_cols, left_fringe_width,
+ right_fringe_width, fringes_outside_margins, scroll_bar_width,
+ and vertical_scroll_bar_type.
+ (coordinates_in_window): Adapt to new fringe/margin positions
+ and per-window fringes and scroll-bars.
+ Fix bug related to incorrectly adjusting coordinates by
+ frame's internal_border_width (the effect normally negible since
+ the internal_border_width is typically 0 or 1 pixel, but very
+ noticeable for an internal_border_width of e.g. 25 pixels).
+ Upon successful return (other than ON_NOTHING), the coordinates
+ are now always properly converted to window relative for the
+ given display element.
+ (window_from_coordinates): Add new parameters wx and wy to
+ return the window relative x and y position in the returned
+ window and part. A null arg means, don't return the position.
+ All callers changed.
+ (adjust_window_margins): New function which may reduce the width
+ of the display margins if a window's text area is too small after
+ resizing or splitting windows.
+ (size_window): Fix bug that did not account for display margin
+ widths when checking the minimum width of a window; use
+ adjust_window_margins.
+ (set_window_buffer): Call Fset_window_fringes and
+ Fset_window_scroll_bars to setup per-window elements.
+ Add new arg KEEP_MARGINS_P. Non-nil means to keep window's
+ existing display margin, fringe widths, and scroll bar settings
+ (e.g. after splitting a window or resizing the frame).
+ All callers changed.
+ (Fset_window_buffer): New arg KEEP_MARGINS. All callers changed.
+ (Fsplit_window): Duplicate original window's display margin,
+ fringe, and scroll-bar settings; then call Fset_window_buffer with
+ KEEP_MARGINS non-nil. This fixes a bug which caused a split
+ window to only preserve the display margins in one of the windows.
+ When splitting horizontally, call adjust_window_margins on both
+ windows to ensure that the text area of the new windows is non too
+ narrow. This fixes a bug which could cause Emacs to trap if the
+ width of the split window was less than the width of the display
+ margins.
+ (window_box_text_cols): Rename from window_internal_width.
+ All uses changed. Adapt to per-window fringes and scroll bars.
+ Fix bug that caused vertical separator to be subtracted also on
+ window frames. Fix another bug that did not reduce the returned
+ value by the columns used for display margins.
+ (window_scroll_line_based): Fix bug related to scrolling too much
+ when display margins are present (implicitly fixed by the fix to
+ window_box_text_cols).
+ (scroll_left, scroll_right): Fix bug related to scrolling too far
+ by default when display margins are present (implicitly fixed by
+ the fix to window_box_text_cols).
+ (struct saved_window): Rename members left to left_col, top to
+ top_line, width to total_cols, height to total_lines, orig_top to
+ orig_top_line, orig_height to orig_total_lines. All uses changed.
+ New members left_margin_cols, right_margin_cols,
+ left_fringe_width, right_fringe_width, fringes_outside_margins,
+ scroll_bar_width, and vertical_scroll_bar_type for saving
+ per-window display elements.
+ (Fset_window_configuration): Restore display margins, fringes,
+ and scroll bar settings. This fixes a bug which caused display
+ margins to be discarded when saving and restoring a window
+ configuration.
+ (save_window_save): Save display margins, fringes, and scroll bar
+ settings. This fixes a bug which caused display margins to be
+ discarded when saving and restoring a window configuration.
+ (Fset_window_margins): Do nothing if display margins are not
+ really changed. Otherwise, call adjust_window_margins to ensure
+ the text area doesn't get too narrow. This fixes a bug which
+ could cause Emacs to trap if setting display margins wider than
+ the width of the window.
+ (Fset_window_fringes): New defun to allow user to specifically set
+ this window's fringe widths and position vs. display margins.
+ (Fwindow_fringes): New defun to return window's actual fringe settings.
+ (Fset_window_scroll_bars): New defun to allow user to specifically
+ set this window's scroll bar width and position.
+ (Fwindow_scroll_bars): New defun to return window's actual scroll
+ bar settings.
+ (compare_window_configurations): Also compare display margins,
+ fringes, and scroll bar settings.
+ (syms_of_window): Defsubr new defuns for fringe and scroll bars.
+
+ * xdisp.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (window_box_width): Adapt to per-window fringes and scroll bars,
+ and new fringe vs. display margin position. Note that returned
+ value is no longer guaranteed to be a whole multiple of the frame
+ column width, since per-window fringes may now be any width.
+ (window_box_left_offset): New function like window_box_left, but
+ value is relative to left border of window (rather than frame).
+ (window_box_right_offset): New function like window_box_right,
+ but value is relative to left border of window.
+ (window_box_left): Adapt to per-window fringes and scroll bars,
+ and new fringe vs. display margin position. Simplify by using
+ WINDOW_LEFT_EDGE_X and window_box_left_offset.
+ (window_box): Allow null args for unnecessary return values;
+ change/simplify relevant callers.
+ (x_y_to_hpos_vpos): Adapt to per-window fringes and scroll bars,
+ and new fringe vs. display margin position.
+ Use window_box_left_offset and window_box_right_offset
+ (get_glyph_string_clip_rect): Adapt to per-window fringes and
+ scroll bars, and new fringe vs. display margin position.
+ Use WINDOW_LEFT_EDGE_X and WINDOW_TOTAL_WIDTH.
+ (draw_fringe_bitmap): Rework to handle per-window fringes and new
+ fringe vs. display margin position.
+ (hscroll_window_tree): Use window_box_width instead of window_box.
+ (redisplay_window): Adapt to per-window scroll bars.
+ (draw_glyphs): Rework to handle per-window fringes and scroll
+ bars, and new fringe vs. display margin position.
+ Use WINDOW_LEFT_EDGE_X, WINDOW_TOTAL_WIDTH, and window_box_left.
+ (x_clear_end_of_line): Adapt to per-window fringes and scroll
+ bars, and new fringe vs. display margin position. Fix bug which
+ increased total width of full_width rows by width of scroll bars
+ although window's total width already includes that.
+ (x_fix_overlapping_area): Simplify using window_box_left_offset.
+ (expose_area): Simplify using window_box_left_offset.
+ (x_draw_vertical_border): Handle per-window scroll bar settings,
+ mixing windows with left, right and no scroll bars.
+
+ * xfaces.c [WINDOWSNT]: Move redefinition of FONT_WIDTH macro to
+ where it's used in x_list_fonts (for clarity).
+ (frame_update_line_height): Remove unused function; functionality
+ is now done directly when setting the default font in x_set_font.
+
+ * xfns.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * xmenu.c: Make (some) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * xterm.h (struct x_output): Move members left_pos, top_pos,
+ border_width, pixel_height, pixel_width, line_height,
+ internal_border_width, vertical_scroll_bar_extra,
+ left_fringe_width, right_fringe_width, fringe_cols,
+ fringes_extra, win_gravity, size_hint_flags, want_fullscreen,
+ x_pixels_diff, and y_pixels_diff to struct frame (frame.h).
+ (FRAME_INTERNAL_BORDER_WIDTH, FRAME_LINE_HEIGHT): Move to frame.h.
+ (FRAME_DEFAULT_FONT_WIDTH): Remove macro.
+ (PIXEL_WIDTH, PIXEL_HEIGHT)
+ (FRAME_X_FRINGE_COLS, FRAME_X_FRINGE_WIDTH)
+ (FRAME_X_LEFT_FRINGE_WIDTH, FRAME_X_RIGHT_FRINGE_WIDTH): Move to
+ frame.h and renamed [see frame.h changes].
+ (CHAR_TO_PIXEL_ROW, CHAR_TO_PIXEL_COL, CHAR_TO_PIXEL_WIDTH)
+ (CHAR_TO_PIXEL_HEIGHT, PIXEL_TO_CHAR_ROW, PIXEL_TO_CHAR_COL)
+ (PIXEL_TO_CHAR_WIDTH, PIXEL_TO_CHAR_HEIGHT): Move to frame.h
+ and renamed [see frame.h changes].
+
+ * xterm.c: Make (several) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (x_draw_glyph_string_box): Adapt to per-window fringes and scroll-bars.
+ (scroll_run): Adapt to new fringe position.
+ (glyph_rect): Use window coordinates returned from
+ window_from_coordinates rather than frame_to_window_pixel_xy.
+ (XTset_vertical_scroll_bar): Adapt to per-window fringes and
+ scroll-bars.
+ (handle_one_xevent): Simplify a USE_GTK conditional.
+ (x_clip_to_row): Remove superfluous whole_line_p arg and code
+ (fringes are now inside margins, i.e. always in the clipping area).
+ All callers changed.
+ (x_new_font): Set FRAME_COLUMN_WIDTH and FRAME_LINE_HEIGHT
+ directly, then call compute_fringe_widths. Don't call
+ frame_update_line_height.
+
+ * w32term.h (struct w32_output): Move members left_pos, top_pos,
+ border_width, pixel_height, pixel_width, line_height,
+ internal_border_width, vertical_scroll_bar_extra,
+ left_fringe_width, right_fringe_width, fringe_cols,
+ fringes_extra, win_gravity, size_hint_flags, want_fullscreen,
+ x_pixels_diff, and y_pixels_diff to struct frame (frame.h).
+ (FRAME_INTERNAL_BORDER_WIDTH, FRAME_LINE_HEIGHT): Move to frame.h.
+ (FRAME_DEFAULT_FONT_WIDTH): Remove macro.
+ (PIXEL_WIDTH, PIXEL_HEIGHT)
+ (FRAME_X_FRINGE_COLS, FRAME_X_FRINGE_WIDTH)
+ (FRAME_X_LEFT_FRINGE_WIDTH, FRAME_X_RIGHT_FRINGE_WIDTH): Move to
+ frame.h and renamed [see frame.h changes].
+ (CHAR_TO_PIXEL_ROW, CHAR_TO_PIXEL_COL, CHAR_TO_PIXEL_WIDTH)
+ (CHAR_TO_PIXEL_HEIGHT, PIXEL_TO_CHAR_ROW, PIXEL_TO_CHAR_COL)
+ (PIXEL_TO_CHAR_WIDTH, PIXEL_TO_CHAR_HEIGHT): Move to frame.h
+ and renamed [see frame.h changes].
+
+ * w32term.c: Make (several) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (x_draw_glyph_string_box): Adapt to per-window fringes and scroll-bars.
+ (glyph_rect): Use window coordinates returned from
+ window_from_coordinates rather than frame_to_window_pixel_xy.
+ (XTset_vertical_scroll_bar): Adapt to per-window fringes and
+ scroll-bars.
+ (w32_clip_to_row): Remove superfluous whole_line_p arg and code
+ (fringes are now inside margins, i.e. always in the clipping area).
+ All callers changed.
+ (x_new_font): Set FRAME_COLUMN_WIDTH and FRAME_LINE_HEIGHT
+ directly, then call compute_fringe_widths. Don't call
+ frame_update_line_height.
+
+ * w32console.c: Make (few) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * w32fns.c: Make (many) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * w32menu.c: Make (few) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * macterm.h (struct mac_output): Move members left_pos, top_pos,
+ border_width, pixel_height, pixel_width, line_height,
+ internal_border_width, vertical_scroll_bar_extra,
+ left_fringe_width, right_fringe_width, fringe_cols,
+ fringes_extra, win_gravity, size_hint_flags, want_fullscreen,
+ x_pixels_diff, y_pixels_diff to struct frame (frame.h).
+ (FRAME_INTERNAL_BORDER_WIDTH, FRAME_LINE_HEIGHT): Move to frame.h.
+ (FRAME_DEFAULT_FONT_WIDTH): Remove macro.
+ (PIXEL_WIDTH, PIXEL_HEIGHT)
+ (FRAME_X_FRINGE_COLS, FRAME_X_FRINGE_WIDTH)
+ (FRAME_X_LEFT_FRINGE_WIDTH, FRAME_X_RIGHT_FRINGE_WIDTH): Move to
+ frame.h and renamed [see frame.h changes].
+ (CHAR_TO_PIXEL_ROW, CHAR_TO_PIXEL_COL, CHAR_TO_PIXEL_WIDTH)
+ (CHAR_TO_PIXEL_HEIGHT, PIXEL_TO_CHAR_ROW, PIXEL_TO_CHAR_COL)
+ (PIXEL_TO_CHAR_WIDTH, PIXEL_TO_CHAR_HEIGHT): Move to frame.h
+ and renamed [see frame.h changes].
+
+ * macterm.c: Make (several) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (x_draw_glyph_string_box): Adapt to per-window fringes and scroll-bars.
+ (glyph_rect): Use window coordinates returned from
+ window_from_coordinates rather than frame_to_window_pixel_xy.
+ (XTset_vertical_scroll_bar): Adapt to per-window fringes and
+ scroll-bars.
+ (x_clip_to_row): Remove superfluous whole_line_p arg and code
+ (fringes are now inside margins, i.e. always in the clipping area).
+ All callers changed.
+ (x_new_font): Set FRAME_COLUMN_WIDTH and FRAME_LINE_HEIGHT
+ directly, then call compute_fringe_widths. Don't call
+ frame_update_line_height.
+
+ * macfns.c: Make (several) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (x_real_positions): Set f->x_pixels_diff and f->y_pixels_diff to 0.
+
+ * macmenu.c: Make (few) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+
+ * msdos.h (struct x_output): Remove members left_pos, top_pos,
+ and line_height, and use corresponding new members in struct
+ frame. All uses changed.
+ (FRAME_LINE_HEIGHT, FRAME_INTERNAL_BORDER_WIDTH): Remove macros;
+ superseeded by corresponding macros in frame.h.
+
+ * msdos.c: Make (several) trivial substitutions for renamed and
+ new macros in dispextern.h, frame.h and window.h.
+ (IT_note_mouse_highlight): Use updated window coordinates returned
+ by window_from_coordinates, rather than adjusting them locally.
+ (internal_terminal_init): No need to initialize line_height here;
+ it now defaults to 1.
+
+2003-05-24 Stefan Monnier <[email protected]>
+
+ * keyboard.c (read_key_sequence): Adjust fkey and keytran when
+ dropping `down' events.
+
+2003-05-24 Andreas Schwab <[email protected]>
+
+ * coding.c (find_safe_codings): Fix last change.
+
+2003-05-24 Istvan Marko <[email protected]> (tiny change)
+
+ * xfns.c (x_window): Fix typo from 2003-05-21 change.
+
+2003-05-23 Stefan Monnier <[email protected]>
+
+ * xdisp.c (display_mode_element): Increase max depth.
+ Simplify the error handling code. Use a different error string
+ for the case where we hit the depth limit.
+
+ * lisp.h (Vfundamental_mode_abbrev_table): Don't declare.
+
+ * buffer.c (reset_buffer_local_variables): Remove redundant setting.
+
+2003-05-21 Stefan Monnier <[email protected]>
+
+ * intervals.c (get_local_map): Don't get char-property of previous
+ point any more: get_pos_property already does it and better.
+
+2003-05-21 Dave Love <[email protected]>
+
+ [Merged from unicode branch.]
+
+ * xfns.c (x_window, x_window): Use use_xim.
+
+ * xterm.c (use_xim): Initialize.
+ (xim_open_dpy, xim_initialize, xim_close_dpy): Use use_xim.
+ (x_term_init): Maybe set use_xim.
+
+ * xterm.h (use_xim) [HAVE_X_I18N]: Declare.
+
+2003-05-21 Jason Rumney <[email protected]>
+
+ * unexw32.c (_start): Remove _fmode initialization.
+
+ * emacs.c (main) [WINDOWSNT]: Move it here.
+
+2003-05-20 Dave Love <[email protected]>
+
+ * s/gnu-linux.h (MAIL_USE_FLOCK): Make it conditional.
+
+2003-05-19 Richard M. Stallman <[email protected]>
+
+ * xfaces.c (Finternal_set_lisp_face_attribute): Handle Qunspecified
+ as value for QCfont attribute.
+ (realize_default_face): lface should already exist; crash if not.
+ Specify 0 for FORCE_P when calling set_lface_from_font_name.
+
+ * frame.c (Fignore_event): Doc fix.
+
+2003-05-19 Kenichi Handa <[email protected]>
+
+ * coding.c (decode_coding_string): Handle post-read-conversion
+ even if the coding doesn't require decoding.
+
+2003-05-18 Richard M. Stallman <[email protected]>
+
+ * callproc.c (Fcall_process_region): Doc fix.
+
+2003-05-17 Stefan Monnier <[email protected]>
+
+ * lread.c (Fload): Print a message if package is obsolete.
+
+ * window.c (Fselect_window): Add optional `norecord' arg.
+ (select_window_1): Fold into Fselect_window.
+ (select_window_norecord): New function.
+ (temp_output_buffer_show): Use it. Preserve current buffer.
+
+ * window.h (Fselect_window): Update declaration.
+
+ * window.c (delete_window, Fother_window, Fset_window_configuration):
+ * minibuf.c (read_minibuf):
+ * macterm.c (x_new_focus_frame):
+ * frame.c (do_switch_frame, Fset_frame_selected_window, Fdelete_frame):
+ * callint.c (Fcall_interactively):
+ * xterm.c (x_new_focus_frame): Pass nil as new arg to Fselect_window.
+
+ * buffer.c (Fpop_to_buffer): Pass norecord to Fselect_window.
+
+2003-05-17 David Kastrup <[email protected]>
+
+ * process.c (read_process_output): Back out change from 2003-03-09.
+
+2003-05-17 Stefan Monnier <[email protected]>
+
+ * editfns.c (get_pos_property): Don't assume that `object' = nil.
+
+ * textprop.c (text_property_stickiness): New arg `buffer'.
+
+ * intervals.h (text_property_stickiness): New arg `buffer'.
+ (get_pos_property): Declare.
+
+ * intervals.c (get_local_map): Use get_pos_property, to obey
+ stickiness and empty overlays.
+ (create_root_interval, graft_intervals_into_buffer): Use BEG.
+ (merge_properties, intervals_equal, merge_properties_sticky):
+ Use XCAR, XCDR.
+ (adjust_for_invis_intang): Pass new arg to text_property_stickiness.
+
+2003-05-17 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (read_minibuf): If buffer is empty, record the default
+ in the history.
+ (Fminibuffer_complete_word): When deleting the overlap, take account
+ of its real position.
+
+ * fns.c (map_char_table): Fix previous change.
+
+ * syntax.c (find_defun_start):
+ When open_paren_in_column_0_is_defun_start,
+ return beginning of buffer.
+
+ * lisp.h (map_char_table): Declare added arg.
+
+ * fns.c (map_char_table): New arg TABLE gets the master table.
+ All calls changed.
+ Process default and inheritance, resorting to Faref if necessary.
+
+ * keymap.c (Fset_keymap_parent, map_keymap, Fcopy_keymap)
+ (Faccessible_keymaps): Pass new arg to map_char_table.
+
+ * fontset.c (Ffontset_info): Pass new arg to map_char_table.
+
+ * casetab.c (set_case_table): Pass new arg to map_char_table.
+
+ * data.c (let_shadows_buffer_binding_p): Make target of p volatile.
+
+ * lisp.h (specbinding_func): New typedef.
+ (struct specbinding): Use specbinding_func, to put the `volatile'
+ in the right place.
+
+ * alloc.c (Fgarbage_collect): Cast pointers into specpdl
+ to avoid GCC warning.
+
+2003-05-16 Ralph Schleicher <[email protected]>
+
+ * fileio.c (Fdelete_file): Handle symlinks pointing to directories.
+
+2003-05-15 Stefan Monnier <[email protected]>
+
+ * keyboard.c (apply_modifiers): Don't fill the other cache.
+
+2003-05-14 Stefan Monnier <[email protected]>
+
+ * .gdbinit-union: New file, for USE_LISP_UNION_TYPE users.
+
+ * window.h (Qwindowp, Qwindow_live_p, Vwindow_list)
+ (Fwindow_end, Fselected_window, Fdelete_window, Fwindow_buffer)
+ (Fget_buffer_window, Fsave_window_excursion, Fsplit_window)
+ (Fset_window_configuration, Fcurrent_window_configuration)
+ (compare_window_configurations, Fcoordinates_in_window_p, Fwindow_at)
+ (Fpos_visible_in_window_p, mark_window_cursors_off)
+ (window_internal_height, window_internal_width, Frecenter)
+ (Fscroll_other_window, Fset_window_start, temp_output_buffer_show)
+ (replace_buffer_in_all_windows, init_window_once, init_window)
+ (syms_of_window, keys_of_window): Move from lisp.h.
+ * lisp.h: Move window.c declarations to window.h.
+
+ * bytecode.c: Include window.h.
+ * emacs.c: Include window.h.
+
+ * keyboard.c (make_lispy_event): Apply modifiers to multibyte-char key.
+ (keyremap): Add `parent' field.
+ (keyremap_step): Use it. Remove `parent' argument.
+ (read_key_sequence): Setup and use the new `parent' field.
+
+2003-05-11 Stefan Monnier <[email protected]>
+
+ * keyboard.c (adjust_point_for_property): Ensure termination.
+
+2003-05-10 Stefan Monnier <[email protected]>
+
+ * keyboard.c (follow_key): Remove dead variable `did_meta'.
+ (access_keymap_keyremap, keyremap_step): New funs, extracted from the
+ duplicated handling of function-key-map and key-translation-map
+ in read_key_sequence.
+ (read_key_sequence): Use them.
+
+ * keyboard.c (adjust_point_for_property): Try harder to move point
+ to the non-sticky end of an invisible property.
+
+ * xdisp.c (single_display_prop_intangible_p): Make `space' display
+ property intangible as well.
+
+2003-05-10 Andreas Schwab <[email protected]>
+
+ * xmenu.c (single_menu_item): Change last parameter to void* to
+ avoid warning.
+
+2003-05-09 Richard M. Stallman <[email protected]>
+
+ * print.c (Fprin1_to_string): Instead of gcpro, set abort_on_gc.
+ Bind Qinhibit_modification_hooks to t so there will be no GC.
+ Rename local `tem' to `save_deactivate_mark'.
+
+ * eval.c (specpdl_ptr): Declare volatile.
+ (unbind_to): Copy the whole binding and decrement specpdl_ptr
+ before doing the work of unbinding it.
+
+ * lisp.h (struct specbinding): Declare elements volatile.
+ (specpdl_ptr): Declare volatile.
+
+ * Makefile.in (alloca.o): Specify -DDO_BLOCK_INPUT in compiling.
+
+ * alloca.c: Test DO_BLOCK_INPUT rather than `emacs'
+ for use of BLOCK_INPUT and inclusion of lisp.h and blockinput.h.
+
+2003-05-08 Dave Love <[email protected]>
+
+ * coding.c (Vlast_coding_system_used): Doc fix.
+
+2003-05-07 Jason Rumney <[email protected]>
+
+ * fileio.c (Ffile_symlink_p): Let handlers handle symlinks even
+ when system does not support them.
+
+2003-05-05 Stefan Monnier <[email protected]>
+
+ * fileio.c (Qwrite_region_annotate_functions): New var.
+ (build_annotations): Use it to process the global part of the hook.
+ (syms_of_fileio): Init and staticpro it.
+
+ * keyboard.c (safe_run_hooks_error): Display a message instead of
+ silently ignoring the error.
+
+2003-05-03 Stefan Monnier <[email protected]>
+
+ * keyboard.c (input_available_signal): Mark static.
+ (menu_bar_items): Use map_keymap.
+ (menu_bar_one_keymap): Remove.
+ (menu_bar_item): Adjust arglist (for use in map_keymap).
+ Properly hide a second binding when not both are keymaps.
+
+ * xmenu.c (struct skp): New struct, to pass args through map_keymap.
+ (single_keymap_panes): Use it and map_keymap.
+ (single_menu_item): Use skp as well.
+
+ * keymap.h (map_keymap_function_t): New type.
+ (map_keymap): Declare.
+
+ * keymap.c (map_keymap_item, map_keymap_char_table_item, map_keymap)
+ (map_keymap_call, Fmap_keymap): New functions.
+ (syms_of_keymap): Defsubr map-keymap.
+
+2003-05-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (create_dialog, make_widget_for_menu_item)
+ (make_menu_item, create_menus, xg_update_menu_item): Don't call
+ ..._with_mnemonic functions for menu items.
+
+2003-05-01 Kenichi Handa <[email protected]>
+
+ * coding.c (coding_system_accept_latin_extra_p): Delete this
+ function.
+ (find_safe_codings): Pay attention to
+ the property tranlsation-table-for-encode of each codings.
+ (syms_of_coding): Give Qtranslation_table the extra slot number 2.
+
+2003-05-01 Stefan Monnier <[email protected]>
+
+ * eval.c (Funwind_protect): Use func=Fprogn rather than symbol=Qnil.
+
+2003-04-30 Stefan Monnier <[email protected]>
+
+ * eval.c (unbind_to): Don't handle symbol = Qnil any more.
+
+ * lisp.h (CHECK): Wrap args in parenthesis.
+ (specbind): Fix doc: symbol = Qnil is not supported any more.
+
+ * bytecode.c (Fbyte_code) <unwind-protect>:
+ Use Fprogn rather than 0 and Qnil.
+
+ * keyboard.c (parse_modifiers_uncached): Parse `down', `drag',
+ `double', and `triple' modifiers as well.
+
+2003-04-30 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (echo_char): Don't clear out a dash that follows a space.
+
+ * alloc.c (abort_on_gc): New variable.
+ (Fgarbage_collect): Abort if abort_on_gc is set.
+
+ * lisp.h (abort_on_gc): Add decl.
+
+ * eval.c (Fsignal): Clear abort_on_gc.
+
+ * editfns.c (Fformat): Set abort_on_gc during first scan of format.
+ Reinit FORMAT_START and END before second scan.
+
+ * xdisp.c (move_it_vertically_backward): Do the final big else
+ even if nlines is 0.
+
+ * xdisp.c (redisplay_internal): Finish the per-frame loop
+ even if redisplay is suspended by input.
+
+2003-04-24 Andrew Choi <[email protected]>
+
+ * macterm.c (x_list_fonts): Return all fonts that match if
+ maxnames = -1.
+
+2003-04-25 Kenichi Handa <[email protected]>
+
+ * syntax.c (skip_chars): Fix previous change.
+
+2003-04-24 Kenichi Handa <[email protected]>
+
+ * syntax.c (skip_chars): Make the code faster by using the common
+ technique of *p, *stop, and *endp.
+
+2003-04-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * xdisp.c (update_tool_bar): BLOCK_INPUT before calling
+ tool_bar_items so GTK tool bar expose callback does not access items
+ being updated.
+
+2003-04-19 Stefan Monnier <[email protected]>
+
+ * eval.c (Fapply): Undo last change and add a comment about why.
+
+2003-04-18 Miles Bader <[email protected]>
+
+ * data.c (Faset): Calculate nbytes earlier, to satisfy the now
+ pickier PARSE_MULTIBYTE_SEQ.
+
+2003-04-17 Stefan Monnier <[email protected]>
+
+ * eval.c (For, Fand, Fprogn, un_autoload, do_autoload):
+ Use XCDR, XCAR, CONSP.
+ (Fdefmacro): Fix docstring. Use XCAR, XCDR.
+ (Fapply): Remove unnecessary GCPRO.
+
+ * doc.c (Fsubstitute_command_keys): Remove spurious casts.
+
+ * charset.h (PARSE_MULTIBYTE_SEQ): Pretend `length' is used.
+
+ * buffer.h: Don't hardcode BEG==1.
+
+ * abbrev.c (Fdefine_abbrev_table): Use XCAR, XCDR.
+
+2003-04-16 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (try_window, try_window_reusing_current_matrix):
+ When at end of window, set window_end_pos to Z-ZV.
+
+ * buffer.c (Foverlay_recenter): Doc fix.
+
+2003-04-14 Stefan Monnier <[email protected]>
+
+ * dispnew.c (Fsit_For): Support XEmacs-style arg list.
+
+2003-04-14 Andrew Choi <[email protected]>
+
+ * macterm.c (mac_check_for_quit_char): Don't check more often than
+ once a second.
+
+2003-04-11 Stefan Monnier <[email protected]>
+
+ * keyboard.c (kbd_buffer_get_event): Don't handle SELECT_WINDOW_EVENT
+ specially, so that they can't hide an implicit switch-frame event.
+ (make_lispy_event): Handle SELECT_WINDOW_EVENT.
+ (head_table): Use switch-frame as event_kind for select-window.
+ (keys_of_keyboard): Don't bind [select-window] in special-event-map.
+
+ * editfns.c (Fformat): Lisp_Object/int mixup.
+ (format2): Remove unused var numargs.
+
+2003-04-11 Kenichi Handa <[email protected]>
+
+ * fileio.c (Vafter_insert_file_adjust_coding_function): Delete.
+ (Qafter_insert_file_set_coding): New variable.
+ (syms_of_fileio): Initialize and staticpro it. Delete declaration
+ for after-insert-file-adjust-coding-function.
+ (Finsert_file_contents): Call Qafter_insert_file_set_coding
+ instead of Vafter_insert_file_adjust_coding_function.
+
+2003-04-11 Kenichi Handa <[email protected]>
+
+ * lisp.h (temp_echo_area_glyphs): Adjust prototype.
+
+ * minibuf.c (temp_echo_area_glyphs): Change the arg to Lisp
+ string. Callers changed.
+
+2003-04-10 Kenichi Handa <[email protected]>
+
+ * fileio.c (Vafter_insert_file_adjust_coding_function): New variable.
+ (syms_of_fileio): Declare it as a lisp variable.
+ (Finsert_file_contents):
+ Call Vafter_insert_file_adjust_coding_function before calling
+ decode-format.
+
+2003-04-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (xg_scroll_callback): Call gtk_range_get_adjustment to
+ get GtkAdjustment as widget now is a GtkRange.
+
+ * gtkutil.c (xg_create_scroll_bar): Connect to value-changed on
+ GtkRange to avoid memory leak.
+
+2003-04-09 Kenichi Handa <[email protected]>
+
+ * xfaces.c (Vface_font_rescale_alist): New variable.
+ (struct font_name): New member rescale_ratio.
+ (font_rescale_ratio): New function.
+ (split_font_name): If NUMERIC_P is nonzero, set font->rescale_ratio.
+ (better_font_p): On comparing point sized, pay attention to
+ recale_ratio member of fonts.
+ (build_scalable_font_name): Reflect font->rescale_ratio in the
+ font name.
+ (syms_of_xfaces): Declare Vface_font_rescale_alist as a Lisp variable.
+
+ * lread.c (read1): Before calling index, check if the 2nd
+ arguemnt is in ASCII range.
+
+2003-04-08 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Ffile_symlink_p): Doc fix.
+
+ * editfns.c (Fformat): Translate positions of text properties
+ in the format string to apply them to the result.
+
+ * fileio.c (Finsert_file_contents): Doc fix.
+ (syms_of_fileio) <after-insert-file-functions>: Doc fix.
+
+2003-04-08 Ivan Zakharyaschev <[email protected]> (tiny change)
+
+ * lread.c (openp): Get the Qfile_exists_p handler for STRING, not FN.
+
+2003-04-08 Steven Tamm <[email protected]>
+
+ * mac.c (init_mac_osx_environment): Switch libexec and bin so
+ that self-contained application finds libexec files.
+
+2003-04-08 Kenichi Handa <[email protected]>
+
+ * coding.c (code_convert_region_unwind):
+ Set Vlast_coding_system_used to the argument.
+ (code_convert_region): If post-read-conversion function changed
+ the value of last-coding-sytem, keep the new value in
+ coding->symbol so that it won't be overridden.
+ (run_pre_post_conversion_on_str): Likewise.
+ (coding_system_accept_latin_extra_p): New function.
+ (find_safe_codings): Pay attention to characters registered in
+ latin-extra-code-table.
+
+2003-04-07 Thien-Thi Nguyen <[email protected]>
+
+ * Makefile.in (md5.o): Add missing dependency info.
+
+2003-04-06 Richard M. Stallman <[email protected]>
+
+ * xselect.c (x_handle_selection_request): Move UNGCPRO to very end.
+
+ * marker.c (verify_bytepos): New function.
+
+ * intervals.c (set_intervals_multibyte_1): When becoming
+ multibyte, adjust right and left child sizes to a whole set of
+ characters. If an interval gets zero total-length, delete it.
+ If an interval consists of just its children, delete one of them.
+
+ * intervals.h (CHECK_TOTAL_LENGTH): New macro.
+ * intervals.c: Add many calls to CHECK_TOTAL_LENGTH.
+
+ * alloc.c (VALIDATE_LISP_STORAGE): Macro deleted.
+ All calls deleted.
+ (lisp_malloc): Do the work here directly.
+
+2003-04-06 Gareth Jones <[email protected]> (tiny change)
+
+ * fns.c (Flength): Return SUB_CHAR_TABLE_ORDINARY_SLOTS for sub
+ char tables.
+
+2003-04-04 Kenichi Handa <[email protected]>
+
+ * editfns.c (Fformat): Use a copy of FORMAT string so that we can
+ destructively change "%S" to "%s".
+
+2003-04-03 Miles Bader <[email protected]>
+
+ * xfaces.c (choose_face_font): Make sure *NEEDS_OVERSTRIKE is
+ always set.
+
+2003-04-01 Dave Love <[email protected]>
+
+ * xfns.c (xpm_lookup_color): Grok "opaque".
+
+2003-03-31 Andrew Choi <[email protected]>
+
+ * frame.c (x_report_frame_params) [HAVE_CARBON]: Do not report
+ parent window ID.
+
+ * macfns.c (syms_of_macfns): Remove call to init_x_parm_symbols.
+
+ * macterm.h (struct mac_output): Define x_pixels_diff and
+ y_pixels_diff.
+
+2003-03-31 Juanma Barranquero <[email protected]>
+
+ * makefile.w32-in ($(BLD)/frame.$(O)): Add dependency on
+ blockinput.h and files included from it.
+
+2003-03-31 Kim F. Storm <[email protected]>
+
+ The following changes consolidates the common code related to
+ frame-parameter handling from the xfns.c, w32fns.c, and macfns.c
+ files into frame.c.
+
+ * frame.c: Include blockinput.h.
+ (Vx_resource_name, Vx_resource_class, Qx_frame_parameter)
+ (Qx_resource_name, Qface_set_after_frame_default): Define vars here.
+ (Qauto_raise, Qauto_lower, ...): Define all frame parameter
+ related vars here.
+ (struct frame_parm_table, frame_parms): New table for describing
+ frame parameters and their associated Q-variable.
+ The order of the parameters corresponds to the sequence of the
+ frame_parm_handlers table in redisplay_interface.
+ (x_fullscreen_move, x_set_frame_parameters)
+ (x_report_frame_params, x_set_fullscreen, x_set_line_spacing)
+ (x_set_screen_gamma, x_set_font, x_set_fringe_width)
+ (x_set_border_width, x_set_internal_border_width, x_set_visibility)
+ (x_set_autoraise, x_set_autolower, x_set_unsplittable)
+ (x_set_vertical_scroll_bars, x_set_scroll_bar_width, x_icon_type):
+ Generic functions for processing of frame parameters.
+ (validate_x_resource_name, xrdb_get_resource, Fx_get_resource)
+ (display_x_get_resource, x_get_resource_string): Functions for
+ generic access to X resources.
+ (x_get_arg, x_frame_get_arg, x_frame_get_and_record_arg)
+ (x_default_parameter, Fx_parse_geometry): Functions for generic
+ access to frame parameters.
+ (x_figure_window_size): Generic calculation of frame size.
+ Fixed to add space needed for tool bar. Also setup size_hint_flags.
+ (syms_of_frame): Intern and staticpro frame parameter variables.
+ Defvar_lisp Vx_resource_class and Vx_resource_name here.
+ Defsubr Sx_get_resource and Sx_parse_geometry.
+
+ * frame.h (Qauto_raise, Qauto_lower, ...): Declare extern all frame
+ parameter related vars defined in frame.c.
+ (EMACS_CLASS): Define here.
+ (enum FULLSCREEN_*): Define here.
+ (x_set_scroll_bar_default_width, x_wm_set_icon_position)
+ (x_set_offset, x_new_font, x_new_fontset): Add prototypes.
+ (x_fullscreen_adjust, x_set_frame_parameters, x_report_frame_params)
+ (x_set_fullscreen, x_set_line_spacing, x_set_screen_gamma, x_set_font)
+ (x_set_fringe_width, x_set_border_width, x_set_internal_border_width)
+ (x_set_visibility, x_set_autoraise, x_set_autolower)
+ (x_set_unsplittable, x_set_vertical_scroll_bars)
+ (x_set_scroll_bar_width, x_icon_type, validate_x_resource_name)
+ (x_figure_window_size): Add prototypes.
+
+ * dispextern.h (frame_parm_handler): New typedef.
+ (struct redisplay_interface): New member frame_parm_handlers.
+ (enum resource_types): Move declaration here.
+ (x_get_arg, x_frame_get_arg, x_frame_get_and_record_arg)
+ (x_default_parameter): Add prototypes.
+
+ * window.c: Remove extern decl for frame parameter vars.
+ (change_window_heights): New generic function;
+ replaces x_change_window_heights. All users changed.
+
+ * window.h (change_window_heights): Add prototype.
+
+ * xfaces.c: Remove extern decl for frame parameter vars.
+
+ * xterm.h (EMACS_CLASS): Remove. Use generic define.
+ (struct w32_display_info): Fix type of xrdb member.
+ (enum FULLSCREEN_*): Remove.
+ Remove prototypes for generic functions (in frame.h).
+
+ * xfns.c (Qauto_raise, Qauto_lower, ...): Remove vars for frame
+ parameters now defined in frame.h and frame.c.
+ (Vx_resource_name): Remove. Use generic var.
+ (enum x_frame_parms): Remove (bogus, unused enum).
+ (check_x_display_info): Make non-static (for frame.c).
+ (struct x_frame_parm_table, x_frame_parms): Remove.
+ (init_x_parm_symbols, x_set_frame_parameters, x_report_frame_params)
+ (x_set_line_spacing, x_set_screen_gamma, x_icon_type, x_set_font)
+ (x_set_border_width, x_set_internal_border_width, x_set_visibility)
+ (x_change_window_heights, x_set_autoraise, x_set_autolower)
+ (x_set_vertical_scroll_bars, x_set_scroll_bar_width)
+ (validate_x_resource_name, Fx_get_resource, x_get_resource_string)
+ (x_default_parameter, Fx_parse_geometry, x_figure_window_size):
+ Remove. Use generic functions instead.
+ (enum resource_types): Remove.
+ (x_set_scroll_bar_default_width): New global function (for frame.c).
+ (Fx_create_frame): Depend on x_figure_window_size to add space for
+ toolbar and setup size_hint_flags.
+ (x_frame_parm_handlers): New table for redisplay_interface.
+ (syms_of_xfns): Don't intern/staticpro removed vars.
+
+ * xterm.c: Remove unnecessary extern declarations.
+ (x_fullscreen_adjust): Remove. Use generic instead.
+ (x_redisplay_interface): Add x_frame_parm_handlers member.
+
+ * w32gui.h (XrmDatabase): New (dummy) typedef.
+
+ * w32term.h (EMACS_CLASS): Remove. Use generic define.
+ (struct w32_display_info): Fix type of xrdb member.
+ (enum FULLSCREEN_*): Remove.
+ (x_fullscreen_adjust): Remove prototype.
+
+ * w32fns.c (Qauto_raise, Qauto_lower, ...): Remove vars for frame
+ parameters now defined in frame.h and frame.c.
+ (Vx_resource_name): Remove. Use generic var.
+ (enum x_frame_parms): Remove (bogus, unused enum).
+ (check_x_display_info): Make non-static (for frame.c).
+ (struct x_frame_parm_table, x_frame_parms): Remove.
+ (init_x_parm_symbols, x_set_frame_parameters, x_report_frame_params)
+ (x_set_line_spacing, x_set_screen_gamma, x_icon_type, x_set_font)
+ (x_set_border_width, x_set_internal_border_width, x_set_visibility)
+ (x_change_window_heights, x_set_autoraise, x_set_autolower)
+ (x_set_vertical_scroll_bars, x_set_scroll_bar_width)
+ (validate_x_resource_name, Fx_get_resource, x_get_resource_string)
+ (x_default_parameter, Fx_parse_geometry, x_figure_window_size):
+ Remove. Use generic functions instead.
+ (enum resource_types): Remove.
+ (x_set_scroll_bar_default_width): New global function (for frame.c).
+ (Fx_create_frame): Depend on x_figure_window_size to add space for
+ toolbar and setup size_hint_flags.
+ (w32_frame_parm_handlers): New table for redisplay_interface.
+ (syms_of_w32fns): Don't intern/staticpro removed vars.
+
+ * w32term.c: Remove unnecessary extern declarations.
+ (x_fullscreen_adjust): Remove. Use generic instead.
+ (x_redisplay_interface): Add w32_frame_parm_handlers member.
+
+ * w32reg.c (x_get_string_resource): Use XrmDatabase.
+
+ * macgui.h (XrmDatabase): New (dummy) typedef.
+
+ * macterm.h (EMACS_CLASS): Remove.
+ (struct mac_display_info): Add xrdb member.
+ (struct mac_output): Add want_fullscreen member.
+
+ * macfns.c (Qauto_raise, Qauto_lower, ...): Remove vars for frame
+ parameters now defined in frame.h and frame.c.
+ (Vx_resource_name): Remove. Use generic var.
+ (check_x_display_info): Make non-static (for frame.c).
+ (struct x_frame_parm_table, x_frame_parms): Remove.
+ (init_x_parm_symbols, x_set_frame_parameters, x_report_frame_params)
+ (x_set_line_spacing, x_set_screen_gamma, x_icon_type, x_set_font)
+ (x_set_border_width, x_set_internal_border_width, x_set_visibility)
+ (x_change_window_heights, x_set_autoraise, x_set_autolower)
+ (x_set_vertical_scroll_bars, x_set_scroll_bar_width)
+ (validate_x_resource_name, Fx_get_resource, x_get_resource_string)
+ (x_default_parameter, Fx_parse_geometry, x_figure_window_size):
+ Remove. Use generic functions instead.
+ (enum resource_types): Remove.
+ (x_set_scroll_bar_default_width): New global function (for frame.c).
+ (mac_frame_parm_handlers): New table for redisplay_interface.
+ (syms_of_macfns): Don't intern/staticpro removed vars.
+
+ * macterm.c: Remove unnecessary extern declarations.
+ (x_redisplay_interface): Add mac_frame_parm_handlers member.
+
+ * Makefile.in (frame.o): Add dependency on blockinput.h and files
+ included from it (atimer.h and systime.h).
+
+2003-03-30 Andreas Schwab <[email protected]>
+
+ * xdisp.c (x_insert_glyphs): Fix swapped width and height
+ parameters for shift_glyphs_for_insert.
+
+ * macterm.c (x_redisplay_interface): Add missing entry for
+ draw_vertical_window_border.
+
+2003-03-29 Kai Gro,A_(Bjohann <[email protected]>
+
+ * fileio.c (Fexpand_file_name): In the no-handler case, after
+ expanding, look again for a handler and invoke it. This is needed
+ for filenames like "/foo/../user@host:/bar/../baz" -- the first
+ expansion produces "/user@host:/bar/../baz" which needs to be
+ expanded again for the finame result "/user@host:/baz".
+
+2003-03-28 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_tool_bar_item_expose_callback): Reduce size
+ of area to be redrawn for better performance.
+
+2003-03-28 Stefan Monnier <[email protected]>
+
+ * xterm.c (take_vertical_position_into_account): Remove.
+ (xt_action_hook): Call set_vertical_scroll_bar if needed.
+ (XM_SB_MIN, XM_SB_RANGE): Remove (min is now set to 0).
+ (xm_scroll_callback, x_create_toolkit_scroll_bar)
+ (x_set_toolkit_scroll_bar_thumb): Simplify.
+ (x_scroll_bar_expose): Only compile if !USE_TOOLKIT_SCROLL_BARS.
+ (XTread_socket): Remove unused var.
+ (x_make_frame_invisible): Replace goto with else.
+
+ * xdisp.c (set_vertical_scroll_bar): New fun.
+ (redisplay_window): Use it.
+
+2003-03-26 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (update_tool_bar): Recompute tool bar if
+ update_mode_lines is set. Set w->update_mode_line
+ only if the tool bar contents actually change.
+ (update_menu_bar): Undo previous change.
+
+2003-03-26 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_resize_widgets): Don't call xg_frame_cleared.
+ (xg_frame_set_char_size): Calculate scroll bar width before frame
+ width. Call SET_FRAME_GARBAGED and cancel_mouse_face.
+ (xg_separator_p): Check for all documented separator types.
+ (xg_update_scrollbar_pos): Variable gheight not needed, use height.
+ (update_frame_tool_bar): Don't call gdk_window_process_all_updates.
+
+ * xdisp.c (update_menu_bar): Set w->update_mode_line to Qt
+ so tool bar gets updated.
+
+2003-03-26 Stefan Monnier <[email protected]>
+
+ * data.c (store_symval_forwarding): Re-instate part of the code
+ that was deleted with too much enthusiasm.
+
+2003-03-25 Stefan Monnier <[email protected]>
+
+ * data.c (store_symval_forwarding): Delete special read-only
+ hack for type == -1, since we now use ->constant instead.
+ (Fkill_local_variable): Don't use XBUFFER if it can be nil.
+
+ * buffer.c (overlays_in): Declare static.
+ (syms_of_buffer) <enable-multibyte-characters>: Use the symbol's
+ `constant' field rather than the variable's `type' field.
+
+2003-03-24 Andrew Choi <[email protected]>
+
+ * config.in [MAC_OSX]: Do not redefine bcopy, bzero, and bcmp.
+
+ * dispextern.h [HAVE_CARBON]: Include Carbon.h.
+
+ * fns.c [MAC_OSX]: Do not redefine vector.
+
+ * keyboard.c [MAC_OSX]: Handle SIGINT with interrupt_signal.
+
+ * macgui.h: Remove definition of No_Cursor.
+
+ * macterm.h: Include Carbon.h. Replace (struct Cursor *) by Cursor.
+
+ * xdisp.c: Define No_Cursor.
+ (x_write_glyphs, notice_overwritten_cursor)
+ (draw_phys_cursor_glyph, note_mode_line_or_margin_highlight)
+ (note_mouse_highlight): Remove Mac-specific code.
+ (note_mouse_highlight): Use bcmp instead of == to compare Cursors.
+
+2003-03-24 John Paul Wallington <[email protected]>
+
+ * xdisp.c (redisplay_window): If mini window's buffer is not
+ empty, then redisplay it like other windows.
+
+2003-03-23 Kim F. Storm <[email protected]>
+
+ * w32term.c (w32_draw_window_cursor): Fix last change.
+
+2003-03-23 Kenichi Handa <[email protected]>
+
+ * alloc.c (make_string_from_bytes, make_specified_string):
+ Add `const' for the arg CONTENTS.
+
+ * lisp.h (make_string_from_bytes, make_specified_string):
+ Prototypes adjusted.
+
+2003-03-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * xdisp.c (get_glyph_string_clip_rect): Remove ; at end of #endif.
+
+ * gtkutil.h: Take two more arguments to xg_update_scrollbar_pos.
+ (XG_SB_RANGE): New define.
+
+ * gtkutil.c (xg_fixed_handle_expose): New function.
+ (xg_create_frame_widgets): Call xg_fixed_handle_expose for
+ expose events.
+ (xg_update_scrollbar_pos): Take two more arguments, left and width
+ of scroll bar including borders.
+ Clear left and right part outside scroll bar separately as some
+ themes have bars that are not an even number of pixels.
+ Don't set reallocate_redraws, don't call
+ gdk_window_process_all_updates.
+ (xg_set_toolkit_scroll_bar_thumb): Upper value is fixed,
+ so no need to change it. Calculate size and value with XG_SB_RANGE.
+
+ * xterm.c (x_scroll_bar_create, XTset_vertical_scroll_bar):
+ Pass left and width of scroll bar including borders to
+ xg_update_scrollbar_pos.
+
+2003-03-22 Thien-Thi Nguyen <[email protected]>
+
+ * Makefile.in: Make sure space precedes end-of-line backslashes.
+
+2003-03-22 Kim F. Storm <[email protected]>
+
+ * xdisp.c (pixel_to_glyph_coords, glyph_to_pixel_coords):
+ Add generic versions here. Remove system specific versions
+ defined elsewhere.
+
+ * dispextern.h (pixel_to_glyph_coords, glyph_to_pixel_coords):
+ Add prototypes.
+
+ * xterm.h (STORE_NATIVE_RECT): New macro.
+
+2003-03-21 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_glyph_string_clip_rect):
+ Use FRAME_INTERNAL_BORDER_WIDTH.
+
+ * dispextern.h (struct redisplay_interface): Add active_p
+ argument to draw_window_cursor member. All uses changed.
+
+2003-03-21 Kim F. Storm <[email protected]>
+
+ The following changes consolidate code related to writing and
+ inserting glyphs, exposing frame, the tool bar, the mouse face,
+ the output cursor, and help echo from xterm.c, w32term.c and
+ macterm.c into xdisp.c. It also generalizes the use of the
+ window_part enum instead of using numeric values throughout.
+
+ * xdisp.c: Consolidate gui-independent code here.
+ Include keymap.h.
+ (Qhelp_echo): Import.
+ (mouse_autoselect_window, x_stretch_cursor_p): Declare here.
+ (help_echo_string, help_echo_window, help_echo_object)
+ (previous_help_echo_string, help_echo_pos): Declare here.
+ (output_cursor, last_mouse_frame, last_tool_bar_item): Declare here.
+ (estimate_mode_line_height): Define here. Handle windowing
+ systems directly (without using estimate_mode_line_height_hook).
+ (x_y_to_hpos_vpos, get_tool_bar_item, note_tool_bar_highlight):
+ (update_window_cursor, update_cursor_in_window_tree)
+ (fast_find_position, fast_find_string_pos)
+ (note_mode_line_highlight, note_mode_line_or_margin_highlight)
+ (expose_area, expose_line, expose_overlaps, expose_window)
+ (expose_window_tree, phys_cursor_in_rect_p): New generic versions;
+ declared static as they are only used locally in xdisp.c.
+ (draw_glyphs): Rename from x_draw_glyphs and make static.
+ (tool_bar_item_info, notice_overwritten_cursor): Make static.
+ (frame_to_window_pixel_xy, get_glyph_string_clip_rect)
+ (set_output_cursor, x_cursor_to, handle_tool_bar_click)
+ (x_write_glyphs, x_insert_glyphs, x_clear_end_of_line):
+ (x_fix_overlapping_area, draw_phys_cursor_glyph, erase_phys_cursor)
+ (display_and_set_cursor, x_update_cursor, x_clear_cursor)
+ (show_mouse_face, clear_mouse_face, cursor_in_mouse_face_p)
+ (note_mouse_highlight, x_clear_window_mouse_face)
+ (cancel_mouse_face, x_draw_vertical_border, expose_frame)
+ (x_intersect_rectangles): New generic functions for use by xdisp.c
+ and GUI front-ends.
+ (syms_of_xdisp): Initialize and staticpro help_echo* variables.
+ Defvar_bool "x-streach-cursor" and "mouse-autoselect-window" here.
+
+ * dispextern.h (Display_Info): Generic typedef for *_display_info.
+ (NativeRectangle): Generic typedef for rectangle type.
+ (enum window_part): Move here from window.c.
+ (struct redisplay_interface): New members flush_display_optional,
+ define_frame_cursor, clear_frame_area, draw_window_cursor,
+ draw_vertical_window_border, shift_glyphs_for_insert.
+ Rename member clear_mouse_face to clear_window_mouse_face.
+ (estimate_mode_line_height_hook): Remove hook.
+ (auto_raise_tool_bar_buttons_p): Don't declare extern.
+ (tool_bar_item_info): Remove prototype.
+ (help_echo_string, help_echo_window, help_echo_object)
+ (previous_help_echo_string, help_echo_pos)
+ (last_mouse_frame, last_tool_bar_item, mouse_autoselect_window):
+ (x_stretch_cursor_p, output_cursor): Declare extern.
+ (x_draw_glyphs, notice_overwritten_cursor): Remove prototypes.
+ (x_write_glyphs), x_insert_glyphs, x_clear_end_of_line)
+ (x_fix_overlapping_area, draw_phys_cursor_glyph, erase_phys_cursor)
+ (display_and_set_cursor, set_output_cursor, x_cursor_to)
+ (x_update_cursor, x_clear_cursor, x_draw_vertical_border)
+ (frame_to_window_pixel_xy, get_glyph_string_clip_rect)
+ (note_mouse_highlight, x_clear_window_mouse_face, cancel_mouse_face)
+ (handle_tool_bar_click, clear_mouse_face, show_mouse_face)
+ (cursor_in_mouse_face_p, expose_frame, x_intersect_rectangles):
+ Add prototypes.
+ (mode_line_string, marginal_area_string): Fix prototypes.
+
+ * window.c (enum window_part): Move to dispextern.h.
+ (coordinates_in_window): Use enum window_part member names
+ instead of numbers to describe return value.
+ (struct check_window_data): Change part member to window_part.
+ (check_window_containing): Return window_part unaltered.
+ (window_from_coordinates): Change part arg from int to enum
+ window_part. Allow part arg to be null. All users changed.
+
+ * window.h (window_from_coordinates): Fix prototype.
+
+ * term.c (estimate_mode_line_height): Move to xdisp.c.
+
+ * keyboard.c (make_lispy_event): Use enum window_part.
+
+ * dispnew.c (mode_line_string, marginal_area_string): Use enum
+ window_part instead of int in arg list. Users changed.
+
+ * xterm.h (No_Cursor): Declare as None for X.
+ (struct mac_output): Replace member cross_cursor by hand_cursor.
+
+ * xterm.c: Remove consolidated defines and code.
+ (BETWEEN): Remove unused macro.
+ (x_draw_vertical_window_border, x_shift_glyphs_for_insert)
+ (x_define_frame_cursor, x_clear_frame_area)
+ (x_draw_window_cursor): New X-specific functions for RIF.
+ (x_redisplay_interface): Add new members.
+
+ * xfns.c: Setup and use hand_cursor instead of cross_cursor.
+
+ * w32term.h (struct w32_output): Remove cross_cursor member.
+
+ * w32term.c: Remove consolidated defines and code.
+ (BETWEEN): Remove unused macro.
+ (w32_draw_vertical_window_border, w32_shift_glyphs_for_insert)
+ (w32_define_frame_cursor, w32_clear_frame_area)
+ (w32_draw_window_cursor): New W32-specific functions for RIF.
+ (w32_redisplay_interface): Add new members.
+
+ * w32gui.h (No_Cursor): Define as 0 for W32.
+ (XRectangle): Add X compatible rectangle type.
+ (NativeRectangle): Declare as RECT for W32.
+ (CONVERT_TO_XRECT, CONVERT_FROM_XRECT, STORE_NATIVE_RECT): New macros.
+
+ * w32fns.c: Remove setup of cross_cursor (already has hand_cursor).
+
+ * w32console.c: Remove consolidated defines and code.
+
+ * msdos.h (Display_Info): Add generic typedef.
+
+ * msdos.c: Remove consolidated defines and code.
+ (IT_note_mouse_highlight, dos_rawgetc): Use enum window_part.
+
+ * macterm.h (struct mac_output): Replace member cross_cursor by
+ hand_cursor.
+ (activate_scroll_bars, deactivate_scroll_bars): Add prototypes.
+
+ * macterm.c: Remove consolidated defines and code.
+ (BETWEEN): Remove unused macro.
+ (mac_draw_vertical_window_border, mac_shift_glyphs_for_insert)
+ (mac_define_frame_cursor, mac_clear_frame_area)
+ (mac_draw_window_cursor): New Mac-specific functions for RIF.
+ (x_redisplay_interface): Add new members.
+
+ * macgui.h (No_Cursor): Define as 0 for Mac.
+ (XRectangle): Add X compatible rectangle type.
+ (NativeRectangle): Declare as Rect for Mac.
+ (CONVERT_TO_XRECT, CONVERT_FROM_XRECT, STORE_NATIVE_RECT): New macros.
+
+ * macfns.c (x_set_mouse_color): Setup hand_cursor.
+ (x_set_cursor_color): Use x_display_and_set_cursor.
+
+ * Makefile.in (xdisp.o): Add dependency on blockinput.h and files
+ included from it. Add dependency on keymap.h.
+
+ * makefile.w32-in (xdisp.o): Add dependency on keymap.h.
+
+2003-03-21 Kenichi Handa <[email protected]>
+
+ * fileio.c (Fexpand_file_name): Fix previous change.
+
+2003-03-19 Kenichi Handa <[email protected]>
+
+ * fileio.c (Ffile_name_directory): Reconstruct file name by
+ make_specified_string.
+ (Ffile_name_nondirectory, Ffile_name_as_directory)
+ (Fdirectory_file_name, Fexpand_file_name)
+ (Fsubstitute_in_file_name): Likewise.
+ (Fread_file_name): Compare decoded homedir with DIR and
+ DEFAULT_FILENAME.
+
+ * alloc.c (make_specified_string): If NCHARS is negative, count
+ the number of characters.
+
+2003-03-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_frame_cleared): Call gtk_widget_queue_draw for
+ all widgets.
+
+ * gtkutil.h: Removed xg_ignore_next_thumb.
+
+2003-03-18 Kenichi Handa <[email protected]>
+
+ * coding.c (Vchar_coding_system_table): Remove this variable.
+ (Vcoding_system_safe_chars): New variable.
+ (intersection): Remove this function.
+ (find_safe_codings): Don't use Vchar_coding_system_table, but try
+ all codings in SAFE_CODINGS.
+ (Ffind_coding_systems_region_internal): Adjust for the change of
+ find_safe_codings. Get generic coding systems from
+ Vcoding_system_safe_chars.
+ (Fdefine_coding_system_internal): New function.
+ (syms_of_coding): Defsubr Sdefine_coding_system_internal.
+ Initialize and staticpro Vcoding_system_safe_chars.
+
+2003-03-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_set_toolkit_scroll_bar_thumb): Check if new values
+ equal old values before updating.
+
+ * xterm.c (xg_scroll_callback): Remove xg_ignore_next_thumb.
+
+ * gtkutil.c (xg_initialize): Remove xg_ignore_next_thumb.
+
+2003-03-17 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c: Removed handle_fixed_child, struct xg_last_sb_pos.
+ (xg_resize_widgets): Don't call foreach(handle_fixed_child).
+ (xg_gtk_scroll_destroy): Remove free of struct xg_last_sb_pos.
+ (scroll_bar_button_cb): Set bar->dragging to nil on button release.
+ (xg_create_scroll_bar): Pass bar to button event callback.
+ (xg_find_top_left_in_fixed): New function.
+ (xg_update_scrollbar_pos): Don't call gdk_window_clear on
+ whole scroll bar area. Get old position with
+ xg_find_top_left_in_fixed, calculate and only clear needed areas.
+ (xg_set_toolkit_scroll_bar_thumb): Do not adjust scroll bar if
+ dragging is in progress. Calculate whole as for Motif.
+ Remove code that saved last values. Call gtk_range functions to
+ set scroll bar sizes.
+
+ * gtkutil.h: Removed xg_ignore_next_thumb.
+
+2003-03-17 Juanma Barranquero <[email protected]>
+
+ * makefile.w32-in ($(BLD)/xdisp.$(O)): Add dependency on blockinput.h
+ and files included from it.
+
+2003-03-18 Stefan Monnier <[email protected]>
+
+ * keymap.c (accessible_keymaps_1): Break cycles but without preventing
+ multiple occurrences of the same keymap under different prefixes.
+ (Faccessible_keymaps): Remove code redundant since 1994-08-03T07:39:[email protected].
+
+2003-03-16 Jason Rumney <[email protected]>
+
+ * w32gui.h: Use HDC for Display.
+
+ * w32term.c (w32_encode_char): Prevent double-byte chars from
+ crashing Emacs.
+
+ * w32fns.c (jpeg_load, png_load, slurp_file): Read image files
+ as binary.
+
+2003-03-16 Juanma Barranquero <[email protected]>
+
+ * xdisp.c (x_produce_glyphs): Use FRAME_BASELINE_OFFSET.
+
+2003-03-16 Kim F. Storm <[email protected]>
+
+ The following changes consolidate some of the gui-independent
+ parts of the processing and drawing of "glyph strings" from
+ xterm.c, w32term.c, and macterm.c into xdisp.c.
+
+ * dispextern.h (struct glyph): Reduce face_id member from 22 to
+ 21 bits (this reduces number of faces from 4M to 2M).
+ Replace W32 specific w32_font_type member (2 bits) by generic
+ font_type member (3 bits) for portability.
+ (FONT_TYPE_UNKNOWN): New define, default for font_type member.
+ (enum draw_glyphs_face): Define here.
+ (struct glyph_string): Define here. Merge W32 and X versions.
+ (struct redisplay_interface): New members per_char_metric,
+ encode_char, compute_glyph_string_overhangs, draw_glyph_string.
+ (VCENTER_BASELINE_OFFSET): Define here.
+ (dump_glyph_string, x_get_glyph_overhangs, x_produce_glyphs)
+ (x_draw_glyphs, notice_overwritten_cursor): Declare prototypes here.
+
+ * xdisp.c: Consolidate gui-independent "glyph string" code here.
+ (dump_glyph_string): Moved here.
+ (init_glyph_string, append_glyph_string_lists, append_glyph_string)
+ (prepend_glyph_string_lists, get_glyph_face_and_encoding)
+ (fill_composite_glyph_string, fill_glyph_string)
+ (fill_image_glyph_string, fill_stretch_glyph_string)
+ (left_overwritten, left_overwriting, right_overwritten)
+ (right_overwriting, get_char_face_and_encoding)
+ (set_glyph_string_background_width, compute_overhangs_and_x)
+ (append_glyph, append_composite_glyph, produce_image_glyph)
+ (take_vertical_position_into_account, append_stretch_glyph)
+ (produce_stretch_glyph): New generic functions (based on X version).
+ Call platform specific functions through rif.
+ (INIT_GLYPH_STRING): New macro, hides W32 details.
+ (BUILD_STRETCH_GLYPH_STRING, BUILD_IMAGE_GLYPH_STRING)
+ (BUILD_CHAR_GLYPH_STRINGS, BUILD_COMPOSITE_GLYPH_STRING)
+ (BUILD_GLYPH_STRINGS): Generic macros (based on X version).
+ (x_draw_glyphs, x_get_glyph_overhangs, x_produce_glyphs)
+ (notice_overwritten_cursor):
+ Generic functions exported to platform modules. Users changed.
+
+ * xterm.h (FONT_DESCENT, FRAME_X_OUTPUT, FRAME_BASELINE_OFFSET)
+ (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE)
+ (STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2):
+ New macros for consolidated code.
+
+ * xterm.c: Remove consolidated defines and code.
+ (x_per_char_metric, x_encode_char)
+ (x_compute_glyph_string_overhangs): Adapt to RIF requirements.
+ (x_redisplay_interface): Add new members.
+
+ * w32gui.h (Display): Add dummy typedef for consolidation.
+ (XChar2b): Define alias for wchar_t for consolidation.
+ (STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2): New macros.
+
+ * w32term.h (FRAME_X_OUTPUT, FRAME_X_WINDOW, FRAME_X_DISPLAY)
+ (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE):
+ New macros for consolidation.
+
+ * w32term.c: Remove consolidated defines and code.
+ (BUILD_WCHAR_T, BYTE1, BYTE2): Macros removed; callers changed
+ to use STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2 instead.
+ (w32_per_char_metric): Change font_type arg to int for RIF.
+ (w32_encode_char): Return int according to RIF requirements.
+ (w32_compute_glyph_string_overhangs): Adapt to RIF.
+ (w32_get_glyph_overhangs): New function for RIF. Uses generic
+ x_get_glyph_overhangs.
+ (w32_redisplay_interface): Add new members.
+
+ * macgui.h (XChar2b): Move typedef here for consolidation.
+ (STORE_XCHAR2B, XCHAR2B_BYTE1, XCHAR2B_BYTE2): New macros.
+
+ * macterm.h (FRAME_X_OUTPUT, FRAME_X_WINDOW, FRAME_X_DISPLAY):
+ (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE): New macros for
+ consolidation.
+
+ * macterm.c: Remove consolidated defines and code.
+ (mac_per_char_metric): New function for RIF.
+ (mac_encode_char): Adapt to new RIF requirements.
+ (mac_compute_glyph_string_overhangs): Adapt for RIF.
+ (x_redisplay_interface): Add new members.
+
+2003-03-15 Stefan Monnier <[email protected]>
+
+ * keymap.c (Vmenu_events): New var.
+ (syms_of_keymap): Initialize it.
+ (where_is_internal): Check more carefully what is a menu event.
+
+2003-03-14 Richard M. Stallman <[email protected]>
+
+ * lread.c (read1): After #!, exit loop on eof.
+
+2003-03-14 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.h: Add declaration for xg_frame_cleared.
+
+ * xterm.c (x_clear_frame): Call xg_frame_cleared for GTK.
+
+ * gtkutil.c (struct xg_last_sb_pos): New structure.
+ (handle_fixed_child): New function.
+ (xg_resize_widgets): Call handle_fixed_child on all scroll bar widgets
+ and force a redraw on them.
+ (xg_gtk_scroll_destroy): Free struct xg_last_sb_pos also.
+ (xg_create_scroll_bar): Add struct xg_last_sb_pos to scroll bar
+ so we can avoid unneeded redraws.
+ (xg_update_scrollbar_pos): Invalidate data in xg_last_sb_pos
+ and force a redraw on the scroll bar.
+ (xg_set_toolkit_scroll_bar_thumb): Do not change/redraw scroll bar
+ if xg_last_sb_pos shows the positions are up to date.
+ (xg_frame_cleared): New function.
+
+2003-03-13 Kenichi Handa <[email protected]>
+
+ * coding.c (Fdetect_coding_region): Fix docstring.
+ (Fdetect_coding_string): Fix docstring.
+
+2003-03-13 Andreas Schwab <[email protected]>
+
+ * gtkutil.c: Add prototype for create_menus.
+
+ * data.c (long_to_cons): Fix type of top.
+
+ * xselect.c (selection_data_to_lisp_data): Use int instead of
+ long for an integer of size 4.
+
+ * gtkutil.c (xg_update_frame_menubar): Add missing return value.
+ (xg_tool_bar_help_callback): Likewise.
+
+2003-03-12 Andreas Schwab <[email protected]>
+
+ * xterm.c (x_term_init) [USE_GTK]: Fix typo.
+
+2003-03-12 Kim F. Storm <[email protected]>
+
+ The following changes consolidate the fringe handling from
+ xterm.c, w32term.c, and macterm.c into xdisp.c.
+
+ * xdisp.c: Consolidate fringe handling code here.
+ (left_bits, right_bits, continued_bits, continuation_bits)
+ (ov_bits, zv_bits): Define fringe bitmaps.
+ (fringe_bitmaps): New array holding fringe bitmaps.
+ (draw_fringe_bitmap): Draw a specific bitmap; call display
+ specific drawing routine via rif->draw_fringe_bitmap.
+ (draw_row_fringe_bitmaps): Generic replacement for
+ x_draw_row_fringe_bitmaps; all callers changed.
+ (compute_fringe_widths): Generic replacement for
+ x_compute_fringe_widths; all callers changed.
+
+ * dispextern.h (enum fringe_bitmap_type): Define here.
+ (struct fringe_bitmap, struct draw_fringe_bitmap_params): New.
+ (fringe_bitmaps): Declare extern.
+ (struct redisplay_interface): New member draw_fringe_bitmap.
+ (draw_row_fringe_bitmaps, compute_fringe_widths): Declare extern.
+
+ * xterm.c: Remove generic fringe code.
+ (x_draw_fringe_bitmap): Only perform actual fringe drawing.
+ (x_redisplay_interface): Add x_draw_fringe_bitmap member.
+
+ * w32term.c: Remove generic fringe code.
+ (w32_draw_fringe_bitmap): Only perform actual fringe drawing.
+ (w32_redisplay_interface): Add w32_draw_fringe_bitmap member.
+
+ * macterm.c: Remove generic fringe code.
+ (x_draw_fringe_bitmap): Only perform actual fringe drawing.
+ (x_redisplay_interface): Add x_draw_fringe_bitmap member.
+
+2003-03-11 Stefan Monnier <[email protected]>
+
+ * print.c (Fprin1_to_string): Return unibyte string if possible.
+
+2003-03-09 David Kastrup <[email protected]>
+
+ * process.c (read_process_output): We have allocated enough space
+ for readmax and carryover, so actually use the alloted space.
+
+2003-03-09 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c (make_lispy_event): Extend mouse_syms if needed for
+ toolkit scrollbar click.
+
+ * xterm.c (x_window_to_scroll_bar): Call xg_get_scroll_id_for_window
+ for USE_GTK.
+ (x_scroll_bar_handle_click): Use this function for toolkit scrollbars
+ also.
+ (handle_one_xevent): ButtonPress/Release: If event is for a toolkit
+ scrollbar and control is pressed, call x_scroll_bar_handle_click.
+
+ * gtkutil.h (xg_get_scroll_id_for_window): Declare.
+
+ * gtkutil.c (xg_get_scroll_id_for_window): New function.
+ (xg_tool_bar_item_expose_callback): New function.
+ (xg_tool_bar_expose_callback): Call update_frame_tool_bar.
+ (xg_create_tool_bar): Connect xg_tool_bar_expose_callback to expose
+ on the tool bar widget.
+ (update_frame_tool_bar): Connect xg_tool_bar_item_expose_callback
+ to expose on the tool bar item widgets.
+
+2003-03-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Compare pixmap ID instead of
+ struct image* when deciding to update (struct image* may have been
+ deleted from the image cache).
+
+ * xterm.c (handle_one_xevent): Pass ReparentNotify to Xt even if
+ the event isn't for a frame (i.e. for dialogs).
+
+2003-03-07 Kenichi Handa <[email protected]>
+
+ * coding.c (CODING_ADD_COMPOSITION_COMPONENT): If the number of
+ composition components reaches the limit, terminate composing.
+ (COMPOSITION_OK): New macro.
+ (detect_coding_iso2022): Use it if an escape sequence for
+ composition is found.
+ (coding_restore_composition): Adjust the number of composition
+ components if it is not sane.
+
+2003-03-06 Juanma Barranquero <[email protected]>
+
+ * w32term.h (struct w32_display_info): Add xrdb member to support
+ passing resources via -xrm on Windows.
+
+ * w32term.c (w32_make_rdb): New function.
+ (w32_term_init): Use it to initialize xrdb member of w32_display_info
+ struct. Delete leftover code.
+
+ * w32fns.c (Fx_get_resource, x_get_resource_string): Pass xrdb to check
+ for resources passed on the command line.
+
+ * w32reg.c (w32_get_rdb_resource): New function.
+ (x_get_string_resource): Use it, so resources passed with -xrm
+ supercede the ones in the registry.
+
+2003-03-04 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_detect_focus_change): Call x_any_window_to_frame
+ instead of x_top_window_to_frame.
+
+2003-03-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * xsmfns.c (smc_save_yourself_CB): Add --no-splash to options
+ when restarting Emacs.
+
+2003-03-03 Richard M. Stallman <[email protected]>
+
+ * buffer.c (Fkill_buffer): Use Frun_hook_with_args_until_failure
+ to run kill-buffer-query-functions.
+ (Qkill_buffer_query_functions): New var.
+ (syms_of_buffer): Init and staticpro it.
+
+2003-03-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h (XSync): Define as gdk_window_process_all_updates for GTK.
+
+2003-02-25 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Fix infinite loop in redisplay.
+ If centering point failed to make whole line visible and vscroll
+ is non-zero, disable vscroll and try centering point again.
+
+ * lread.c (read1): Accept `single space' syntax like (? x).
+
+2003-02-25 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c (cancel_hourglass_unwind): Surround with
+ #ifdef HAVE_X_WINDOWS.
+
+2003-02-25 Kenichi Handa <[email protected]>
+
+ * buffer.c (Fset_buffer_multibyte): Pay attention to the buffer
+ process only when "subprocesses" is defined.
+
+2003-02-24 Stefan Monnier <[email protected]>
+
+ * syntax.c (back_comment): Only check nestedness of 2nd char if needed.
+
+2003-02-24 Juanma Barranquero <[email protected]>
+
+ * callint.c (fix_command): Declare as static void and move before
+ Fcall_interactively.
+
+ * xdisp.c (Qwhen): Declare external; it's now defined in callint.c.
+ (syms_of_xdisp): Don't initialize Qwhen.
+
+2003-02-23 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c (cancel_hourglass_unwind): New function.
+ (command_loop_1): Cancel hourglass with unwind-protect.
+
+2003-02-23 Richard M. Stallman <[email protected]>
+
+ * callint.c (fix_command): New subroutine, from Fcall_interactively.
+ Detect (when ... (region-beginning)) etc.
+ (Fcall_interactively): Call fix_command.
+ (Qif, Qwhen): New variables.
+ (syms_of_callint): Init and staticpro them.
+
+ * regex.c (print_partial_compiled_pattern): Output to stderr.
+
+2003-02-23 Kai Gro,A_(Bjohann <[email protected]>
+
+ * dired.c (directory_files_internal): Don't expand directory.
+ (Fdirectory_files, Fdirectory_files_and_attributes): Do it here
+ instead. From Lars Hansen <[email protected]>.
+
+2003-02-22 Stefan Monnier <[email protected]>
+
+ * fns.c (string_to_multibyte): Remove unused var i.
+ (Flanginfo): Fix int/Lisp_Object mixup.
+ (void_call2): New fun.
+ (Fmap_char_table): Use it in place of call2.
+
+ * xfaces.c (x_face_list_fonts): Fix int/Lisp_Object mixup.
+
+ * macros.c (Fstart_kbd_macro): Remove redundant assignment.
+
+ * keymap.c (copy_keymap_1): Make it static.
+
+ * alloc.c (Fgarbage_collect): Don't use XSETFLOAT.
+
+2003-02-22 David Ponce <[email protected]>
+
+ * lread.c (Fload): Don't check STRING_MULTIBYTE.
+
+2003-02-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * process.h: Removed subtty field from struct Lisp_Process.
+
+ * process.c (create_process): Remove setting of subtty.
+ (emacs_get_tty_pgrp): New function.
+ (Fprocess_running_child_p, process_send_signal):
+ Call emacs_get_tty_pgrp instead of ioctl.
+ (process_send_signal): Call EMACS_KILLPG if ioctl TIOCSIGSEND fails.
+
+2003-02-21 Kai Gro,A_(Bjohann <[email protected]>
+
+ * keymap.c (Fdefine_key): Doc fix.
+
+2003-02-21 Juanma Barranquero <[email protected]>
+
+ Port of patch for RC by Klaus Zeitler <[email protected]>.
+
+ * s/hpux10.h: Define POLL_INTERRUPTED_SYS_CALL, not
+ POLLING_PROBLEM_IN_SELECT.
+
+ * s/hpux11.h: Include hpux10-20.h instead of hpux10.h.
+ Delete #undef of POLLING_PROBLEM_IN_SELECT.
+
+ * s/hpux10-20.h: New file.
+
+ * process.c (wait_reading_process_input):
+ Use POLL_INTERRUPTED_SYS_CALL, not POLLING_PROBLEM_IN_SELECT.
+
+2003-02-20 Kenichi Handa <[email protected]>
+
+ * fontset.c (check_fontset_name): If NAME is nil, return the
+ default fontset.
+ (override_font_info): New function.
+ (Fset_fontset_font): Document that NAME nil means the default fontset.
+ (Ffontset_info): If FONTSET is not the default fontset, merge
+ FONTSET onto the copy of the default fontset, and work on that
+ copy. Document that NAME nil means the default fontset.
+ (Ffontset_font): Document that NAME nil means the default fontset.
+
+ * process.c (setup_process_coding_systems): If the process's
+ in/out descriptor is -1, do nothing.
+
+2003-02-19 Andreas Schwab <[email protected]>
+
+ * lisp.h (Fcancel_kbd_macro_events, Fstring_to_multibyte):
+ Add prototypes.
+
+2003-02-19 Kenichi Handa <[email protected]>
+
+ * xfaces.c (try_alternative_families): Try all scalable fonts if
+ Vscalable_fonts_allowed is not Qt.
+
+2003-02-19 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfaces.c (x_face_list_fonts): Set *pfonts to 0 if no fonts found.
+
+2003-02-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_list_fonts): If maxnames is less than 0, get all font
+ names.
+
+ * xfaces.c (x_face_list_fonts): Allocate struct font_name here.
+ (sorted_font_list): Move allocation of struct font_name to
+ x_face_list_fonts.
+ (Fx_font_family_list): Set font-list-limit to -1 to get all font names.
+ (Fx_list_fonts): Set maxnames to -1 to get all font names.
+
+2003-02-18 Kim F. Storm <[email protected]>
+
+ * lread.c (read1): Fix last change.
+ "`" is not always special. Allow "?" after a character constant.
+
+2003-02-18 Andrew Choi <[email protected]>
+
+ * unexmacosx.c (copy_data_segment): Also copy __cfstring section.
+
+2003-02-18 Andreas Schwab <[email protected]>
+
+ * window.c (window_scroll_pixel_based): Move outside a
+ multi-glyph character before setting new window start.
+
+ * xdisp.c (in_display_vector_p): New function.
+ * dispextern.h (in_display_vector_p): Declare.
+
+2003-02-18 Kim F. Storm <[email protected]>
+
+ * lread.c (read1): Fix and relax read syntax.
+ Recognize "[", ";", "#", and "?" after a dotted-pair dot.
+ Only recognize "," after dotted-pair dot if inside backquote.
+ Never include "`" or "," (inside backquote) in a symbol.
+ Allow dotted-pair dot after a character constant.
+ Allow "`" and "," (inside backquote) after a character constant.
+
+2003-02-17 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_tool_bar_expose_callback): New function.
+ (xg_create_tool_bar): Force style of tool bar to be horizontal with
+ icons. Set name of tool bar to emacs-toolbar.
+ (update_frame_tool_bar): Connect expose event to
+ xg_tool_bar_expose_callback.
+
+2003-02-17 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (this_command_key_count_reset): New variable.
+ Initiatize to 0 where this_command_key_count is set.
+ (read_char): Save and restore this_command_key_count_reset
+ around input method code.
+ (read_char): If this_command_key_count_reset, echo reread commands.
+ (Freset_this_command_lengths): Set this_command_key_count_reset to 1.
+
+2003-02-17 Kenichi Handa <[email protected]>
+
+ * fns.c (string_to_multibyte): Always return a multibyte string.
+
+2003-02-16 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_list_bdf_fonts, w32_list_fonts):
+ Negative max_fonts parameter means list all.
+
+2003-02-14 Dave Love <[email protected]>
+
+ * fns.c (Flanginfo): Doc fix.
+
+2003-02-13 Kim F. Storm <[email protected]>
+
+ * lread.c (read_escape): Interpret \s as a SPACE character, except
+ for \s-X in a character constant which still is the super modifier.
+ (read1): Signal an `invalid read syntax' error if a character
+ constant is immediately followed by a digit or symbol character.
+
+ * search.c (Fmatch_data): Doc fix. Explicitly state that
+ match-data is undefined if last search failed.
+
+ * keymap.c (Fcommand_remapping): Rename from Fremap_command.
+ All uses changed.
+
+2003-02-12 Juanma Barranquero <[email protected]>
+
+ * eval.c (Fdefmacro): Fix typo.
+
+2003-02-12 Kim F. Storm <[email protected]>
+
+ * macros.c (Fstart_kbd_macro): If appending, and last keyboard
+ macro is a string, convert meta modifiers in string when copying
+ the string into a vector.
+
+2003-02-11 Kim F. Storm <[email protected]>
+
+ * keymap.c (Fremap_command): Return nil if arg is not a symbol.
+
+2003-02-11 Kenichi Handa <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): Add malayalam.el and tamil.el.
+
+2003-02-10 Kim F. Storm <[email protected]>
+
+ * process.c: Doc fixes.
+ (syms_of_process): Add `:' prefix to QCfilter_multibyte.
+
+2003-02-10 Kenichi Handa <[email protected]>
+
+ * fns.c (Fstring_to_multibyte): Fix typo in the docstring.
+
+ * process.c (QCfilter_multibyte): New variable.
+ (setup_process_coding_systems): New function.
+ (Fset_process_buffer, Fset_process_filter):
+ Call setup_process_coding_systems.
+ (Fstart_process): Initialize the member `filter_multibyte' of
+ struct Lisp_Process.
+ (create_process): Call setup_process_coding_systems.
+ (Fmake_network_process): New keyward `:filter-multibyte'.
+ Initialize the member `filter_multibyte' of struct Lisp_Process.
+ Call setup_process_coding_systems.
+ (server_accept_connection): Call setup_process_coding_systems.
+ (read_process_output): If the process has a filter, decide the
+ multibyteness of a string to given to the filter by
+ `filter_multibyte' member of the process. If the process doesn't
+ have a filter and the result of conversion is unibyte, use
+ Fstring_to_multibyte (not Fstring_make_multibyte) to get the
+ multibyte form.
+ (Fset_process_coding_system): Call setup_process_coding_systems.
+ (Fset_process_filter_multibyte): New function.
+ (Fprocess_filter_multibyte_p): New function.
+ (syms_of_process): Intern and staticpro QCfilter_multibyte.
+ Defsubr Sset_process_filter_multibyte and
+ Sprocess_filter_multibyte_p.
+
+ * process.h (struct Lisp_Process): New member filter_multibyte.
+
+ * lisp.h (setup_process_coding_systems): Add prototype.
+
+ * buffer.c (Fset_buffer_multibyte): If the current buffer has a
+ process, update coding systems for the process.
+
+2003-02-09 Kenichi Handa <[email protected]>
+
+ * fns.c (string_to_multibyte): New function.
+ (Fstring_to_multibyte): New function.
+ (syms_of_fns): Defsubr it.
+
+2003-02-08 Andreas Schwab <[email protected]>
+
+ * Makefile.in (EXEEXT): Define to @EXEEXT@ and use this variable
+ instead of the substitution.
+
+2003-02-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_make_frame_visible): Call gtk_window_deiconify.
+
+ * xmenu.c (menu_position_func): Adjust menu popup position so that
+ the menu is fully visible.
+
+2003-02-07 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (x_text_icon, x_raise_frame, x_lower_frame)
+ (x_make_frame_invisible, x_wm_set_icon_position):
+ Use FRAME_OUTER_WINDOW instead of ifdef X_TOOLKIT/else/endif.
+
+ * xfns.c (x_set_name, x_set_title): Ditto.
+
+2003-02-04 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (echo_now): Update before_command_echo_length.
+ (Freset_this_command_lengths): Reset this_command_key_count etc.
+ immediately rather than arranging to do it later.
+ (before_command_key_count_1, before_command_echo_length_1)
+ (before_command_restore_flag): Vars deleted.
+ (add_command_key): Don't handle before_command_restore_flag.
+ (read_char, record_menu_key): Don't update before_command_key_count or
+ before_command_echo_length.
+ (read_char): Don't handle before_command_restore_flag.
+
+ * keyboard.c (command_loop_1): Don't call adjust_point_for_property
+ in direct-output clauses if it wouldn't be called in the ordinary case.
+
+2003-02-04 Kim F. Storm <[email protected]>
+
+ * keyboard.c (syms_of_keyboard) <this-original-command>: Doc fix.
+
+2003-02-02 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (remove_from_container): Copying list is not needed.
+ (xg_update_menubar, xg_update_menu_item, xg_update_submenu)
+ (xg_modify_menubar_widgets, update_frame_tool_bar): Call g_list_free
+ on list returned from gtk_container_get_children to avoid memory leak.
+
+2003-02-01 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_create_pixmap_from_bitmap_data): Use alloca for
+ local malloc.
+ [HAVE_XPM]: Avoid clashes with XColor, XImage and Pixel
+ definitions in xpm.h.
+ (init_xpm_functions): New function.
+ (xpm_load): Sync with xfns.c. Adapt for Windows version of libXpm.
+ (init_external_image_libraries): Try to load libXpm.dll.
+
+ * fileio.c (Fcopy_file) [WINDOWSNT]: Reverse logic for setting
+ timestamp.
+
+2003-01-31 Dave Love <[email protected]>
+
+ * syntax.c (Fskip_chars_forward)
+ (open-paren-in-column-0-is-defun-start): Doc fix.
+
+2003-01-31 Joe Buehler <[email protected]>
+
+ * fileio.c: Support // at start of name for Cygwin (just added proper
+ preprocessor tests).
+
+ * keyboard.c: Port to Cygwin (just added proper preprocessor tests).
+
+ * Makefile.in: Use @EXEEXT@ for Cygwin.
+
+ * mem-limits.h: Added ifdef to define BSD4_2 for Cygwin.
+
+ * s/cygwin.h: Added for Cygwin port.
+
+2003-01-31 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (DrawText): Kludge to avoid a redefinition on Windows
+ when including gif_lib.h.
+ (init_gif_functions, init_tiff_functions): New functions.
+ (gif_load, tiff_load): Sync with xfns.c version. Adjust colors for
+ Windows. Disable color table lookups. Call library functions
+ through pointers determined at runtime.
+ (init_external_image_libraries): Try to load libungif.dll and
+ libtiff.dll.
+
+2003-01-31 Kenichi Handa <[email protected]>
+
+ * xdisp.c (SKIP_GLYPHS): New macro.
+ (set_cursor_from_row): Skip all glyphs that comes from overlay string.
+
+2003-01-30 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (free_frame_tool_bar): Remove debug printf.
+
+2003-01-30 Dave Love <[email protected]>
+
+ * alloc.c (Vgc_elapsed, gcs_done): New variables.
+ (Fgarbage_collect): Use them.
+ (init_alloc, syms_of_alloc): Set them up.
+
+2003-01-30 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (init_external_image_libraries): Add missing operator.
+
+2003-01-29 Jason Rumney <[email protected]>
+
+ * w32fns.c (init_external_image_libraries): Allow jpeg-62.dll as
+ an alternative name for jpeg.dll.
+
+2003-01-29 Kenichi Handa <[email protected]>
+
+ * xdisp.c (set_cursor_from_row): Pay attention to string display
+ properties.
+
+2003-01-28 Benjamin Riefenstahl <[email protected]>
+
+ * macterm.c (keycode_to_xkeysym_table): Add <tab>, <backspace>,
+ <escape>.
+ (keycode_to_xkeysym_table): Reformat and add more comments.
+ (XTread_socket): Drop special case for backspace.
+
+2003-01-28 Andrew Choi <[email protected]>
+
+ * macfns.c (x_to_mac_color): Correct the order for parsing the RGB
+ values in old-style RGB specs.
+
+2003-01-27 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (init_external_image_libraries): Try alternate names for the
+ jpeg dll.
+
+2003-01-27 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (create_dialog, xg_separator_p)
+ (xg_item_label_same_p, xg_update_menu_item): Check for NULL string
+ before calling strcmp or strlen.
+
+2003-01-26 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (update_frame_tool_bar): Call prepare_image_for_display
+ and handle image load failure.
+
+2003-01-26 Jason Rumney <[email protected]>
+
+ * w32fns.c (init_jpeg_functions, jpeg_resync_to_restart_wrapper):
+ New functions.
+ (jpeg_load): Sync with xfns.c version. Adjust colors for Windows.
+ Disable color table lookups. Call jpeg library functions
+ through pointers determined at runtime.
+ (init_external_image_libraries): Try to load jpeg.dll.
+
+2003-01-25 Richard M. Stallman <[email protected]>
+
+ * lisp.h: Declare format2 instead of format1.
+
+ * fileio.c (barf_or_query_if_file_exists):
+ Call format2 instead of format1.
+
+ * editfns.c (format2): New function, replaces format1
+ but takes exactly two Lisp Objects as format args.
+
+ * buffer.c (Fkill_buffer): Call format2 instead of format1.
+
+2003-01-25 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h: Change to return value of x_dispatch_event to int.
+
+ * xterm.c (x_filter_event): New function.
+ (event_handler_gdk, XTread_socket): Call x_filter_event.
+ (x_dispatch_event): Change to return value of finish.
+ (event_handler_gdk): Use return value from x_dispatch_event.
+
+ * xfns.c (x_window): Call create_frame_xic for GTK version to
+ initialize input methods.
+
+ * gtkutil.h: Add (void) prototypes.
+
+ * gtkutil.c (create_menus): Remove code that puts the help menu to
+ the right.
+
+2003-01-25 Jason Rumney <[email protected]>
+
+ * w32fns.c (XPutPixel): Handle monochrome images; used for masks.
+ [HAVE_PNG]: Sync with xfns.c version.
+ (png_load): Adjust colors for Windows. Use Windows
+ bitmaps. Disable color table lookups.
+ (DEF_IMGLIB_FN, LOAD_IMGLIB_FN): New macros.
+ (init_png_functions): New function.
+ (png_read_from_memory, png_load): Call png library functions
+ through pointers determined at runtime.
+ (QCloader, QCbounding_box, QCpt_width, QCpt_height): Declare.
+ (init_external_image_libraries): New function.
+ (init_xfns): Call it.
+
+2003-01-24 Andreas Schwab <[email protected]>
+
+ * minibuf.c (Fminibuffer_message): Verify type of parameter.
+
+2003-01-24 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_initialize): Initialize id_to_widget here instead
+ of static initializer.
+
+2003-01-24 Dave Love <[email protected]>
+
+ * s/gnu-linux.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define for more
+ architectures.
+
+ * alloc.c (mark_stack) [!GC_LISP_OBJECT_ALIGNMENT && __GNUC__]:
+ Use __alignof__.
+
+2003-01-24 Kenichi Handa <[email protected]>
+
+ * keyboard.c (adjust_point_for_property): New second arg MODIFIED.
+ It it is nonzero, don't pretend that an invisible area doesn't exist.
+ (command_loop_1): Call adjust_point_for_property with proper
+ second arg.
+
+2003-01-22 Jason Rumney <[email protected]>
+
+ Sync changes with xterm.c and xfns.c.
+
+ * w32term.c (x_draw_glyph_string_foreground)
+ (x_draw_composite_glyph_string_foreground): Implement overstriking.
+
+ * w32term.c (x_write_glyphs): Clear phys_cursor_on_p if current
+ phys_cursor's hpos is overwritten. This is still not completely
+ correct, as it doesn't really make sense to use hpos at all to
+ get the cursor glyph (as that is relative to the width of the
+ characters on the line, which may have changed during the update).
+
+ * w32term.c (notice_overwritten_cursor): Handle the special case
+ of the cursor being in the first blank non-text line at the
+ end of a window.
+
+ * w32term.c (x_draw_hollow_cursor, x_draw_bar_cursor)
+ (x_draw_phys_cursor_glyph): Set phys_cursor_width here.
+ Compute from the x position returned by x_draw_glyphs.
+
+ (x_display_and_set_cursor): Don't set phys_cursor_width here,
+ except for NO_CURSOR and system caret, to make phys_cursor_width
+ contain what its name suggests.
+ (notice_overwritten_cursor): Consider the cursor image erased if
+ the output area intersects the cursor image in y-direction.
+
+ * w32term.c (note_mode_line_or_margin_highlight): Rename from
+ note_mode_line_highlight and extend.
+
+ * w32term.c (last_window): New variable.
+ (w32_read_socket) <WM_MOUSEMOVE>: Generate SELECT_WINDOW_EVENTs.
+ (note_mouse_movement): Remove reimplemented code in #if 0.
+
+ * w32fns.c (x_set_cursor_type): Set cursor_type_changed,
+ not update_mode_lines, and always set it to 1.
+
+2003-01-21 Jason Rumney <[email protected]>
+
+ * w32fns.c (IDC_HAND): Define it if system headers don't.
+
+2003-01-21 KOBAYASHI Yasuhiro <[email protected]>
+
+ * w32term.h (struct w32_output): New member hand_cursor.
+ (WM_EMACS_SETCURSOR): New message definition.
+
+ * w32term.c (note_mode_line_highlight): Delete #if 0 to enable
+ function w32_define_cursor.
+ (note_mouse_highlight): Initialize, setup cursor accoding to mouse
+ position, change member name output_data.x to output_data.w32 and
+ add function w32_define_cursor.
+ (show_mouse_face): Delete #if 0 to enable function w32_define_cursor
+ and change member name output_data.x to output_data.w32.
+ (w32_initialize_display_info):
+ Setup dpyinfo->vertical_scroll_bar_cursor.
+
+ * w32fns.c (Vx_hand_shape): New variable.
+ (w32_wnd_proc): Add message entries for WM_SETCURSOR and
+ WM_EMACS_SETCURSOR.
+ (x-create-frame): Setup Cursor types.
+
+2003-01-21 David Ponce <[email protected]>
+
+ * w32term.c (w32_encode_char): For DIM=1 charset, set
+ ccl->reg[2] to -1 before calling ccl_driver.
+ (Sync. with xterm.c x_encode_char change by Kenichi Handa
+ <[email protected]> on 2002-09-30.)
+ (w32_draw_relief_rect): Declare all args.
+ (w32_define_cursor): New.
+
+ * w32fns.c (w32_load_cursor): New function.
+ (w32_init_class): Use it.
+ (x_put_x_image): Declare all args.
+
+2003-01-21 Richard Dawe <[email protected]>
+
+ * Makefile.in (ALL_CFLAGS): Include MYCPPFLAGS, not MYCPPFLAG.
+
+2003-01-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c: Must include stdio.h before termhooks.h.
+
+2003-01-21 Dave Love <[email protected]>
+
+ * alloc.c (Fgc_status): Print zombie list.
+ (mark_maybe_object) [GC_MARK_STACK==GC_USE_GCPROS_CHECK_ZOMBIES]:
+ Fix assignment of zombies.
+ (Fgarbage_collect) [GC_MARK_STACK==GC_USE_GCPROS_CHECK_ZOMBIES]:
+ Don't take car of non-cons.
+
+ * s/sol2-5.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
+
+ * s/sunos4-0.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
+
+2003-01-20 David Ponce <[email protected]>
+
+ * w32menu.c (digest_single_submenu): Declare all args.
+
+ Sync with 2002-12-23 Richard M. Stallman <[email protected]>
+ changes in xmenu.c:
+
+ (parse_single_submenu): Use individual keymap's prompt
+ string as pane name, if there is one.
+ (set_frame_menubar): Save menu_items_n_panes from each call to
+ parse_single_submenu and use it when calling digest_single_submenu.
+
+2003-01-20 Steven Tamm <[email protected]>
+
+ * macterm.c (XTread_socket): Check for valid, visible window
+ before sending a scroll-wheel event.
+
+2003-01-20 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (redisplay_window): If mini window's buffer is not
+ a minibuffer, then redisplay it like other windows.
+
+2003-01-20 Jan Dj,Ad(Brv <[email protected]>
+
+ * gtkutil.c (xg_create_frame_widgets): Check if there is an
+ external tool bar before setting tool bar height.
+
+2003-01-19 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (handle_one_xevent): Surround popup_activated
+ with #ifdef:s for non-toolkit version.
+
+ * Makefile.in (XOBJ): Add gtkutil.o if USE_GTK.
+ (gtkutil.o): New file.
+ (TOOLKIT_DEFINES): Set to -DUSE_GTK if HAVE_GTK.
+ (LIBW): Set to @GTK_LIBS@ if USE_GTK.
+
+ * gtkutil.c: New file for GTK version.
+
+ * gtkutil.h: New file for GTK version.
+
+ * xterm.h: Add xt_or_gtk_widget.
+ Include gtk files for USE_GTK.
+ (struct x_output): Add toolbar_height.
+ (struct x_output): Add GTK widgets and Gdk size_hints.
+ (GTK_WIDGET_TO_X_WIN, FRAME_GTK_OUTER_WIDGET, FRAME_GTK_WIDGET)
+ (FRAME_OUTER_WINDOW): New macros for USE_GTK.
+ (FRAME_OUTER_TO_INNER_DIFF_Y): Add FRAME_TOOLBAR_HEIGHT to calculation.
+
+ * xterm.c: Include gtkutil.h for USE_GTK.
+ (free_frame_menubar): Declare extern void for USE_GTK.
+ (note_mouse_highlight): Check popup_activated for USE_GTK.
+ (xt_action_hook): Don't compile if USE_GTK.
+ (x_scroll_bar_to_input_event): Use CurrentTime for USE_GTK.
+ (xg_scroll_callback): New function.
+ (x_create_toolkit_scroll_bar): Call xg_create_scroll_bar for USE_GTK.
+ (x_set_toolkit_scroll_bar_thumb): Call xg_set_toolkit_scroll_bar_thumb
+ for USE_GTK.
+ (x_scroll_bar_create): Call xg_update_scrollbar_pos and
+ xg_show_scroll_bar for USE_GTK.
+ (x_scroll_bar_remove): Call xg_remove_scroll_bar for USE_GTK.
+ (XTset_vertical_scroll_bar): Call xg_update_scrollbar_pos for USE_GTK.
+ (event_handler_gdk): New function for USE_GTK.
+ (handle_one_xevent): Call xg_resize_widgets for USE_GTK.
+ (handle_one_xevent): Make sure widget is mapped before
+ calling x_real_positions for USE_GTK.
+ (XTread_socket): Add GTK event loop for USE_GTK.
+ (x_set_window_size): Call xg_frame_set_char_size for USE_GTK.
+ (x_make_frame_visible): Call gtk_widget_show_all for USE_GTK.
+ (x_make_frame_invisible): Call gtk_widget_hide for USE_GTK.
+ (x_iconify_frame): Add code for USE_GTK.
+ (x_free_frame_resources): Call gtk_widget_destroy for USE_GTK.
+ (x_wm_set_size_hint): Only compile if not USE_GTK. GTK version
+ is in gtkutil.c.
+ (x_term_init): Add initialization for GTK.
+ (syms_of_xterm): Set Vx_toolkit_scroll_bars for USE_GTK.
+
+ * xmenu.c: Include gtkutil.h for USE_GTK.
+ (Fx_popup_menu): Use current position if x and y are nil.
+ (single_menu_item, single_menu_item, Fx_popup_dialog):
+ Check for USE_GTK.
+ (popup_widget_loop): New function for USE_GTK.
+ (x_activate_menubar): Add code for USE_GTK.
+ (popup_activate_callback, popup_deactivate_callback)
+ (menu_highlight_callback, menubar_selection_callback):
+ Add USE_GTK versions.
+ (update_frame_menubar): Call xg_update_frame_menubar for USE_GTK.
+ (set_frame_menubar): Call xg_modify_menubar_widgets for USE_GTK.
+ (free_frame_menubar): Only compile if not USE_GTK. GTK version
+ is in gtkutil.c.
+ (popup_selection_callback): New version for USE_GTK.
+ (create_and_show_popup_menu): New fuction, one USE_GTK version and
+ one USE_X_TOOLKIT version.
+ (xmenu_show): Call create_and_show_popup_menu.
+ (dialog_selection_callback): New version for USE_GTK.
+ (create_and_show_dialog): New fuction, one USE_GTK version and
+ one USE_X_TOOLKIT version.
+ (xdialog_show): Call create_and_show_dialog.
+
+ * xfns.c: Include gtkutil for USE_GTK.
+ (x_window_to_frame, x_any_window_to_frame)
+ (x_non_menubar_window_to_frame, x_menubar_window_to_frame)
+ (x_top_window_to_frame): Add code for USE_GTK.
+ (x_set_background_color): Call xg_set_background_color for GTK.
+ (x_set_menu_bar_lines): Check for USE_GTK.
+ (x_set_tool_bar_lines): Call update_frame_tool_bar for USE_GTK.
+ (x_set_name, x_set_title): Call gtk_window_set_title for USE_GTK.
+ (x_window): Call xg_create_frame_widgets for USE_GTK.
+ (Fx_create_frame): Check for USE_GTK.
+ (Fx_file_dialog): New implementation for USE_GTK.
+
+ * xdisp.c: Add check for USE_GTK for extern void set_frame_menubar.
+ (update_menu_bar): Add check for USE_GTK.
+ (update_tool_bar): Add check for USE_GTK and external tool bar.
+ (redisplay_tool_bar): Add check for USE_GTK and external tool bar.
+ (redisplay_internal): Add check for USE_GTK and popup_activated.
+ (redisplay_window): Add check for USE_GTK and FRAME_EXTERNAL_MENU_BAR.
+ (redisplay_window): Add check for USE_GTK and FRAME_EXTERNAL_TOOL_BAR.
+ (display_menu_bar): Add check for USE_GTK.
+
+ * lisp.h (Vx_resource_name): Declare extern.
+
+ * keyboard.c (kbd_buffer_get_event): Check MENU_BAR_ACTIVATE_EVENT
+ for USE_GTK.
+ (make_lispy_event): Check MENU_BAR_EVENT for USE_GTK.
+
+ * frame.h (struct frame): Add external_tool_bar. Check for USE_GTK.
+ (FRAME_EXTERNAL_TOOL_BAR): New macro.
+ (FRAME_EXTERNAL_MENU_BAR): Check for USE_GTK.
+
+ * fileio.c (Fread_file_name): Add check for USE_GTK.
+
+ * dispnew.c (adjust_frame_glyphs_for_window_redisplay):
+ Add check for USE_GTK.
+
+ * config.in: Added HAVE_GTK.
+
+ * alloc.c (Fgarbage_collect): Call xg_mark_data for GTK.
+
+2003-01-18 Stefan Monnier <[email protected]>
+
+ * charset.h (Funibyte_char_to_multibyte): Export.
+
+2003-01-18 Jan Dj,Ad(Brv <[email protected]>
+
+ * xmenu.c (mouse_position_for_popup): New function.
+ (Fx_popup_menu): Call mouse_position_for_popup for X and
+ mouse_position_hook for others.
+
+2003-01-17 Kim F. Storm <[email protected]>
+
+ * editfns.c (Finsert): Mention `string-make-multibyte' and
+ `string-as-multibyte' in doc string.
+
+2003-01-17 Kenichi Handa <[email protected]>
+
+ * fontset.c (syms_of_fontset): Setup Vfont_encoding_alist here.
+
+ * editfns.c (Fformat): Convert an unibyte char argument that is
+ formatted by "%c" to multibyte if the total result must be a
+ multibyte string.
+
+2003-01-16 Kim F. Storm <[email protected]>
+
+ * process.c (set-process-filter): Document unibyte/multibyte-ness
+ of string argument.
+
+2003-01-16 Kenichi Handa <[email protected]>
+
+ * charset.h (NEXT_CHAR_BOUNDARY, PREV_CHAR_BOUNDARY): New macros.
+
+ * regex.c (GET_CHAR_BEFORE_2): Use PREV_CHAR_BOUNDARY.
+ (re_search_2): Likewise.
+
+2003-01-15 Kenichi Handa <[email protected]>
+
+ * xdisp.c (message_dolog): Fix bug of the case that *Message*
+ buffer is unibyte.
+
+2003-01-15 Francesco Potort,Al(B <[email protected]>
+
+ * fns.c (Fsubstring): Clarify doc string.
+
+ * textprop.c (Ftext_properties_at, Fnext_char_property_change)
+ (Fprevious_char_property_change)
+ (Fnext_single_char_property_change)
+ (Fprevious_single_char_property_change, Fnext_property_change)
+ (Fnext_single_property_change, Fprevious_property_change)
+ (Fprevious_single_property_change, Fadd_text_properties)
+ (Fput_text_property, Fset_text_properties)
+ (Fremove_text_properties, Fremove_list_of_text_properties)
+ (Ftext_property_any, Ftext_property_not_all): Clarify doc strings.
+
+2003-01-14 Kim F. Storm <[email protected]>
+
+ * process.h (struct Lisp_Process): New member plist replaces old
+ member private_vars. All uses changed.
+
+ * process.c: Reworked 2003-01-12 change -- call a plist a plist!
+ (QCplist): Rename from QCvars. Change all uses.
+ (Fprocess_plist): Replaces Fprocess_variable. Simplified.
+ (Fset_process_plist): Replaces Fset_process_variable. Simplify.
+ (syms_of_process): Intern, staticpro, defsubr these.
+ (Fmake_network_process): Describe :plist arg. Remove :vars arg.
+
+2003-01-14 Francesco Potort,Al(B <[email protected]>
+
+ * m/delta.h: Remove (obsolete).
+
+2003-01-13 Francesco Potort,Al(B <[email protected]>
+
+ * fileio.c (Fdelete_directory, Fdelete_file): Document the
+ behaviour in front of symlinks.
+ (Fdelete_file): Raise an error on directories.
+
+2003-01-13 Dave Love <[email protected]>
+
+ * fns.c (Freverse): Use QUIT.
+
+2003-01-13 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (minibuffer_completion_contents):
+ Error if point is inside prompt.
+
+ * keyboard.c (command_loop_1): Don't redisplay directly
+ if there's a post-command-hook.
+
+ * fileio.c (syms_of_fileio) <directory-sep-char>: Doc fix.
+ (Fdo_auto_save): Add gcpros around Ffile_name_directory.
+
+2003-01-12 Kim F. Storm <[email protected]>
+
+ * process.h (struct Lisp_Process): New member private_vars.
+
+ * process.c (QCvars): New variable.
+ (syms_of_process): Intern and staticpro it.
+ (Fset_process_contact): Removed function.
+ (Fprocess_variable, Fset_process_variable): New functions.
+ (syms_of_process): Defsubr them.
+ (Fstart_process): Initialize private_vars plist to nil.
+ (Fmake_network_process): New arg :vars to setup the private
+ variables for new network process.
+ (server_accept_connection): Copy server's private variables to
+ client process.
+
+ * alloc.c (pure_alloc): Fixed 2003-01-10 changed (caused spurious
+ crashes). Code rewritten and simplified. Now directly aligns the
+ pointer and recalculates pure_bytes_used, rather than aligning the
+ size and adjusting the pointer.
+
+2003-01-11 Kim F. Storm <[email protected]>
+
+ * process.c (Fset_process_contact): New function.
+ (syms_of_process): defsubr it.
+ (make-network-process): Update doc.
+
+2003-01-10 Andreas Schwab <[email protected]>
+
+ * alloc.c (pure_alloc): Correct alignment for Lisp_Floats.
+ Reported by Berthold Gunreben <[email protected]>.
+
+2003-01-10 Dave Love <[email protected]>
+
+ * composite.c (syms_of_composite): Make composition_hash_table weak.
+
+2003-01-09 Kim F. Storm <[email protected]>
+
+ * process.c (Fmake_network_process): Convert new port number
+ to host byte order for `:service t' case. From Mario Lang.
+
+2003-01-08 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (Fx_file_dialog): Call XtAppNextEvent and x_dispatch_event
+ instead of XtAppProcessEvent.
+
+ * xterm.c (handle_one_xevent): New function.
+ (x_dispatch_event): New function.
+ (XTread_socket): Call handle_one_xevent.
+
+ * xterm.h (FRAME_OUTER_TO_INNER_DIFF_X/Y): New.
+
+ * xmenu.c (Fx_popup_menu): If popping up at mouse position,
+ call XQueryPointer to get coordinates.
+ (popup_get_selection): Do not set popup_activated_flag to zero,
+ let popup_deactivate_callback do that. Needed for Motif.
+ Call x_dispatch_event instead of XtDispatchEvent.
+ (xmenu_show): Calculate root coordinate from frame top/left position.
+
+2003-01-08 Kim F. Storm <[email protected]>
+
+ * process.c (server_accept_connection): Fix recording of new
+ connection's local address in :local property of contact info.
+ (Fmake_network_process): Record local network address for new
+ client processes in :local property of contact info.
+ (format-network-address): Add arg OMIT-PORT. Change callers.
+
+2003-01-07 Dave Love <[email protected]>
+
+ * Makefile.in (fns.o): Depend on coding.h.
+
+2003-01-06 Dave Love <[email protected]>
+
+ * fns.c: Include coding.h. Use POINTER_TYPE*, not void*.
+ (Vlocale_coding_system): Declare.
+ (Qcodeset, Qdays, Qmonths, Qpaper): New.
+ (Flanginfo): New.
+ (syms_of_fns): Initialize new stuff.
+
+2003-01-07 Markus Rost <[email protected]>
+
+ * minibuf.c (Fread_variable): Doc fix.
+
+ * eval.c (Fuser_variable_p): Doc change. For custom variables,
+ use the same test as for custom-variable-p.
+
+2003-01-05 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (try_scrolling): New arg LAST_LINE_MISFIT.
+ Count LAST_LINE_MISFIT in scroll margin for end of window.
+ Move label too_near_end before setting SCROLL_MARGIN_POS.
+ Set LAST_LINE_MISFIT before jumping there.
+
+ * xdisp.c (try_scrolling): Calculate amount_to_scroll better in
+ scroll_conservatively case. If scrolling that much doesn't change
+ STARTP, move it down one line.
+
+ * xdisp.c (redisplay_window): Pass last_line_misfit arg to
+ try_scrolling. Make it 1 after make_cursor_line_fully_visible fails.
+
+ * xdisp.c (setup_echo_area_for_printing): Kill Emacs if no
+ selected frame.
+
+ * keymap.c (apropos_predicate, apropos_accumulate): Make them static.
+ (syms_of_keymap): Staticpro them.
+ (Fapropos_internal): Initialize them and clear them out.
+ Don't GCPRO them.
+
+ * buffer.c (syms_of_buffer) <scroll-up|down-aggressively>: Doc fixes.
+
+ * lisp.h: New misc type Lisp_Save_Value.
+ (enum Lisp_Misc_Type): Add Lisp_Misc_Save_Value.
+ (XSAVE_VALUE): New macro.
+ (struct Lisp_Save_Value): New data type.
+ (union Lisp_Misc): Add u_save_value alternative.
+ (make_save_value): Declare.
+
+ * alloc.c (make_save_value): New function.
+
+ * xterm.c (x_catch_errors): Save dpy using make_save_value.
+ (x_catch_errors_unwind): Call XSync.
+
+2003-01-01 Richard M. Stallman <[email protected]>
+
+ * window.c (window_scroll_pixel_based): Partially undo last change.
+
+ * keyboard.c (command_loop_1): Call adjust_point_for_property
+ in direct action cases for Qforward_char and Qbackward_char.
+ Set already_adjusted so it won't be done twice.
+
+2002-12-30 Richard Dawe <[email protected]>
+
+ * src/config.in (!HAVE_SIZE_T): Fix order of arguments in
+ type definition of size_t.
+
+2003-01-02 Steven Tamm <[email protected]>
+
+ * macterm.c (syms_of_macterm): Provide the feature "mac-carbon" to
+ distinguish Carbon GUI builds from X11 builds on darwin.
+
+2002-12-30 Steven Tamm <[email protected]>
+
+ * macterm.c (syms_of_macterm): Set mac-wheel-button-is-mouse-2
+ to default to t.
+
+2002-12-29 Francesco Potort,Al(B <[email protected]>
+
+ * data.c (Fstring_to_number, Fminus): Better English in doc strings.
+
+2002-12-28 Steven Tamm <[email protected]>
+
+ * Makefile.in (macosx-bundle): Fix Mac OS X/Carbon port to
+ allow building in a different directory than source. Uses some
+ GNU Make extensions, but there is no other make on Mac OS X.
+
+2002-12-26 Francesco Potort,Al(B <[email protected]>
+
+ * data.c (Fmakunbound, Ffmakunbound, Fmake_variable_buffer_local)
+ (Fsetq_default, Fmake_local_variable, Fkill_local_variable)
+ (Fmake_variable_frame_local, Faset, Fnumber_to_string, Fminus)
+ (Fstring_to_number): Mention the returned value in the doc strings.
+
+2002-12-23 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer) <scroll-up-aggressively>
+ <scroll-down-aggressively>: Doc fix.
+
+ * xmenu.c (parse_single_submenu): Use individual keymap's prompt
+ string as pane name, if there is one.
+ (set_frame_menubar): Save menu_items_n_panes from each call to
+ parse_single_submenu and use it when calling digest_single_submenu.
+
+ * window.c (window_scroll_pixel_based): Fix check for reaching BEGV.
+ Don't try to make last line fully visible if it is past end of window.
+
+2002-12-22 Steven Tamm <[email protected]>
+
+ * macmenu.c (MIN_POPUP_SUBMENU_ID): Add.
+ (mac_menu_show): Add support for hierarchical popup menus.
+ (add_menu_item): Remove indentation support.
+ (fill_submenu, fill_menu): Create hierarchical menus
+ instead of using indentation.
+
+2002-12-22 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (try_cursor_movement): Don't call try_window here.
+ (redisplay_window): Never redisplay minibuffer when inactive.
+
+ * window.c (select_window_1): Undo 9/21 change.
+
+2002-12-22 Steven Tamm <[email protected]>
+
+ * macterm.c (XTread_socket): Call KeyTranslate for control and
+ meta to deal correctly shifted non-alpha characters, like C-S-5
+ being treated like C-%. Do not look for shift key to deal
+ with masking off control-key with mac-reverse-ctrl-meta.
+
+2002-12-21 Richard M. Stallman <[email protected]>
+
+ * xmenu.c (popup_get_selection): Now static. New arg DO_TIMERS.
+ If it is non-nil, run timers. Use an unwind-protect to requeue
+ the events that were read ahead.
+ (popup_get_selection_unwind): New subroutine.
+ (popup_get_selection_queue): File-scope variable now holds that queue.
+ (xmenu_show): Pass 0 for DO_TIMERS to popup_get_selection.
+ (xdialog_show): Pass 1 for DO_TIMERS to popup_get_selection.
+ Use an unwind-protect to pop down the dialog box.
+ (xdialog_show_unwind): New subroutine implements that.
+
+ * xdisp.c (row_containing_pos): Change exit test using last_y.
+ (try_window_id): Abort if row_containing_pos returns null.
+
+ * lread.c (load_error_handler): New function.
+ (Fload): Handle errors in Fsubstitute_in_file_name.
+ Don't expect Fsignal to return.
+
+ * eval.c: Errors and throws work right with interrupt blocking.
+ (struct catchtag): New elt interrupt_input_blocked.
+ (unwind_to_catch): Restore interrupt_input_blocked from saved value.
+ (internal_catch, Fcondition_case, internal_condition_case)
+ (internal_condition_case_1, internal_condition_case_2): Save it.
+ (Fsignal): Don't do TOTALLY_UNBLOCK_INPUT.
+
+ * editfns.c (Fformat): Add parens.
+
+ * dired.c (file_name_completion): Fix that change.
+ Delete special quit-handling code; just use QUIT.
+
+2002-12-21 Tak Ota <[email protected]>
+
+ * dired.c (file_name_completion): Close directory on error
+ just as in directory_files_internal.
+
+2002-12-19 David Kastrup <[email protected]>
+
+ * window.c (Fset_window_configuration): Set old_point to correct
+ value when new_current_buffer == current_buffer.
+
+2002-12-17 Ben Key <[email protected]>
+
+ Revisited my earlier fix for the following entry in etc/PROBLEMS:
+ "Emacs built on Windows 9x/ME crashes at startup on Windows XP,
+ or Emacs builtpart of on XP crashes at startup on Windows 9x/ME."
+
+ These changes were in part based upon suggestions made by Peter
+ 'Luna' Runestig [[email protected]].
+
+ * w32.c (g_b_init_is_windows_9x, g_b_init_open_process_token)
+ (g_b_init_get_token_information, g_b_init_lookup_account_sid)
+ (g_b_init_get_sid_identifier_authority ): Add several static
+ global variables.
+
+ * w32.c (globals_of_w32): New function. Used to initialize those
+ global variables that must always be initialized on startup even
+ when the global variable initialized is non zero. Its primary
+ purpose at this time is to set the global variables
+ g_b_init_is_windows_9x, g_b_init_open_process_token,
+ g_b_init_get_token_information, g_b_init_lookup_account_sid, and
+ g_b_init_get_sid_identifier_authority to 0 on startup.
+ Called from main.
+
+ * w32.c (is_windows_9x): Perform initialization only if
+ g_b_init_is_windows_9x is equal to 0. On initialization set
+ g_b_init_is_windows_9x equal to 1.
+
+ * w32.c (open_process_token): Perform initialization only if
+ g_b_init_open_process_token is equal to 0. On initialization set
+ g_b_init_open_process_token equal to 1.
+
+ * w32.c (get_token_information): Perform initialization only if
+ g_b_init_get_token_information is equal to 0. On initialization
+ set g_b_init_get_token_information equal to 1.
+
+ * w32.c (lookup_account_sid): Perform initialization only if
+ g_b_init_lookup_account_sid is equal to 0. On initialization
+ set g_b_init_lookup_account_sid equal to 1.
+
+ * w32.c (get_sid_identifier_authority): Perform initialization
+ only if g_b_init_get_sid_identifier_authority is equal to 0.
+ On initialization set g_b_init_get_sid_identifier_authority equal to 1.
+
+ * w32fns.c (globals_of_w32fns): New function. Used to initialize
+ those global variables that must always be initialized on startup
+ even when the global variable initialized is non zero.
+ Its primary purpose at this time is to initialize the global variable
+ track_mouse_event_fn.
+
+ * w32fns.c (w32_wnd_proc): Remove initialization of
+ track_mouse_event_fn from the handler for the WM_SETFOCUS message.
+
+ * w32fns.c (syms_of_w32fns): Call globals_of_w32fns.
+
+ * w32menu.c (globals_of_w32menu): New function. Used to
+ initialize those global variables that must always be initialized
+ on startup even when the global variable initialized is non zero.
+ Its primary purpose at this time is to initialize the global
+ variables get_menu_item_info and set_menu_item_info.
+
+ * w32menu.c (initialize_frame_menubar): Remove initialization of
+ get_menu_item_info and set_menu_item_info.
+
+ * w32menu.c (syms_of_w32menu): Call globals_of_w32menu.
+
+ * w32.h (globals_of_w32, globals_of_w32fns, globals_of_w32menu):
+ Declare them.
+
+ * emacs.c (main): Call globals_of_w32 prior to calling
+ init_environment if WINDOWSNT is defined. Call globals_of_w32fns
+ and globals_of_w32menu if initialized is non zero and HAVE_NTGUI
+ is defined.
+
+ * w32term.c (x_update_window_begin): Fix Windows API error
+ detected by BoundsChecker. Test to determine if
+ w32_system_caret_hwnd is NULL prior to attempting to use
+ SendMessage to send the WM_EMACS_HIDE_CARET message to it.
+
+ * w32term.c (x_update_window_end): Fix Windows API error
+ detected by BoundsChecker. Test to determine if
+ w32_system_caret_hwnd is NULL prior to attempting to use
+ SendMessage to send the WM_EMACS_SHOW_CARET message to it.
+
+2002-12-17 Kenichi Handa <[email protected]>
+
+ * coding.c (coding_system_require_warning): New variable.
+ (syms_of_coding): DEFVAR it.
+
+ * coding.h (coding_system_require_warning): Extern it.
+
+ * fileio.c (choose_write_coding_system): Even if
+ Vcoding_system_for_write is non-nil, if
+ coding_system_require_warning is nonzero, call
+ Vselect_safe_coding_system_function.
+
+2002-12-17 Markus Rost <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): Add cus-face and timer.
+ (lisp): Add font-core.
+
+2002-12-13 Stefan Monnier <[email protected]>
+
+ * textprop.c (text_read_only): New arg `propval'.
+ (get_char_property_and_overlay): Remove unused var `next_overlay'.
+ (verify_interval_modification): Use text_read_only's new arg.
+
+2002-12-13 Kenichi Handa <[email protected]>
+
+ * coding.c (Funencodable_char_position): Set pend correctly.
+
+2002-12-12 Jason Rumney <[email protected]>
+
+ * w32term.c (last_mousemove_x, last_mousemove_y): New variables.
+ (w32_read_socket) <WM_MOUSEMOVE>: Use them to detect non-movement.
+ Be more careful about when help_events are generated.
+
+2002-12-12 Steven Tamm <[email protected]>
+
+ * macterm.c (mac_check_for_quit_char): Correctly set the
+ modifiers of the event to 0.
+ * mac.c (sys_select): Duplicate rfds before calling select to
+ ensure that rfds survive the while loop.
+
+2002-12-11 Kim F. Storm <[email protected]>
+
+ * xdisp.c (try_window_id): Don't call set_cursor_from_row if
+ row_containing_pos returned NULL.
+
+2002-12-10 Steven Tamm <[email protected]>
+
+ * mac.c (sys_read): Fix sys_read to not call select if IO is
+ non-blocking.
+ (sys_select): Fix sys_select to not use a timeout larger than
+ the one given.
+
+2002-12-10 Juanma Barranquero <[email protected]>
+
+ * editfns.c (Fformat): Use alloca, not _alloca.
+
+2002-12-09 Richard M. Stallman <[email protected]>
+
+ * buffer.c (Fget_buffer_create): Call Qucs_set_table_for_input
+ as the last thing.
+
+2002-12-09 Dave Love <[email protected]>
+
+ * s/sol2-8.h: Removed. (Not necessary.)
+
+2002-12-09 Matthew Swift <[email protected]>
+
+ * editfns.c (Fformat): Handle precision in string conversion
+ specifiers like libc functions do (ie, print at most that many
+ characters).
+
+2002-12-08 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (row_containing_pos): Check more carefully
+ whether charpos is really in the row before returning it.
+
+2002-12-07 Steven Tamm <[email protected]>
+
+ * sysdep.c (emacs_read) [HAVE_CARBON]: Have emacs_read use sys_read.
+
+ * eval.c (Feval) [HAVE_CARBON]: Calls mac_check_for_quit_char at
+ each stack frame. This may change as it could be time consuming.
+
+ * macterm.c (mac_check_for_quit_char, quit_char_comp)
+ (init_quit_char_handler, mac_determine_quit_char_modifiers)
+ (mac_initialize): Add code to check for pressing of quit_char
+ in the OS event queue.
+
+ * mac.c (sys_select): Call mac_check_for_quit_char every second
+ while blocking on select.
+
+ * mac.c (sys_read): Use sys_select to test for input first
+ before calling read, to allow C-g to break.
+
+2002-12-07 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (Fcompleting_read): Doc fix.
+
+ * lread.c (syms_of_lread) <load-history>: Doc fix.
+
+ * fileio.c (Fcopy_file): Set immediate_quit around emacs_open call.
+
+ * eval.c (Fdefun, Fdefmacro): Record in load-history redefining an
+ autoload.
+
+ * data.c (Fdefalias): Record in load-history redefining an autoload.
+
+ * alloca.c: Undo ifdef change accidentally made on 12-04.
+
+2002-12-06 Francesco Potort,Al(B <[email protected]>
+
+ * xfns.c (png_load): Avoid double gamma correction for PNG images.
+
+2002-12-04 Richard M. Stallman <[email protected]>
+
+ * sysdep.c (fcntl.h): Test only HAVE_FCNTL_H.
+
+ * fileio.c (fcntl.h): Test only HAVE_FCNTL_H.
+
+ * alloca.c: Don't use #error.
+
+2002-12-03 Dave Love <[email protected]>
+
+ * buffer.c (Qucs_set_table_for_input): New.
+ (Fget_buffer_create): Use it.
+ (Qset_buffer_major_mode_hook): Deleted.
+ (Fset_buffer_major_mode): Revert previous change.
+ (init_buffer_once): Intern ucs-set-table-for-input.
+ (syms_of_buffer): Delete Qset_buffer_major_mode_hook.
+ Add &Qucs_set_table_for_input.
+
+2002-12-03 Andreas Schwab <[email protected]>
+
+ * callint.c (Fcall_interactively): Use next_event only if less
+ than key_count.
+
+2002-12-02 Andrew Choi <[email protected]>
+
+ * macmenu.c (add_menu_item, fill_menubar): Truncate menu item
+ names to 255 characters.
+
+ * macterm.c (XTread_socket): If all frames have been collapsed,
+ expand the first one before handling drag-and-drop events.
+
+ * s/darwin.h (GETPGRP_NO_ARG): Delete. Replaced by GETPGRP_VOID,
+ which is detected by autoconf.
+
+2002-12-01 Steven Tamm <[email protected]>
+
+ * unexmacosx.c (copy_twolevelhints, dump_it): Now corrects the
+ offset in two hints table to allow prebinding to be redone and
+ allow the executable to be stripped.
+
+2002-11-29 Dave Love <[email protected]>
+
+ * fns.c (Frequire): Don't call LOADHIST_ATTACH if feature was
+ already provided.
+
+2002-11-29 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (start_display): Check more intelligently for
+ whether the line is continued.
+ (move_it_vertically_backward): Clear it->continuation_lines_width.
+
+2002-11-28 Dave Love <[email protected]>
+
+ * s/amdahl.h, s/unipl5-0.h, m/sgi3000.h, s/3700.h, s/alliant-2800.h:
+ * s/alliant.h, s/altos.h: Deleted. (Unused/empty.)
+
+2002-11-27 Steven Tamm <[email protected]>
+
+ * fns.c (Frequire): Change nesting allowance from 2 to 3 to cause
+ more descriptive error output from lread.c:Fload upon most require
+ cycles during boostrapping.
+
+2002-11-27 Jason Rumney <[email protected]>
+
+ * fileio.c (Finsert_file_contents): Give a more appropriate error
+ for files bigger than 2Gb when off_t is 32 bit.
+
+ * dired.c (Ffile_attributes): Don't return negative file sizes for
+ files bigger than 2Gb when off_t is 32 bit.
+
+2002-11-27 Dave Love <[email protected]>
+
+ * s/irix6-0.h (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
+
+ * systty.h: Don't conditionally define GETPGRP_NO_ARG.
+ Test GETPGRP_VOID instead.
+ [BSD_TERMIOS]: Remove definitions (never used).
+
+ * s/osf5-0.h (WAIT_USE_INT, SYS_SIGLIST_DECLARED, sys_siglist):
+ Don't define.
+ (GC_SETJMP_WORKS, GC_MARK_STACK): Define.
+
+ * m/mips.h (WORDS_BIG_ENDIAN): Define conditionally.
+
+2002-11-25 Jason Rumney <[email protected]>
+
+ * w32.c (sys_write): Avoid non-blocking mode, which is not fully
+ supported.
+
+2002-11-25 Dave Love <[email protected]>
+
+ * unexalpha.c (update_dynamic_symbols): Cast arg of fatal_unexec.
+
+ * Makefile.in (TEMACS_LDFLAGS): Update last change.
+
+2002-11-25 Andreas Schwab <[email protected]>
+
+ * m/ia64.h: Restore `#ifndef NOT_C_CODE' deleted by last change.
+
+2002-11-24 Steven Tamm <[email protected]>
+
+ * unexmacosx.c (unexec_realloc): Use malloc_default_zone to
+ determine the size of pointers alloced in unexed space instead
+ of using possibly invalid emacs_zone pointers. This fixes the
+ binary incompatibility problems caused by updates to libSystem.B.
+
+2002-11-24 Richard M. Stallman <[email protected]>
+
+ * search.c (Fstring_match): Doc fix.
+
+ * callint.c (Fcall_interactively): If a command fails because
+ `*' detects a read-only buffer, but RECORD_FLAG is set,
+ record it anyway if the args don't actually do tty input.
+
+2002-11-22 Dave Love <[email protected]>
+
+ * sysdep.c (stuff_char) [PROTOTYPES]: Provide ISO C arglist.
+
+ * keyboard.c (interrupt_signal): Provide forward declaration.
+ (kbd_buffer_store_event): Don't declare interrupt_signal.
+
+ * xdisp.c (store_frame_title_char) [PROTOTYPES]: Provide ISO C arglist.
+
+2002-11-21 Richard M. Stallman <[email protected]>
+
+ * eval.c (interactive_p): Skip any number of bytecode
+ and special form frames, in any order.
+
+2002-11-20 Jason Rumney <[email protected]>
+
+ * w32fns.c (convert_mono_to_color_image): New function.
+ (xbm_load, xbm_load_image): Use it when foreground or background
+ is explicitly set.
+
+2002-11-19 Dave Love <[email protected]>
+
+ * s/usg5-4.h, sco4.h (bcopy, bzero, bcmp): Don't define.
+
+2002-11-18 Jason Rumney <[email protected]>
+
+ * w32fns.c (x_build_heuristic_mask): Filter palette info from color.
+ (XPutPixel): Swap blue and red.
+ (xpm_format, pbm_format, png_format, jpeg_format, tiff_format)
+ (gif_format, gs_format): Use IMAGE_ASCENT_VALUE.
+ (xpm_image_p, pbm_image_p, png_image_p, jpeg_image_p)
+ (tiff_image_p, gif_image_p, gs_image_p): Don't check ascent.
+
+2002-11-18 Dave Love <[email protected]>
+
+ * m/orion105.h (HAVE_ALLOCA): Don't define.
+
+ * m/m68k.h, m/arm.h, mtekxd88.h, m/tower32v3.h: Don't define alloca.
+
+ * m/intel386.h: Don't include alloca.h or define alloca.
+
+ * m/ia64.h: Don't include alloca.h, stdlib.h. Don't declare
+ malloc, realloc, calloc.
+
+ * m/hp800.h, m/sr2k.h, m/ns16000.h, m/wicat.h (bcopy, bzero)
+ (bcmp): Don't define.
+
+ * m/delta.h (bcopy, bzero, bcmp, alloca): Don't define.
+
+ * m/amdahl.h: Don't define LIB_STANDARD.
+
+ * m/alpha.h: Move OSF1 stuff from here to s/osf1.h.
+
+ * s/osf1.h: Move OSF1 stuff from m/alpha.h to here.
+
+ * s/irix4-0.h, s/irix5-0.h, m/powerpcle.h, m/sparc.h:
+ Don't include alloca.h.
+
+ * s/aix3-2.h (HAVE_FSYNC): Don't define.
+
+ * regex.c (_GNU_SOURCE): Don't define.
+
+ * process.c (_GNU_SOURCE): Don't define.
+
+ * fileio.c (_GNU_SOURCE, HAVE_FSYNC): Don't define.
+
+2002-11-18 Markus Rost <[email protected]>
+
+ * s/sol2-8.h: Include sol2-6.h.
+
+2002-11-18 Miles Bader <[email protected]>
+
+ * dispextern.h (struct face): Add `overstrike' field.
+ * xterm.c (x_draw_glyph_string_foreground)
+ (x_draw_composite_glyph_string_foreground): Implement overstriking.
+ * xfaces.c (load_face_font): Set `face->overstrike' based on
+ result from choose_face_font.
+ (best_matching_font, choose_face_font): Add `needs_overstrike'
+ argument, and use it to return whether overstriking is desirable
+ for this face/font combo.
+ (set_font_frame_param): Pass new argument to choose_face_font.
+
+2002-11-17 Ben Key <[email protected]>
+
+ This change is my fix for the following entry in etc/PROBLEMS:
+ "Emacs built on Windows 9x/ME crashes at startup on Windows XP,
+ or Emacs builtpart of on XP crashes at startup on Windows 9x/ME."
+
+ * w32.c: Added wrapper functions around the win32 API functions
+ OpenProcessToken, GetTokenInformation, LookupAccountSid, and
+ GetSidIdentifierAuthority. These wrapper functions serve two
+ purposes:
+ 1. They ensure that the wrapped function can never be called
+ when Emacs is running on an operating system on which they are
+ not supported (Microsoft Windows 95 / 98 / ME).
+ 2. They call the wrapped functions via function pointers rather
+ than calling them directly. This avoids taking advantage of the
+ undocumented fact that although these functions are not supported
+ in the 9x branch of Microsoft Windows, the functions do exist in
+ the version of advapi32.dll that is found in the 9x branch of
+ Microsoft Windows.
+
+ * w32.c (init_user_info): Replace the calls to the win32 API
+ functions OpenProcessToken, GetTokenInformation, LookupAccountSid,
+ and GetSidIdentifierAuthority with calls to the newly added
+ wrapper functions.
+
+ * w32.h: Added extern declarations for the following functions:
+ syms_of_w32term, syms_of_w32fns, syms_of_w32select,
+ syms_of_w32menu, and void syms_of_fontset.
+
+ * w32fns.c (w32_wnd_proc): Add code to reinitialize the
+ function pointer track_mouse_event_fn in the handler for the
+ WM_SETFOCUS message.
+
+ * w32menu.c (initialize_frame_menubar): Add code to
+ reinitialize the function pointers set_menu_item_info and
+ get_menu_item_info.
+
+2002-11-17 Ben Key <[email protected]>
+
+ * sound.c: Added a partial implementation of play-sound-internal
+ for Microsoft Windows. Added various #ifdef / #else / #endif
+ code blocks to separate the code that will compile under
+ Microsoft Windows from the code that is specific to GNU/Linux.
+ Moved several blocks of code around to make this separation of code
+ into Windows compatible and GNU/Linux compatible code blocks easier.
+
+ * makefile.w32-in: Include sound.c and link with WinMM.lib.
+
+ * s/ms-w32.h: Defined the symbol HAVE_SOUND so that the newly
+ added support for play-sound-internal under Windows would be
+ included in the build of Emacs.
+
+2002-11-16 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_load_system_font): Don't disable Cleartype.
+
+ * w32term.c (w32_get_glyph_string_clip_rect): Clip cursor tightly.
+
+2002-11-15 Stefan Monnier <[email protected]>
+
+ * keyboard.c (command_loop_1): Fix int/Lisp_Object mixup.
+ (adjust_point_for_property): Move out of display and invisible even if
+ we were already inside before (in case a property was added while
+ we weren't looking). Be more careful when handling invisible props.
+ Skip invisible text as if it really wasn't there at all.
+
+2002-11-15 Jason Rumney <[email protected]>
+
+ * w32term.c (x_draw_image_foreground)
+ (w32_draw_image_foreground_1): Use standard copy and invert
+ operations to draw images.
+
+ * w32fns.c (x_create_x_image_and_pixmap): Fill in palette for
+ depth of 1.
+ (xbm_read_bitmap_data): Invert bits as xbm is read in.
+ (XPutPixel): Don't invert bits here.
+
+2002-11-15 Jason Rumney <[email protected]>
+
+ * w32term.c (x_draw_image_foreground, x_draw_image_glyph_string)
+ (w32_draw_image_foreground_1): Handle image masks.
+ (x_draw_image_glyph_string): Don't BitBlt transparently.
+
+ * w32fns.c (w32_defined_color): Adjust RGB values for Emacs.
+ (x_from_xcolors): Adjust RGB values for W32.
+ (image_background, image_background_transparent)
+ (postprocess_image, x_to_xcolors, x_disable_image)
+ (x_build_heuristic_mask): Adapt for W32 and enable.
+ (x_create_x_image_and_pixmap): Mark images with palettes as such.
+ (xbm_load): Remove unused variable.
+
+2002-11-14 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer): Doc fix.
+
+2002-11-14 Dave Love <[email protected]>
+
+ * alloc.c (SETJMP_WILL_NOT_WORK): Add note.
+
+ * xterm.c (x_draw_relief_rect, x_draw_box_rect, x_update_cursor):
+ * xmenu.c (unuse_menu_items, digest_single_submenu):
+ * xfns.c (x_put_x_image):
+ * xdisp.c (message2_nolog, set_message):
+ * undo.c (record_point):
+ * terminfo.c (tparam):
+ * syntax.c (scan_sexps_forward):
+ * scroll.c (calculate_scrolling, calculate_direct_scrolling):
+ * composite.c (update_compositions):
+ * cm.c (calccost, cmgoto):
+ * charset.c (c_string_width): Declare all args (per C99).
+
+ * frame.h (get_specified_cursor_type, get_window_cursor_type): Declare.
+
+ * lisp.h (get_specified_cursor_type, get_window_cursor_type):
+ Don't declare.
+
+ * emacs.c (main) [!VMS]: Avoid third arg.
+
+ * fns.c (Fcopy_sequence): Doc fix.
+ (Fmap_char_table): Cast `call2'.
+
+2002-11-14 Francesco Potort,Al(B <[email protected]>
+
+ * s/sol2-8.h: New file.
+
+2002-11-14 Kim F. Storm <[email protected]>
+
+ * buffer.c (syms_of_buffer) <mode-line-format>: Document symbol
+ dependency on `risky-local-variable' and the :propertize form.
+
+2002-11-12 Stefan Monnier <[email protected]>
+
+ * fns.c (Fmap_char_table): Don't use map_char_table's function arg.
+
+ * syntax.c (scan_sexps_forward): Undo last patch.
+ Use a more obvious fix: check eob before updating the syntax table.
+
+2002-11-09 Stefan Monnier <[email protected]>
+
+ * syntax.c (scan_sexps_forward): Update syntax table before reading
+ a char rather than after so we don't update the table past eob.
+
+2002-11-09 Dave Love <[email protected]>
+
+ * buffer.c (Fset_buffer_major_mode): Fix last change.
+
+ * regex.c (regexec): Fix pmatch declaration.
+
+ * cmds.c (Fself_insert_command): Apply Vtranslation_table_for_input.
+
+ * keyboard.c (command_loop_1): Apply Vtranslation_table_for_input
+ to self-inserting characters.
+ (syms_of_keyboard) <keyboard-translate-table>: Doc fix.
+
+ * coding.c (Vtranslation_table_for_input): New.
+ (syms_of_coding): DEFVAR it.
+
+2002-11-08 Juanma Barranquero <[email protected]>
+
+ * w32term.c (w32_draw_fringe_bitmap): Remove unused local variable
+ window.
+
+2002-11-08 Pavel Jan,Am(Bk <[email protected]>
+
+ * process.c (Fformat_network_address): Remove unused locals p,
+ cp, and i.
+
+2002-11-06 Dave Love <[email protected]>
+
+ * buffer.c (Qset_buffer_major_mode_hook): New.
+ (Fset_buffer_major_mode): Use it.
+
+2002-11-06 Richard M. Stallman <[email protected]>
+
+ * xterm.c (x_term_init): Use turn_on_atimers, not start_polling
+ and stop_polling.
+
+ * process.c (wait_reading_process_input):
+ Test POLLING_PROBLEM_IN_SELECT, not hpux.
+ Avoid initialization for auto Lisp_Object var.
+
+ * s/hpux11.h (POLLING_PROBLEM_IN_SELECT): Add #undef.
+
+ * s/hpux10.h (POLLING_PROBLEM_IN_SELECT): Defined.
+
+2002-11-05 Richard M. Stallman <[email protected]>
+
+ * s/sol2-5.h (BROKEN_SIGIO): Turn off the #undef.
+
+ * callint.c (Fcall_interactively): New local filter_specs.
+ (Fcall_interactively): Check for progn as well as let.
+ Add a gcpro.
+ (Qprogn): New variable.
+ (syms_of_callint): Staticpro and init Qprogn.
+
+2002-11-04 John Paul Wallington <[email protected]>
+
+ * lread.c (Feval_buffer): Doc fix.
+
+2002-11-04 Dave Love <[email protected]>
+
+ * keyboard.c (read_char): Always translate iff
+ Vkeyboard_translate_table is a char table and c is valid.
+
+ * xterm.c (XTread_socket): Check Lisp types for Vx_keysym_table
+ and fix C types.
+
+2002-11-03 Stefan Monnier <[email protected]>
+
+ * xdisp.c (single_display_prop_intangible_p): Strings are intangible.
+
+ * editfns.c (get_pos_property): Don't hardcode Qfield.
+
+ * keyboard.c (adjust_point_for_property): Handle `display' prop on
+ overlays. Also handle `invisible' prop.
+
+2002-11-02 Stefan Monnier <[email protected]>
+
+ * coding.c (decode_coding_emacs_mule, decode_coding_iso2022)
+ (decode_coding_sjis_big5, decode_eol): Allow lone \r in DOS EOL.
+
+2002-11-01 Andreas Schwab <[email protected]>
+
+ * editfns.c (Fmessage): Revert last change to properly handle %%.
+
+2002-11-01 Stefan Monnier <[email protected]>
+
+ * xmenu.c (unuse_menu_items): New fun.
+ (menu_items_inuse): New var.
+ (syms_of_xmenu): Initialize it.
+ (init_menu_items): Use it to detect re-entrance.
+ (Fx_popup_menu, Fx_popup_dialog, set_frame_menubar): Reset when done.
+ (Fx_popup_menu): Remove spurious XSETFRAME.
+
+ * editfns.c (find_field): Make an exception for nil fields.
+
+2002-11-01 Dave Love <[email protected]>
+
+ * m/gec63.h: Deleted.
+
+2002-10-31 Dave Love <[email protected]>
+
+ * xterm.c (XTread_socket): Fix last change.
+ (xaw_scroll_callback): Cast call_data to long to avoid warning.
+
+2002-10-31 Stefan Monnier <[email protected]>
+
+ * process.c (Fformat_network_address): Fix int/Lisp_Object mixup.
+
+2002-10-30 Stefan Monnier <[email protected]>
+
+ * editfns.c (overlays_around, get_pos_property): New funs.
+ (find_field): Use them.
+ Also be careful not to modify POS before its last use.
+ (Fmessage): Don't Fformat if there's nothing to format.
+
+2002-10-30 Dave Love <[email protected]>
+
+ * process.c [HAVE_SYS_WAIT]: Include sys/wait.h.
+ [HAVE_PTY_H]; Include pty.h.
+
+ * lread.c (Fload) <!load_dangerous_libraries>: Close fd.
+
+ * xterm.c (Qeql): Declare.
+ (Vx_keysym_table): New.
+ (syms_of_xterm): Initialize it.
+ (XTread_socket): Use it. Deal with ASCII keysyms.
+ (XSetIMValues) [HAVE_X11R6]: Prototype.
+
+ * keyboard.c (lispy_accent_codes, lispy_accent_keys): Extended.
+ (lispy_kana_keys): Comment out.
+ (make_lispy_event) [XK_kana_A]: Comment out.
+ (modify_event_symbol) <sizeof (long) == sizeof (EMACS_INT)>:
+ Fix sprintf call.
+
+ * s/osf5-0.h (C_SWITCH_SYSTEM): Revert last change (fixed by
+ regexp.h change).
+ (TERMINFO, LIBS_TERMCAP): Define.
+
+ * s/usg5-4.h (bcopy, bzero): Define conditional on HAVE_BCOPY.
+ (bcmp): Define conditional on HAVE_BCMP.
+ (NO_SIOCTL_H): Don't define.
+ (TIOCSIGSEND): Don't make conditional on IRIX6.
+
+ * s/sol2-5.h: Don't include strings.h.
+ (bcopy, bzero, bcmp) [HAVE_BCOPY]: Don't undef.
+
+ * s/irix6-0.h (IRIX6): Don't define.
+ (bcopy, bcmp, bzero): Don't undef.
+
+ * s/irix6-5.h: Don't include strings.h.
+ (IRIX6): Don't define.
+ (bcopy, bcmp, bzero): Don't undef.
+
+ * syntax.c (Fforward_comment): Doc fix.
+
+2002-10-29 Kim F. Storm <[email protected]>
+
+ * process.c (Fsignal_process): Allow PROCESS to be specified by
+ name in addition to pid (as integer or string).
+
+2002-10-28 Harald Maier <[email protected]> (tiny change)
+
+ * w32heap.c: Don't redefine _heap_init and _heap_term on MSVC 7 build
+ environments.
+
+2002-10-27 Kim F. Storm <[email protected]>
+
+ * xterm.c (note_mouse_highlight): Don't use mouse-face if hidden.
+
+ * w32term.c (note_mouse_highlight): Don't use mouse-face if hidden.
+
+ * msdos.c (IT_note_mouse_highlight): Don't use mouse-face if hidden.
+
+ * macterm.c (note_mouse_highlight): Don't use mouse-face if hidden.
+
+2002-10-26 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fformat): Detect invalid format letters for floats.
+
+2002-10-25 Kenichi Handa <[email protected]>
+
+ * xfns.c (x_set_name): Encode by Qcompound_text unconditionally.
+ (x_set_title): Likewise.
+
+2002-10-25 Juanma Barranquero <[email protected]>
+
+ * macgui.h:
+ * w32gui.h: Remove definition of XColor.
+
+ * dispextern.h [!HAVE_X_WINDOWS]: Define XColor.
+
+2002-10-24 Kim F. Storm <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): New arg ACTIVE_CURSOR.
+ Callers changed (supply dummy arg).
+
+ * lisp.h (get_window_cursor_type): Update prototype.
+
+ * w32term.c (x_display_and_set_cursor): Get active_cursor from
+ get_window_cursor_type to track system caret.
+
+2002-10-24 Kim F. Storm <[email protected]>
+
+ * process.c (Fformat_network_address): New function.
+ (syms_of_process): Defsubr it.
+ (list_processes_1): Use it to format :local/:remote address if
+ service/host is not set; before Emacs would crash in that case.
+ (Fmake_network_process): Don't use Ffind_operation_coding_system
+ to setup coding system if host or service is not set.
+
+2002-10-23 Juanma Barranquero <[email protected]>
+
+ Patch suggested by Jay Finger <[email protected]>.
+
+ * w32term.c (w32_term_init): Pass XColor to w32_define_color, not
+ COLORREF.
+
+ * macgui.h:
+ * w32gui.h: Add definition of XColor.
+
+ * macfns.c:
+ * w32fns.c:
+ * xfaces.c: Remove definition of XColor.
+
+2002-10-22 Stefan Monnier <[email protected]>
+
+ * xfns.c (x_set_name, x_set_title): `icon.value' has unsigned char.
+
+ * window.c (window_loop): For GET_LRU_WINDOW and GET_LARGEST_WINDOW>,
+ Only ignore truly dedicated windows. For UNSHOW_BUFFER, delete the
+ window if it is dedicated.
+ (Fshrink_window): Add preserve_before as was done for enlarge_window.
+ (Vspecial_display_function): Update docstring.
+
+ * buffer.c (assoc_ignore_text_properties, Fother_buffer, Fkill_buffer)
+ (call_overlay_mod_hooks): Use CONSP and XCAR/XCDR.
+ (Fget_buffer_create, advance_to_char_boundary): Use BEG and BEG_BYTE.
+
+2002-10-21 Stefan Monnier <[email protected]>
+
+ * casefiddle.c (casify_region): Don't treat a prefix char as part
+ of a word when at the beginning.
+
+2002-10-17 Juanma Barranquero <[email protected]>
+
+ * lread.c (syms_of_lread): Fix typos.
+
+2002-10-17 Dave Love <[email protected]>
+
+ * Makefile.in (TEMACS_LDFLAGS): Add trailing comment.
+
+2002-10-16 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fcopy_file): Fix backward test of KEEP_TIME.
+
+2002-10-14 Juanma Barranquero <[email protected]>
+
+ * w16select.c (syms_of_win16select): Fix docstring for
+ `selection-coding-system'.
+
+ * w32select.c (syms_of_w32select): Likewise.
+
+2002-10-14 Stefan Monnier <[email protected]>
+
+ * syntax.c (scan_lists): Don't get fooled by a symbol ending with
+ a backslash-quoted char.
+ (scan_lists, scan_sexps_forward): Pacify the compiler.
+
+2002-10-13 Richard M. Stallman <[email protected]>
+
+ * window.c (window_scroll): Set immediate_quit.
+
+ * print.c (print): When backquote form is the car of a list,
+ output in old style. Use old_backquote_output to output all
+ comma forms inside it in old style too.
+
+ * buffer.h (struct buffer): Move `undo_list' down below `name'.
+
+2002-10-11 Markus Rost <[email protected]>
+
+ * emacs.c (syms_of_emacs) <kill-emacs-hook>: Doc fix (not run in
+ batch mode).
+
+ * lread.c (Fload): Doc fix (load-suffixes).
+
+2002-10-10 Steven Tamm <[email protected]>
+
+ * macterm.c (syms_of_macterm, mac_get_mouse_btn):
+ Reverse functionality of mac-wheel-button-is-mouse-2 to be correct.
+ Also switch the default to Qnil from Qt.
+
+2002-10-08 Kenichi Handa <[email protected]>
+
+ * coding.c (code_convert_region): When we need more GAP for
+ conversion, pay attention to the case that coding->produced is not
+ greater than coding->consumed.
+
+2002-10-07 Richard M. Stallman <[email protected]>
+
+ * unexelf.c (unexec): Redo 9/16 change, but only if IRIX6_5.
+
+2002-10-06 Andrew Choi <[email protected]>
+
+ * macmenu.c (mac_menu_show): Add j to count menu items; match
+ menu_item_selection to it to find selected item.
+
+2002-10-06 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (XTread_socket): Fix from 2002-10-03 didn't cover all
+ cases. The correct fix is to pass ReparentNotify to Xt.
+ The shell widget interprets ConfigureNotify differently depending
+ on if it has been reparented or not.
+
+2002-10-05 Markus Rost <[email protected]>
+
+ * editfns.c (Fformat_time_string): Doc fix.
+
+2002-10-05 John Paul Wallington <[email protected]>
+
+ * fns.c (Flength): Doc fix.
+
+2002-10-04 Stefan Monnier <[email protected]>
+
+ * keyboard.c (keyremap): New struct.
+ (read_key_sequence): Use it: globally replace keytran_foo with
+ keytran.foo and fkey_foo with fkey.foo. Rename temp vars
+ keytran_next and fkey_next to just `next'.
+
+2002-10-04 Steven Tamm <[email protected]>
+
+ * macterm.c (keycode_to_xkeysym_table): Change return to be
+ treated like an X keysym.
+
+2002-10-03 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.c (XTread_socket): For ConfigureNotify, with x and y == 0,
+ and USE_MOTIF, call XTranslateCoordinates to get the real x and y.
+ This is to also handle x/y changes that occur because of a resize.
+
+2002-10-02 John Paul Wallington <[email protected]>
+
+ * frame.c (Vdelete_frame_functions): New variable.
+ (syms_of_frame): Initialize and defvar it.
+ (Fdelete_frame): Use it instead of delete-frame-hook. Don't run
+ it when frame's `tooltip' parameter is non-nil.
+
+ * xfns.c (x_create_tip_frame): Set `tooltip' frame parameter to t.
+
+ * w32fns.c (x_create_tip_frame): Likewise.
+
+ * macfns.c (x_create_tip_frame): Likewise.
+
+2002-09-30 Kenichi Handa <[email protected]>
+
+ * xterm.c (x_encode_char): For DIM=1 charset, set ccl->reg[2] to
+ -1 before calling ccl_driver.
+
+ * coding.c (decode_coding_emacs_mule): Check coding->cmp_data.
+ Only when it is non-nil, handle composition sequence.
+ (setup_coding_system) <0>: Don't force composition handling.
+
+ * Makefile.in (lisp, shortlisp): Add utf-16.elc.
+
+2002-09-29 Richard M. Stallman <[email protected]>
+
+ * search.c (Freplace_match): Adjust match data for the substitution
+ just made in the buffer.
+
+ * xdisp.c (STOP_POLLING, RESUME_POLLING): New macros.
+ (redisplay_internal): Use them. Do RESUME_POLLING at end of function.
+
+2002-09-27 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (STOP_POLLING, RESUME_POLLING): New macros.
+ (read_char): Use them. Do all exits thru the end of the function.
+
+2002-09-27 Kenichi Handa <[email protected]>
+
+ * xfaces.c (try_font_list): Pay attention to the case that FAMILY
+ is nil.
+
+2002-09-26 Richard M. Stallman <[email protected]>
+
+ * regex.h (__restrict_arr): Don't define if already defined.
+
+ * coding.c (run_pre_post_conversion_on_str):
+ Save and restore Vdeactivate_mark.
+
+2002-09-26 John Paul Wallington <[email protected]>
+
+ * minibuf.c (Fminibufferp): Add an optional `buffer' argument.
+
+2002-09-26 Kenichi Handa <[email protected]>
+
+ * xfaces.c (try_font_list): New arg PREFER_FACE_FAMILY. If it is
+ nonzero, try face's family at first. Otherwise try FAMILY at first.
+ (choose_face_font): If C is a single byte char or latin-1, call
+ try_font_list with PREFER_FACE_FAMILY 1.
+
+2002-09-21 Richard M. Stallman <[email protected]>
+
+ * window.c (select_window_1): Don't select frame.
+ Set frame's selected window only when frame itself is selected.
+ (Fselect_window): Doc fix.
+
+2002-09-18 Kim F. Storm <[email protected]>
+
+ * process.c (make-network-process): Doc fix (there is no
+ network-server-log-function hook).
+
+2002-09-18 Richard M. Stallman <[email protected]>
+
+ * print.c (print): Clear out the unused parts of Vprint_number_table.
+ (syms_of_print): Doc fix for `print-number-table'.
+
+ * unexelf.c (unexec): Undo previous change.
+
+2002-09-17 Andreas Schwab <[email protected]>
+
+ * m/alpha.h [LINUX]: Don't define DATA_START.
+
+2002-09-16 Dave Love <[email protected]>
+
+ * unexelf.c (unexec): Deal with .got, reinstating change from
+ 25-08-1999.
+
+2002-09-13 Richard M. Stallman <[email protected]>
+
+ * s/sol2-6.h (UNEXEC): Comment out definition.
+
+ * unexsol.c (unexec): Don't downcase first letter of error msg.
+
+ * xfaces.c (Fcolor_supported_p): Just one arg is required.
+
+2002-09-12 Markus Rost <[email protected]>
+
+ * unexsol.c: Include buffer.h, charset.h, coding.h.
+
+2002-09-11 Richard M. Stallman <[email protected]>
+
+ * unexsol.c: Don't use report_file_error; do it by hand
+ using dlerror.
+
+ * process.c (wait_reading_process_input, both versions):
+ Before calling turn_on_atimers, call stop_polling.
+
+ * emacs.c (syms_of_emacs) <command-line-args>: Doc fix.
+
+ * xdisp.c (try_scrolling): If after make_cursor_line_fully_visible
+ we go to too_near_end, call clear_glyph_matrix.
+ (redisplay_window): After make_cursor_line_fully_visible,
+ call clear_glyph_matrix and bypass `goto done'.
+
+ * xfns.c (x_report_frame_params): If FRAME_SCROLL_BAR_PIXEL_WIDTH is 0
+ and we have non-toolkit scroll bars, return nil for scroll-bar-width.
+
+2002-09-10 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fdo_auto_save): Catch error making directory.
+ Only call push_message if we need to.
+ At the same time, make an unwind-protect to pop it.
+ Rename local message_p to old_message_p.
+ (do_auto_save_make_dir, do_auto_save_eh): New functions.
+ (do_auto_save_unwind): Don't call pop_message.
+
+ * lisp.h (pop_message_unwind): Renamed from push_message_unwind.
+
+ * keyboard.c (Fexecute_extended_command): Use pop_message_unwind.
+
+ * alloc.c (Fgarbage_collect): Use pop_message_unwind.
+
+ * xdisp.c (pop_message_unwind): Renamed from push_message_unwind.
+
+2002-09-10 Stefan Monnier <[email protected]>
+
+ * regex.c (DISCARD_FAILURE_REG_OR_COUNT): Delete.
+ (CHECK_INFINITE_LOOP): Don't pop anything: just set `cycle' to 1.
+ (re_match_2_internal): Be more careful with infinite loops.
+
+2002-09-10 Kim F. Storm <[email protected]>
+
+ * macros.c (end_kbd_macro): New function.
+ (Fend_kbd_macro): Use it.
+
+ * macros.h (end_kbd_macro): Declare extern.
+
+ * keyboard.c (Fdiscard_input): If defining keyboard macro,
+ end and save it instead of discarding it.
+
+2002-09-09 Markus Rost <[email protected]>
+
+ * s/sol2-6.h: Fix typo. Add comment.
+
+2002-09-09 Richard M. Stallman <[email protected]>
+
+ * regex.c (regnum_t): Use signed int, not unsigned int.
+
+ * s/sol2-6.h: New file.
+
+ * s/sol2-5.h (UNEXEC): Definition deleted.
+
+2002-09-08 Kim F. Storm <[email protected]>
+
+ * macros.c (executing_macro_index): Change type to EMACS_INT.
+ (syms_of_macros): DEFVAR_INT it (needed by kmacro).
+
+ * macros.h (executing_macro_index): Change type to EMACS_INT.
+
+2002-09-06 Richard M. Stallman <[email protected]>
+
+ * casetab.c (set_case_table): Make canon table point to eqv table.
+
+2002-09-06 Juanma Barranquero <[email protected]>
+
+ * coding.c (syms_of_coding): Fix spacing.
+
+ * composite.c (Fcompose_region_internal)
+ (Fcompose_string_internal): Likewise.
+
+ * data.c (Flsh): Likewise.
+
+ * fontset.c (Fset_fontset_font): Likewise.
+
+ * macfns.c (Fx_server_max_request_size): Likewise.
+
+ * w16select.c (syms_of_win16select): Likewise.
+
+ * w32select.c (syms_of_w32select): Likewise.
+
+ * xselect.c (syms_of_xselect): Likewise.
+
+2002-09-05 Richard M. Stallman <[email protected]>
+
+ * regex.c (set_image_of_range_1): In no-TRANSLATE case,
+ call EXTEND_RANGE_TABLE and return a proper value.
+ (set_image_of_range): Don't call set_image_of_range_1
+ if no TRANSLATE or if range includes all of Latin-1.
+ Only call it for the Latin-1 part of the range.
+ For other cases, make two separate ranges,
+ one for the original specified characters and one for
+ their case-conversions.
+
+2002-09-04 Richard M. Stallman <[email protected]>
+
+ * s/sol2-5.h (UNEXEC): Use unexsol.o.
+
+ * window.c (displayed_window_lines): Correct for one-off bug
+ in HEIGHT on non-window displays.
+
+ * regex.c (set_image_of_range_1): New function.
+ (set_image_of_range): Use set_image_of_range_1 for Latin-1.
+ Return a value to indicate running out of memory.
+ (SET_RANGE_TABLE_WORK_AREA): Check value from set_image_of_range.
+ (extend_range_table_work_area): New subroutine.
+ (EXTEND_RANGE_TABLE): Replaces EXTEND_RANGE_TABLE_WORK_AREA.
+ Different calling conventions, and used from set_image_of_range{,_1}.
+ (IMMEDIATE_QUIT_CHECK): Definitions moved.
+
+2002-09-04 Juanma Barranquero <[email protected]>
+
+ * makefile.w32-in: All dependencies updated.
+
+2002-09-01 Richard M. Stallman <[email protected]>
+
+ * unexsol.c: New file.
+
+ * xfns.c (Qbox): Declare external, don't define.
+
+ * xdisp.c (redisplay_window) <force-start case>:
+ If point is on semi-visible last line, reposition
+ it at previous line.
+
+ * alloc.c (display_malloc_warning): Use display-warning.
+ (malloc_warning_1): Function deleted.
+
+ * alloc.c [ALLOC_DEBUG]: #undef INLINE.
+
+ * lread.c (read1): Handle #! by skipping the line.
+
+2002-08-31 Richard M. Stallman <[email protected]>
+
+ * Makefile.in (TEMACS_LDFLAGS): Renamed from ALL_LDFLAGS.
+ Don't include LDFLAGS.
+ (temacs): Pass LDFLAGS separately, and not via YMF_PASS_LDFLAGS.
+
+2002-08-31 Eli Zaretskii <[email protected]>
+
+ * xdisp.c (get_window_cursor_type): Don't use x_highlight_frame
+ member of x_display_info unless we compile for some window system.
+
+2002-08-31 Kim F. Storm <[email protected]>
+
+ * xdisp.c (Valternate_cursor_type, Qalternate_cursor_type): Removed.
+ (get_window_cursor_type): Don't use them.
+ (syms_of_xdisp): Remove intern, staticpro, and defvar for them.
+
+2002-08-30 Kenichi Handa <[email protected]>
+
+ * xdisp.c (get_next_display_element): Fix previous change.
+
+2002-08-30 Andrew Choi <[email protected]>
+
+ * macterm.c (expose_overlaps): New function (merge code from xterm.c).
+ (expose_window): Use it to fix the display of overlapping
+ rows (merge code from xterm.c).
+
+ * macfns.c (Qbox): Add extern declaration.
+
+2002-08-30 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (Qbox): Make extern.
+ (syms_of_w32fns): Remove initialization of Qbox.
+
+2002-08-30 Rune Kleveland <[email protected]> (tiny change)
+
+ * xfns.c (Fx_open_connection): Fix error message.
+
+2002-08-30 Kim F. Storm <[email protected]>
+
+ The following changes consolidates the handling of the cursor
+ type in xdisp.c, moving duplicate code and functionality from
+ xfns.c, xterm.c, w32fns.c, w32term.c, macfns.c, and macterm.c.
+
+ * frame.h (enum text_cursor_kinds): Consolidated here.
+ Added DEFAULT_CURSOR value.
+ (struct frame) <desired_cursor, cursor_width>
+ <blink_off_cursor, blink_off_cursor_width>: New fields.
+ Consolidated from output_x, output_w32 and output_mac structs.
+ (FRAME_DESIRED_CURSOR, FRAME_CURSOR_WIDTH, FRAME_BLINK_OFF_CURSOR)
+ (FRAME_BLINK_OFF_CURSOR_WIDTH): Macros consolidated here.
+
+ * xdisp.c (Qbar, Qhbar, Qbox, Qhollow, Vblink_cursor_alist):
+ Variables consolidated here.
+ (Valternate_cursor_type, Qalternate_cursor_type): New variables.
+ (Vcursor_in_non_selected_windows): Renamed from
+ cursor_in_non_selected_windows and changed to Lisp_Object.
+ (syms_of_xdisp): Define and staticpro new and moved variables.
+ (get_specified_cursor_type): Renamed from x_specified_cursor_type;
+ consolidated here. Recognize Qhollow setting.
+ (set_frame_cursor_types): New function to set frame cursor types
+ based on the frame parameters.
+ (get_window_cursor_type): New function to calculate new cursor
+ type and width for the specified window. Based on duplicated
+ code consolidated here.
+ Enhancements: cursor-in-non-selected-windows may be a cursor type,
+ check buffer-local alternate-cursor-type and blink-cursor-alist
+ before using built-in blink off methods.
+
+ * dispextern.h (cursor_in_non_selected_windows): Extern removed.
+
+ * lisp.h (Qcursor_in_non_selected_windows): Extern removed.
+ (get_specified_cursor_type, get_window_cursor_type)
+ (set_frame_cursor_types): Added prototypes.
+
+ * macfns.c (x_specified_cursor_type): Removed.
+ (x_set_cursor_type): Use set_frame_cursor_types.
+ (Qbar, Qbox): Removed.
+ (syms_of_macfns): Don't intern or staticpro them.
+
+ * macterm.c (x_specified_cursor_type): Remove prototype.
+ (x_draw_bar_cursor): Use FRAME_CURSOR_WIDTH.
+ (x_display_and_set_cursor): Use get_window_cursor_type.
+ Remove unused local variables cursor_non_selected, active_cursor.
+ Redraw cursor if hbar cursor width changes.
+ (make_mac_frame): Set FRAME_DESIRED_CURSOR.
+
+ * macterm.h (enum text_cursor_kinds): Removed.
+ (struct output_mac) <current_cursor, desired_cursor, cursor_width>
+ <blink_off_cursor, blink_off_cursor_width>: Members removed.
+ (FRAME_DESIRED_CURSOR): Macro removed.
+
+ * w32fns.c (Vblink_cursor_alist): Removed.
+ (Qbar, Qhbar, Qbox, Qhollow): Removed.
+ (syms_of_w32fns): Don't intern, staticpro, or define them.
+ (x_specified_cursor_type): Removed.
+ (x_set_cursor_type): Use set_frame_cursor_types.
+
+ * w32term.c (x_specified_cursor_type): Remove prototype.
+ (x_draw_bar_cursor): Use FRAME_CURSOR_WIDTH.
+ (x_display_and_set_cursor): Use get_window_cursor_type.
+ Remove unused local variables cursor_off_state.
+ Redraw cursor if hbar cursor width changes.
+ Changed all occurrences of w32_highlight_frame to x_highlight_frame.
+
+ * w32term.h (enum text_cursor_kinds): Removed.
+ (struct output_w32) <current_cursor, desired_cursor, cursor_width>
+ <blink_off_cursor, blink_off_cursor_width>: Members removed.
+ (FRAME_DESIRED_CURSOR, FRAME_CURSOR_WIDTH, FRAME_BLINK_OFF_CURSOR)
+ (FRAME_BLINK_OFF_CURSOR_WIDTH): Macros removed.
+ (struct w32_display_info) <x_highlight_frame>: Renamed member from
+ w32_highlight_frame.
+
+ * xfns.c (Vblink_cursor_alist): Removed.
+ (Qbar, Qhbar, Qbox, Qhollow): Removed.
+ (syms_of_xfns): Don't intern, staticpro, or define them.
+ (x_specified_cursor_type): Removed.
+ (x_set_cursor_type): Use set_frame_cursor_types.
+
+ * xterm.c (x_specified_cursor_type): Remove prototype.
+ (x_draw_bar_cursor): Use FRAME_CURSOR_WIDTH.
+ (x_display_and_set_cursor): Use get_window_cursor_type.
+ Remove unused local variables cursor_off_state.
+ Redraw cursor if hbar cursor width changes.
+
+ * xterm.h (enum text_cursor_kinds): Removed.
+ (struct output_x) <current_cursor, desired_cursor, cursor_width>
+ <blink_off_cursor, blink_off_cursor_width>: Members removed.
+ (FRAME_DESIRED_CURSOR, FRAME_CURSOR_WIDTH, FRAME_BLINK_OFF_CURSOR)
+ (FRAME_BLINK_OFF_CURSOR_WIDTH): Macros removed.
+ (x_specified_cursor_type): Remove prototype.
+
+2002-08-28 Richard M. Stallman <[email protected]>
+
+ * w32fns.c (x_set_cursor_type): Set FRAME_BLINK_OFF_CURSOR and
+ FRAME_BLINK_OFF_CURSOR_WIDTH using defaults and Vblink_cursor_alist.
+ (Vblink_cursor_alist): New variable.
+ (syms_of_w32fns): Initialize and defvar it.
+ (x_specified_cursor_type): Recognize Qbox for filled box.
+ Exceptions are hollow boxes.
+ (Qbox, Qhollow): New variables.
+ (syms_of_w32fns): Initialize and staticpro them.
+
+ * w32term.h (FRAME_BLINK_OFF_CURSOR, FRAME_BLINK_OFF_CURSOR_WIDTH):
+ New macros.
+ (struct w32_output): New fields blink_off_cursor,
+ blink_off_cursor_width.
+ (FRAME_CURSOR_WIDTH): New macro.
+
+ * w32term.c (x_display_and_set_cursor): Use FRAME_BLINK_OFF_CURSOR
+ and FRAME_BLINK_OFF_CURSOR_WIDTH for blinking cursor off.
+
+ * w32term.c (x_display_and_set_cursor): Check FRAME_CURSOR_WIDTH
+ for bar cursor.
+
+ * w32term.c (expose_overlaps): New function.
+ (expose_window): Use it to fix the display of overlapping rows.
+
+2002-08-28 Simon Josefsson <[email protected]>
+
+ * xfns.c (Fx_open_connection): Improve help when X connection
+ fails, xhost is insecure and xauth is better.
+
+2002-08-28 Juanma Barranquero <[email protected]>
+
+ * makefile.w32-in: Add missing dependencies on w32term.h and
+ composite.h.
+
+ * emacs.c (USAGE1): Add missing newline.
+
+2002-08-27 Andrew Choi <[email protected]>
+
+ * s/darwin.h [HAVE_LIBNCURSES]: Define HAVE_TERMINFO.
+
+2002-08-27 Richard M. Stallman <[email protected]>
+
+ * xfns.c (x_set_cursor_type): Set FRAME_BLINK_OFF_CURSOR and
+ FRAME_BLINK_OFF_CURSOR_WIDTH using defaults and Vblink_cursor_alist.
+ (Vblink_cursor_alist): New variable.
+ (syms_of_xfns): Initialize and defvar it.
+ (x_specified_cursor_type): Recognize Qbox for filled box.
+ Exceptions are hollow boxes.
+ (Qbox, Qhollow): New variables.
+ (syms_of_xfns): Initialize and staticpro them.
+
+ * xterm.h (FRAME_BLINK_OFF_CURSOR, FRAME_BLINK_OFF_CURSOR_WIDTH):
+ New macros.
+ (struct x_output): New fields blink_off_cursor, blink_off_cursor_width.
+
+ * xterm.c (x_display_and_set_cursor): Use FRAME_BLINK_OFF_CURSOR
+ and FRAME_BLINK_OFF_CURSOR_WIDTH for blinking cursor off.
+
+ * emacs.c (main): Handle --script.
+ (USAGE1): Mention --script.
+ (standard_args): Define sort order for --script.
+
+2002-08-27 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (redisplay_updating_p): Variable removed.
+ (inhibit_free_realized_faces, Qinhibit_free_realized_faces):
+ New variables.
+ (init_iterator): Don't free realized faces if
+ inhibit_free_realized_faces is set.
+ (redisplay_internal): Bind Qinhibit_free_realized_faces to nil.
+ (syms_of_xdisp): DEFVAR_BOOL inhibit-free-realized-faces,
+ initialize Qinhibit_free_realized_faces.
+
+ * dispextern.h (PRODUCE_GLYPHS): Set inhibit_free_realized_faces
+ when iterator is adding glyphs to a glyph matrix.
+
+2002-08-27 Kenichi Handa <[email protected]>
+
+ * xdisp.c (get_next_display_element): In unibyte case, don't use
+ octal form for such eight-bit characters that can be converted to
+ multibyte char.
+
+2002-08-26 Kim F. Storm <[email protected]>
+
+ * frame.c (make_terminal_frame) [CANNOT_DUMP]: Initialize
+ foreground and background colors. From Joe Buehler.
+
+2002-08-26 Miles Bader <[email protected]>
+
+ * bytecode.c (Fbyte_code): Fsub1 can GC, so protect it.
+
+2002-08-25 Andrew Choi <[email protected]>
+
+ * emacs.c (main): Call init_mac_osx_environment if HAVE_CARBON is
+ defined instead of MAC_OSX.
+
+ * s/darwin.h (select): Define select to sys_select only if
+ HAVE_CARBON is defined.
+ (HAVE_WORKING_VFORK): #undef it. Define vfork to fork.
+ (DONT_REOPEN_PTY): #def it.
+
+ * macterm.c (XTread_socket): Remove code to call
+ SendEventToEventTarget for keys with command modifiers when
+ mac_command_key_is_meta is nil.
+
+2002-08-24 Andreas Schwab <[email protected]>
+
+ * eval.c (Fdefvar): Fix last change.
+
+2002-08-23 Richard M. Stallman <[email protected]>
+
+ * eval.c (Fdefvar, Fdefconst, Fdefvaralias):
+ Record variables in load history as (defvar . VAR).
+ (Fdefvar): Don't record in load history if no initial value.
+ (Qdefvar): New variable.
+ (syms_of_eval): Init and staticpro it.
+
+ * lread.c (syms_of_lread): Doc fix.
+ (build_load_history): Use Fmember to see if a definition
+ is already in the Vload_history element.
+
+ * process.c (Fstart_process): Remove /: from program name.
+
+ * emacs.c (decode_env_path): Don't add /: if file name handler
+ has a `safe-magic' property.
+
+ * callproc.c (Fcall_process): Remove /: from program name.
+
+2002-08-23 Stefan Monnier <[email protected]>
+
+ * regex.c (PATFETCH): Remove the translating fetch.
+ (PATFETCH_RAW): Rename to PATFETCH.
+ (set_image_of_range): New fun.
+ (SET_RANGE_TABLE_WORK_AREA): Use it.
+ (regex_compile): Don't translate the pattern chars so eagerly.
+ Only do it when inserting an `exactn' bytecode or when handling
+ a char-range.
+ (mutually_exclusive_p): Avoid empty statement.
+
+2002-08-22 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Do not `goto try_to_scroll' when we
+ end up on a partially visible line; this reverts a specific part
+ of the 2002-07-07 change by Richard M. Stallman to "fix" a nasty
+ display error which has been reported several times now.
+ However it introduces the problem that changes was supposed to fix.
+ See my comments in the source if you want to debug this further.
+
+2002-08-20 Kenichi Handa <[email protected]>
+
+ * abbrev.c (Fexpand_abbrev): Fix for the multibyte case.
+
+2002-08-19 Eli Zaretskii <[email protected]>
+
+ * msdos.c (croak): Add `void' to definition.
+
+ * sysdep.c (request_sigio, unrequest_sigio) [MSDOS]:
+ Don't define them, they are defined in msdos.c.
+
+ * mem-limits.h [MSDOS]: Declare etext.
+
+ * fileio.c (Ffile_name_directory) [DOS_NT]: Don't declare `beg'
+ `const' since CORRECT_DIR_SEPS modifies its target.
+
+2002-08-19 Kim F. Storm <[email protected]>
+
+ * keyboard.c (Fclear_this_command_keys): Add optional arg
+ KEEP-RECORD to avoid clearing lossage when we just want to clear
+ the current key sequence (kmacro needs this).
+
+2002-08-19 Kenichi Handa <handa@localhost>
+
+ * composite.c (run_composition_function): Call FUNC if it is fboundp.
+
+ * composite.h (COMPOSITION_MODIFICATION_FUNC): If PROP is not a
+ cons, return Qnil.
+
+2002-08-17 Richard M. Stallman <[email protected]>
+
+ * s/sol2-5.h (BROKEN_SIGIO): Add #undef.
+
+ * sysdep.c [!VMS]: Include sys/files.h.
+
+ * editfns.c (save_restriction_restore): Defend from unchained marker.
+
+ * buffer.c (overlays_at): Handle extending vec uniformly.
+ (overlays_in): Handle extending vec from length 0 as in overlays_at.
+
+2002-08-15 Andrew Choi <[email protected]>
+
+ * mac.c (init_mac_osx_environment): New function.
+
+ * emacs.c (main) [MAC_OSX]: Call init_mac_osx_environment.
+
+2002-08-14 Kim F. Storm <[email protected]>
+
+ * macros.c (Fstart_kbd_macro): Added NO-EXEC argument to inhibit
+ executing macro before appending to it (when used from Lisp).
+ (Fexecute_kbd_macro): Added LOOPFUNC argument to supply function
+ which is called prior to each iteration of macro (for kmacro.el).
+ (Fend_kbd_macro, Fcall_last_kbd_macro): Likewise.
+
+ * lisp.h (Fexecute_kbd_macro): Update prototype.
+
+ * keyboard.c (Fcommand_execute): Update call to Fexecute_kbd_macro.
+
+2002-08-14 Kenichi Handa <[email protected]>
+
+ * xselect.c (QUTF8_STRING): New variable.
+ (symbol_to_x_atom): Pay attention to QUTF8_STRING.
+ (x_atom_to_symbol): Likewise.
+ (x_get_local_selection): New argument local_request. If it is
+ nonzero, call handler_fn with the second arg nil.
+ (x_handle_selection_request): Call x_get_local_selection with
+ local_request 0.
+ (lisp_data_to_selection_data): Don't encode the string here.
+ (Fx_get_selection_internal): Call x_get_local_selection with
+ local_request 1.
+ (syms_of_xselect): Intern and staticpro QUTF8_STRING.
+
+ * xterm.c (x_term_init): Initialize dpyinfo->Xatom_UTF8_STRING.
+
+ * xterm.h (struct x_display_info): New member Xatom_UTF8_STRING.
+
+2002-08-13 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (Fminibufferp): New function.
+ (syms_of_minibuf): Defsubr it.
+ (Fminibuffer_prompt_end): Handle non-minibuffers specially.
+
+2002-08-13 Gerd Moellmann <[email protected]>
+
+ * coding.c (Funencodable_char_position): Lisp_Object/int mixup.
+
+2002-08-12 Richard M. Stallman <[email protected]>
+
+ * syswait.h: Only the include of sys/wait.h tests HAVE_SYS_WAIT_H.
+ [!VMS] (WCOREDUMP, WEXITSTATUS, WIFEXITED, WIFSTOPPED, WIFSIGNALED)
+ (WSTOPSIG, WTERMSIG): Define each one independently if not defined
+ already.
+
+ * buffer.c (syms_of_buffer) <fill-column>: Doc fix.
+
+2002-08-11 Andrew Choi <[email protected]>
+
+ * macterm.c (XTmouse_position): Check wp with is_emacs_window.
+ (Vmac_pass_command_to_system): New variable.
+ (Vmac_pass_control_to_system): New variable.
+ (do_mouse_moved): Check wp with is_emacs_window.
+ (XTread_socket): Check window_ptr with is_emacs_window.
+ Call FrontNonFloatingWindow instead of FrontWindow. Send keydown
+ events back to Mac Toolbox for processing, depending on values of
+ Vmac_pass_command_to_system and Vmac_pass_control_to_system.
+ (syms_of_macterm): DEFVAR_LISP Vmac_pass_command_to_system and
+ Vmac_pass_control_to_system.
+
+2002-08-10 Kenichi Handa <[email protected]>
+
+ * coding.c (unencodable_char_position): New function.
+ (Funencodable_char_position): New function.
+ (syms_of_coding): Defsubr Funencodable_char_position.
+
+2002-08-10 Andrew Choi <[email protected]>
+
+ * mac.c (sys_select) [MAC_OSX]: New function.
+
+ * macterm.c (MakeMeTheFrontProcess): New function.
+ (mac_initialize): Call MakeMeTheFrontProcess.
+
+ * s/darwin.h: Define select to sys_select.
+
+2002-08-09 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (make_lispy_event): Test WINDOWSNT, not WINDOWS_NT.
+
+2002-08-09 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (forward_to_next_line_start): Return 0 when reaching the
+ end of the buffer.
+
+2002-08-08 Ken Raeburn <[email protected]>
+
+ * coding.c (Ffind_operation_coding_system): Fix Lisp_Object/int mixup.
+
+ * puresize.h (BASE_PURESIZE): Increase to 910000.
+
+2002-08-08 Kenichi Handa <[email protected]>
+
+ * coding.c (Ffind_operation_coding_system): For write-region, if
+ VISIT is a filename, make it the target.
+
+2002-08-07 Richard M. Stallman <[email protected]>
+
+ * alloc.c (mark_object): Detect long lists for debugging.
+ (mark_object_loop_halt): New variable.
+
+ * s/hpux10.h (C_SWITCH_SYSTEM): #undef it.
+
+ * data.c (Fmake_variable_frame_local): Doc fix.
+
+2002-08-01 David Ponce <[email protected]>
+
+ * w32menu.c (local_heap, local_alloc, local_free): New macros.
+ (malloc_widget_value, free_widget_value)
+ (w32_free_submenu_strings): Use them.
+
+ (push_submenu_start, push_submenu_end, push_left_right_boundary)
+ (push_menu_pane, push_menu_item, single_keymap_panes)
+ (single_menu_item, Fx_popup_menu, menubar_selection_callback)
+ (single_submenu, set_frame_menubar)
+ (w32_menu_show, w32_dialog_show): Use AREF, ASET, ASIZE.
+
+ (Fx_popup_menu): Don't show pop up menu until preceding one is
+ actually cleaned up. Moved UNGCPRO outside #ifdef HAVE_MENUS block.
+
+ * w32menu.c: Changes adapted from xmenu.c
+ (set_frame_menubar): First parse all submenus,
+ then make widget_value trees from them.
+ Don't allocate any widget_value objects
+ until we are done with the parsing.
+ (parse_single_submenu): New function.
+ (digest_single_submenu): New function.
+ (single_submenu): Function deleted, replaced by those two.
+
+2002-08-04 Andrew Choi <[email protected]>
+
+ * macterm.c (XTread_socket): Check that FrontNonFloatingWindow
+ returns a valid window pointer before proceeding for keyDown and
+ autoKey events.
+
+2002-08-03 Andrew Choi <[email protected]>
+
+ * macterm.c (USE_CARBON_EVENTS): New macro.
+ (macCtrlKey, macShiftKey, macMetaKey, macAltKey): New macros.
+ (x_iconify_frame): Call CollapseWindow.
+ (Vmac_reverse_ctrl_meta): New variable.
+ (Vmac_wheel_button_is_mouse_2): New variable.
+ (init_mac_drag_n_drop): New function.
+ (mac_do_receive_drag): New function.
+ (mac_handle_service_event): New function.
+ (init_service_handler): New function.
+ (mac_to_emacs_modifiers): New function.
+ (mac_event_to_emacs_modifiers): New function.
+ (mac_get_mouse_btn): New function.
+ (mac_convert_event_ref): New function.
+ (XTread_socket) [USE_CARBON_EVENTS]: Call ReceiveNextEvent,
+ SendEventToEventTarget, mac_event_to_emacs_modifiers, and
+ mac_get_mouse_btn.
+ (mac_initialize): Call init_mac_drag_n_drop and init_service_handler.
+
+ * keyboard.c: Define Qmouse_wheel, mouse_wheel_syms, and
+ lispy_mouse_wheel_names for MAC_OSX as well as for WINDOWS_NT.
+ (kbd_buffer_get_event): Set used_mouse_menu for MENU_BAR_EVENT and
+ TOOL_BAR_EVENT for MAC_OS as well.
+ (make_lispy_event): Handle MOUSE_WHEEL_EVENT for MAC_OSX as well
+ as for WINDOWS_NT.
+ (syms_of_keyboard): Initialize Qmouse_wheel for MAC_OSX.
+
+ * termhooks.h (event_kind): Define MOUSE_WHEEL_EVENT also for MAC_OSX.
+
+2002-08-03 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (forward_to_next_line_start): Fix a condition that
+ lead to a newline being skipped.
+
+2002-08-02 Andrew Choi <[email protected]>
+
+ * mac.c (syms_of_mac): Defsubr Sx_selection_exists_p.
+
+2002-08-01 Richard M. Stallman <[email protected]>
+
+ * Makefile.in (SOME_MACHINE_OBJECTS): Add fontset.o.
+
+2002-07-31 Andrew Choi <[email protected]>
+
+ * macfns.c: #undef init_process before #define-ing it.
+
+ * s/darwin.h: Define MAC_OS, SYMS_SYSTEM, and OTHER_FILES only if
+ HAVE_CARBON is defined.
+
+2002-07-31 Richard M. Stallman <[email protected]>
+
+ * xmenu.c (set_frame_menubar): First parse all submenus,
+ then make widget_value trees from them.
+ Don't allocate any widget_value objects
+ until we are done with the parsing.
+ (parse_single_submenu): New function.
+ (digest_single_submenu): New function.
+ (single_submenu): Function deleted, replaced by those two.
+
+2002-07-30 Juanma Barranquero <[email protected]>
+
+ * w32proc.c (syms_of_ntproc): Fix docstring of
+ `w32-get-true-file-attributes'.
+
+2002-07-28 Richard M. Stallman <[email protected]>
+
+ * s/hpux8.h (HPUX8): Define this before including hpux.h.
+ (HAVE_SYS_WAIT_H): #define deleted; we let Autoconf decide.
+
+ * s/hpux.h (HAVE_SYS_WAIT_H): The #undef is conditional on HPUX8.
+
+ * keyboard.c (make_lispy_event):
+ Use #ifdef to test USE_TOOLKIT_SCROLL_BARS.
+ Explicitly clear up_modifier in event->modifiers.
+
+2002-07-27 Richard M. Stallman <[email protected]>
+
+ * xterm.h (FRAME_CURSOR_WIDTH): New macro.
+
+ * xterm.c (x_display_and_set_cursor): Check FRAME_CURSOR_WIDTH
+ for bar cursor.
+
+2002-07-26 Kenichi Handa <[email protected]>
+
+ * coding.c (detect_coding_iso2022): While checking a byte sequence
+ for CODING_CATEGORY_MASK_ISO_8_2, if we read one extra byte, check
+ it in the normal loop.
+
+2002-07-24 Gerd Moellmann <[email protected]>
+
+ * xterm.c (expose_overlaps): New function.
+ (expose_window): Use it to fix the display of overlapping rows.
+
+ * xdisp.c (unwind_redisplay): Clear redisplay_updating_p.
+
+2002-07-23 Ken Raeburn <[email protected]>
+
+ * lisp.h (XPNTR): Use NO_UNION_TYPE version for union as well,
+ since it only depends on XUINT.
+
+ * m/alpha.h (BITS_PER_LONG, BITS_PER_EMACS_INT, EMACS_INT,
+ EMACS_UINT, SPECIAL_EMACS_INT, DATA_SEG_BITS,
+ PNTR_COMPARISON_TYPE, VALBITS, MARKBIT, XINT, XUINT, XPNTR):
+ Macros deleted.
+
+ * mem-limits.h (start_of_data): If DATA_START is defined, prefer
+ its value over other approaches.
+ * sysdep.c (start_of_data): Don't define the function if a macro
+ form has been defined.
+
+2002-07-23 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (redisplay_updating_p): New variable.
+ (init_iterator): Don't free realized faces when
+ redisplay_updating_p is set.
+ (redisplay_internal): Set redisplay_updating_p while updating
+ the display.
+
+2002-07-23 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fmessage): Treat "" like nil.
+
+2002-07-23 Kenichi Handa <[email protected]>
+
+ * xdisp.c (face_before_or_after_it_pos):
+ Call FETCH_MULTIBYTE_CHAR with byte postion, not char position.
+
+2002-07-22 Juanma Barranquero <[email protected]>
+
+ * callproc.c (init_callproc) [DOS_NT]:
+ Initialize Vshared_game_score_directory to nil.
+ (syms_of_callproc) [DOS_NT]: Likewise.
+
+2002-07-22 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (display_line): Replace an abort with xassert.
+
+2002-07-21 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (redisplay_window): Don't test BEG_UNCHANGED
+ and END_UNCHANGED when setting buffer_unchanged_p.
+ Use current_matrix_up_to_date_p to decide whether to use
+ try_cursor_movement.
+
+ * config.in (HAVE_SHARED_GAME_DIR): Undef deleted.
+
+ * epaths.in (PATH_GAME): New macro, edited by ../Makefile.in.
+
+ * callproc.c (init_callproc): Set up Vshared_game_score_directory.
+ Set to nil if dir does not exist.
+ (syms_of_callproc): Init unconditionally and simply.
+
+ * buffer.c (Fbuffer_list): Doc fix.
+
+2002-07-21 Ken Raeburn <[email protected]>
+
+ * sysdep.c (end_of_text, end_of_data): Unused functions deleted.
+
+ * buffer.c (mmap_realloc): When shrinking, make sure number of
+ pages to unmap is rounded towards zero.
+
+ * m/mips-siemens.h (XSETUINT, XSETPNTR): Unused macros deleted.
+ (XSETINT): Deleted.
+
+ * m/att3b.h (XINT): Don't define.
+ (VALBITS, VALMASK, XTYPE): Deleted.
+ (DATA_SEG_BITS): Define.
+ * m/gec63.h (VALBITS, VALAMASK, XTYPE, XSETTYPE, XPNTR, XSET,
+ ARRAY_MARK_FLAG): Deleted.
+ (DATA_SEG_BITS): Define.
+ * m/pfa50.h (VALBITS, VALMASK, XTYPE): Deleted.
+ (DATA_SEG_BITS): Define.
+
+2002-07-20 Richard M. Stallman <[email protected]>
+
+ * print.c (print_error_message): New args CONTEXT and CALLER.
+ Calls changed.
+
+ * lisp.h (print_error_message): Declare new args.
+
+ * keyboard.c (cmd_error_internal): Pass Vsignaling_function
+ and CONTEXT to print_error_message, don't print them here.
+ For a Quit, don't use Vsignaling_function.
+ Call message_log_maybe_newline.
+
+ * Makefile.in (xsmfns.o): Don't depend on lisp.h.
+
+2002-07-20 Kim F. Storm <[email protected]>
+
+ * xdisp.c (redisplay_window): Test MODIFF to set buffer_unchanged_p.
+
+2002-07-19 Ken Raeburn <[email protected]>
+
+ * bytecode.c (struct byte_stack): Pointers into byte string now
+ point to const.
+ * callproc.c (Fcall_process): Make NEW_ARGV array hold pointer to
+ const.
+ * charset.h (BCOPY_SHORT): Source pointer now points to const.
+ * coding.c (encode_eol, detect_coding, detect_eol):
+ (decode_coding, encode_coding, detect_coding_system):
+ Source strings now treated as const.
+ (decode_coding_string, encode_coding_string): Use STRING_COPYIN to
+ modify Lisp string contents.
+ * coding.h (decode_coding, encode_coding, detect_coding,
+ detect_eol): Declarations updated.
+ * composite.c (compose_chars_in_text): Treat Lisp string contents
+ as const.
+ * dispnew.c (safe_bcopy): Source pointer now points to const.
+ * lisp.h (STRING_COPYIN): New macro.
+ (detect_coding_system, safe_bcopy, temp_output_buffer_setup):
+ (internal_with_output_to_temp_buffer): Declarations updated.
+ * print.c (temp_output_buffer_setup):
+ (internal_with_output_to_temp_buffer): Buffer name argument is now
+ pointer to const.
+ * sound.c (struct sound_device): Function pointer field "write"
+ buffer argument now points to const.
+ (vox_write): Buffer argument points to const.
+ * syntax.c (Fstring_to_syntax, skip_chars): Treat Lisp string
+ contents as const.
+ * sysdep.c (emacs_write): Buffer pointer now const.
+ * term.c (encode_terminal_code): Buffer pointer now const.
+ * xfaces.c (may_use_scalable_font_p): Argument now points to const.
+ (x_face_list_fonts, x_update_menu_appearance):
+ (hash_string_case_insensitive): Treat Lisp string contents as const.
+
+2002-07-19 Juanma Barranquero <[email protected]>
+
+ * xdisp.c (syms_of_xdisp): Remove redundant deprecation info.
+
+ * fileio.c (syms_of_fileio): Likewise.
+ (Ffile_name_as_directory): Fix argument name in docstring.
+ (file_name_as_directory): Use literal '/' instead of DIRECTORY_SEP.
+
+2002-07-18 Richard M. Stallman <[email protected]>
+
+ * data.c (Fdefalias): Doc fix.
+
+2002-07-17 Dave Love <[email protected]>
+
+ * intervals.h (text_property_stickiness): Use P_.
+
+ * ccl.c: Remove `emacs' conditionals.
+ (ccl_backtrace_table): Fix size spec.
+ (ccl_driver): Fix type errors.
+
+2002-07-16 Ken Raeburn <[email protected]>
+
+ * alloc.c (xstrdup, make_string, make_unibyte_string)
+ (make_multibyte_string, build_string): String pointer args now
+ point to const.
+ * charset.c (find_charset_in_text, c_string_width):
+ (chars_in_text, multibyte_chars_in_text, parse_str_as_multibyte):
+ * fileio.c (report_file_error):
+ * insdel.c (copy_text, count_size_as_multibyte, insert_1):
+ (count_combining_before, count_combining_after, insert_1_both):
+ (insert, insert_and_inherit, insert_string):
+ (insert_before_markers, insert_before_markers_and_inherit):
+ * lread.c (intern, oblookup, hash_string):
+ * minibuf.c (temp_echo_area_glyphs):
+ * search.c (fast_c_string_match_ignore_case):
+ * sysdep.c (emacs_open, set_file_times):
+ * xfaces.c (xstricmp):
+ * xdisp.c (store_frame_title, string_char_and_length):
+ (message_dolog, message2, message2_nolog, set_message): Likewise.
+ (set_message_1): Cast message string argument to const pointer.
+ * editfns.c (general_insert_function): Insertion function now
+ takes pointer to const for input data.
+ * charset.h (find_charset_in_text, c_string_width):
+ (parse_str_as_multibyte): Declarations updated.
+ * dispextern.h (xstricmp): Declaration updated.
+ * lisp.h (chars_in_text, multibyte_chars_in_text, copy_text):
+ (count_size_as_multibyte, count_combining_before):
+ (count_combining_after, insert_1, insert_1_both, message_dolog):
+ (insert, insert_and_inherit, insert_before_markers)
+ (insert_before_markers_and_inherit, set_message, message2):
+ (message2_dolog, build_string, make_string, make_unibyte_string):
+ (make_multibyte_string, intern, oblookup, report_file_error):
+ (fast_c_string_match_ignore_case, temp_echo_area_glyphs):
+ (emacs_open, xstrdup): Declarations updated.
+ * systime.h (set_file_times): Declaration updated.
+
+ * charset.c (find_charset_in_text, lisp_string_width): Use const
+ for pointer to lisp string data.
+ * charset.h (FETCH_STRING_CHAR_ADVANCE):
+ (FETCH_STRING_CHAR_ADVANCE_NO_CHECK):
+ * coding.c (Ffind_coding_systems_region_interval):
+ * fileio.c (Ffile_name_directory, Ffile_name_nondirectory):
+ (Fmake_directory_internal, Fdelete_directory):
+ (Ffile_name_absolute_p, Fwrite_region, double_dollars):
+ * fontset.c (font_family_registry, fs_query_fontset):
+ (list_fontsets):
+ * frame.c (Fframe_parameter):
+ * keyboard.c (cmd_error_internal):
+ * keymap.c (Fdescribe_buffer_bindings):
+ * lread.c (complete_filename_p, openp):
+ * minibuf.c (Fminibuffer_complete_word):
+ * xdisp.c (string_pos_nchars_ahead, init_from_display_pos):
+ (face_before_or_after_it_pos, next_element_from_string):
+ (get_overlay_arrow_glyph_row, display_mode_element):
+ (decode_mode_spec_coding):
+ * xterm.c (same_x_server): Likewise.
+
+ * buffer.c (reset_buffer_local_variables): Delete "#if 0"
+ settings of non-existent fields.
+
+ * editfns.c (Fstring_to_char): Don't use XSTRING/XSETSTRING to
+ copy a lisp value.
+
+ * lread.c (Fintern_soft): Use string macros instead of
+ Lisp_String fields.
+ * keyboard.c (echo_char, parse_modifiers_uncached):
+ (parse_solitary_modifier, Fexecute_extended_command): Likewise.
+ * textprop.c (validate_interval_range, interval_of): Likewise.
+
+ * fontset.c (Fset_fontset_font): Use SDATA instead of XSTRING()->data.
+
+ * charset.h (FETCH_STRING_CHAR_ADVANCE)
+ (FETCH_STRING_CHAR_ADVANCE_NO_CHECK): Use SBYTES instead of
+ XSTRING()->size_byte.
+
+ * lisp.h (SDATA, SREF): Produce rvalue.
+ (SSET): New macro.
+ * alloc.c (make_event_array): Use SSET for storing into a string.
+ * buffer.c (Fother_buffer): Use SREF when retrieving a byte from
+ a string.
+ * casefiddle.c (casify_object): Use SSET.
+ * charset.h (FETCH_STRING_CHAR_ADVANCE)
+ (FETCH_STRING_CHAR_ADVANCE_NO_CHECK): Use SDATA when getting
+ address of string contents.
+ * data.c (Faref): Use SDATA.
+ (Faset): Use SDATA, SSET.
+ * dired.c (directory_files_internal): Use SSET.
+ * fileio.c (Fmake_symbolic_link, Fexpand_file_name): Use SSET.
+ (Fread_file_name): Use SREF, SSET.
+ * fns.c (concat): Use SSET.
+ (concat, Fdelete): Use SDATA.
+ * insdel.c (insert_from_string_1): Use SDATA.
+ * keyboard.c (Fevent_convert_list): Use SREF.
+ * lread.c (Fload): Use SDATA, SSET.
+ * macfns.c (validate_x_resource_name): Use SSET.
+ * process.c (status_message): Use SSET.
+ * search.c (wordify): Use SDATA.
+ (Freplace_match): Use SREF.
+ * w32fns.c (validate_x_resource_name): Use SSET.
+ * xfns.c (validate_x_resource_name): Use SSET.
+ * xterm.c (x_catch_errors, x_clear_errors): Use SSET.
+
+2002-07-16 Richard M. Stallman <[email protected]>
+
+ * s/hpux11.h (USG_SUBTTY_WORKS): Defined.
+
+ * xdisp.c (reconsider_clip_changes):
+ Don't test prevent_redisplay_optimizations_p.
+ (redisplay_internal): Test prevent_redisplay_optimizations_p
+ along with clip_changed in some cases.
+ (try_window_id): Likewise.
+ (redisplay_window): New local var buffer_unchanged_p.
+
+ * keyboard.c (cmd_error) [HAVE_X_WINDOWS]: Maybe call cancel_houglass.
+
+ * process.c (create_process): Test USG_SUBTTY_WORKS.
+ (process_send_signal): Clean up handling of GID.
+ Detect errors in ioctls meant to set GID.
+
+ * window.c (temp_output_buffer_show):
+ Don't set prevent_redisplay_optimizations_p.
+
+2002-07-15 Juanma Barranquero <[email protected]>
+
+ * eval.c (Fdefvaralias): Add docstring argument.
+
+2002-07-15 Ken Raeburn <[email protected]>
+
+ * lisp.h (STRING_INTERVALS): Produce rvalue.
+ (STRING_SET_INTERVALS): New macro.
+ * buffer.c (Fget_buffer_create, Fmake_indirect_buffer): Use it.
+ * fns.c (Fstring_as_multibyte): Likewise.
+ * intervals.c (balance_possible_root_interval, delete_interval)
+ (create_root_interval, copy_intervals_to_string): Likewise.
+ * textprop.c (set_text_properties): Likewise. Use NULL_INTERVAL
+ instead of 0.
+
+2002-07-14 Ken Raeburn <[email protected]>
+
+ * lisp.h (STRING_SET_CHARS): New macro.
+ (SCHARS, SBYTES): Produce rvalues.
+ * dired.c (directory_files_internal): Use STRING_SET_CHARS.
+ * fns.c (concat): Likewise.
+ * lread.c (read_vector): Likewise.
+
+ * lisp.h (SMBP): Delete. All uses changed to STRING_MULTIBYTE.
+ (STRING_SET_UNIBYTE): New macro.
+ (SET_STRING_BYTES): Delete. Callers (all of which supplied a
+ length of -1) changed to use STRING_SET_UNIBYTE.
+ * abbrev.c, alloc.c, buffer.c, bytecode.c, callint.c, callproc.c,
+ casefiddle.c, category.c, ccl.c, charset.c, charset.h, coding.c,
+ composite.c, data.c, dired.c, dispnew.c, disptab.h, doc.c,
+ dosfns.c, editfns.c, emacs.c, eval.c, fileio.c, filelock.c, fn.c,
+ fontset.c, frame.c, indent.c, insdel.c, intervals.c, keyboard.c,
+ keymap.c, lread.c, mac.c, macfns.c, macmenu.c, macterm.c,
+ minibuf.c, msdos.c, print.c, process.c, search.c, sound.c,
+ sunfns.c, syntax.c, syntax.h, sysdep.c, textprop.c, undo.c,
+ w16select.c, w32.c, w32fns.c, w32menu.c, w32proc.c, w32select.c,
+ w32term.c, window.c, xdisp.c, xfaces.c, xfns.c, xmenu.c,
+ xselect.c, xsmfns.c, xterm.c: Most uses of XSTRING combined with
+ STRING_BYTES or indirection changed to SCHARS, SBYTES,
+ STRING_INTERVALS, SREF, SDATA; explicit size_byte references left
+ unchanged for now.
+
+2002-07-13 Kim F. Storm <[email protected]>
+
+ * keyboard.c (command_loop_1): Invert check on Vmemory_full.
+
+2002-07-12 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fwrite_region): Doc fix.
+
+ * print.c (print_error_message): Don't handle Vsignaling_function here.
+
+ * keyboard.c (cmd_error_internal): Handle Vsignaling_function here.
+ (command_loop_1): Avoid certain actions after memory-full error.
+
+ * eval.c (Fsignal): Don't call cancel_hourglass.
+ For a memory-full error, don't call Vsignal_hook_function
+ and don't set Vsignaling_function.
+
+ * process.c (process_send_signal): Add abort call.
+
+2002-07-11 Markus Rost <[email protected]>
+
+ * keymap.c (Fkey_binding): Fix typo.
+
+2002-07-11 Richard M. Stallman <[email protected]>
+
+ * alloc.c (Vmemory_full): New variable.
+ (Vmemory_signal_data): Rename from memory_signal_data.
+ Uses changed.
+ (syms_of_alloc): Defvar them.
+ (memory_full, buffer_memory_full): Set Vmemory_full.
+
+ * lisp.h (Vmemory_full): Add declaration.
+ (current_column, indented_beyond_p): Change declaration.
+
+ * indent.c (last_known_column): Declare as double, not float.
+ (current_column, current_column_1, string_display_width)
+ (position_indentation): Return `double'.
+ (indented_beyond_p): Arg `column' is `double'. Callers changed.
+
+ * xdisp.c (message_dolog): Do nothing if Vmemory_full is non-nil.
+ (back_to_previous_visible_line_start)
+ (reseat_at_next_visible_line_start, next_element_from_buffer):
+ Use `double', not `float', when calling indented_beyond_p.
+
+ * s/hpux11.h (BROKEN_SA_RESTART): Define.
+
+ * sysdep.c (sys_signal): Test BROKEN_SA_RESTART.
+
+2002-07-11 Juanma Barranquero <[email protected]>
+
+ * alloc.c, buffer.c, bytecode.c, callint.c, callproc.c, coding.c,
+ * composite.c, dired.c, dispnew.c, editfns.c, emacs.c, eval.c,
+ * fileio.c, fns.c, insdel.c, keyboard.c, keymap.c, lread.c, macfns.c,
+ * macmenu.c, macros.c, minibuf.c, print.c, process.c, sound.c,
+ * textprop.c, w32fns.c, w32menu.c, window.c, xfaces.c, xfns.c,
+ * xmenu.c, xselect.c, xterm.c: Use SPECPDL_INDEX wherever makes sense.
+
+2002-07-10 Juanma Barranquero <[email protected]>
+
+ * lisp.h (SPECPDL_INDEX): Rename from BINDING_STACK_SIZE.
+ All callers changed.
+
+2002-07-09 Stefan Monnier <[email protected]>
+
+ * data.c (Fdefalias): Add an optional `docstring' argument.
+ (set_internal, Fsetq_default): Use XCAR/XCDR.
+
+ * composite.c (HASH_VALUE, HASH_KEY):
+ * ccl.c (HASH_VALUE): Remove (it's in lisp.h now).
+
+2002-07-09 Kenichi Handa <[email protected]>
+
+ * callproc.c (Fcall_process): Fix previous change.
+
+2002-07-07 Stefan Monnier <[email protected]>
+
+ * minibuf.c (Ftry_completion, Fall_completions, Ftest_completion):
+ Add support for hash-tables.
+ (Ftry_completion): Return t even if the string appears multiple times.
+
+ * fns.c (Fnconc): Use XCDR.
+ (Fprovide): Use CONSP and XCDR.
+ (HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
+ (HASH_TABLE_SIZE): Delete: moved to lisp.h.
+ (Fmake_hash_table): Accept `:size nil'.
+ (Fmakehash): Delete: moved to subr.el.
+ (syms_of_fns): Don't defsubr makehash.
+
+ * lisp.h (HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
+ (HASH_TABLE_SIZE): Move from fns.c.
+
+2002-07-07 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (make_cursor_line_fully_visible): Don't try short scrolls.
+ Instead just return 0 when there is something to be done.
+ (try_scrolling): If make_cursor_line_fully_visible returns 0,
+ retry scrolling as if cursor were off the bottom.
+ (try_cursor_movement): If make_cursor_line_fully_visible returns 0,
+ return CURSOR_MOVEMENT_MUST_SCROLL.
+ (redisplay_window): If make_cursor_line_fully_visible returns 0,
+ go to try_to_scroll.
+
+ * buffer.c (Fbuffer_local_value): Store current value into its binding
+ so we get the up-to-date value for the binding that is loaded.
+
+ * eval.c (Fdefmacro): Doc fix.
+
+2002-07-05 Dave Love <[email protected]>
+
+ * keyboard.c (read_key_sequence): Set initial_idleness_start_time
+ correctly.
+
+ * ccl.c (Vtranslation_hash_table_vector, GET_HASH_TABLE)
+ (HASH_VALUE, CCL_LookupIntConstTbl, CCL_LookupCharConstTbl): New.
+ (ccl_driver): Add cases for CCL_LookupIntConstTbl,
+ CCL_LookupCharConstTbl.
+ (syms_of_ccl): Defvar translation-hash-table-vector.
+
+2002-07-05 Pavel Jan,Am(Bk <[email protected]>
+
+ * xdisp.c: Remove unused variable `face'.
+
+2002-07-04 Juanma Barranquero <[email protected]>
+
+ * keyboard.c (post_command_idle_hook): Remove redundant (and inexact)
+ obsolescence information.
+
+2002-07-03 Andrew Choi <[email protected]>
+
+ * macterm.c (x_list_fonts): Fix comment. Cache fonts matching
+ pattern. Search cache first.
+ (init_font_name_table): Also add entry for jisx0201.1976-0 coding
+ for Japanese font.
+ (XLoadQueryFont): Use it.
+
+2002-07-02 Richard M. Stallman <[email protected]>
+
+ * keymap.c (Fdefine_key): Doc fix.
+
+ * xterm.c (x_term_init): Turn off polling around XtOpenDisplay.
+
+2002-07-02 Juanma Barranquero <[email protected]>
+
+ * keymap.c (syms_of_keymap): Fix typo.
+
+2002-07-01 Andrew Choi <[email protected]>
+
+ * s/darwin.h: Define POSIX_SIGNALS.
+
+ * macterm.c (do_ae_open_documents) [MAC_OSX]: Call FSpMakeFSRef
+ and FSRefMakePath to convert FSSpec returned with Apple Event to
+ Posix pathname.
+ (mac_initialize) [TARGET_API_MAC_CARBON]:
+ Call init_required_apple_events and disable the `Quit' menu item
+ provided automatically by the Carbon Toolbox.
+
+2002-07-01 Dave Love <[email protected]>
+
+ * keyboard.c (kbd_buffer_store_event): Fix interrupt_signal decl
+ for K&R.
+
+ * xterm.c: Fix prototype for K&R.
+
+ * term.c (costs_set): Declare static, non-initialized for pcc.
+
+2002-07-01 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (timer_last_idleness_start_time): New variable.
+ (timer_start_idle): Set that.
+ (read_key_sequence): Use that to reset timer_idleness_start_time
+ to previous value.
+
+ * window.c (Frecenter): With arg, set optional_new_start.
+
+ * xdisp.c (redisplay_internal): Make optional_new_start really work.
+
+ * minibuf.c (Fminibuffer_complete_and_exit): Move to end of
+ buffer for completion.
+
+2002-06-29 Ken Raeburn <[email protected]>
+
+ * xdisp.c (store_mode_line_string): Lisp_Object/int mixup.
+
+2002-06-28 Jan Dj,Ad(Brv <[email protected]>
+
+ * keyboard.c (readable_filtered_events): New function that filters
+ FOCUS_IN_EVENT depending on parameter.
+ (readable_events): Calls readable_filtered_events, not filtering
+ FOCUS_IN_EVENT.
+ (get_filtered_input_pending): New function, filtering parameter passed
+ to readable_filtered_events.
+ (get_input_pending): Calls get_filtered_input_pending, not filtering
+ FOCUS_IN_EVENT.
+ (Finput_pending_p): Calls get_filtered_input_pending, DO filter
+ FOCUS_IN_EVENT.
+
+ * xterm.h (struct x_output): Add focus_state.
+
+ * xterm.c (x_focus_changed): New function.
+ (x_detect_focus_change): New function.
+ (XTread_socket): Call x_detect_focus_change for FocusIn/FocusOut
+ EnterNotify and LeaveNotify to track X focus changes.
+
+2002-06-28 Andreas Schwab <[email protected]>
+
+ * lisp.h: Remove duplicate declaration of code_convert_string_norecord.
+
+2002-06-27 Kim F. Storm <[email protected]>
+
+ * xdisp.c (mode_line_string_list, mode_line_string_face)
+ (mode_line_string_face_prop): New variables.
+ (store_mode_line_string): New function.
+ (display_mode_element): Use store_mode_line_string to
+ add mode-line string elements to mode_line_string_list
+ when mode_line_string_list is non-nil.
+ (Fformat_mode_line): Now returns propertized string by
+ default. New arg NO-PROPS to ignore properties.
+ (decode_mode_spec): Only add two dashes for %- in propertized
+ mode-line string.
+ (syms_of_xdisp): Init and staticpro mode_line_string_list.
+
+2002-06-27 Stefan Monnier <[email protected]>
+
+ * minibuf.c (minibuffer_completion_contents): Add return type.
+
+2002-06-27 Juanma Barranquero <[email protected]>
+
+ * charset.c (Fchar_bytes): Remove obsolescence info from docstring.
+
+2002-06-26 Juanma Barranquero <[email protected]>
+
+ * fileio.c (read_file_name_cleanup): Add missing return.
+
+2002-06-26 Richard M. Stallman <[email protected]>
+
+ * window.c (Frecenter): Don't set force_start flag.
+
+ * minibuf.c (do_completion, Fminibuffer_complete_word)
+ (Fminibuffer_completion_help): Complete just the text before point.
+ (minibuffer_completion_contents): New function.
+
+ * buffer.c (Fbury_buffer): Use frames_discard_buffer.
+
+ * frame.c (frames_bury_buffer): Function deleted.
+
+2002-06-25 Miles Bader <[email protected]>
+
+ * callint.c (Fcall_interactively): When checking to see if doprnt hit
+ the end of callint_message, allow for a terminating '\0'.
+
+2002-06-24 Juanma Barranquero <[email protected]>
+
+ * w32select.c: Include composite.h.
+
+ * w16select.c: Likewise.
+
+2002-06-24 Kenichi Handa <[email protected]>
+
+ * callproc.c (Fcall_process): If code detection is necessary,
+ call detect_coding directly here.
+
+ * coding.c (detect_eol): Preserve coding->cmp_data.
+
+ * w16select.c (Fw16_get_clipboard_data):
+ * w32fns.c (w32_to_x_font):
+ * w32select.c (Fw32_get_clipboard_data):
+ * xselect.c (selection_data_to_lisp_data):
+ * xterm.c (XTread_socket): Disable composition handling.
+
+2002-06-24 Stefan Monnier <[email protected]>
+
+ * print.c (temp_output_buffer_setup): Kill all local variables.
+
+2002-06-22 Stefan Monnier <[email protected]>
+
+ * lread.c (Fread): Remove redundant and imprecise declaration.
+
+ * xfns.c (check_x_display_info): Use check_x_frame.
+
+ * .gdbinit (xprintsym): Use the new `xname' field.
+ (xsymbol): Use it.
+
+2002-06-22 Jason Rumney <[email protected]>
+
+ * w32fns.c (file_dialog_callback): New function.
+ (Fx_file_dialog): Allow selecting directories as well as files.
+
+2002-06-21 Pavel Jan,Am(Bk <[email protected]>
+
+ * m/pmax.h (START_FILES): Define START_FILES for NetBSD and
+ OpenBSD. Add support for mipseb-*-netbsd* machines.
+
+2002-06-17 Andrew Choi <[email protected]>
+
+ * macterm.c (mac_scroll_area): Set foreground and backcolor to
+ black and white before scrolling. Restore frame background and
+ foreground color after scrolling.
+ (do_window_update): Call XClearWindow before calling expose_frame.
+ (make_mac_frame): Don't set FRAME_BACKGROUND_PIXEL and
+ FRAME_FOREGROUND_PIXEL of frame.
+
+ * macterm.c (XTread_socket): If Vmac_command_key_is_meta is nil,
+ test Mac command key as <ALT> key.
+
+2002-06-17 Stefan Monnier <[email protected]>
+
+ * window.c (Fset_window_configuration): Lisp_Object/int mixup.
+
+ * keyboard.c (read_key_sequence): Be more careful with first_unbound.
+ Lookup keys in function-key-map immediately so that key-translation-map
+ can be applied earlier.
+ Remove function_key_possible and key_translation_possible, replaced
+ by checking `keytran_start < t'.
+
+ * .gdbinit (xsymbol): Use the new `xname' field.
+
+2002-06-17 Andrew Choi <[email protected]>
+
+ * macterm.c (XTread_socket): If Vmac_command_key_is_meta is nil,
+ test Mac command key as <ALT> key.
+
+ * mac.c (do_applescript): Call initialize_applescript if necessary
+ when first called. Dispose of result_desc only when there is no error.
+ (Fdo_applescript): Use %d format specifier instead of %ld.
+
+2002-06-16 Andrew Choi <[email protected]>
+
+ * macterm.c (XTread_socket): Call FrontNonFloatingWindow instead
+ of FrontWindow for cases keyDown and autoKey.
+
+ * fontset.c (syms_of_fontset) [MAC_OS]: Set ASCII font of
+ Vdefault_fontset to Monaco with mac-roman coding.
+
+ * mac.c, macfns.c, macmenu.c, macterm.c: Undefine and redefine
+ init_process before and after inclusion of Carbon/Carbon.h, resp.
+
+ * macterm.c (x_new_font): Set font for normal_gc, reverse_gc, and
+ cursor_gc.
+ (add_font_name_table_entry): New function.
+ (init_font_name_table): Use add_font_name_table_entry; add italic,
+ bold, and bold-italic entries for truetype fonts.
+
+ * xfaces.c (init_frame_faces) [MAC_OS]: Call realize_basic_faces
+ for Mac too.
+ (try_font_list) [MAC_OS]: If no font matches given registry, try
+ fonts with any registry matching face_family.
+ (realize_x_face) [MAC_OS]: Remove old ad-hoc fix to load font here.
+
+ * s/darwin.h: If autoconf detects the Ncurses library, define
+ LIBS_TERMCAP to -lncurses to use it.
+
+2002-06-16 Eli Zaretskii <[email protected]>
+
+ * strftime.c [__hpux]: Include sys/_mbstate_t.h.
+
+2002-06-15 Richard M. Stallman <[email protected]>
+
+ * window.c (Fset_window_configuration): Explicitly preserve
+ the point value that new_current_buffer had at the start.
+
+2002-06-14 Juanma Barranquero <[email protected]>
+
+ * composite.c (Fcompose_region_internal, Fcompose_string_internal):
+ Fix typos.
+
+2002-06-14 Kim F. Storm <[email protected]>
+
+ * insdel.c (insert_1_both, insert_from_string_1)
+ (insert_from_buffer_1): Recalculate END_UNCHANGED in case the
+ insert happened in the end_unchanged region. Otherwise, the
+ redisplay may be confused and duplicate the last line in the
+ buffer [seen after save-buffer when require-final-newline==t].
+
+2002-06-13 Jason Rumney <[email protected]>
+
+ * w32.c (init_environment): Remove EMACSLOCKDIR.
+ (stat): Swap _S_IFDIR and _S_IFREG.
+
+2002-06-13 Pavel Jan,Am(Bk <[email protected]>
+
+ * keyboard.c, macterm.c, macmenu.c, msdos.c, sysdep.c
+ * termhooks.h, xmenu.c, xsmfns.c, xterm.h, xterm.c, w32term.c,
+ * w32menu.c, w32inevt.c: Rename enum event_kind as follows:
+ ascii_keystroke to ASCII_KEYSTROKE_EVENT, multibyte_char_keystroke
+ to MULTIBYTE_CHAR_KEYSTROKE_EVENT, non_ascii_keystroke to
+ NON_ASCII_KEYSTROKE_EVENT, timer_event to TIMER_EVENT, mouse_click
+ to MOUSE_CLICK_EVENT, mouse_wheel to MOUSE_WHEEL_EVENT,
+ language_change_event to LANGUAGE_CHANGE_EVENT, scroll_bar_click
+ to SCROLL_BAR_CLICK_EVENT, w32_scroll_bar_click to
+ W32_SCROLL_BAR_CLICK_EVENT, selection_request_event to
+ SELECTION_REQUEST_EVENT, selection_clear_event to
+ SELECTION_CLEAR_EVENT, buffer_switch_event to BUFFER_SWITCH_EVENT,
+ delete_window_event to DELETE_WINDOW_EVENT, iconify_event to
+ ICONIFY_EVENT, deiconify_event to DEICONIFY_EVENT,
+ menu_bar_activate_event to MENU_BAR_ACTIVATE_EVENT, drag_n_drop to
+ DRAG_N_DROP_EVENT, save_session_event to SAVE_SESSION_EVENT and
+ no_event to NO_EVENT.
+
+2002-06-12 Pavel Jan,Am(Bk <[email protected]>
+
+ * macmenu.c: Remove declaration of Qmouse_click and Qevent_kind.
+
+2002-06-12 Stefan Monnier <[email protected]>
+
+ * intervals.c (textget): Don't forget to `return'.
+ (lookup_char_property): Use XCAR/XCDR.
+
+2002-06-12 Juanma Barranquero <[email protected]>
+
+ * xdisp.c (Fformat_mode_line): Fix typo.
+
+2002-06-12 Kim F. Storm <[email protected]>
+
+ * xdisp.c (Fformat_mode_line): New function.
+ (frame_title_buf, frame_title_buf_end, frame_title_ptr)
+ (store_frame_title_char, store_frame_title): Use unconditionally.
+ (init_xdisp): Defsubr Fformat_mode_line.
+ Initialize frame_title_buf etc. unconditionally.
+
+2002-06-11 Stefan Monnier <[email protected]>
+
+ * keyboard.c (read_key_sequence):
+ Remove prev_(fkey|keytran}_(map|start|end) since we don't want to pass
+ things through those maps after downcasing events.
+ Enforce that keytran_end <= fkey_start, i.e. that key-translation-map
+ applies after function-key-map.
+ Make sure that keytran can be done in the middle in the sequence.
+ Be careful not to throw away events past the one we downcase.
+
+ * lread.c (read_integer): Remove unused var `tem'.
+ (read1): Fix int/Lisp_Object mixup.
+
+ * xfaces.c (tty_lookup_color): Type bool/Lisp_Object mismatch fixed.
+
+2002-06-11 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (readable_events): Ignore any number of
+ FOCUS_IN_EVENT events and return 0 if nothing else in buffer.
+
+2002-06-09 Miles Bader <[email protected]>
+
+ * xfaces.c (Ftty_supports_face_attributes_p): New function.
+ (parse_rgb_list, tty_lookup_color): New functions.
+ (tty_defined_color): Use `tty_lookup_color' to do all the work.
+ (color_distance, Fcolor_distance): New functions.
+ (TTY_SAME_COLOR_THRESHOLD): New macro.
+ (Qtty_color_standard_values): New variable.
+ (syms_of_xfaces): Initialize new vars & functions.
+
+2002-06-08 Colin Walters <[email protected]>
+
+ * textprop.c (Vchar_property_alias_alist): New variable.
+ (syms_of_textprop) <Vchar_property_alias_alist>: DEFVAR_LISP.
+
+ * intervals.c (lookup_char_property): New function for looking up
+ overlay and text properties, created from textget.
+ (textget): Use it.
+
+ * intervals.h (lookup_char_property): Declare.
+ (Vchar_property_alias_alist): Declare.
+
+ * buffer.c (Foverlay_get): Use lookup_char_property.
+
+2002-06-07 Sam Steingold <[email protected]>
+
+ * xselect.c (lisp_data_to_selection_data): Fix last change:
+ *data_ret is not a Lisp string, while unibyte_string is.
+
+2002-06-07 Eli Zaretskii <[email protected]>
+
+ * xselect.c (lisp_data_to_selection_data): Fix last change:
+ set size_ret.
+
+2002-06-07 Andreas Schwab <[email protected]>
+
+ * m/amdx86-64.h: New file.
+
+2002-06-05 Eli Zaretskii <[email protected]>
+
+ * fns.c (Fstring_make_unibyte): Doc fix.
+
+ * xselect.c (lisp_data_to_selection_data): If the requested type
+ is STRING, call string_make_unibyte to encode the selected text
+ as a string.
+
+ * window.c (Fset_window_hscroll): Doc fix.
+
+2002-06-05 Pavel Jan,Am(Bk <[email protected]>
+
+ * fileio.c (choose_write_coding_system):
+ Call select-safe-coding-system properly.
+
+2002-06-03 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (message_with_string): Error if STRING is not a string.
+
+ * fns.c (md5): Pass FILE arg to Vselect_safe_coding_system_function.
+
+ * fileio.c (choose_write_coding_system): Pass FILE arg to
+ Vselect_safe_coding_system_function.
+
+2002-06-03 Ken Raeburn <[email protected]>
+
+ * buffer.c (fix_overlays_before): Fix list-walking bug in 05-19 change.
+
+2002-06-02 Thien-Thi Nguyen <[email protected]>
+
+ * bytecode.c (Fbyte_code): Cast `current_column' return value to int.
+ * cmds.c (Fdelete_backward_char, internal_self_insert): Likewise.
+ * keymap.c (describe_command): Likewise.
+ * minibuf.c (read_minibuf): Likewise.
+
+ * xdisp.c (redisplay_internal, redisplay_window, decode_mode_spec):
+ Cast `current_column' return value to int.
+ (back_to_previous_visible_line_start)
+ (reseat_at_next_visible_line_start, next_element_from_buffer):
+ Cast `indented_beyond_p' 3rd arg to float.
+
+ * indent.c (last_known_column): Now a float.
+ (current_column_1, position_indentation, current_column)
+ (string_display_width): Return float.
+ (Fcurrent_column): Cast `current_column' return value to int.
+ (Fcurrent_indentation): Cast `position_indentation' retval to int.
+ (indented_beyond_p): Third arg now a float.
+ (compute_motion, vmotion): Cast `indented_beyond_p' 3rd arg to float.
+
+ * lisp.h (current_column): Now returns float.
+ (indented_beyond_p): 3rd arg now a float.
+
+2002-05-31 Eli Zaretskii <[email protected]>
+
+ * xfns.c (x_encode_text): Return stringp non-NULL if coding_system
+ is Qcompound_text_with_extensions.
+
+ * xselect.c (lisp_data_to_selection_data): Always set selection
+ type as string if x_encode_text returns streingp non-NULL.
+
+ * s/netbsd.h: Include /usr/pkg in the run time shared library path.
+
+2002-05-30 Richard M. Stallman <[email protected]>
+
+ * window.c (Fset_window_configuration): Correct the handling
+ of point in current buffer, to work with multiple windows.
+
+2002-05-29 Colin Walters <[email protected]>
+
+ * lread.c (Fread_from_string): Don't depend on order of evaluation
+ for C function parameters.
+
+2002-05-28 Richard M. Stallman <[email protected]>
+
+ * xterm.c (x_display_and_set_cursor): Change the cursor in the same
+ way for blinked-off state and for a nonselected window.
+
+ * window.c (window_scroll_pixel_based): Don't call Fbolp;
+ instead, see if the new start pos is at beginning of line.
+
+ * fileio.c (Fwrite_region): If START is a string, don't
+ make any annotations.
+
+ * eval.c (syms_of_eval): Doc fix.
+
+2002-05-28 Colin Walters <[email protected]>
+
+ * emacs.c (USAGE1): Add --no-splash.
+ (standard_args): Ditto.
+
+2002-05-28 Colin Walters <[email protected]>
+
+ * lread.c (readchar_count): New variable.
+ (readchar): Increment it.
+ (unreadchar): Decrement it.
+ (read_multibyte): Decrement it.
+ (Vread_with_symbol_positions): New variable.
+ (Vread_symbol_positions_list): New variable.
+ (read_internal_start): New function, created from Fread and
+ Fread_from_string. Handle Vread_symbol_positions_list and
+ Vread_with_symbol_positions.
+ (readevalloop, Fread, Fread_from_string): Use it.
+ (read1): Use readchar_count to add symbol positions to
+ Vread_symbol_positions_list if Vread_with_symbol_positions is non-nil.
+ (syms_of_lread): DEFVAR_LISP and initialize them.
+
+ * lread.c (read0, read1, read_list, read_vector, read_multibyte)
+ (substitute_object_recurse, substitute_object_in_subtree)
+ (substitute_in_interval): Prototype.
+ (read_multibyte): Return c if it's less than zero.
+
+2002-05-28 Kim F. Storm <[email protected]>
+
+ * fileio.c (Fread_file_name_internal): Added brute-force
+ speed up for using predicate file-directory-p.
+
+2002-05-28 Kim F. Storm <[email protected]>
+
+ * fileio.c (Vread_file_name_function, Vread_file_name_predicate):
+ New variables.
+ (syms_of_fileio): DEFVAR_LISP them.
+ (read_file_name_cleanup): New unwind function.
+ (Fread_file_name_internal): Only return completions satifying
+ Vread_file_name_predicate. Temporarily unwind protect and rebind
+ default-directory while checking completions against the predicate.
+ (Fread_file_name): Added PREDICATE argument. Specbind it to
+ Vread_file_name_predicate during completion.
+ Call Vread_file_name_function to read the file name if non-nil.
+
+ * lisp.h (Fread_file_name): Now has 6 args.
+
+ * callint.c (Fcall_interactively) <"D">: Supply Qfile_directory_p
+ predicate for Fread_file_name when reading directory name.
+ Supply Qnil for predicate in other calls to Fread_file_name.
+
+2002-05-26 Miles Bader <[email protected]>
+
+ * term.c (tty_capable_p): New function.
+ * dispextern.h (tty_capable_p): New function declaration.
+ (TTY_CAP_INVERSE, TTY_CAP_UNDERLINE, TTY_CAP_BOLD, TTY_CAP_DIM)
+ (TTY_CAP_BLINK, TTY_CAP_ALT_CHARSET): New macros.
+
+2002-05-23 Stefan Monnier <[email protected]>
+
+ * fileio.c (read_non_regular, Finsert_file_contents): Use BEG_BYTE.
+ (Finsert_file_contents, build_annotations): Use XCAR, XCDR.
+ (Vwrite_region_annotate_functions): Docstring fix.
+
+2002-05-23 Kim F. Storm <[email protected]>
+
+ * xterm.c (x_write_glyphs): Clear phys_cursor_on_p if current
+ phys_cursor's hpos is overwritten. This is still not completely
+ correct, as it doesn't really make sense to use hpos at all to
+ get the cursor glyph (as that is relative to the width of the
+ characters on the line, which may have changed during the update).
+
+2002-05-22 Jason Rumney <[email protected]>
+
+ * w32fns.c (enumfont_t): Remove tail, make pattern a normal
+ Lisp_Object.
+ (enum_font_cb2, enum_font_maybe_add_to_list, w32_list_fonts):
+ Use modified enumfont_t struct.
+
+ * w32term.h (text_cursor_kinds): New enumeration member HBAR_CURSOR.
+
+ * w32term.c (x_draw_bar_cursor): New argument KIND; callers changed.
+ Handle the `hbar' cursor type.
+ (x_display_and_set_cursor): Handle the HBAR_CURSOR case.
+
+ * w32fns.c (Qhbar): New variable.
+ (x_specified_cursor_type): Use it.
+
+2002-05-21 Ken Raeburn <[email protected]>
+
+ * w32fns.c (enum_font_maybe_add_to_list): Use XCDR_AS_LVALUE for
+ now, when the address is needed.
+
+2002-05-21 Colin Walters <[email protected]>
+
+ * Makefile.in (shortlisp): Add font-core.el.
+
+2002-05-20 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer) <cursor-type>: Doc fix.
+
+ * keyboard.c (read_char_minibuf_menu_prompt): Don't list
+ equivalent key bindings here.
+
+2002-05-20 Ken Raeburn <[email protected]>
+
+ Change symbol structure to contain a lisp object for the symbol
+ name:
+ * lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
+ object field named "xname".
+ (SYMBOL_NAME): New macro.
+ * abbrev.c (write_abbrev): Use SYMBOL_NAME instead of XSYMBOL and
+ name field.
+ * alloc.c (Fmake_symbol): Set symbol xname field instead of name.
+ (mark_object, gc_sweep): Use symbol xname field and XSTRING
+ instead of name field.
+ * buffer.c (buffer_slot_type_mismatch): Use XSTRING and
+ SYMBOL_NAME instead of XSYMBOL and name field.
+ * callint.c (Fcall_interactively): Use XSTRING and SYMBOL_NAME
+ instead of XSYMBOL and name field.
+ * charset.c (Fdefine_charset, Fdeclare_equiv_charset): Use XSTRING
+ and SYMBOL_NAME instead of XSYMBOL and name field.
+ * coding.c (Fread_coding_system, code_convert_region1)
+ (code_convert_string1, code_convert_string_norecord)
+ (Ffind_operation_coding_system): Use SYMBOL_NAME instead of
+ XSYMBOL and name field.
+ * data.c (Fkeywordp, Fsymbol_name, store_symval_forwarding)
+ (Fmake_variable_buffer_local, Fmake_local_variable)
+ (Fmake_variable_frame_local): Use SYMBOL_NAME and XSTRING instead
+ of XSYMBOL and name field.
+ * editfns.c (Fformat): Use SYMBOL_NAME and XSTRING instead of
+ XSYMBOL and name field.
+ * emacs.c (shut_down_emacs) [#if 0]: Use SYMBOL_NAME and XSTRING
+ instead of XSYMBOL and name field.
+ * eval.c (do_autoload): Use SYMBOL_NAME and XSTRING instead of
+ XSYMBOL and name field.
+ * fns.c (Fstring_equal, Fstring_lessp, Frequire, sxhash):
+ Use SYMBOL_NAME and XSTRING instead of XSYMBOL and name field.
+ * fontset.c (Fset_fontset_font): Use SYMBOL_NAME and XSTRING
+ instead of XSYMBOL and name field.
+ * keyboard.c (echo_char, record_char, parse_modifiers_uncached)
+ (parse_modifiers, apply_modifiers, Fevent_convert_list)
+ (parse_solitary_modifier, Fexecute_extended_command):
+ Use SYMBOL_NAME and XSTRING instead of XSYMBOL and name field.
+ * keymap.c (silly_event_symbol_error, Fsingle_key_description)
+ (Fdescribe_buffer_bindings): Use SYMBOL_NAME and XSTRING instead
+ of XSYMBOL and name field.
+ (describe_command, describe_translation): Use SYMBOL_NAME and
+ assignment instead of XSYMBOL and name field and XSETSTRING.
+ * lread.c (Fintern_soft, oblookup): Use SYMBOL_NAME and XSTRING
+ instead of XSYMBOL and name field.
+ (Funintern): Use SYMBOL_NAME and assignment instead of XSYMBOL and
+ name field and XSETSTRING.
+ * macfns.c (parse_image_spec): Use SYMBOL_NAME and XSTRING instead
+ of XSYMBOL and name field.
+ * minibuf.c (Fread_command, Fread_variable): Use SYMBOL_NAME and
+ assignment instead of XSYMBOL and name field and XSETSTRING.
+ * print.c (print_error_message, print_object): Use SYMBOL_NAME and
+ XSTRING instead of XSYMBOL and name field.
+ * process.c (set_socket_options, Fsignal_process): Use SYMBOL_NAME
+ and XSTRING instead of XSYMBOL and name field.
+ * w32fns.c (parse_image_spec, w32_parse_hot_key): Use SYMBOL_NAME
+ and XSTRING instead of XSYMBOL and name field.
+ * xfaces.c (merge_face_vector_with_property): Use SYMBOL_NAME and
+ XSTRING instead of XSYMBOL and name field.
+ * xfns.c (parse_image_spec): Use SYMBOL_NAME and XSTRING instead
+ of XSYMBOL and name field.
+ * xselect.c (symbol_to_x_atom, x_get_foreign_selection):
+ Use SYMBOL_NAME and XSTRING instead of XSYMBOL and name field.
+
+2002-05-19 Ken Raeburn <[email protected]>
+
+ * lisp.h (LISP_MAKE_RVALUE): Delete disabled version, making XCAR
+ and XCDR real rvalues in most configurations.
+
+ * buffer.c (fix_overlays_in_range, fix_overlays_before):
+ Don't take the address of the cdr part of a cons cell; instead, track
+ the parent cell and call XSETCDR, or set the variable for the head
+ of the list if we haven't started down the list yet.
+
+2002-05-19 Richard M. Stallman <[email protected]>
+
+ * doc.c (reread_doc_file): Don't ask for confirmation.
+
+2002-05-18 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_create_pixmap_from_bitmap_data): New function.
+ (xbm_load_image): Use it.
+ (xbm_load): Ditto.
+ (xbm_read_bitmap_data): Reverted to xfns.c version.
+ From David Ponce <[email protected]>.
+
+2002-05-17 Eli Zaretskii <[email protected]>
+
+ * msdos.c (sig_suspender, sigprocmask): Don't define for DJGPP
+ 2.02 and later.
+
+2002-05-16 Juanma Barranquero <[email protected]>
+
+ * keyboard.c (Fthis_command_keys, Fthis_command_keys_vector): Fix typo.
+
+2002-05-15 Stefan Monnier <[email protected]>
+
+ * keyboard.c (read_char_x_menu_prompt): Use an equivalent but more
+ meaningful test.
+ (read_char_minibuf_menu_prompt): Fix typo.
+
+2002-05-15 Eli Zaretskii <[email protected]>
+
+ * eval.c (Fcommandp): Doc fix.
+
+2002-05-13 Stefan Monnier <[email protected]>
+
+ * keymap.c (keymap_parent): New fun, extracted from Fkeymap_parent.
+ (Fkeymap_parent, keymap_memberp, fix_submap_inheritance): Use it.
+ (Fset_keymap_parent): Gcpro a bit more.
+ (access_keymap): Gcpro around meta_map call and around the main loop.
+ (get_keyelt): Gcpro when following indirect references.
+ (copy_keymap_item): New fun, extracted from Fcopy_keymap.
+ (copy_keymap_1, Fcopy_keymap): Use it. Don't copy the parent map.
+ (Fdefine_key, Flookup_key): Gcpro before calling get_keymap.
+ Remove useless ad-hoc remap code.
+
+2002-05-13 Richard M. Stallman <[email protected]>
+
+ * search.c (search_buffer): Give up boyer moore search if inverse
+ translation change charset_base.
+
+2002-05-12 Eli Zaretskii <[email protected]>
+
+ * coding.c (decode_coding) <coding_type_ccl>: If a lone CR
+ characters is carried over from the previous block of text, adjust
+ coding->produced to account for the extra character.
+
+2002-05-11 Andreas Schwab <[email protected]>
+
+ * coding.c (intersection): Keep the elements of the returned list
+ in the same order as in the first list.
+
+2002-05-11 Kim F. Storm <[email protected]>
+
+ * keymap.c (current_minor_maps): Fix resizing of cmm_maps;
+ only update cmm_size if realloc actually succeeds.
+ Testing with initial size of 2 elements revealed that using
+ realloc on GNU/Linux would cause a random trap in xmalloc
+ later on, so I rewrote the code to use malloc/bcopy/free instead
+ of realloc.
+
+2002-05-10 Jason Rumney <[email protected]>
+
+ * w32fns.c (enum_font_cb2): Avoid DBCS raster fonts.
+
+2002-05-10 Eli Zaretskii <[email protected]>
+
+ * coding.c (encode_coding_sjis_big5): Enclose bitwise AND in
+ parens, to ensure correct evaluation order.
+
+2002-05-10 Kim F. Storm <[email protected]>
+
+ * keymap.c (Vemulation_mode_map_alists): New variable.
+ (syms_of_keymap): DEFVAR_LISP it.
+ (current_minor_maps): Process keymap alists in that list before
+ minor-mode-overriding-map-alist and minor-mode-map-alist.
+
+2002-05-09 Richard M. Stallman <[email protected]>
+
+ * search.c (Freplace_match): Doc fix.
+
+2002-05-09 Kim F. Storm <[email protected]>
+
+ * macterm.c (x_draw_image_foreground, x_draw_image_foreground_1):
+ Enlarge cursor rectangle drawn around image with non-zero relief.
+
+ * w32term.c (x_draw_image_foreground, w32_draw_image_foreground_1):
+ Enlarge cursor rectangle drawn around image with non-zero relief.
+
+ * xterm.c (x_draw_image_foreground, x_draw_image_foreground_1):
+ Enlarge cursor rectangle drawn around image with non-zero relief.
+
+2002-05-07 Eli Zaretskii <[email protected]>
+
+ * xselect.c (lisp_data_to_selection_data): Don't set selection
+ type if comes from the Lisp object's car. If the selection
+ contains a pure ASCII text, always return QSTRING as its type.
+
+2002-05-06 Pavel Jan,Am(Bk <[email protected]>
+
+ * mac.c (mac-cut-function): Doc fix.
+
+2002-05-05 Richard M. Stallman <[email protected]>
+
+ * s/gnu.h [DOUG_LEA_MALLOC] (REL_ALLOC): Undefine it.
+
+2002-05-04 Jason Rumney <[email protected]>
+
+ * keyboard.c (make_lispy_event) <mouse-wheel>: Set count to 1
+ for event-click-count.
+
+ * process.c (init_process): Only add server subfeature if we can
+ use non-blocking I/O.
+
+2002-05-04 Andrew Choi <[email protected]>
+
+ * macterm.c (XTread_socket): Call WaitNextEvent once instead of
+ repeatedly.
+
+2002-05-03 Jason Rumney <[email protected]>
+
+ * process.c (Fmake_network_process): Only support server sockets
+ when we can make them non-blocking.
+
+ * s/ms-w32.h (HAVE_SELECT): Define.
+
+ * w32.h (FILE_NDELAY): New flag.
+
+ * w32.c (sys_getpeername, fcntl): New functions.
+ (_sys_read_ahead): Temporarily block on non-blocking sockets.
+
+ * w32proc.c: Include sys/file.h.
+
+2002-05-03 Colin Walters <[email protected]>
+
+ * callproc.c (Vgame_score_directory): Renamed to
+ Vshared_game_score_directory.
+
+2002-04-30 Richard M. Stallman <[email protected]>
+
+ * s/gnu.h [emacs]: Include stdio.h.
+ (GNU_LIBRARY_PENDING_OUTPUT_COUNT): New definition, conditional.
+
+ * eval.c (do_autoload): Error if called while preparing to dump.
+
+ * fns.c (Frequire): Error if need to load while preparing to dump.
+
+2002-04-28 Colin Walters <[email protected]>
+
+ * callproc.c (Vgame_score_directory) [!HAVE_SHARED_GAME_DIR]:
+ Default to "~/.emacs.d/games".
+
+2002-04-29 Stefan Monnier <[email protected]>
+
+ * lread.c (openp): Change arg exec_only to predicate.
+ (build_load_history): Use XCAR/XCDR.
+ (Flocate_file_internal): New fun.
+ (syms_of_lread): Defsubr it.
+ (Fload): Update call to openp.
+
+ * lisp.h (openp): Update prototype.
+
+ * xfns.c (x_create_bitmap_from_file, x_find_image_file):
+ * w32proc.c (sys_spawnve):
+ * w32fns.c (x_create_bitmap_from_file, x_find_image_file):
+ * w32.c (check_windows_init_file):
+ * sound.c (Fplay_sound_internal):
+ * process.c (Fstart_process):
+ * macfns.c (x_create_bitmap_from_file, x_find_image_file):
+ * mac.c (run_mac_command):
+ * emacs.c (init_cmdargs):
+ * callproc.c (Fcall_process): Update call to openp.
+
+ * textprop.c (remove_properties): Don't use XCAR without CONSP.
+
+ * xterm.c (XTread_socket): Disable the Xutf8LookupString code.
+
+2002-04-29 Pavel Jan,Am(Bk <[email protected]>
+
+ * dispextern.h (DEFAULT_TOOL_BAR_BUTTON_MARGIN)
+ (DEFAULT_TOOL_BAR_BUTTON_RELIEF): Change default values.
+
+2002-04-28 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (Fall_completions, Ftry_completion): New arg to Fcommandp.
+
+ * eval.c (Fcommandp): New arg for_call_interactively.
+ * lisp.h (Fcommandp): Declare new arg.
+
+2002-04-28 Jason Rumney <[email protected]>
+
+ * w32proc.c (syms_of_w32proc): Get true file attributes by default.
+
+ * w32.c (stat, fstat): Use file index information to generate
+ inodes for directories where available.
+
+2002-04-26 Andrew Choi <[email protected]>
+
+ * Makefile.in (C_SWITCH_SYSTEM_TEMACS): Add.
+ [HAVE_CARBON]: Include Mac object files.
+
+ * alloc.c, callproc.c, dispextern.h, dispnew.c, emacs.c,
+ fontset.c, frame.c, frame.h, keyboard.c, sysdep.c, term.c,
+ termcap.c, window.c, xdisp.c, xfaces.c: Use macros MAC_OS8,
+ MAC_OSX, and MAC_OS instead of macintosh.
+
+ * editfns.c [MAC_OS8]: Include stdio.h.
+
+ * emacs.c [MAC_OS8]: Call mac_initialize instead of x_term_init.
+
+ * fontset.c [MAC_OS]: Set Vdefault_fontset to ETL Fixed instead of
+ Apple Monaco.
+
+ * process.c (QCfamily, QCfilte): Declare extern.
+ (wait_reading_process_input) [MAC_OSX]: Clear bit for stdin before
+ calling select.
+
+ * termcap.c [MAC_OSX]: Don't define tgetnum, PC, tputs, and tgetent.
+
+ * tparam.c [MAC_OSX]: Don't define BC and UP.
+
+ * config.in [HAVE_CARBON]: Add.
+
+ * mac.c, macgui.h, macfns.c, macmenu.c, macterm.c, macterm.h:
+ Move here from mac/src and mac/inc.
+
+ * s/darwin.h, m/powermac.h, unexmacosx.c: New files.
+
+2002-04-26 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_draw_phys_cursor_glyph): Undo last change.
+ Compute phys_cursor_width from the x position returned
+ by x_draw_glyhs, which is cheaper.
+ (x_display_and_set_cursor): Compute the buffer-local value
+ of `cursor-in-non-selected-windows' only when needed.
+
+2002-04-25 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_draw_phys_cursor_glyph): Take into account that a box
+ cursor on a stretch glyph has a width that depends on
+ x_stretch_cursor_p.
+
+2002-04-25 Pavel Jan,Am(Bk <[email protected]>
+
+ * abbrev.c (abbrev-start-location): Doc fix.
+
+ * indent.c (Fvertical_motion): Fix last change.
+
+2002-04-25 Gerd Moellmann <[email protected]>
+
+ * indent.c (Fvertical_motion): Move to the start of the line
+ containing PT before moving up or down.
+
+2002-04-24 Gerd Moellmann <[email protected]>
+
+ * dispnew.c (update_text_area): Set phys_cursor_on_p to 0 in the
+ case of writing a whole row, more or less analogous to the case of
+ writing only parts of a row.
+
+ * xterm.c (x_display_and_set_cursor): Set phys_cursor_width to
+ 0 for NO_CURSOR.
+
+ * xterm.c (notice_overwritten_cursor): Fix an off by 1 error.
+
+2002-04-23 Colin Walters <[email protected]>
+
+ * buffer.c (syms_of_buffer): Doc fix.
+
+2002-04-23 Gerd Moellmann <[email protected]>
+
+ * xterm.c (notice_overwritten_cursor): Handle the special case
+ of the cursor being in the first blank non-text line at the
+ end of a window.
+
+ * xterm.c (x_draw_hollow_cursor, x_draw_bar_cursor)
+ (x_draw_phys_cursor_glyph): Set phys_cursor_width here.
+ (x_display_and_set_cursor): Don't set phys_cursor_width here, for
+ bar cursors only, to make phys_cursor_width contain what its name
+ suggests.
+ (notice_overwritten_cursor): Consider the cursor image erased if
+ the output area intersects the cursor image in y-direction.
+
+2002-04-23 Simon Marshall <[email protected]>
+
+ * xfns.c (x_set_mouse_color): Change default for cross_cursor
+ to XC_hand2.
+
+2002-04-23 Pavel Jan,Am(Bk <[email protected]>
+
+ * xdisp.c: Remove unused global variable `minibuf_prompt_pixel_width'.
+
+2002-04-22 Kim F. Storm <[email protected]>
+
+ * textprop.c (remove_properties): Fixed trap for malformed plist.
+
+2002-04-22 Richard M. Stallman <[email protected]>
+
+ * cmds.c (Fend_of_line): Handle intangible text in mid line.
+
+ * window.c (make_window): Initialize height_fixed_p,
+ last_cursor_off_p, and p->cursor_off_p slots.
+
+2002-04-20 Pavel Jan,Am(Bk <[email protected]>
+
+ * fns.c (use-dialog-box): Doc fix.
+
+2002-04-19 Pavel Jan,Am(Bk <[email protected]>
+
+ * xterm.c (note_mode_line_or_margin_highlight): Remove unused
+ variables `row', `i' and `area'.
+ (XTread_socket) <KeyPress>: Pass KeyPress events when in menu to
+ toolkit library.
+
+2002-04-19 Stefan Monnier <[email protected]>
+
+ * xfaces.c (clear_font_table): Don't free the default font of
+ a frame even if it's on another display.
+ (Finternal_set_lisp_face_attribute): Don't use XFRAME on something
+ that could be Qt.
+
+2002-04-19 Juanma Barranquero <[email protected]>
+
+ * indent.c (Fmove_to_column): Remove unused local variable
+ `next_boundary_byte'.
+ (current_column_1): Likewise.
+
+2002-04-19 Eli Zaretskii <[email protected]>
+
+ * msdos.c (Qhbar): New variable.
+ (syms_of_msdos): Intern and staticpro it.
+ (IT_set_cursor_type, IT_set_frame_parameters): Handle the `hbar'
+ cursor type.
+
+2002-04-19 Dave Lambert <[email protected]>
+
+ Theses change implement an underscore-like (`hbar') cursor.
+
+ * xterm.h (text_cursor_kinds): New enumeration member HBAR_CURSOR.
+
+ * xterm.c (x_draw_bar_cursor): New argument KIND; callers changed.
+ Handle the `hbar' cursor type.
+ (x_display_and_set_cursor): Handle the HBAR_CURSOR case.
+
+ * xfns.c (Qhbar): New variable.
+ (syms_of_xfns): Intern and staticpro it.
+ (x_specified_cursor_type): Handle `hbar' cursor.
+
+ * s/sol2-5.h (bcopy, bzero, bcmp): Define only if HAVE_BCOPY is
+ not defined.
+
+2002-04-18 Richard M. Stallman <[email protected]>
+
+ * textprop.c (remove_properties): New arg LIST allows scanning
+ either a list or a plist.
+ (interval_has_some_properties_list): New function, like
+ interval_has_some_properties using list instead of plist.
+ All callers changed.
+ (Fremove_list_of_text_properties): New function.
+ (syms_of_textprop): Defsubr it.
+
+2002-04-17 Eli Zaretskii <[email protected]>
+
+ * s/sol2.h (HAVE_LIBKSTAT): Define only if not already defined.
+
+2002-04-17 Juanma Barranquero <[email protected]>
+
+ * indent.c (Fmove_to_column): Remove unused local variable `end_byte'.
+
+2002-04-17 Eli Zaretskii <[email protected]>
+
+ * window.c (coordinates_in_window): Don't report on margin area
+ if its width is zero.
+
+2002-04-16 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fx_file_dialog): Decode file name before using.
+
+ * w32term.c (construct_drag_n_drop): Likewise.
+
+2002-04-16 Eli Zaretskii <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 830000, since we now
+ store load-history in pure space.
+
+ * s/msdos.h (SYSTEM_PURESIZE_EXTRA): Reduce to 50000.
+
+2002-04-16 Stefan Monnier <[email protected]>
+
+ * xterm.c (Qlatin_1, Qutf_8): New vars.
+ (syms_of_xterm): Initialize them.
+ (XTread_socket): Eliminate incorrect optimization that tried to avoid
+ decoding the output of X*LookupString.
+ Always use latin-1 to decode the output of XLookupString.
+ Try Xutf8LookupString if XmbLookupString failed.
+
+ * region-cache.c (new_region_cache): Use BEG.
+
+2002-04-16 Gerd Moellmann <[email protected]>
+
+ * buffer.c (MMAP_ALLOCATED_P): New macro to be set from system
+ configuration files.
+ (mmap_enlarge): Enlarge mapped regions only if MMAP_ALLOCATED_P
+ returns 0.
+
+2002-04-15 Andreas Schwab <[email protected]>
+
+ * config.in: Regenerated using autoheader.
+
+ * m/7300.h, m/acorn.h, m/alliant-2800.h, m/alliant.h, m/alpha.h,
+ m/altos.h, m/amdahl.h, m/apollo.h, m/arm.h, m/att3b.h, m/aviion.h,
+ m/celerity.h, m/clipper.h, m/cnvrgnt.h, m/convex.h, m/cydra5.h,
+ m/delta.h, m/delta88k.h, m/dpx2.h, m/elxsi.h, m/gec63.h,
+ m/gould.h, m/hp800.h, m/hp9000s300.h, m/i860.h, m/ia64.h,
+ m/ibmps2-aix.h, m/ibmrs6000.h, m/ibmrt-aix.h, m/ibmrt.h,
+ m/ibms390.h, m/intel386.h, m/iris4d.h, m/irist.h, m/isi-ov.h,
+ m/m68k.h, m/macppc.h, m/masscomp.h, m/mg1.h, m/mips-siemens.h,
+ m/mips.h, m/news-r6.h, m/news.h, m/next.h, m/nh3000.h, m/nh4000.h
+ m/ns32000.h, m/orion.h, m/pfa50.h, m/plexus.h, m/pmax.h,
+ m/powerpcle.h, m/pyrmips.h, m/sequent-ptx.h, m/sequent.h,
+ m/sparc.h, m/sr2k.h, m/symmetry.h, m/tad68k.h, m/tahoe.h,
+ m/targon31.h, m/tek4300.h, m/tekxd88.h, m/template.h, m/tower32.h,
+ m/tower32v3.h, m/ustation.h, m/vax.h, m/wicat.h, m/windowsnt.h,
+ m/xps100.h, s/aix3-2.h, s/aix4-2.h, s/irix4-0.h, s/irix5-0.h,
+ s/sco5.h, s/unixware.h: Don't set HAVE_ALLOCA, C_ALLOCA and
+ STACK_DIRECTION, now set by autoconf.
+
+2002-04-14 Pavel Jan,Am(Bk <[email protected]>
+
+ * dispnew.c (marginal_area_string): Sort arguments.
+
+ * dispextern.h (marginal_area_string): Add prototype.
+
+2002-04-13 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Finsert_file_contents):
+ Don't call temp_output_buffer_setup--do just part, by hand.
+
+ * coding.c (run_pre_post_conversion_on_str):
+ Don't call temp_output_buffer_setup--do just part, by hand.
+
+ * keyboard.c (command_loop_1): Don't call start_hourglass
+ or cancel_hourglass when executing a macro.
+
+ * marker.c (count_markers): New function.
+
+ * xdisp.c (display_mode_element): Don't let mode_line_proptrans_alist
+ grow without limit. Move recently used elements to the front.
+
+2002-04-13 Eli Zaretskii <[email protected]>
+
+ * unexelf.c (unexec) [__sgi]: Undo the change from 2002-01-20.
+
+2002-04-12 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (sync_frame_with_window_matrix_rows): Don't give frame
+ rows marginal areas.
+ (Fdump_frame_glyph_matrix) [GLYPH_DEBUG]: New function.
+ (syms_of_xdisp) [GLYPH_DEBUG]: Defsubr it.
+
+ * dispnew.c (marginal_area_string): Check that glyph row is enabled.
+
+2002-04-12 Dave Love <[email protected]>
+
+ * dispnew.c (marginal_area_string): New.
+
+ * window.c (window_part): Add ON_LEFT_MARGIN, ON_RIGHT_MARGIN.
+ (Qleft_margin, Qright_margin): Declare.
+ (coordinates_in_window, (Fcoordinates_in_window_p): Deal with margins.
+
+ * xterm.c (note_mode_line_or_margin_highlight): Renamed from
+ note_mode_line_highlight and extended.
+
+ * keyboard.c (Qleft_margin, Qright_margin): Declare.
+ (make_lispy_event): Deal with mouse events in margins.
+
+2002-04-12 Stefan Monnier <[email protected]>
+
+ * msdos.c (dos_rawgetc): Use a single event for HELP_EVENT.
+
+ * keyboard.c (command_loop_1): Turn off transient-mark-mode rather
+ than deactivating the mark if tmm is set to `lambda'.
+ (gen_help_event, kbd_buffer_store_help_event, kbd_buffer_get_event):
+ Use a single event for HELP_EVENT.
+ (Fexecute_extended_command): Save last_point_position.
+
+2002-04-12 Pavel Jan,Am(Bk <[email protected]>
+
+ * lisp.h (Fpropertize): Add prototype.
+
+ * fns.c (Fy_or_n_p): Use `minibuffer-prompt' face for prompt.
+
+2002-04-10 Colin Walters <[email protected]>
+
+ * config.in: Add HAVE_SHARED_GAME_DIR.
+
+ * callproc.c (Vgame_score_directory): New variable.
+ (syms_of_callproc) <Vgame_score_directory>: DEFVAR_LISP.
+
+2002-04-10 Richard M. Stallman <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Reduce again to avoid big excess.
+
+2002-04-09 Stefan Monnier <[email protected]>
+
+ * minibuf.c (read_minibuf): Use empty_string.
+ (Ftry_completion): Allow lambda forms and lists of strings for `alist'.
+ Short-circuit the search as soon as it "failed".
+ (Fall_completions): Allow lambda forms and lists of strings for alist.
+ (Fcompleting_read): Set Qminibuffer_completion_confirm to nil
+ when require_match is nil.
+ (Ftest_completion): Rename from `test_completion' and export to elisp.
+ Call the predicate also when alist is a list.
+ Obey Vcompletion_regexp_list.
+ (do_completion, Fminibuffer_complete_and_exit): Use it.
+ (Fassoc_string): Rename from `assoc_for_completion'.
+ Allow list of strings as well and export to elisp.
+
+2002-04-08 Stefan Monnier <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 900KB.
+
+2002-04-08 Juanma Barranquero <[email protected]>
+
+ * w32.c (sys_accept): Don't hide variable `s'.
+
+2002-04-05 Gerd Moellmann <[email protected]>
+
+ * callint.c (Fcall_interactively): Use INTEGERP instead of
+ NUMBERP for checking Vhistory_length.
+
+2002-04-05 Pavel Jan,Am(Bk <[email protected]>
+
+ * sound.c (Fplay_sound_internal): Renamed from Fplay_sound.
+ Doc fix to reflect it.
+
+2002-04-04 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (display_mode_element): New arg RISKY.
+ Disregard text props found or specified within a variable
+ that isn't marked risky-local-variable.
+ (Qrisky_local_variable): New variable.
+ (syms_of_xdisp): Init and staticpro it.
+
+2002-04-04 Stefan Monnier <[email protected]>
+
+ * undo.c (record_point): New fun.
+ (record_delete, record_insert): Use it.
+
+2002-04-03 Juanma Barranquero <[email protected]>
+
+ * doc.c (Fdocumentation): Add missing parentheses.
+ (Fdocumentation_property): Likewise.
+
+2002-04-03 Stefan Monnier <[email protected]>
+
+ * doc.c (Fdocumentation, Fdocumentation_property): When the doc
+ data is 0, just return nil.
+
+2002-04-03 Eli Zaretskii <[email protected]>
+
+ * msdos.c (syms_of_msdos): Fix last change with
+ mouse_autoselect_window.
+
+2002-04-03 Pavel Jan,Am(Bk <[email protected]>
+
+ * w32term.c, xterm.c, msdos.c: Rename autoselect_window_p to
+ mouse_autoselect_window.
+
+2002-04-02 Stefan Monnier <[email protected]>
+
+ * keyboard.c (make_lispy_event): Handle unknown keysyms together
+ with system-specific keysyms. Use it also for unknown function keys.
+
+ * doc.c (reread_doc_file): Return whether reload was attempted.
+ (Fdocumentation, Fdocumentation_property): Don't try to reload
+ if the doc is 0 and only ask once.
+
+ * Makefile.in (lisp, shortlisp): Add ucs-tables.elc.
+
+2002-04-02 Eli Zaretskii <[email protected]>
+
+ * keyboard.c (read_char): If the event was Qselect_window,
+ restore timer_idleness_start_time to its previous value.
+
+ * msdos.c (dos_rawgetc): Generate SELECT_WINDOW_EVENTs when required.
+
+2002-04-01 Stefan Monnier <[email protected]>
+
+ * region-cache.c (new_region_cache): Use BEG.
+
+ * marker.c (buf_charpos_to_bytepos, buf_bytepos_to_charpos):
+ Use BEG and BEG_BYTE.
+
+ * doc.c (get_doc_string): Return nil if the location is wrong.
+ (reread_doc_file): New fun.
+ (Fdocumentation, Fdocumentation_property):
+ Call it if get_doc_string fails.
+ (Fsnarf_documentation): Make it work for a dumped Emacs.
+
+ * charset.h (DEC_POS, BUF_DEC_POS): Use BEG_BYTE.
+ Bound the search with MAX_MULTIBYTE_LENGTH to avoid pathological case.
+
+ * charset.c (Fstring): Allow 0 arguments.
+
+ * xterm.c (XTread_socket): Fix int/Lisp_Object confusion.
+
+ * process.c (DATAGRAM_CONN_P, list_processes_1)
+ (Fprocess_datagram_address, Fset_process_datagram_address)
+ (Fset_network_process_options, server_accept_connection):
+ Fix some int/Lisp_Object confusions (thank you union types).
+
+2002-04-01 Pavel Jan,Am(Bk <[email protected]>
+
+ * msdos.c: Rename x_autoselect_window_p to autoselect_window_p.
+
+ * w32term.c: Likewise.
+ (note_mouse_movement): Put code for x_autoselect_window_p in #if 0.
+
+ * keyboard.c (Qselect_window): New symbol.
+ (head_table): Use it.
+ (keys_of_keyboard): Bound select-window event to handle-select-window.
+ (kbd_buffer_get_event): Make a Lisp event from SELECT_WINDOW_EVENT.
+
+ * xterm.c: Rename x_autoselect_window_p to autoselect_window_p.
+ (last_window): New variable.
+ (XTread_socket): Generate SELECT_WINDOW_EVENTs.
+ (note_mouse_movement): Remove reimplemented code in #if 0.
+ (XTread_socket): Generate SELECT_WINDOW_EVENTs only for
+ Emacs windows.
+
+ * termhooks.h (enum event_kind): New event type `SELECT_WINDOW_EVENT'.
+
+2002-03-31 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_get_char_face_and_encoding): Add parameter DISPLAY_P.
+ Callers changed.
+
+2002-03-30 Richard M. Stallman <[email protected]>
+
+ * window.c (window_scroll_pixel_based): Exit the move_it_by_lines
+ loop whenever it stops making progress.
+
+ * widget.c (set_frame_size): Don't call change_frame_size.
+
+2002-03-30 Gerd Moellmann <[email protected]>
+
+ * dispnew.c (direct_output_for_insert):
+ Call mark_window_display_accurate.
+
+2002-03-29 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_draw_relief_rect): Fix calculations of line lengths.
+
+2002-03-29 Eli Zaretskii <[email protected]>
+
+ * Makefile.in (lread.o): Depend on coding.h.
+
+ * lread.c (openp, Fload): Encode the file name before passing it
+ to `stat', `access', and `emacs_open'.
+ (openp): GCPRO the encoded file name. Don't recompute Lisp
+ strings unnecessarily.
+
+2002-03-29 Kim F. Storm <[email protected]>
+
+ * fns.c (Flax_plist_put): Doc fix.
+
+2002-03-28 Miles Bader <[email protected]>
+
+ * process.c (DATAGRAM_CONN_P): Make sure PROC is really a process.
+
+2002-03-27 Pavel Jan,Am(Bk <[email protected]>
+
+ * process.c (set-network-process-options): Add usage.
+ (make-network-process): Doc fix.
+
+2002-03-26 Eli Zaretskii <[email protected]>
+
+ * emacs.c (Fdump_emacs): Fix a typo in "command-line-processed".
+
+2002-03-26 Richard M. Stallman <[email protected]>
+
+ * fns.c (Fsubstring_no_properties): New function.
+ (Flax_plist_get, Flax_plist_put): New functions.
+ (syms_of_fns): defsubr them.
+
+ * xdisp.c (update_menu_bar): Test only update_mode_lines;
+ don't test or alter w->update_mode_line.
+
+ * window.c (Fdisplay_buffer): Doc fix.
+
+2002-03-24 Richard M. Stallman <[email protected]>
+
+ * regex.c (GET_UNSIGNED_NUMBER): Give proper error for spaces.
+
+2002-03-24 Gerd Moellmann <[email protected]>
+
+ * eval.c (Qdeclare, Vmacro_declaration_function): New variables.
+ (Fdefmacro): Handle `(declare ...)'.
+ (syms_of_eval) <Qdeclare>: Initialize and staticpro.
+ (syms_of_eval) <Vmacro_declaration_function>: DEFVAR_LISP.
+
+2002-03-24 Jason Rumney <[email protected]>
+
+ * w32fns.c (xbm_scan, xbm_load_image, xbm_read_bitmap_data)
+ (xbm_file_p): Add prototypes.
+ (xbm_format, xbm_image_p): Sync with xfns.c.
+ (reflect_byte): New function.
+ (xbm_read_bitmap_data): Sync with xfns.c, adapt for Windows.
+ (xbm_load_image): Create bitmaps with a depth of 1.
+ (init_xfns): Enable XBM images.
+
+2002-03-23 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_handle_tool_bar_click): Detect up and down events
+ correctly. Do not pass up_modifier to keyboard buffer.
+
+ * w32fns.c [HAVE_IMAGES, HAVE_PBM]: Remove conditionals.
+
+2002-03-22 Stefan Monnier <[email protected]>
+
+ * Makefile.in (bootstrapclean): New target.
+ (bootstrap-temacs, bootstrap-doc): Remove.
+ (bootstrap-emacs): Use a bog-standard `temacs'.
+ Don't bother to build a DOC file.
+
+ * sysdep.c (wait_for_termination): Use sigsuspend rather than sigpause.
+
+ * emacs.c (main): Handle --unibyte, --multibyte, and --no-loadup
+ in temacs even if !CANNOT_DUMP.
+ (standard_args): Keep --no-loadup even if !CANNOT_DUMP.
+
+ * alloc.c (check_pure_size): Only output a warning.
+
+2002-03-22 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fx_create_frame): Enable tool-bar when images are
+ supported.
+
+ * w32term.c (zv_bits): Declare as short, for word alignment.
+ (w32_read_socket) <WM_XBUTTONUP>: Fix last change.
+ (syms_of_w32term): Define x-use-underline-position-properties.
+
+ * w32fns.c (x_set_cursor_color): Set cursor_gc as well.
+ (clear_image_cache): Block input, fix logic, clear matrices in
+ all frames that share this cache.
+
+2002-03-22 Eli Zaretskii <[email protected]>
+
+ * emacs.c (main): Update the Copyright year in the blurb printed
+ by "emacs --version".
+
+ * xdisp.c (message_with_string): Fix syntax of a call to GCPRO2.
+
+ * xterm.c (XTread_socket): If XK_ISO_Lock and
+ XK_ISO_Last_Group_Lock are defined, handle keysyms between
+ XK_ISO_Lock and XK_ISO_Last_Group_Lock similarly to Mode_switch.
+
+2002-03-21 Kim F. Storm <[email protected]>
+
+ * keyboard.c (menu_bar_items): Mostly undo 2002-02-20 patch, so
+ menu-bar bindings in keymap and local-map properties _are_ used.
+ But try keymap property first in accordance with 2002-01-03 patch.
+ Added comment describing why this is not always reliable.
+ (tool_bar_items): Ditto for tool-bar.
+
+2002-03-21 Jason Rumney <[email protected]>
+
+ * w32fns.c (x_clear_image_1): Disable color table code.
+
+2002-03-21 Kim F. Storm <[email protected]>
+
+ * lisp.h (DEFUN) [USE_NONANSI_DEFUN]: The 2001-10-17 patch
+ removed the wrong version of the DEFUN macro; fixed it.
+
+ * fns.c (Ffeaturep): Allow subfeature to be a list (test using
+ Fmember rather than Fmemq).
+ (Fprovide): Check that subfeatures is a list.
+
+ * process.c (QCfeature, QCdatagram): Removed variables.
+ (QCtype, Qdatagram): New variables.
+ (network_process_featurep): Removed function.
+ (Fmake_network_process): Removed :feature check.
+ Use :type 'datagram instead of :datagram t to create a datagram
+ socket. This allows us to add other connection types (e.g. raw
+ sockets) later in a consistent manner.
+ (init_process) [subprocess, HAVE_SOCKETS]: Provide list of
+ supported subfeatures for feature make-network-process.
+ (syms_of_process) [subprocess]: Remove QCfeature and QCdatagram.
+ Intern and staticpro QCtype and Qdatagram.
+ (syms_of_process) [!subprocess]: Intern and staticpro QCtype.
+
+ * xfns.c (QCtype): Remove duplicate declaration and
+ initialization (is now declared in process.c).
+
+ * w32fns.c (QCtype): Remove duplicate declaration and
+ initialization (is now declared in process.c).
+
+2002-03-21 Richard M. Stallman <[email protected]>
+
+ * regex.c (DISCARD_FAILURE_REG_OR_COUNT): New macro.
+ (CHECK_INFINITE_LOOP): Use DISCARD_FAILURE_REG_OR_COUNT
+ when jumping to `fail' to avoid undoing reg changes in the
+ last iteration of the loop.
+ (GET_UNSIGNED_NUMBER): Skip spaces around the number.
+
+ * Makefile.in (dispnew.o, sysdep.o, xdisp.o, xselect.o, alloc.o):
+ Depend on process.h.
+
+2002-03-20 Jason Rumney <[email protected]>
+
+ Most of the following changes are still conditional on HAVE_IMAGES
+ which is not set by default on Windows.
+
+ * emacs.c (main) [WINDOWSNT]: Call init_xfns.
+
+ * w32fns.c (x_set_cursor_color): Set foreground of cursor, not frame.
+ (Fimage_size, Fimage_mask_p, XPutPixel): New functions.
+ (four_corners_best, x_clear_image_1, x_clear_image)
+ (x_alloc_image_color, postprocess_image)
+ (x_create_x_image_and_pixmap, x_destroy_x_image, xbm_load_image)
+ (x_from_x_colors, x_disable_image, pbm_load): Adapt for Windows.
+ (init_xfns, syms_of_w32fns): Initialize image functions and constants.
+
+ * w32gui.h (struct XImage): Define.
+
+ * w32term.c (w32_read_socket) <WM_XBUTTONUP>: Use XFASTINT to
+ extract mouse co-ordinates.
+
+2002-03-20 Jason Rumney <[email protected]>
+
+ * w32.c (init_winsock): Dynamically load new server and UDP
+ socket functions.
+ (socket_to_fd): New function.
+ (sys_socket): Use it.
+ (sys_setsockopt, sys_listen, sys_getsockname, sys_accept)
+ (sys_recvfrom, sys_sendto): New wrapper functions.
+
+ * process.c (QCfamily, QCfilter): Remove duplicate declaration
+ and initialization.
+
+ * makefile.w32-in (LIBS): Remove $(WSOCK32).
+
+2002-03-20 Eli Zaretskii <[email protected]>
+
+ * process.c (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr):
+ Don't use "sun" as a variable, it's a predefined constant on Sun
+ machines.
+
+2002-03-20 Pavel Jan,Am(Bk <[email protected]>
+
+ * bytecode.c (Fbyte_code): Revert last change.
+
+2002-03-19 Kim F. Storm <[email protected]>
+
+ * makefile.w32-in (LIBS): Add $(WSOCK32).
+ From David Ponce <[email protected]>.
+
+2002-03-18 Pavel Jan,Am(Bk <[email protected]>
+
+ * process.c (wait_reading_process_input): Move variables `pname'
+ and `pnamelen' down where they are used.
+
+ * bytecode.c (Fbyte_code): Discard unused computed value to
+ prevent gcc warning.
+
+ * lisp.h (Fplist_member): Add prototype.
+
+2002-03-18 Kim F. Storm <[email protected]>
+
+ * config.in: Add HAVE_SENDTO, HAVE_RECVFROM, HAVE_SETSOCKOPT,
+ HAVE_GETSOCKOPT, HAVE_GETPEERNAME, HAVE_GETSOCKNAME, and HAVE_SYS_UN_H.
+
+ * process.c: Define HAVE_LOCAL_SOCKETS based on HAVE_SYS_UN_H.
+ Remove explicit GNU_LINUX settings for datagram support.
+
+2002-03-18 Pavel Jan,Am(Bk <[email protected]>
+
+ * process.c (Fmake_network_process): Remove unused variable `sa'.
+ Doc fix. Add usage:.
+ (set_socket_options): Remove unused variables `optnum' and `opttype'.
+
+2002-03-17 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (cursor_type_changed): New variable.
+ (redisplay_internal): Redisplay all windows if cursor_type_changed.
+ Clear it when clearing windows_or_buffers_changed.
+ (try_cursor_movement, redisplay_window, try_window_id)
+ (try_window_reusing_current_matrix): Test cursor_type_changed
+ along with windows_or_buffers_changed.
+
+ * window.h (cursor_type_changed): New variable.
+
+ * xfns.c (x_set_cursor_type): Set cursor_type_changed,
+ not update_mode_lines, and always set it to 1.
+
+ * xdisp.c (clear_garbaged_frames): Don't set windows_or_buffers_changed
+ if no frames needed redrawing.
+
+2002-03-17 Kim F. Storm <[email protected]>
+
+ The following changes add support for network server processes,
+ datagram connections, and local (unix) sockets.
+
+ * process.h (struct Lisp_Process): New member log.
+ Doc fix: Member command used to indicate stopped network process.
+ Doc fix: Member childp contains plist for network process.
+ Doc fix: Member kill_without_query is inverse of query-on-exit flag.
+
+ * process.c (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
+ (QClocal, QCremote, QCserver, QCdatagram, QCnowait, QCnoquery, QCstop)
+ (QCcoding, QCoptions, QCfilter, QCsentinel, QClog, QCfeature): New
+ variables.
+ (NETCONN1_P): New macro.
+ (DATAGRAM_SOCKETS): New conditional symbol.
+ (datagram_address): New array.
+ (DATAGRAM_CONN_P, DATAGRAM_CHAN_P): New macros.
+ (status_message): Use concat3.
+ (Fprocess_status): Add `listen' status to doc string. Return
+ `stop' for a stopped network process.
+ (Fset_process_buffer): Update contact plist for network process.
+ (Fset_process_filter): Ditto. Don't enable input for stopped
+ network processes. Server must listen, even if filter is t.
+ (Fset_process_query_on_exit_flag, Fprocess_query_on_exit_flag):
+ New functions.
+ (Fprocess_kill_without_query): Removed. Now defined in simple.el.
+ (Fprocess_contact): Added KEY argument. Handle datagrams.
+ (list_processes_1): Optionally show only processes with the query
+ on exit flag set. Dynamically adjust column widths. Omit tty
+ column if not needed. Report stopped network processes. Identify
+ server and datagram network processes.
+ (Flist_processes): New optional arg `query-only'.
+ (conv_sockaddr_to_lisp, get_lisp_to_sockaddr_size)
+ (conv_lisp_to_sockaddr, set_socket_options)
+ (network_process_featurep, unwind_request_sigio): New helper
+ functions.
+ (Fprocess_datagram_address, Fset_process_datagram_address):
+ (Fset_network_process_options): New lisp functions.
+ (Fopen_network_stream): Removed. Now defined in simple.el.
+ (Fmake_network_process): New lisp function. Code is based on
+ previous Fopen_network_stream, but heavily reworked with new
+ property list based argument list, support for datagrams, server
+ processes, and local sockets in addition to old client-only
+ functionality.
+ (server_accept_connection): New function.
+ (wait_reading_process_input): Use it to handle incoming connects.
+ Do not enable input on a new connection if process is stopped.
+ (read_process_output): Handle datagram sockets. Use 2k buffer for
+ them.
+ (send_process): Handle datagram sockets.
+ (Fstop_process, Fcontinue_process): Apply to network processes. A
+ stopped network process is indicated by setting command field to t.
+ (Fprocess_send_eof): No-op if datagram connection.
+ (Fstatus_notify): Don't read input for a stream server socket or a
+ stopped network process.
+ (init_process): Initialize datagram_address array.
+ (syms_of_process): Intern and staticpro new variables, defsubr new
+ functions.
+
+2002-03-16 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_to_all_x_charsets): Return correct type in
+ startup case.
+
+2002-03-16 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (redisplay_internal, redisplay_windows):
+ Use list_of_error to call internal_condition_case_1.
+ (safe_eval, safe_call): Pass Qt to internal_condition_case_{1,2}
+ so as to catch all errors with no possibility of debugger redisplay.
+ (list_of_error): New variable.
+ (syms_of_xdisp): Init and staticpro it.
+
+ * print.c (print_object): Delete `\ ' from printed rep of frame.
+
+2002-03-15 Eli Zaretskii <[email protected]>
+
+ * msdos.c (dos_rawgetc): Disable the x-autoselect-window feature,
+ until its implementation is fixed.
+
+2002-03-14 Pavel Jan,Am(Bk <[email protected]>
+
+ * xfns.c (png_load): Remove unused variable `gamma_str'.
+
+2002-03-14 Richard M. Stallman <[email protected]>
+
+ * xfns.c (x_real_positions): Handle failure in XQueryTree.
+
+2002-03-14 Miles Bader <[email protected]>
+
+ * intervals.c (adjust_for_invis_intang): New function.
+ (set_point_both): Use `adjust_for_invis_intang' to do most of the
+ work for dealing with invisible+intangible regions. Do so before
+ and after both forward and backward movements, to handle both
+ front-sticky and rear-sticky cases.
+ * textprop.c (text_property_stickiness): Function moved here from
+ `editfns.c'.
+ * intervals.h (text_property_stickiness): New declaration.
+ * editfns.c (char_property_eq): Function removed.
+ (text_property_stickiness): Function moved to `textprop.c'.
+
+2002-03-13 Jason Rumney <[email protected]>
+
+ * config.in: Add STRFTIME_NO_POSIX2.
+
+ * strftime.c (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
+ and %OX when underlying strftime does not.
+
+2002-03-13 Stefan Monnier <[email protected]>
+
+ * xterm.c (x_set_toolkit_scroll_bar_thumb) <USE_MOTIF>:
+ Use a fixed-size thumb (based on an ad-hoc estimate of 30 chars per
+ line) to avoid annoying flicker.
+ (xm_scroll_callback): Get rid of the now unnecessary kludge.
+ (XTread_socket): Mark it static.
+
+ * xdisp.c (display_mode_element): Fix int/Lisp_Object mixup.
+
+2002-03-13 Kim F. Storm <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 775000.
+
+2002-03-12 Juanma Barranquero <[email protected]>
+
+ * editfns.c (syms_of_editfns): Fix typo.
+
+2002-03-12 Gerd Moellmann <[email protected]>
+
+ * xsmfns.c: Include stdio.h because termhooks.h needs it.
+ Include termopt.h for interrupt_input.
+
+2002-03-11 Andreas Schwab <[email protected]>
+
+ * coding.c (syms_of_coding) <file-coding-system-alist>: Doc fix.
+
+2002-03-11 Gerd Moellmann <[email protected]>
+
+ * xterm.c (note_mouse_movement): Put code for
+ x_autoselect_window_p in #if 0.
+
+ * lread.c (Fload): Don't assume that message_with_string uses the
+ string it is given like a C string.
+
+2002-03-10 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h (x_session_check_input, x_session_initialize): Declare.
+
+ * xterm.c (XTread_socket): Add call to x_session_check_input and
+ x_session_have_connection.
+ (x_initialize): Add call to x_session_initialize.
+
+ * termhooks.h (enum event_kind): Add save_session_event.
+
+ * keyboard.c: Add Emacs event save_session_event.
+
+ * emacs.c (main): Add call to syms_of_xsmfns.
+
+ * lisp.h (syms_of_xsmfns): Declare extern.
+
+ * config.in: Add HAVE_X_SM.
+
+ * Makefile.in (LIBXT): Add -lSM -lICE
+ if HAVE_X_SM and not USE_X_TOOLKIT.
+ (XOBJ): New file xsmfns.c added.
+
+ * xsmfns.c: New file for X session management.
+
+2002-03-09 Jason Rumney <[email protected]>
+
+ * fileio.c (Fcopy_file) [WINDOWS_NT]: Ensure file is not
+ read-only when setting modified time.
+
+2002-03-08 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (move_it_vertically_backward): At the end of the function,
+ when moving forward by lines, treat terminal frames specially.
+
+ * keyboard.c (echo_char): Make sure to add a separator between
+ keys even if echo_dash hasn't been called.
+
+ * xdisp.c: Use new string macros.
+ (update_echo_area): Pass number of bytes to message3 instead of
+ number of chars.
+ (set_message_1): Don't access a string's size_byte directly.
+ (decode_mode_spec_coding): Use number of bytes of eoltype string
+ instead number of chars.
+
+ * lisp.h (SREF, SDATA, SCHARS, SBYTES, SMBP): New macros.
+
+2002-03-08 Juanma Barranquero <[email protected]>
+
+ * w32fns.c (Fx_display_color_cells): Force 24+ bit color depths to
+ 24-bit.
+
+2002-03-06 Jason Rumney <[email protected]>
+
+ * w32term.c (x_draw_hollow_cursor): Draw same size as block cursor.
+
+2002-03-06 Gerd Moellmann <[email protected]>
+
+ * keyboard.c (echo_prompt, echo_char, echo_dash, echo_now)
+ (cancel_echoing, echo_length, echo_truncate): Changed to
+ work with new kboard definition.
+ (echo_now): Use message3_nolog instead of message2_nolog.
+
+ * alloc.c (mark_kboards): Mark echo_string.
+
+ * keyboard.h (ECHOBUFSIZE): Removed.
+ (struct kboard): Member echoptr removed, member echobuf renamed
+ to echo_string.
+
+ * xdisp.c (message_with_string): Use Fformat instead of doprnt and
+ message3 instead of message2 to display the message using STRING's
+ text properties.
+
+2002-03-05 Andreas Schwab <[email protected]>
+
+ * xdisp.c (hscroll_margin): Change to EMACS_INT.
+
+2002-03-05 Per Abrahamsen <[email protected]>
+
+ * frame.c (default-frame-alist): Explain that setting it doesn't
+ affect existing frames.
+
+2002-03-05 Stefan Monnier <[email protected]>
+
+ * indent.c (skip_invisible): Fix my brain fart.
+
+ * dispnew.c (sit_for): Don't wait if executing a kbd macro.
+
+2002-03-04 Stefan Monnier <[email protected]>
+
+ * dosfns.c, dosfns.h, dispnew.c, dispextern.h, commands.h, charset.c,
+ * alloc.c, abbrev.c, emacs.c, eval.c, keyboard.c, keyboard.h,
+ * lisp.h, lread.c, sysdep.c, termcap.c, termchar.h, w32term.c,
+ * window.c, xdisp.c, xselect.c, xterm.c: Change defvar_int definition
+ and variables to use EMACS_INT instead of just int.
+
+ * buffer.c (syms_of_buffer): Allow non-string `mode-name'.
+
+2002-03-04 Eli Zaretskii <[email protected]>
+
+ * sysdep.c (sys_subshell) [MSDOS]: If PWD is set in the
+ environment, pass it down with corrected value.
+
+2002-03-04 Pavel Jan,Am(Bk <[email protected]>
+
+ * lread.c (read_filtered_event): Do not call start_hourglass
+ before returning.
+
+2002-03-04 Juanma Barranquero <[email protected]>
+
+ * w32term.c (x_display_and_set_cursor): Fix typo.
+
+2002-03-03 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fmake_temp_name): Doc fix.
+
+2002-03-03 Gary Wong <[email protected]>
+
+ * termcap.c [!emacs]: Replace ospeed for building standalone
+ libtermcap, for binary compatibility.
+
+ * tparam.c [!emacs]: Move #define of bcopy to after string.h.
+
+2002-03-03 Richard M. Stallman <[email protected]>
+
+ * xrdb.c (file_p): Rename arg `path' to `filename'.
+
+ * abbrev.c (Fexpand_abbrev): Increment plist as use count
+ only if it is an integer.
+
+ * xfns.c (png_load): Set screen_gamma based on f->gamma.
+ If png_get_sRGB gives an answer, call png_set_gamma
+ using the default image gamma value.
+
+ * lread.c (read1): When reading from a file, default string to
+ multibyte only if it has some multibyte characters.
+
+ * print.c (print_object): Output multibyte chars 128...255
+ using \x even if ! print_escape_multibyte.
+
+ * xdisp.c (display_mode_element): Move the places where
+ bytepos, charpos, this, and lisp_string are set.
+ Use lisp_string to set bytepos.
+
+ * xdisp.c (redisplay_internal):
+ Call clear_image_cache only if HAVE_WINDOW_SYSTEM.
+
+ * xdisp.c (display_mode_element): Merge properties specified with
+ :propertize onto those that come with the string.
+
+2002-03-03 Eli Zaretskii <[email protected]>
+
+ * xdisp.c (syms_of_xdisp) <auto-hscroll-mode>: Renamed from
+ automatic-hscrolling. Users changed.
+ <hscroll-margin>: Renamed from automatic-hscroll-margin.
+ Users changed.
+ <hscroll-step>: Renamed from automatic-hscroll-step. Users changed.
+
+2002-03-02 Eli Zaretskii <[email protected]>
+
+ * buffer.c (syms_of_buffer) <buffer-file-coding-system>: Doc fix.
+
+2002-03-02 Kim F. Storm <[email protected]>
+
+ * window.c (Fminibuffer_selected_window): New function.
+ (syms_of_window): Defsubr it.
+
+2002-03-01 Kim F. Storm <[email protected]>
+
+ * window.h (struct window): New member phys_cursor_width.
+
+ * window.c (make_window, replace_window): Init phys_cursor_width.
+
+ * xterm.c (x_display_and_set_cursor): Blink box cursor using
+ hollow box cursor. Blink bar cursor using 1 pixel wide bar.
+
+ * w32term.c (x_display_and_set_cursor): Blink box cursor using
+ hollow box cursor. Blink bar cursor using 1 pixel wide bar.
+
+ * lisp.h (GCPRO6): New macro.
+
+ * process.c (Fopen_network_stream): Use GCPRO6.
+
+2002-03-01 Kim F. Storm <[email protected]>
+
+ * process.c (Qconnect, Qfailed): New variables.
+ (syms_of_process): Intern and staticpro them.
+ (Fprocess_status): Document connect and failed return values.
+ [NON_BLOCKING_CONNECT]: New conditional.
+ (connect_wait_mask, num_pending_connects): New variables.
+ (status_message): Convert Qfailed status.
+ (Fopen_network_stream): Added support for non-blocking connect.
+ New optional args: filter, sentinel, non_blocking. Doc updated.
+ [HAVE_GETADDRINFO, !HAVE_GETADDRINFO]: Merged common code.
+ (deactivate_process): Handle pending non-blocking connect.
+ (wait_reading_process_input): Poll for status of non-blocking
+ connects. Exec sentinel directly when connect succeeds.
+ (status_notify): Don't read process output if not yet connected.
+
+2002-02-28 Kim F. Storm <[email protected]>
+
+ * window.c (minibuf_selected_window): Renamed from
+ Vminibuf_selected_window. Users changed.
+ (syms_of_window): Staticpro it.
+
+2002-02-26 Kim F. Storm <[email protected]>
+
+ The following changes add a new Vminibuf_selected_window variable
+ which is similar to Vminibuf_scroll_window, but which is only set
+ on entry to the minibuffer (from a non-minibuffer window):
+
+ * window.c (Vminibuf_selected_window): New variable.
+ (struct save_window_data): New member minibuf_selected_window.
+ (Fset_window_configuration): Restore Vminibuf_selected_window.
+ (Fcurrent_window_configuration): Save Vminibuf_selected_window.
+ Set minibuf_scroll_window member to nil if minibuf_level is 0.
+ (compare_window_configurations): Compare minibuf_selected_window.
+
+ * window.h (Vminibuf_selected_window): Declare extern.
+
+ * minibuf.c (read_minibuf): Set Vminibuf_selected_window on first
+ entry to minibuffer or on entry from a non-minibuffer window.
+
+ * dispextern.h (CURRENT_MODE_LINE_FACE_ID_3): Compare with
+ Vminibuf_selected_window instead of Vminibuf_scroll_window.
+
+ * xdisp.c (init_iterator): Compare with Vminibuf_selected_window
+ instead of Vminibuf_scroll_window when deciding in which window
+ the region should be highlighted. Consequently, the region remains
+ highlighteded even when a completion buffer is also displayed.
+
+2002-02-26 Eli Zaretskii <[email protected]>
+
+ * fileio.c (Fsubstitute_in_file_name): Fix the change from 2002-02-08.
+
+ * xselect.c (Qcompound_text_with_extensions): Renamed from
+ Qcompound_text_no_extensions.
+ (lisp_data_to_selection_data, syms_of_xselect): Use the new name.
+
+2002-02-26 Juanma Barranquero <[email protected]>
+
+ * w32proc.c (syms_of_ntproc): Doc fix.
+
+2002-02-24 Pavel Jan,Am(Bk <[email protected]>
+
+ * intervals.h: Include "dispextern.h" unconditionally.
+
+2002-02-24 Jason Rumney <[email protected]>
+
+ * Makefile.in (WINNT_SUPPORT) [WINDOWSNT]: Add w32-vars.elc
+ and disp-table.elc.
+ (lisp): Add emacs-lisp/backquote.elc.
+
+2002-02-24 Kim F. Storm <[email protected]>
+
+ * keymap.c (Flookup_key): Fix problem in 2001-12-28 patch:
+ The validation of the event type was too strict as it didn't
+ allow string events; buffer names are used in bindings for
+ menu-bar-select-buffer (see `menu-bar-update-buffers').
+
+2002-02-23 Kim F. Storm <[email protected]>
+
+ The following changes rework my patch of 2002-02-06 which
+ added command remapping by entering the commands directly into
+ the keymaps. Now, command remapping uses an explicit `remap'
+ prefix in the keymaps, i.e. [remap COMMAND].
+
+ * keymap.c (Qremap, remap_command_vector): New variables.
+ (is_command_symbol): Remove function.
+ (Fdefine_key): No longer accept a symbol for KEY.
+ Added validation of [remap COMMAND] argument for KEY.
+ The DEF is no longer required to be a symbol when remapping a command.
+ (Fremap_command): New function to remap command through keymaps.
+ (Flookup_key): Perform command remapping initiated by
+ Fremap_command directly for speed.
+ (Fkey_binding): Use Fremap_command for command remapping.
+ (where_is_internal): Handle new command remapping representation.
+ (syms_of_keymap): Intern Qremap, initialize remap_command_vector,
+ staticpro them. Defsubr Fremap_command.
+
+ * keymap.h (Fremap_command): Declare extern.
+ (is_command_symbol): Remove extern.
+
+ * keyboard.c (command_loop_1): Use Fremap_command for command
+ remapping; now try command remapping for all symbols.
+
+2002-02-23 Eli Zaretskii <[email protected]>
+
+ * coding.h (run_pre_post_conversion_on_str): Add prototype.
+
+2002-02-23 Jason Rumney <[email protected]>
+
+ * w32select.c (Fw32_set_clipboard_data): Run pre-write-conversion
+ on the string before encoding it.
+ (Fw32_get_clipboard_data): Run post-read-conversion on the string
+ after decoding it.
+
+ * w32fns.c (w32_wnd_proc) <WM_TIMER>: Fix last change.
+
+2002-02-23 Pavel Jan,Am(Bk <[email protected]>
+
+ * w32term.c (enter_timestamp): Remove unused static variable to
+ prevent warning.
+
+ * xterm.c (enter_timestamp): Put in #if 0 to prevent warning.
+
+2002-02-23 Eli Zaretskii <[email protected]>
+
+ * w16select.c (Fw16_get_clipboard_data): Fix last change.
+
+ * xselect.c (selection_data_to_lisp_data): Fix last change.
+
+2002-02-22 Jason Rumney <[email protected]>
+
+ * w32term.h (struct w32_output): New member menu_command_in_progress.
+
+ * w32menu.c (menubar_selection_callback): Free the menu and
+ clear the menu_command_in_progress flag.
+
+ * w32fns.c (mouse_move_timer, mouse_button_timer): Initialize.
+ (menu_free_timer): New variable.
+ (MENU_FREE_ID, MENU_FREE_DELAY): New constants.
+ (w32_wnd_proc) <WM_TIMER>: Handle menu_free_timer.
+ <WM_EXITMENULOOP>: Delay before freeing menu. Do nothing if a
+ menu command is in progress.
+ <WM_COMMAND>: Set the menu_command_in_progress flag.
+ Kill any menu_free_timer that is running.
+
+ * w32term.c (w32_text_out): Renamed from W32_TEXTOUT.
+ Call ExtTextOutA rather than ExtTextOut.
+
+2002-02-22 Eli Zaretskii <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 755000.
+
+2002-02-22 Eli Zaretskii <[email protected]>
+
+ * w16select.c (Fw16_set_clipboard_data): Run pre-write-conversion
+ on the string before encoding it.
+ (Fw16_get_clipboard_data): Run post-read-conversion on the string
+ after decoding it.
+
+2002-02-22 Eli Zaretskii <[email protected]>
+
+ Support for ICCCM Extended Segments in X selections:
+
+ * xselect.c <Qcompound_text_no_extensions>: New variable.
+ (syms_of_xselect): Intern and staticpro it.
+ (selection_data_to_lisp_data): Run post-read-conversion on decoded
+ selection text.
+ (lisp_data_to_selection_data): If next-selection-coding-system is
+ compound-text-no-extensions, set the type of selection to be
+ compound-text.
+
+ * xterm.h (x_encode_text): Update prototype.
+
+ * xfns.c (x_encode_text): Accept additional arg SELECTIONP; all
+ callers changed. If SELECTIONP is non-zero, run the
+ pre-write-conversion function before encoding the selection text.
+
+2002-02-21 Kim F. Storm <[email protected]>
+
+ * frame.c (syms_of_frame): Change mouse-highlight default to t.
+
+ * keyboard.c (kbd_buffer_get_event) [WINDOWSNT]:
+ Correct composing of language-change event.
+
+2002-02-20 Kim F. Storm <[email protected]>
+
+ * keyboard.c (menu_bar_items): Don't include keymap or local-map
+ bindings at PT when building menu (the menu is not updated often
+ enough for this to work reliable).
+ (tool_bar_items): Likewise.
+ (current_active_maps): Removed unused (and buggy) function.
+
+2002-02-20 Pavel Jan,Am(Bk <[email protected]>
+
+ * xfns.c (gif_load): Use correct width and height for GIF images.
+
+2002-02-19 Eli Zaretskii <[email protected]>
+
+ * floatfns.c (Fatan): Accept an optional second arg and call
+ atan2 if passed 2 args.
+
+2002-02-18 Jason Rumney <[email protected]>
+
+ * w32term.c (glyph_rect): Determine the row and glyph more precisely.
+
+2002-02-17 Jason Rumney <[email protected]>
+
+ * w32term.c (x_autoselect_window_p): New variable.
+ (syms_of_w32term): DEFVAR_BOOL and initialize it.
+ (note_mouse_movement): Use it.
+
+ * w32fns.c (w32_load_system_font): Never set fonts_changed_p to zero.
+
+ * w32bdf.c (w32_load_bdf_font): Maybe set fonts_changed_p.
+
+ * w32fns.c (Qfullscreen, Qfullwidth, Qfullheight, Qfullboth):
+ New variables.
+ (syms_of_w32fns): Intern and staticpro them.
+ (x_frame_parms) <"fullscreen">: New parameter.
+ (x_fullscreen_move, x_set_fullscreen): New functions.
+ (x_set_frame_parameters): Support Qfullscreen.
+ (x_real_positions): Save x/y_pixels_diff frame params.
+ (x_figure_window_size): Support full-screen frames.
+ (Fx_create_frame): Default the fullscreen parameter.
+
+ * w32term.c (x_check_fullscreen, x_check_fullscreen_move)
+ (x_fullscreen_adjust): New functions.
+ (w32_read_socket) <WM_WINDOWPOSCHANGED>: Don't resize to
+ fullscreen. Call x_check_fullscreen_move, and set the
+ want_fullscreen member of output_data.w32
+ <WM_ACTIVATE, WM_ACTIVATEAPP>: Call x_check_fullscreen.
+
+ * w32term.h: New enum for FULLSCREEN_* constants.
+ (struct w32_output): New members want_fullscreen, x_pixels_diff,
+ y_pixels_diff, x_pixels_outer_diff, and y_pixels_outer_diff.
+ (x-fullscreen-adjust): New prototype.
+
+2002-02-17 Kim F. Storm <[email protected]>
+
+ * frame.c (Vmouse_highlight): New variable.
+ (syms_of_frame): DEFVAR_LISP it.
+
+ * frame.h (Vmouse_highlight): Declare extern.
+
+ * xterm.h (struct x_display_info): Add mouse_face_hidden.
+
+ * xterm.c (disable_mouse_highlight): Removed variable.
+ (note_mouse_highlight): Don't highlight if Vmouse_highlight is nil.
+ (show_mouse_face): Don't show highlight if mouse_face_hidden is set.
+ (XTread_socket): Turn mouse_face_hidden off after mouse movement,
+ and on after keyboard input.
+ (x_term_init): Initialize mouse_face_hidden.
+
+ * msdos.h (struct display_info): Add mouse_face_hidden.
+
+ * msdos.c (disable_mouse_highlight): Removed variable.
+ (show_mouse_face): Don't show highlight if mouse_face_hidden is set.
+ (IT_note_mouse_highlight): Don't highlight if Vmouse_highlight is nil.
+ (internal_terminal_init): Initialize mouse_face_hidden.
+ (dos_rawgetc): Turn mouse_face_hidden off after mouse movement,
+ and on after keyboard input.
+
+ * w32term.h (struct w32_display_info): Add mouse_face_hidden.
+
+ * w32term.c (disable_mouse_highlight): Removed variable.
+ (note_mouse_highlight): Disable highlight if Vmouse_highlight is nil.
+ (show_mouse_face): Don't show highlight if mouse_face_hidden is set.
+ (w32_read_socket): Turn mouse_face_hidden off after mouse movement,
+ and on after keyboard input.
+ (w32_initialize_display_info): Initialize mouse_face_hidden.
+
+2002-02-16 Eli Zaretskii <[email protected]>
+
+ * msdos.c (last_mouse_window): New variable.
+ (dos_rawgetc): Fix last change--if the mouse is in the same window
+ as recorded in last_mouse_window, don't select this window.
+
+ * Makefile.in (lisp, shortlisp): Use cus-start.elc, not cus-start.el.
+
+ * msdos.c (x_autoselect_window_p): New variable.
+ (syms_of_msdos): Defvar it.
+ (dos_rawgetc): If x_autoselect_window_p is set, select the window in
+ which the last mouse movement occured, unless it is already selected.
+
+ * xdisp.c (automatic_hscroll_margin, Vautomatic_hscroll_step):
+ New variables.
+ (syms_of_xdisp): DEVFAR them.
+ (hscroll_window_tree): Use automatic_hscroll_margin and
+ Vautomatic_hscroll_step to compute the amount of window scrolling.
+
+2002-02-16 Pavel Jan,Am(Bk <[email protected]>
+
+ * xterm.c (x-autoselect-window): New variable.
+ (note_mouse_movement): Use it.
+
+ * keyboard.c: Do not include "systime.h" twice.
+
+2002-02-15 Andreas Schwab <[email protected]>
+
+ * puresize.h (PURESIZE_RATIO): Increase to 9/5.
+
+ * alloc.c (NSTATICS): Increase to 1280.
+
+2002-02-15 Kai Gro,A_(Bjohann <[email protected]>
+
+ * alloc.c (NSTATICS): Bump to 1026.
+
+ * xterm.c (Vx_alt_keysym, Vx_hyper_keysym, Vx_meta_keysym)
+ (Vx_super_keysym): New variables.
+ (syms_of_xterm): DEFVAR_LISP them.
+ (x_x_to_emacs_modifiers, x_emacs_to_x_modifiers): Use the
+ variables to determine which keys to use for the various modifiers.
+
+2002-02-13 Kim F. Storm <[email protected]>
+
+ * window.c (Vmode_line_in_non_selected_windows): Removed.
+ (mode_line_in_non_selected_windows): New variable.
+ (syms_of_window): DEFVAR_BOOL it.
+
+ * dispextern.h (CURRENT_MODE_LINE_FACE_ID_3):
+ Use mode_line_in_non_selected_windows.
+ (mode_line_in_non_selected_windows): Declare extern.
+ (Vmode_line_in_non_selected_windows): Removed extern.
+
+2002-02-13 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (Fthis_command_keys, Fthis_command_keys_vector)
+ (Fthis_single_command_keys, Fthis_single_command_raw_keys)
+ (Fclear_this_command_keys): Doc fixes.
+
+ * xfaces.c (Finternal_make_lisp_face, Finternal_copy_lisp_face)
+ (update_face_from_frame_parameter): Increment face_change_count
+ and windows_or_buffers_changed to force redisplay using changed faces.
+
+ * xdisp.c (QCpropertize): New variable.
+ (mode_line_proptrans_alist): New variable.
+ (display_mode_element): New arg PROPS; all calls changed.
+ Implement this, for strings.
+ Handle literal output of strings by sharing the
+ main-line code for strings, using local var `literal'.
+ Handle :propertize feature.
+ (syms_of_xdisp): Initialze and staticpro QCpropertize and
+ mode_line_proptrans_alist.
+
+2002-02-11 Kim F. Storm <[email protected]>
+
+ * window.c (Vmode_line_in_non_selected_windows): New variable.
+ (syms_of_window): DEFVAR_LISP it.
+
+ * dispextern.h (CURRENT_MODE_LINE_FACE_ID_3): New macro.
+ (CURRENT_MODE_LINE_FACE_ID): Use it.
+ (Vmode_line_in_non_selected_windows): Declare extern.
+
+ * xdisp.c (display_mode_lines): Use CURRENT_MODE_LINE_FACE_ID_3
+ to get mode line face.
+
+2002-02-11 Eli Zaretskii <[email protected]>
+
+ * msdos.c (Vx_bitmap_file_path, x_stretch_cursor_p): Remove these
+ variables; cus-start.el doesn't need them anymore.
+
+2002-02-09 Kim F. Storm <[email protected]>
+
+ * insdel.c (make_gap_smaller): Preserve BEG_UNCHANGED during gap
+ reduction. This fixes a display problem where stray newlines were
+ inserted in the window (corrected by C-l). Clarified code (IMHO).
+
+2002-02-09 Eli Zaretskii <[email protected]>
+
+ * dispextern.h (CURRENT_MODE_LINE_FACE_ID): Fix last change.
+
+ * xdisp.c (display_mode_lines): Fix last change.
+
+2002-02-09 Jason Rumney <[email protected]>
+
+ * w32fns.c (enum_font_cb2): Don't let charsets unknown to Windows
+ match each other.
+ (w32_load_system_font): Prevent Cleartype fonts from loading.
+ (Fx_show_tip): Ensure tip frames are above other topmost windows.
+
+2002-02-09 Kim F. Storm <[email protected]>
+
+ * dispextern.h (CURRENT_MODE_LINE_FACE_ID): New macro.
+ (CURRENT_MODE_LINE_HEIGHT): Use it.
+ (enum face_id): Add MODE_LINE_INACTIVE_FACE_ID.
+
+ * xdisp.c (window_box_height): Use CURRENT_MODE_LINE_FACE_ID.
+ (pos_visible_p, handle_face_prop): Likewise.
+ (display_mode_lines): Likewise, but for the real selected window.
+ (init_iterator) [row == NULL]: Handle MODE_LINE_INACTIVE_FACE_ID.
+
+ * xfaces.c (Qmode_line_inactive): New face variable for mode-line
+ in non-selected windows.
+ (realize_basic_faces): Realize it.
+ (syms_of_term): Intern and staticpro it.
+
+2002-02-08 Kim F. Storm <[email protected]>
+
+ * alloc.c (SETJMP_WILL_LIKELY_WORK, SETJMP_WILL_NOT_WORK):
+ Changed mail addresses to [email protected].
+
+2002-02-08 Eli Zaretskii <[email protected]>
+
+ * fileio.c (Fsubstitute_in_file_name): If the file name includes
+ ~user, and there's no such user, don't discard everything before ~user.
+
+ * floatfns.c (Fround): Doc fix.
+
+2002-02-08 Pavel Jan,Am(Bk <[email protected]>
+
+ * sysdep.c (init_system_name): Put unused variable `p' in #if 0.
+
+2002-02-07 Stefan Monnier <[email protected]>
+
+ * lisp.h (Fx_file_dialog): Add extern decl (used in fileio.c).
+
+2002-02-07 Kim F. Storm <[email protected]>
+
+ * keymap.c (where_is_internal): Only check whether definition is
+ remapped if it fulfills is_command_symbol.
+
+2002-02-07 Andreas Schwab <[email protected]>
+
+ * s/gnu-linux.h (GC_LISP_OBJECT_ALIGNMENT): Define to 2 for m68k.
+
+ * alloc.c (mark_stack): Don't assume sizeof (Lisp_Object) is 4.
+
+2002-02-06 Kim F. Storm <[email protected]>
+
+ * keymap.c (Fdefine_key): Allow symbol as KEY argument for
+ defining command remapping. Doc updated.
+ (Flookup_key): Remap command through keymap if KEY is a symbol.
+ (is_command_symbol): New function.
+ (Fkey_binding): Use it. New optional argument NO-REMAP.
+ Doc updated. Callers changed. Perform command remapping via
+ recursive call unless that arg is non-nil.
+ (where_is_internal): New argument no_remap. Callers changed.
+ Call recursively to find original key bindings for a remapped
+ comand unless that arg is non-nil.
+ (Fwhere_is_internal): New optional argument NO-REMAP.
+ Doc updated. Callers changed. Pass arg to where_is_internal.
+
+ * keymap.h (Fkey_binding, Fwhere_is_internal): Update prototype.
+ (is_command_symbol): Add prototype.
+
+ * keyboard.c (Vthis_original_command): New variable.
+ (syms_of_keyboard): DEFVAR_LISP it.
+ (command_loop_1): Set it, and perform command remapping.
+
+2002-02-06 Pavel Jan,Am(Bk <[email protected]>
+
+ * keyboard.c (recursive_edit_1): Call cancel_hourglass unconditionally.
+
+2002-02-06 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_native_per_char_metric): Disable 2002-01-20 change.
+
+2002-02-06 Eli Zaretskii <[email protected]>
+
+ * charset.c (get_charset_id): Use if-else instead of ?:.
+
+2002-02-06 Richard M. Stallman <[email protected]>
+
+ * filelock.c (S_ISLNK): Define if not defined.
+
+2002-02-03 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fdo_auto_save): Improve "auto save disabled" msg.
+
+ * lread.c (read1): Redesign strategy for force_multibyte and
+ force_singlebyte. Now is_multibyte records whether read_buffer
+ is multibyte. Encountering any multibyte character makes it so.
+
+2002-02-02 Stefan Monnier <[email protected]>
+
+ * term.c (term_get_fkeys_1): If `k0' and `k;' are both specified and
+ with the same sequence, map that sequence to f10 rather than f0.
+
+2002-02-03 Andreas Schwab <[email protected]>
+
+ * s/gnu-linux.h: Check for __mc68000__ instead of __m68k__, the
+ latter never being defined on GNU/Linux.
+
+2002-02-02 Eli Zaretskii <[email protected]>
+
+ * xfaces.c (realize_default_face): Don't set the weight and slant of
+ the default face to Qnormal, unless these attributes are unspecified.
+
+2002-02-02 Pavel Jan,Am(Bk <[email protected]>
+
+ * keyboard.c (command_loop_1) [HAVE_X_WINDOWS]:
+ Call cancel_hourglass unconditionally.
+
+ * eval.c (Fsignal): Remove duplicated declaration of
+ the variable `display_hourglass_p'.
+
+2002-01-31 Richard M. Stallman <[email protected]>
+
+ * editfns.c (region_limit): Nicer error message.
+
+ * coding.c (decode_composition_emacs_mule):
+ Give up if NCOMPONENT gets too large to index `component'.
+
+ * callint.c (check_mark): New arg to specify clearer error message.
+ Callers changed.
+
+2002-01-27 Richard M. Stallman <[email protected]>
+
+ * minibuf.c (Fcompleting_read): Doc fix.
+
+2002-01-27 Pavel Jan,Am(Bk <[email protected]>
+
+ * minibuf.c (Fread_from_minibuffer, Fread_command, Fread_function)
+ (Fread_variable, Fread_buffer, minibuffer-completion-confirm):
+ Fix doc-strings.
+
+2002-01-26 Richard M. Stallman <[email protected]>
+
+ * buffer.c (syms_of_buffer): Doc fixes for scroll-...-aggressively.
+
+ * xdisp.c (try_scrolling): Exchange uses of scroll_down_aggressively
+ and scroll_up_aggressively.
+
+2002-01-26 Pavel Jan,Am(Bk <[email protected]>
+
+ * keyboard.c (parse_tool_bar_item): Remove duplicated prototypes.
+
+2002-01-25 Stefan Monnier <[email protected]>
+
+ * textprop.c (Fnext_property_change, Fnext_single_property_change)
+ (Fprevious_property_change, Fprevious_single_property_change):
+ Stay within the narrowed-buffer boundaries.
+
+2002-01-25 Eli Zaretskii <[email protected]>
+
+ * term.c (Ftty_display_color_cells): New function.
+ (syms_of_term): Defsubr it.
+ (Ftty_display_color_cells, Ftty_display_color_p): Change the
+ argument name to DISPLAY. Doc fix.
+
+ * dispextern.h: Add prototype for set_tty_color_mode and
+ tty_setup_colors.
+
+2002-01-24 Jason Rumney <[email protected]>
+
+ * w32term.c (x_scroll_run): Use ScrollWindowEx in place of BitBlt.
+ If region left to draw is not what was expected, mark the frame as
+ garbaged.
+
+ * w32fns.c (w32_wnd_proc) <WM_PAINT>: Initialize update_rect.
+ Combine the regions returned by BeginPaint and GetUpdateRect.
+
+2002-01-23 Jason Rumney <[email protected]>
+
+ * w32term.c (x_update_window_begin): Only hide caret if
+ w32_use_visible_system_caret is set.
+ (x_update_window_end): Only show caret if
+ w32_use_visible_system_caret is set.
+ (syms_of_w32term): Handle SystemParametersInfo call failing.
+
+ * w32fns.c (syms_of_w32fns): Initialize w32_visible_system_caret_hwnd.
+
+2002-01-22 Richard M. Stallman <[email protected]>
+
+ * unexelf.c (unexec): Define n so as to cause compilation error
+ for the code where people have often written n instead of nn.
+
+ * .gdbinit (hookpost-run): Defined.
+
+2002-01-22 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_set_frame_parameters): Typo in previous fix corrected.
+
+2002-01-21 Jan Dj,Ad(Brv <[email protected]>
+
+ * xfns.c (x_set_frame_parameters): Just call x_fullscreen_adjust
+ if fullscreen is being set.
+
+2002-01-21 Pavel Jan,Am(Bk <[email protected]>
+
+ * minibuf.c (Fminibuffer_contents)
+ (Fminibuffer_contents_no_properties, Fread_from_minibuffer)
+ (Fread_string, Fread_no_blanks_input, Fcompleting_read): Doc fixes.
+
+2002-01-21 Richard M. Stallman <[email protected]>
+
+ * window.c (check_frame_size): Fix minimum height calculation.
+
+2002-01-20 Ken Raeburn <[email protected]>
+
+ * dispextern.h (WINDOW_WANTS_MODELINE_P): Use XFASTINT on window
+ height before comparison.
+ (WINDOW_WANTS_HEADER_LINE_P): Likewise.
+
+2002-01-20 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_system_caret_width): Remove.
+ (w32_use_visible_system_caret): New user flag.
+ (syms_of_w32term): DEFVAR_BOOL it. Initialize based on whether
+ Windows reports a screen reader running.
+ (x_update_window_begin): Hide the system caret.
+ (x_update_window_end): Show the system caret.
+ (x_display_and_set_cursor): Don't draw a cursor when
+ w32_use_visible_system_caret is set. Do not adjust width.
+
+ * w32fns.c (w32_visible_system_caret_hwnd): New static variable.
+ (w32_wnd_proc) <WM_KILL_FOCUS, WM_EMACS_DESTROY_CARET>: Set it.
+ <WM_EMACS_TRACK_CARET>: Arrange for system caret to be visible if
+ the user requests it. Use system default width when creating.
+ <WM_EMACS_HIDE_CARET, WM_EMACS_SHOW_CARET>: Handle new messages.
+
+ * w32term.h (WM_EMACS_SHOW_CARET, WM_EMACS_HIDE_CARET):
+ New window messages.
+
+2002-01-20 Richard M. Stallman <[email protected]>
+
+ * window.c (MIN_SAFE_WINDOW_HEIGHT): Value now 1.
+
+2002-01-20 Pavel Jan,Am(Bk <[email protected]>
+
+ * doprnt.c (doprnt1): Fix typos in error call.
+
+2002-01-20 Eli Zaretskii <[email protected]>
+
+ * unexelf.c (unexec) [__sgi]: Support the .got sections.
+
+2002-01-20 Jason Rumney <[email protected]>
+
+ * w32term.c (w32_native_per_char_metric): Don't trust the metrics
+ that Windows returns. If a double check fails, try to guess how
+ ExtTextOut is going to act.
+
+ * w32fns.c (w32_load_system_font, w32_to_x_charset): Use strnicmp
+ in place of stricmp.
+ (w32_list_synthesized_fonts): Removed.
+ (w32_to_all_x_charsets, enum_font_maybe_add_to_list): New functions.
+ (struct enumfont_t): New element; list.
+ (enum_font_cb2): List all style and charset variations of a font.
+ (Fw32_select_font): New optional argument; include_proportional.
+ Exclude vertical fonts. Exclude proportional fonts unless
+ include_proportional is non-nil.
+ (w32_enable_synthesized_fonts): Change to a boolean.
+ (Fw32_send_sys_command): Doc fix.
+
+2002-01-19 Pavel Jan,Am(Bk <[email protected]>
+
+ * dispnew.c (update_frame): Move the variable `tem' to the block
+ where it is used.
+
+2002-01-19 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fx_create_frame): Bind redisplay-dont-pause around
+ call to face-set-after-frame-default.
+
+2002-01-18 Richard M. Stallman <[email protected]>
+
+ * dispextern.h (WINDOW_WANTS_MODELINE_P): Check window height > 1.
+ (WINDOW_WANTS_HEADER_LINE_P): Check window height provides room.
+
+2002-01-17 Richard M. Stallman <[email protected]>
+
+ * window.c (enlarge_window): When exceeding size of parent,
+ directly delete all the siblings instead of trying to resize it.
+
+2002-01-17 Pavel Jan,Am(Bk <[email protected]>
+
+ * term.c (set_tty_color_mode): Remove unused variable `tem'.
+
+2002-01-16 Henrik Enberg <[email protected]>
+
+ * lread.c (init_lread): Move the installed-lisp dirs later in the path.
+
+2002-01-16 Kim F. Storm <[email protected]>
+
+ * xterm.c (x_erase_phys_cursor): Don't erase cursor if cursor row
+ is invisible. This can happen if cursor is on top line of a
+ window, and we switch to a buffer with a header line.
+
+ * w32term.c (x_erase_phys_cursor): Ditto.
+
+2002-01-16 Pavel Jan,Am(Bk <[email protected]>
+
+ * xterm.c (XTread_socket) [!USE_X_TOOLKIT]: Compute the value of
+ `dont_resize' only when used.
+
+ * xdisp.c: Remove forgotten extern declaration of `Qimage'.
+
+2002-01-15 Eli Zaretskii <[email protected]>
+
+ * xdisp.c (display_mode_element): When computing charpos, depend
+ on multibyteness of elt, not the text in field.
+
+2002-01-15 Pavel Jan,Am(Bk <[email protected]>
+
+ * buffer.c (Fkill_all_local_variables):
+ Increment `update_mode_lines' only once.
+
+2002-01-14 Pavel Jan,Am(Bk <[email protected]>
+
+ * lisp.h (adjust_after_replace_noundo)
+ (Fupdate_coding_systems_internal): Add prototypes.
+
+ * sound.c (Fplay_sound): Initialize header_size also for :data case.
+
+2002-01-14 Eli Zaretskii <[email protected]>
+
+ Support for the --color command-line argument and tty-color-mode
+ frame parameter:
+
+ * term.c (tty_default_color_capabilities, tty_setup_colors)
+ (set_tty_color_mode): New functions.
+ (term_init): Call tty_default_color_capabilities.
+ (Qtty_color_mode_alist): New variable.
+ (syms_of_term): Intern and staticpro it.
+
+ * frame.c (store_frame_param): Call set_tty_color_mode for termcap
+ frames.
+ (do_switch_frame): For termcap frames, switch the tty
+ color mode as specified by the frame's parameters.
+ (Qtty_color_mode): New variable.
+ (syms_of_frame): Intern and staticpro it.
+
+ * emacs.c (USAGE2): Add the --color option.
+ (standard_args): Ditto.
+
+2002-01-13 Jan Dj,Ad(Brv <[email protected]>
+
+ * xterm.h (struct x_output): New members want_fullscreen,
+ x_pixels_diff, y_pixels_diff, x_pixels_outer_diff, and
+ y_pixels_outer_diff.
+ New enum for FULLSCREEN_* constants.
+ (FRAME_OUTER_WINDOW): Handle the case where output_data.x->widget
+ is NULL.
+ (x_fullscreen_adjust): Add prototype.
+
+ * emacs.c (USAGE2): Add the new full-screen arguments.
+ (standard_args): Ditto.
+
+ * xfns.c (Qfullscreen, Qfullwidth, Qfullheight, Qfullboth):
+ New variables.
+ (syms_of_xfns): Intern and staticpro them.
+ (x_frame_parms) <"fullscreen">: New parameter.
+ (x_fullscreen_move, x_set_fullscreen): New functions.
+ (x_set_frame_parameters): Support for Qfullscreen.
+ (x_real_positions): More accurate computation of the frame position.
+ (x_figure_window_size): Support full-screen frames.
+ (Fx_create_frame): Default the fullscreen parameter.
+
+ * xterm.c (x_check_fullscreen, x_fullscreen_adjust): New functions.
+ (XTread_socket) <Expose>: Call x_check_fullscreen.
+ <ConfigureNotify>: Don't resize to fullscreen.
+ Call x_check_fullscreen_move, and set the want_fullscreen member of
+ output_data.x.
+
+2002-01-13 Jason Rumney <[email protected]>
+
+ * w32term.h (WM_XBUTTONDOWN, WM_XBUTTONUP): New window messages
+ for mice with more than 3 buttons.
+
+ * w32term.c (parse_button): New parameter xbutton. Callers changed.
+ (w32_read_socket): Handle new "XBUTTON" messages.
+
+ * w32fns.c (w32_pass_extra_mouse_buttons_to_system): New user option.
+ (syms_of_w32fns): DEFVAR_BOOL it.
+ (w32_wnd_proc): Handle new "XBUTTON" messages.
+
+2002-01-13 Pavel Jan,Am(Bk <[email protected]>
+
+ * keyboard.c (read_key_sequence): Remove unused variable `extra_maps'.
+
+2002-01-13 Andreas Schwab <[email protected]>
+
+ * xterm.c (x_load_font): Never set fonts_changed_p to zero.
+
+2002-01-12 Andreas Schwab <[email protected]>
+
+ * .gdbinit (xbuffer): Remove address operator since data is now a
+ pointer.
+
+2002-01-11 Richard M. Stallman <[email protected]>
+
+ * insdel.c (adjust_after_replace_noundo): New function.
+
+ * coding.c (code_convert_region): Don't copy old text if undo disabled.
+
+2002-01-09 Jason Rumney <[email protected]>
+
+ * xdisp.c (x_consider_frame_title): Don't count the tooltip frame
+ when checking for multiple frames.
+
+2002-01-08 Richard M. Stallman <[email protected]>
+
+ * window.c (delete_window): Rewrite the code for changing the
+ selected window to handle the case where WINDOW is not a leaf.
+
+2002-01-07 Eli Zaretskii <[email protected]>
+
+ * process.c (send_process): Set src_multibyte to 1 after the call
+ top setup_coding_system, not before the call.
+
+2002-01-07 Jason Rumney <[email protected]>
+
+ * xmenu.c (set_frame_menubar, xmenu_show):
+ (xdialog_show): Initialize wv->help to Qnil.
+
+ * w32menu.c (single_submenu, set_frame_menubar, w32_menu_show):
+ (w32_dialog_show): Initialize wv->help to Qnil.
+
+2002-01-06 Jason Rumney <[email protected]>
+
+ * xmenu.c (single_submenu): Initialize wv->help to Qnil.
+
+ * w32menu.c (w32_menu_display_help): Revert last change.
+
+ * xmenu.c (menu_highlight_callback): Revert last change.
+
+2002-01-06 Andreas Schwab <[email protected]>
+
+ * insdel.c (make_gap_larger): Make sure buffer size does not
+ overflow range of int.
+
+2002-01-05 Jason Rumney <[email protected]>
+
+ * w32term.c (x_draw_glyphs): Don't call notice_overwritten_cursor if
+ OVERLAPS_P.
+
+ * w32menu.c (w32_menu_display_help): Hide any tooltip window.
+
+ * w32fns.c (compute_tip_xy): If tooltip won't fit on the screen
+ to the left or to the right of the pointer, put it against
+ the left screen edge.
+ (x_frame_parms): Add missing braces around initializer.
+
+ * w32term.c (x_setup_relief_colors): Don't compute an image's
+ background color if it doesn't have a Pixmap.
+ (notice_overwritten_cursor): Don't depend on
+ output_cursor and updated_area. Compare pixel coordinates with
+ window's cursor pixel coordinates.
+ (x_draw_glyphs, x_clear_end_of_line, show_mouse_face):
+ Call notice_overwritten_cursor with new arg list.
+ (show_mouse_face): Fix bug setting a row's mouse_face_p flag
+ unconditionally.
+ (x_draw_image_relief): Use predefined macro instead of
+ constant when the value of `tool_bar_button_relief' is negative.
+
+ * w32term.c (x_display_and_set_cursor): Fix PostMessage arg types.
+
+2002-01-04 Richard M. Stallman <[email protected]>
+
+ * xmenu.c (menu_highlight_callback): Hide any tooltip window.
+
+2002-01-03 Richard M. Stallman <[email protected]>
+
+ * keymap.c (Fcurrent_active_maps): Put the `keymap' property map first.
+ (Fkey_binding): Try the `keymap' property map first.
+ (Fdescribe_buffer_bindings): Show `keymap' property bindings before
+ minor mode bindings.
+
+2002-01-03 Kim F. Storm <[email protected]>
+
+ * keyboard.c (read_key_sequence): Fix cast of submaps arg to bcopy.
+
+2002-01-02 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (read_key_sequence): Handle the keymap property
+ before minor mode maps.
+
+ * editfns.c (Fformat): Update thissize from field_width
+ based on the actual width, in the string case.
+
+2002-01-01 Pavel Jan,Am(Bk <[email protected]>
+
+ * charset.h (UNIBYTE_STR_AS_MULTIBYTE_P): Parenthesize assignment
+ when used as truth value to prevent gcc warnings.
+
+ * sysdep.c, unexapollo.c, w32.c, w32bdf.c, w32heap.c, w32inevt.c,
+ * w32proc.c: Include <config.h>.
+
+2002-01-01 Andreas Schwab <[email protected]>
+
+ * eval.c (max_specpdl_size, max_lisp_eval_depth): Define as int,
+ not EMACS_INT, to make them compatible with DEFVAR_INT.
+ * lisp.h (max_specpdl_size): Adjust declaration.
+
+2002-01-01 Richard M. Stallman <[email protected]>
+
+ * print.c (print_object): Test print_escape_nonascii only for
+ unibyte strings.
+ (PRINTPREPARE): Once again bind Qprint_escape_nonascii
+ when outputting to a multibyte buffer.
+
+2001-12-29 Richard M. Stallman <[email protected]>
+
+ * print.c (print_object): In multibyte string, use hex escapes.
+ Use octal only for unibyte strings.
+ (PRINTPREPARE): Don't ever set Qprint_escape_nonascii.
+
+ * lread.c (read_escape): New arg BYTEREP for reporting whether
+ escape forces unibyte or multibyte.
+ (read1): When reading a string, take note of that info.
+
+2001-12-29 Ken Raeburn <[email protected]>
+
+ * abbrev.c (Fexpand_abbrev): Use NILP instead of implicit zero
+ comparison to test lisp value returned by Fget.
+
+2001-12-29 Richard M. Stallman <[email protected]>
+
+ * lisp.h (max_specpdl_size): Add declaration.
+
+ * fileio.c (Fdo_auto_save): If NO_MESSAGE, don't call push_message.
+
+ * keymap.c (silly_event_symbol_error): New subrtn, from Fdefine_key.
+ Handle modifier bits. Correct typo in error message.
+
+2001-12-28 Richard M. Stallman <[email protected]>
+
+ * abbrev.c: Use the plist of an abbrev for multiple params if nec.
+ (Fdefine_abbrev): New arg SYSTEM-FLAG for a system abbrev.
+ (Fdefine_global_abbrev, Fdefine_mode_abbrev):
+ Update calls to Fdefine_abbrev.
+ (write_abbrev): Update for changed data format.
+ Don't list "system" abbrevs.
+ (Fexpand_abbrev): Update use count with new data format.
+ (describe_abbrev): Update for changed data format.
+ (Fdefine_abbrev_table): Handle the new SYSTEM-FLAG.
+
+ * config.in (HAVE_MBSINIT): Add #undef.
+
+ * strftime.c (mbsinit): Define as no-op if not available.
+
+ * s/sco5.h (LIBX11_SYSTEM) [MOTIF]: Add -lgen.
+ (sigprocmask_set): Conditionalize decl on ! NOT_C_CODE.
+
+ * keymap.c (Flookup_key): Error message if key has wrong data type.
+ (Fdefine_key): Add error message for trying to bind [DEL], [RET], etc.
+ (exclude_key): New variable.
+
+2001-12-28 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_setup_relief_colors): Don't compute an image's
+ background color if it doesn't have a Pixmap.
+
+ * xterm.c (notice_overwritten_cursor): Don't depend on
+ output_cursor and updated_area. Compare pixel coordinates with
+ window's cursor pixel coordinates.
+ (x_draw_glyphs, x_clear_end_of_line, show_mouse_face):
+ Call notice_overwritten_cursor with new arg list.
+ (show_mouse_face): Fix bug setting a row's mouse_face_p flag
+ unconditionally.
+
+ * xdisp.c (try_scrolling) <PT below scroll margin>: Add the
+ height of the cursor line to the amount to scroll.
+
+2001-12-27 Richard M. Stallman <[email protected]>
+
+ * intervals.c (set_point_both): The position after an invisible,
+ intangible character is not an acceptable stopping point.
+
+2001-12-27 Ken Raeburn <[email protected]>
+
+ * window.c (enlarge_window): In new preserve_before code, convert
+ CURBEG from lisp object to integer before doing arithmetic.
+
+2001-12-27 Richard M. Stallman <[email protected]>
+
+ * bytecode.c (Fbyte_code): Undo previous change.
+
+2001-12-26 Kim F. Storm <[email protected]>
+
+ * keyboard.c (record_char): Ignore duplicate help-echo events only
+ separated by mouse-movement. When tracking mouse, only record
+ first and last mouse-movement event in same window.
+ Don't record mouse-movement events in keyboard macros.
+
+2001-12-25 Richard M. Stallman <[email protected]>
+
+ * window.c (enlarge_window): New arg PRESERVE_BEFORE. Callers changed.
+ (Fenlarge_window): New arg PRESERVE_BEFORE.
+
+ * bytecode.c (Fbyte_code): Use Fstring_make_unibyte
+ instead of Fstring_as_unibyte.
+
+2001-12-22 Pavel Jan,Am(Bk <[email protected]>
+
+ The following changes remove mocklisp support:
+
+ * mocklisp.h, mocklisp.c: Files removed.
+
+ * lisp.h: Remove declarations of variables `Vmocklisp_arguments',
+ `Qmocklisp' and `Qmocklisp_arguments'.
+ Remove prototype of syms_of_mocklisp.
+
+ * makefile.nt, makefile.w32-in, Makefile.in: Remove mocklisp files.
+
+ * callint.c: Do not include mocklisp.h.
+ (Fcall_interactively): Do not test for mocklisp case.
+
+ * eval.c: Remove variables `Qmocklisp_arguments',
+ `Vmocklisp_arguments' and `Qmocklisp'. Remove prototype of ml_apply.
+ (Fprogn, Fwhile, Fcommandp, Feval, Ffuncall, funcall_lambda):
+ Do not test for mocklisp case.
+ (Fwhile): Remove unused variable `tem'.
+ (syms_of_eval): Remove variable `moclisp-arguments'.
+
+ * data.c (wrong_type_argument): Remove mocklisp case.
+
+ * doc.c (Fdocumentation): Remove mocklisp case.
+
+ * emacs.c (main): Do not call syms_of_mocklisp.
+
+2001-12-21 Richard M. Stallman <[email protected]>
+
+ * xfns.c (compute_tip_xy): If tooltip won't fit on the screen
+ to the left or to the right of the pointer, put it against
+ the left screen edge.
+
+2001-12-21 Eli Zaretskii <[email protected]>
+
+ * Makefile.in (distclean): Remove .gdbinit if we are building
+ outside the source tree.
+
+2001-12-19 Eli Zaretskii <[email protected]>
+
+ * w32.c (emacs_root_dir): New function.
+
+ * msdos.c (emacs_root_dir): New function.
+
+ * fileio.c (Fexpand_file_name) [DOS_NT]: Use the root directory
+ of the current drive as the fallback for default_directory.
+
+ * dired.c (file_name_completion): Run the elements of
+ completion-ignored-extensions through ENCODE_FILE.
+
+ * lisp.h (scmp): Remove prototype, since it's now a static
+ function private to dired.c.
+
+2001-12-18 Richard M. Stallman <[email protected]>
+
+ * dired.c (scmp): Function moved from minibuf.c.
+ Delete multibyte handling--used only on encoded strings.
+
+ * minibuf.c (scmp): Function moved to dired.c.
+
+ * fns.c (merge): Add QUIT call.
+
+2001-12-18 Dave Love <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): Add language/utf-8-lang.el,
+ language/georgian.el.
+
+2001-12-18 Eli Zaretskii <[email protected]>
+
+ * Makefile.in (lisp, shortlisp): Synchronize with changes to
+ lisp/Makefile.in:DONTCOMPILE.
+
+2001-12-18 Pavel Jan,Am(Bk <[email protected]>
+
+ * xdisp.c (window_box_height): Do not return negative values.
+ From Gerd Moellmann <[email protected]>.
+
+ * keyboard.c (head_table): Add missing braces around initializer.
+
+ * term.c (keys): Likewise.
+
+ * xfns.c (x_frame_parms, visual_classes): Likewise.
+
+2001-12-17 Sam Steingold <[email protected]>
+
+ * coding.c (DECODE_COMPOSITION_END): Fixed a typo in the last
+ patch (COMPOSING_P, not COMPOSING).
+
+2001-12-17 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fcompare_buffer_substrings): Add QUIT to main loop.
+
+ * coding.c (code_convert_region): Update coding->cmp_data->char_offset
+ before calling decode_coding.
+
+ * charset.c (Fdefine_charset): Call Fupdate_coding_systems_internal.
+
+ * coding.c (DECODE_COMPOSITION_END): Check for ! COMPOSING_P (coding)
+ instead of only for COMPOSITION_DISABLED.
+
+2001-12-16 Richard M. Stallman <[email protected]>
+
+ * alloc.c (pure_alloc): After overflow, allocate just a small block.
+
+ * Makefile.in (xmenu.o, xterm.o, fontset.o): Depend on buffer.h.
+
+ * buffer.h (struct buffer): New field `display_error_modiff'.
+ * buffer.c (reset_buffer): Initialize `display_error_modiff'.
+
+ * window.c (Frecenter): Clear display_error_modiff field.
+
+ * xdisp.c (redisplay_window_0, redisplay_window_1): New functions.
+ Call redisplay_window, but not if display_error_modiff field says no.
+ (redisplay_window_error): New function.
+ (displayed_buffer): New variable.
+ (redisplay_internal, redisplay_windows): Call the new functions
+ instead of redisplay_window directly.
+
+2001-12-15 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (syms_of_keyboard) <double-click-fuzz>: Doc fix.
+
+2001-12-14 Andrew Innes <[email protected]>
+
+ * makefile.w32-in (EMACSLOADPATH): Define.
+ ($(EMACS)): Run `list-load-path-shadows' after dumping Emacs.
+ (bootstrap-temacs): Remove dependency on bootstrap-clean.
+
+2001-12-13 Eli Zaretskii <[email protected]>
+
+ * xfns.c (x_report_frame_params): Make the scroll-bar-width frame
+ parameter have a numeric value all the time.
+
+ * w32fns.c (x_report_frame_params): Likewise.
+
+2001-12-12 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fwrite_region): Doc fix.
+
+ * xdisp.c (CLEAR_FACE_CACHE_COUNT): Redefine as 500.
+ (redisplay_internal): Call clear_image_cache only for window terminals.
+
+2001-12-12 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (move_it_vertically_backward): Change heuristic
+ for the case that we didn't move far enough initially.
+
+ * window.c (Frecenter): Simplify computation in the case of window
+ system frames and ARG < 0; use window_box_height.
+
+2001-12-11 Richard M. Stallman <[email protected]>
+
+ * Makefile.in, mem-limits.h, dispnew.c, emacs.c, fileio.c:
+ * process.c, sysdep.c, unexec.c: Test GNU_LINUX, not LINUX.
+
+2001-12-11 Andrew Innes <[email protected]>
+
+ * insdel.c (make_gap) [DOUG_LEA_MALLOC]: Call make_gap_smaller if
+ arg is negative.
+
+2001-12-11 Richard M. Stallman <[email protected]>
+
+ * m/hp800.h: Split the __hpux conditional into the parts
+ that are right for GNU/Linux too and the parts that are not.
+ Use the former if GNU_LINUX.
+ (HAVE_ALLOCA, LOAD_AVE_TYPE, LOAD_AVE_CVT): New defs for GNU/Linux.
+
+ * s/gnu-linux.h (GNU_LINUX): Defined.
+
+2001-12-11 Pavel Jan,Am(Bk <[email protected]>
+
+ * macros.c, msdos.c, w16select.c: Change doc-string comments to
+ `new style' [w/`doc:' keyword].
+
+2001-12-10 Jason Rumney <[email protected]>
+
+ * w32menu.c (w32_free_submenu_strings): Clear menu item struct
+ before using.
+
+2001-12-09 Pavel Jan,Am(Bk <[email protected]>
+
+ * dosfns.c: Change doc-string comments to `new style' [w/`doc:'
+ keyword].
+
+2001-12-09 Eli Zaretskii <[email protected]>
+
+ * dosfns.c (dos-display-scancodes, dos-decimal): Doc fix.
+
+ * s/hpux10.h (srand48): Don't undefine.
+
+2001-12-09 Jason Rumney <[email protected]>
+
+ * w32menu.c (_widget_value): Make `help' field a Lisp_Object.
+ Add comment to explain where the struct came from.
+ (single_submenu, w32_menu_show): Set `help' field as Lisp_Object.
+ (add_menu_item): Process pop-up menus first to avoid memory leak.
+ (add_menu_item, w32_menu_display_help): Use `help' field as
+ Lisp_Object.
+ (w32_free_submenu_strings): Only free owner-drawn strings.
+
+2001-12-09 Pavel Jan,Am(Bk <[email protected]>
+
+ * COPYING: Moved back.
+
+ * charset.c (char_to_string_1, translate_char, Fdefine_charset):
+ Add parentheses around && within ||.
+
+ * indent.c (compute_motion): Likewise.
+
+ * intervals.c (merge_properties_sticky): Likewise.
+
+ * coding.c (setup_coding_system, shrink_encoding_region)
+ (Fdecode_sjis_char): Likewise.
+
+2001-12-07 Andreas Schwab <[email protected]>
+
+ * xdisp.c (display_mode_element): Don't read past end of string if
+ it ends with '%'.
+
+ * alloc.c (inhibit_garbage_collection): Don't exceed value an int
+ can hold.
+
+ * data.c (Vmost_positive_fixnum, Vmost_negative_fixnum):
+ Rename from most_positive_fixnum and most_negative_fixnum, resp., and
+ type changed to Lisp_Object.
+ (syms_of_data): DEFVAR_LISP them.
+
+2001-12-07 Richard M. Stallman <[email protected]>
+
+ * callproc.c (init_callproc): Set Vdata_directory based on the source
+ location whenever Emacs was run uninstalled.
+
+2001-12-06 Paul Eggert <[email protected]>
+
+ * config.in (HAVE_WORKING_VFORK): New #undefs.
+ * process.c (create_process):
+ Use HAVE_WORKING_VFORK, not HAVE_VFORK.
+ * m/cnvrgnt.h (HAVE_VFORK): Remove #define.
+ * m/ibm370aix.h (HAVE_VFORK): Remove #undef.
+ * m/ibmps2-aix.h (HAVE_VFORK): Remove #define.
+ * m/intel386.h (HAVE_VFORK): Likewise.
+ * m/mips-siemens.h (HAVE_VFORK): Likewise.
+ * m/mips.h (HAVE_VFORK): Likewise.
+ * s/freebsd.h (vfork): Remove #define.
+ * s/lynxos.h (HAVE_VFORK): Remove #undef.
+ * s/usg5-4-2.h: Fix comment about vfork.
+
+2001-12-06 Richard M. Stallman <[email protected]>
+
+ * s/hpux10.h (random): Add undef.
+ (HAVE_RANDOM): Define it just once.
+
+2001-12-06 Stefan Monnier <[email protected]>
+
+ * eval.c: Undo last change: the standard syntax is not wanted.
+
+2001-12-06 Eli Zaretskii <[email protected]>
+
+ * xterm.c (x_free_frame_resources) [USE_X_TOOLKIT]: Remove all the
+ scroll bars of the frame before deleting the frame itself. If the
+ frame has a widget, delete the frame with XtDestroyWidget, and do
+ not call XDestroyWindow before that.
+
+2001-12-06 Kim F. Storm <[email protected]>
+
+ * xfns.c (x_report_frame_params): Return actual fringe widths.
+
+ * w32fns.c (x_report_frame_params): Return actual fringe widths.
+
+2001-12-05 Andrew Innes <[email protected]>
+
+ * alloc.c (Fgarbage_collect): Shrink buffer gaps that are
+ excessively large.
+
+ * insdel.c (make_gap_larger): New function.
+ (make_gap_smaller): New function.
+ (make_gap) [USE_MMAP_FOR_BUFFERS || REL_ALLOC]:
+ Call make_gap_smaller if arg is negative.
+
+2001-12-04 Stefan Monnier <[email protected]>
+
+ * keyboard.c (kbd_buffer_store_event): Fix interrupt_signal prototype.
+ Pass a dummy argument when calling interrupt_signal.
+ (parse_menu_item): Mark disabled items before checking for empty def.
+ (read_char_minibuf_menu_prompt): Make safety more visible.
+ (read_key_sequence): Add a `first_unbound' variable.
+ Use it to detect C-c ESC ESC ESC ESC ... cases and drop the
+ unbound prefix as soon as we can detect it.
+
+ * doc.c (Fsnarf_documentation): Add prototype.
+ (get_doc_string): Handle negative arguments.
+ (Fdocumentation): Use AREF and ASIZE.
+ Move the calls to get_doc_string to a single place.
+ Don't confuse an interactive-spec for a docstring reference.
+ (Fdocumentation_property): Take advantage of the fact that
+ get_doc_string now ignores the sign of the docstring position.
+
+ * eval.c: Use standard syntax for usage in docstrings.
+
+2001-12-03 Pavel Jan,Am(Bk <[email protected]>
+
+ * xdisp.c (syms_of_xdisp): Make `tool-bar-button-relief' an option.
+
+2001-12-02 Pavel Jan,Am(Bk <[email protected]>
+
+ * xterm.c (x_draw_image_relief): Use predefined macro instead of
+ constant when the value of `tool_bar_button_relief' is negative.
+
+2001-12-02 Richard M. Stallman <[email protected]>
+
+ * xmenu.c (menu_highlight_callback): Use `help' field as Lisp_Object.
+ (single_submenu, xmenu_show): Set `help' field as Lisp_Object.
+
+ * fileio.c (read_non_regular): Delete Fsignal call.
+
+2001-12-01 Stefan Monnier <[email protected]>
+
+ * lisp.h (run_hook_list_with_args): Undo last change.
+
+2001-12-01 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_draw_fringe_bitmap): Always undo clipping.
+
+2001-12-01 Jason Rumney <[email protected]>
+
+ * window.c (Qleft_fringe, Qright_fringe): Remove. Now in frame.c.
+
+ * w32term.h (WM_MOUSELEAVE, TME_LEAVE, TRACKMOUSEEVENT)
+ [!WM_MOUSELEAVE]: Define.
+
+ * w32menu.c (current_popup_menu, get_menu_item_info):
+ (set_menu_item_info): New vars.
+ (set_frame_menubar): Doc fix clarifying GC interaction with menus.
+ (w32_menu_show): Set current_popup_menu.
+ (add_menu_item): Allocate new strings for owner-drawn menu items
+ and help strings.
+ Use owner-draw for disabled menu items again.
+ (w32_menu_display_help): Ignore owner-drawn items and popup menus.
+ (w32_free_submenu_strings, w32_free_menu_strings): New functions.
+
+ * w32fns.c (trackmouse_window, track_mouse_event_fn): New vars.
+ (w32_wnd_proc) <WM_MOUSEMOVE>: Notice when mouse enters frame.
+ <WM_EXITMENULOOP>: Free menu strings.
+ <WM_MOUSELEAVE>: Stop tracking mouse.
+ (x_create_tip_frame): Specify no minibuffer, modeline or fringes.
+
+ * w32term.c (w32_read_socket) <WM_MOUSELEAVE>: Cancel help echo
+ and mouse face.
+
+2001-12-01 Kim F. Storm <[email protected]>
+
+ The following changes add left-fringe and right-fringe
+ frame parameters to adjust fringe widths, or remove one or
+ both fringes.
+
+ * frame.h (struct frame): Remove trunc_area_pixel_width and
+ trunc_area_cols fields.
+ (Qleft_fringe, Qright_fringe): Declare.
+ (FRAME_RIGHT_FRINGE_WIDTH): New macro.
+
+ * frame.c (Qleft_fringe, Qright_fringe): New vars.
+ (syms_of_frame): Initialize them.
+
+ * window.c (coordinates_in_window): Handle separate left and right
+ fringe widths.
+
+ * xterm.h (struct x_output): Add left_fringe_width, right_fringe_width,
+ and fringe_cols fields.
+ (FRAME_FRINGE_BITMAP_WIDTH, FRAME_FRINGE_BITMAP_HEIGHT): Remove macros.
+ (FRAME_X_FRINGE_COLS): Use fringe_cols field.
+ (FRAME_X_FRINGE_WIDTH): Use fringes_extra field.
+ (FRAME_X_LEFT_FRINGE_WIDTH): Use left_fringe_width field.
+ (FRAME_X_RIGHT_FRINGE_WIDTH): Use right_fringe_width field.
+ (x_compute_fringe_widths): Add prototype.
+
+ * xterm.c (zv_height, zv_bits, zv_period): Changed zv bitmap to
+ fill fringe evenly with small dashes.
+ (x_draw_fringe_bitmap): Clear background if necessary. Align and
+ clip the new ZV bitmap to avoid jitter between rows.
+ (x_draw_row_fringe_bitmaps): Rely on x_draw_fringe_bitmap to clear
+ background. Don't draw fringe bitmaps if fringe width is zero.
+ (x_compute_fringe_widths): New function.
+ (x_new_font, x_set_window_size_1): Use it.
+
+ * xfns.c (x_frame_parms): Add `left-fringe' and `right-fringe' parms.
+ (x_set_frame_parameters): Process `font' parameter before other
+ parameters as fringe widths depend on it.
+ (x_set_fringe_width): New function.
+ (x_figure_window_size): Use x_compute_fringe_widths.
+ (Fx_create_frame): Process `left-fringe' and `right-fringe' frame
+ parameters.
+
+ * widget.c (set_frame_size): Use x_compute_fringe_widths.
+ (EmacsFrameSetCharSize): Ditto.
+
+ * w32term.h: Merged changes from xterm.h.
+ * w32term.c: Merged changes from xterm.c.
+ * w32fns.c: Merged changes from xfns.c.
+
+2001-11-29 Pavel Jan,Am(Bk <[email protected]>
+
+ * COPYING: Removed.
+
+2001-11-29 Dave Love <[email protected]>
+
+ * coding.c (syms_of_coding) <Qchar_coding_system>: Give it an
+ extra extra slot.
+ (detect_coding_mask): Fix call of detect_coding_iso2022.
+
+2001-11-29 Pavel Jan,Am(Bk <[email protected]>
+
+ * fileio.c (file-name-coding-system)
+ (default-file-name-coding-system): Doc fix (links to referenced
+ variables added).
+
+2001-11-28 Stefan Monnier <[email protected]>
+
+ * lisp.h (GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
+ Add dummy uses of gcproN variables.
+
+ * category.c (describe_category, describe_category_1)
+ (Fdescribe_categories): Remove. (Moved to lisp/help-fns.el.)
+ (syms_of_category): Don't defsubr Sdescribe_categories.
+
+2001-11-28 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Ffind_file_name_handler): Avoid initializer for `result'.
+
+ * Makefile.in (lispdir): New variable, referring to build dir.
+ (TAGS-LISP): Find Makefile in $(lispdir), not $(lispsource).
+
+2001-11-28 Andrew Innes <[email protected]>
+
+ * w32menu.c (w32_menu_display_help): Actually add the new argument
+ OWNER.
+
+2001-11-28 Jason Rumney <[email protected]>
+
+ * w32menu.c (add_menu_item): Do not use owner-draw for disabled
+ menu items. From David Ponce <[email protected]>.
+ (w32_dialog_show) [HAVE_DIALOGS]: Compile whole function
+ conditionally.
+ (w32_menu_display_help): New argument OWNER. Rewritten to store a
+ help event in the owner frame's keyboard buffer.
+
+ * w32fns.c (w32_wnd_proc) <WM_MENUSELECT>: Display help directly.
+ (Fx_show_tip): Don't subtract last width from row width.
+
+ * w32term.c (w32_read_socket) <WM_MENUSELECT>: Remove.
+ (w32_read_socket): Use EQ to compare frames.
+
+2001-11-28 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_draw_glyphs): Don't call notice_overwritten_cursor if
+ OVERLAPS_P.
+
+2001-11-28 Pavel Jan,Am(Bk <[email protected]>
+
+ * xdisp.c (message_dolog): Remove unused variables `gcpro2',
+ `gcpro3' and `gcpro4'.
+
+ * coding.c (decode_coding_string): Remove unused variable `gcpro1'.
+
+2001-11-28 Stefan Monnier <[email protected]>
+
+ * ccl.c: Use AREF and ASIZE.
+
+2001-11-27 Stefan Monnier <[email protected]>
+
+ * lisp.h (run_hook_list_with_args): Remove.
+ (LIST_END_P): Fix call to wrong_type_argument.
+ (make_fixnum_or_float): Use EMACS_INT rather than int.
+
+2001-11-26 Stefan Monnier <[email protected]>
+
+ * syntax.c (syms_of_syntax): Remove defsubr of Sdescribe_syntax.
+ (describe_syntax, describe_syntax_1, Fdescribe_syntax): Remove.
+
+ * eval.c: Use AREF and ASIZE.
+ (Ffetch_bytecode): Add the file name to the error message.
+
+ * fileio.c (Ffind_file_name_handler): Give precedence to handlers
+ which match the end of the file-name.
+ (Fsubstitute_in_file_name): Don't signal an error if $ENVVAR
+ is not a valid env var, but leave it as is instead.
+
+ * keymap.c (access_keymap): Handle t bindings like nil bindings.
+ Make nil bindings in char-tables transparent.
+ (store_in_keymap): Turn a nil binding into a t binding for char-tables.
+
+2001-11-26 Richard M. Stallman <[email protected]>
+
+ * textprop.c (set_text_properties_1): Allow START, END in either order.
+ Do nothing if range is empty.
+
+ * Makefile.in (mallocobj): Simplify logic using auxiliary vars.
+
+ * Makefile.in (mostlyclean): Delete bootstrap-emacs here.
+ (clean): Not here.
+
+2001-11-25 Stefan Monnier <[email protected]>
+
+ * textprop.c (set_text_properties_1): Clearly mark that the
+ interval should not be empty.
+
+ * intervals.c (graft_intervals_into_buffer):
+ Don't call set_text_properties_1 on an empty interval.
+
+2001-11-25 Richard M. Stallman <[email protected]>
+
+ * unexelf.c (unexec): Index by n, not nn, when checking for ".sbss".
+
+ * callproc.c (Fcall_process): When we make a bigger buffer for bufptr,
+ don't lose the data in it.
+
+2001-11-25 Juanma Barranquero <[email protected]>
+
+ * abbrev.c (Fexpand_abbrev): Use Frun_hooks instead of Vrun_hooks.
+
+ * buffer.c (Fkill_buffer): Likewise.
+
+ * print.c (temp_output_buffer_setup): Likewise.
+
+2001-11-25 Stefan Monnier <[email protected]>
+
+ * xfaces.c (merge_face_heights): Coerce back to int explicitly.
+
+2001-11-25 Eli Zaretskii <[email protected]>
+
+ * window.c (Fset_window_vscroll): Doc fix. From Kalle Olavi
+ Niemitalo <[email protected]>.
+
+2001-11-25 Jason Rumney <[email protected]>
+
+ * w32term.h (FRAME_X_FRINGE_COLS): No fringe on tip frames.
+
+ * w32fns.c (x_create_tip_frame): Set frame's fringes_extra to 0.
+ (Fx_show_tip): Block input during frame creation.
+ (Fx_show_tip, Fx_hide_tip): Enable.
+
+2001-11-24 Richard M. Stallman <[email protected]>
+
+ * lread.c (Fload): Detect recursive load error for more than 3
+ nestings of the same file.
+ (Vrecursive_load_depth_limit): Variable deleted.
+ (syms_of_lread) <recursive-load-depth-limit>: Variable deleted.
+
+2001-11-24 Jason Rumney <[email protected]>
+
+ * xfns.c (compute_tip_xy): Initialize root_x and root_y from
+ mouse position if either left or top is not specified.
+
+ * w32fns.c (w32_wnd_proc) <WM_MENUSELECT>: Revert last change.
+ <WM_WINDOWPOSCHANGING>: Let tip frames resize without restriction.
+ (my_create_tip_window, Fx_show_tip): Adjust size for external border.
+ (my_create_tip_window): Assign tip_window.
+ (x_create_tip_frame): Use same defaults as X.
+ (compute_tip_xy): Remove unused variable. Use full screen width.
+ (Fx_show_tip): Do not double height. Call ShowWindow directly.
+
+ * w32term.c (x_after_update_window_line): Doc fix.
+ (w32_read_socket): Doc fix. Avoid SET_FRAME_GARBAGED for tip
+ frames.
+ <WM_SHOWWINDOW>: Redo mouse highlight when hiding tip frame.
+
+ * xdisp.c (prepare_menu_bars) [HAVE_WINDOW_SYSTEM]: Use tip_frame
+ for all Windowed systems.
+
+2001-11-23 Eli Zaretskii <[email protected]>
+
+ * msdos.c (IT_clear_screen): If the frame's faces are not yet
+ realized, use the initial screen colors to clear the screen.
+
+2001-11-23 Pavel Jan,Am(Bk <[email protected]>
+
+ * textprop.c (Fset_text_properties): Remove unused variables
+ `unchanged', `prev_changed', `s' and `len'.
+
+ * search.c (Freplace_match): Remove unused variable `inslen'.
+
+ * keymap.c (access_keymap): Remove unused variables `c1' and `c2'.
+
+2001-11-22 Jason Rumney <[email protected]>
+
+ * w32fns.c (x_window_to_frame): Remove irrelevant TODO comment.
+ (w32_wnd_proc) <WM_MENUSELECT>: Show help echo directly.
+ (my_create_tip_window): New function.
+ (x_create_tip_frame, compute_tip_xy): Adapt for Windows.
+ (Fx_show_tip, Fx_hide_tip) [TEST_TOOLTIPS]: Adapt for Windows.
+
+2001-11-20 Jason Rumney <[email protected]>
+
+ * coding.h (Vw32_system_coding_system) [WINDOWSNT]: Remove.
+ (ENCODE_SYSTEM, DECODE_SYSTEM) [WINDOWSNT]: Use Vlocale_coding_system.
+
+ * w32fns.c (Vw32_system_coding_system): Remove.
+ (w32_to_x_font, x_to_w32_font): Use Vlocale_coding_system.
+
+2001-11-19 Stefan Monnier <[email protected]>
+
+ * fileio.c (Fwrite_region): Move choose_write_coding_system to
+ after build_annotations.
+
+ * syntax.c (describe_syntax): Add dummy arg.
+ (describe_syntax_1): Update call to describe_vector.
+
+ * category.c (describe_category): Add dummy arg.
+ (describe_category_1): Update call to describe_vector.
+
+ * keymap.c (Fdescribe_vector): Add `describer' parameter.
+ (describe_command, describe_translation): Add dummy second param.
+ (describe_map): Call elt_describer with two arguments.
+ (describe_vector_princ): Add `fun' parameter.
+ Call it instead of the hardcoded `princ'.
+ (describe_vector): Add arg `args'.
+ Pass it as a new second argument to elt_describer.
+
+ * keymap.h (describe_vector): Update prototype.
+
+ * frame.c: Don't include keymap.h any more.
+ (keys_of_frame): Remove.
+
+ * lisp.h (keys_of_frame): Remove declaration.
+
+ * emacs.c (main): Don't call `keys_of_frame' any more.
+
+2001-11-14 Andreas Schwab <[email protected]>
+
+ * unexelf.c [!defined MAP_ANON]: Define MAP_ANON to MAP_ANONYMOUS
+ if defined, 0 otherwise.
+ (MAP_FAILED): Define if not defined and use it to test mmap failure.
+ (unexec) [!MAP_ANON]: Use /dev/zero as file to map.
+
+2001-11-19 Richard M. Stallman <[email protected]>
+
+ * indent.c (current_column_1): Fix handling of scan_bytes for mb chars.
+
+2001-11-18 Jason Rumney <[email protected]>
+
+ * w32term.c (note_mouse_highlight): Fix type of variable `ignore'.
+ (x_draw_bar_cursor): If the background color of the glyph under
+ the cursor equals the frame's cursor color, use the glyph's
+ foreground color for drawing the bar cursor.
+ (x_after_update_window_line): Clear internal border in different
+ circumstances.
+ (w32_set_vertical_scroll_bar): Check for width and height > 0.
+ (w32_draw_relief_rect): Correct relief by 1 pixel.
+ (x_set_glyph_string_background_width):
+ Set extends_to_end_of_line_p if the row's fill_line_p is set and
+ drawing the last glyph with DRAW_IMAGE_{RAISED,SUNKEN}.
+ (x_display_and_set_cursor): If cursor_in_echo_area, use NO_CURSOR
+ if cursor_in_non_selected_windows is false.
+ (show_mouse_face): Clean up. Recognize overwritten cursor differently.
+ (x_draw_glyphs): Remove parameters REAL_START and REAL_END.
+ Notice if cursor gets overwritten.
+ (notice_overwritten_cursor): Renamed from
+ note_overwritten_text_cursor. Rewritten to take glyph widths
+ into account, and to take X positions as parameters.
+ (x_draw_phys_cursor_glyph): Save state of w->phys_cursor_on_p
+ around call to x_draw_glyphs.
+ (x_setup_relief_colors): Use `IMAGE_BACKGROUND' and
+ `IMAGE_BACKGROUND_TRANSPARENT' to calculate the correct background
+ color to use for image glyph reliefs.
+ (x_draw_image_relief): Accept zero tool_bar_button_relief.
+ (glyph_rect): Remove unused variable `area'.
+
+ * w32fns.c (x_set_frame_parameters): Avoid infinite recursion for
+ some items.
+ (x_set_internal_border_width): Set frame garbaged when window
+ doesn't exist yet.
+ (Fx_create_frame): Accept zero tool_bar_button_relief.
+ (x_clear_image_1, four_corners_best, image_background)
+ (image_background_transparent): New functions.
+ (xpm_format, png_format, jpeg_format, tiff_format, gif_format)
+ (gs_format): Add `:background' entry.
+ (lookup_image): Set IMG's background color if specified.
+ (pbm_load, xbm_load_image, png_load): Set IMG's background field
+ when appropriate.
+ (x_clear_image_1): Reset `background_valid' and
+ `background_transparent_valid' fields.
+ (x_build_heuristic_mask): Use IMAGE_BACKGROUND instead of
+ calculating it here. Set IMG's background_transparent field.
+ (enum xpm_keyword_index): Add XPM_BACKGROUND.
+ (enum png_keyword_index): Add PNG_BACKGROUND.
+ (enum jpeg_keyword_index): Add JPEG_BACKGROUND.
+ (enum tiff_keyword_index): Add TIFF_BACKGROUND.
+ (enum gif_keyword_index): Add GIF_BACKGROUND.
+ (enum gs_keyword_index): Add GS_BACKGROUND.
+ (pbm_load, png_load, jpeg_load, tiff_load, gif_load):
+ Pre-calculate image background color where necessary.
+ (x_create_x_image_and_pixmap, xbm_load, gs_load):
+ Use display info's n_cbits entry for screen depth.
+ (Fx_show_tip): Remove unused variables `buffer', `top',
+ `left', `max_width' and `max_height'.
+
+ * w32menu.c (w32_menu_show, push_menu_pane): Doc fixes.
+
+2001-11-18 Gerd Moellmann <[email protected]>
+
+ * puresize.h (BASE_PURESIZE): Increase to 750000.
+
+2001-11-18 Pavel Jan,Am(Bk <[email protected]>
+
+ * frame.c (Fframe_live_p): Doc fix.
+
+2001-11-18 Richard M. Stallman <[email protected]>
+
+ * xdisp.c (message_dolog_marker1, message_dolog_marker2)
+ (message_dolog_marker3): New static variables hold three markers.
+ (syms_of_xdisp): Initialize and staticpro them.
+ (message_dolog): Use message_dolog_marker1..3 instead of
+ allocating markers each time. Unchain them when done.
+
+2001-11-17 Richard M. Stallman <[email protected]>
+
+ * doc.c (Fsnarf_documentation): Doc fix.
+
+2001-11-17 Andreas Schwab <[email protected]>
+
+ * xterm.c (note_mouse_highlight): Fix type of variable `ignore'.
+
+2001-11-17 Richard M. Stallman <[email protected]>
+
+ * fileio.c (Fwrite_region): Avoid initializer for Lisp_Object.
+
+2001-11-17 Jason Rumney <[email protected]>
+
+ * xterm.c (notice_overwritten_cursor): Take care of end < 0 case.
+
+2001-11-17 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (tool_bar_item_info): Avoid calling Fget_text_property
+ with invalid position.
+
+2001-11-16 Richard M. Stallman <[email protected]>
+
+ * syswait.h: Delete conditionals for HPUX7, ISC 4.1, and convex.
+
+ * s/isc4-1.h (HAVE_SYS_WAIT_H): Add #undef.
+ * s/hpux.h (HAVE_SYS_WAIT_H): Add #undef.
+ * s/hpux8.h (HAVE_SYS_WAIT_H): Define it.
+
+ * m/convex.h (HAVE_SYS_WAIT_H): Add #undef.
+
+2001-11-16 Stefan Monnier <[email protected]>
+
+ * fileio.c (build_annotations): Split off the tail.
+ (build_annotations_2): New fun. Extracted from build_annotations.
+ (Fwrite_region): Split the call to build_annotations into two
+ calls to build_annotations and build_annotations_2.
+
+2001-11-16 Pavel Jan,Am(Bk <[email protected]>
+
+ * sysdep.c (wait_for_kbd_input) [VMS]: Do not call
+ clear_waiting_for_input with argument.
+
+ * xterm.h (x_update_cursor): Remove duplicated prototype.
+
+ * keyboard.h (clear_waiting_for_input): Remove duplicated prototype.
+
+ * xterm.c (waiting_for_input): Remove unnecessary declaration.
+
+ * data.c (Ftimes, Fquo, Frem, Fmod): Doc fix.
+
+2001-11-16 Stefan Monnier <[email protected]>
+
+ * fileio.c (choose_write_coding_system): New fun, extracted
+ from Fwrite_region.
+ (Fwrite_region): Use it.
+
+ * eval.c (max_specpdl_size, max_lisp_eval_depth): Use EMACS_INT.
+ (funcall_lambda, run_hook_with_args): Make static and add prototype.
+ (ml_apply, find_handler_clause): Add prototype.
+
+2001-11-16 Eli Zaretskii <[email protected]>
+
+ * config.in: Add #undef HAVE_COFF_H.
+
+ * unexec.c (coff.h): Don't include unless HAVE_COFF_H is defined.
+ Required for ISC 4.1.
+
+2001-11-16 Eli Zaretskii <[email protected]>
+
+ * syswait.h (HAVE_SYS_WAIT_H): Undef for ISC 4.1. Reported by
+ Andrew Wiseman <[email protected]>.
+
+2001-11-16 Kim F. Storm <[email protected]>
+
+ The following changes are made to clean up the various internal
+ references to the fringes to actually use the term `fringe' for
+ them. Previously, they were called `flags areas', `bitmap areas',
+ `left/right side of windows', or implicitly as `flags' or
+ `bitmaps':
+
+ * dispextern.h (FRINGE_FACE_ID): Renamed from BITMAP_AREA_FACE_ID.
+ Comments fixed. Use renamed symbols.
+
+ * dispnew.c: Comment fix. Use renamed symbols.
+
+ * frame.h (FRAME_FRINGE_COLS): Renamed from FRAME_FLAGS_AREA_COLS.
+ (FRAME_FRINGE_WIDTH): Renamed from FRAME_FLAGS_AREA_WIDTH.
+ (FRAME_LEFT_FRINGE_WIDTH): Renamed from FRAME_LEFT_FLAGS_AREA_WIDTH.
+
+ * msdos.c: Comment fix.
+
+ * w32fns.c: Use renamed symbols.
+
+ * w32term.c: Comment fixes. Use renamed symbols.
+ (fringe_bitmap_type): Renamed from bitmap_type.
+ (NO_FRINGE_BITMAP): Renamed from NO_BITMAP.
+ (w32_draw_fringe_bitmap): Renamed from w32_draw_bitmap.
+ (x_draw_row_fringe_bitmaps): Renamed from x_draw_row_bitmaps.
+
+ * w32term.h: Comment fixes. Use renamed symbols.
+ (fringes_extra): Renamed from flags_areas_extra.
+ (FRAME_FRINGE_BITMAP_WIDTH): Renamed from FRAME_FLAGS_BITMAP_WIDTH.
+ (FRAME_FRINGE_BITMAP_HEIGHT): Renamed from FRAME_FLAGS_BITMAP_HEIGHT.
+ (FRAME_X_FRINGE_COLS): Renamed from FRAME_X_FLAGS_AREA_COLS.
+ (FRAME_X_FRINGE_WIDTH): Renamed from FRAME_X_FLAGS_AREA_WIDTH.
+ (FRAME_X_LEFT_FRINGE_WIDTH):
+ Renamed from FRAME_X_LEFT_FLAGS_AREA_WIDTH.
+ (FRAME_X_RIGHT_FRINGE_WIDTH):
+ Renamed from FRAME_X_RIGHT_FLAGS_AREA_WIDTH.
+
+ * widget.c: Use renamed symbols.
+
+ * window.c: Comment fixes. Use renamed symbols.
+ (coordinates-in-window-p): Doc fix.
+
+ * xdisp.c: Comment fixes. Use renamed symbols.
+
+ * xfaces.c (realize_basic_faces): Use FRINGE_FACE_ID.
+
+ * xfns.c: Use renamed symbols.
+
+ * xterm.c: Comment fixes. Use renamed symbols.
+ (fringe_bitmap_type): Renamed from bitmap_type.
+ (NO_FRINGE_BITMAP): Renamed from NO_BITMAP.
+ (x_draw_fringe_bitmap): Renamed from x_draw_bitmap.
+ (x_draw_row_fringe_bitmaps): Renamed from x_draw_row_bitmaps.
+
+ * xterm.h: Comment fixes. Use renamed symbols.
+ (fringes_extra): Renamed from flags_areas_extra.
+ (FRAME_FRINGE_BITMAP_WIDTH): Renamed from FRAME_FLAGS_BITMAP_WIDTH.
+ (FRAME_FRINGE_BITMAP_HEIGHT): Renamed from FRAME_FLAGS_BITMAP_HEIGHT.
+ (FRAME_X_FRINGE_COLS): Renamed from FRAME_X_FLAGS_AREA_COLS.
+ (FRAME_X_FRINGE_WIDTH): Renamed from FRAME_X_FLAGS_AREA_WIDTH.
+ (FRAME_X_LEFT_FRINGE_WIDTH):
+ Renamed from FRAME_X_LEFT_FLAGS_AREA_WIDTH.
+ (FRAME_X_RIGHT_FRINGE_WIDTH):
+ Renamed from FRAME_X_RIGHT_FLAGS_AREA_WIDTH.
+
+2001-11-15 Jason Rumney <[email protected]>
+
+ * w32menu.c (add-menu-item): Make help_echo and radio buttons
+ work for most menu items. From David Ponce
+
+2001-11-15 Gerd Moellmann <[email protected]>
+
+ * xfns.c (x_set_frame_parameters): Revert change of 2001-11-07.
+ Some x_set_* function expect to be called even if old and new
+ value are equal.
+
+ * xdisp.c (build_desired_tool_bar_string): Accept zero
+ tool_bar_button_relief.
+
+ * xfns.c (Fx_create_frame): Accept zero tool_bar_button_relief.
+
+ * xterm.c (x_draw_image_relief): Accept zero tool_bar_button_relief.
+
+ * xterm.c (x_draw_bar_cursor): If the background color of the
+ glyph under the cursor equals the frame's cursor color, use
+ the glyph's foreground color for drawing the bar cursor.
+
+ * dispnew.c (direct_output_forward_char): Fix character/byte
+ position comparison.
+
+2001-11-15 Miles Bader <[email protected]>
+
+ * editfns.c (find_field): Add BEG_LIMIT and END_LIMIT parameters.
+ (Fdelete_field, Ffield_string, Ffield_string_no_properties):
+ Update arguments to find_field.
+ (Ffield_beginning, Ffield_end): Add LIMIT param, pass to find_field.
+ (Fconstrain_to_field): Use LIMIT arg to shorten search time.
+ * lisp.h (Ffield_beginning, Ffield_end): Update EXFUN decl.
+ * minibuf.c (Fminibuffer_prompt_end): Update args to Ffield_end.
+
+2001-11-14 Richard M. Stallman <[email protected]>
+
+ * editfns.c (Fpropertize): Allow call with 1 arg.
+
+ * dispextern.h (image_background, image_background_transparent):
+ Conditionalize on HAVE_X_WINDOWS.
+
+2001-11-13 Richard M. Stallman <[email protected]>
+
+ * print.c (Fprin1_to_string): Doc fix.
+
+ * sunfns.c (Fsun_change_cursor_icon): Doc fix.
+
+ * floatfns.c (Fceiling, Ffloor): Doc fixes.
+
+ * filelock.c (Funlock_buffer, Ffile_locked_p): Doc fixes.
+
+ * fileio.c (Ffile_accessible_directory_p): Doc fix.
+
+ * eval.c (syms_of_eval): Doc fix.
+
+ * coding.c (syms_of_coding): Doc fix.
+
+ * doc.c (Fsnarf_documentation): Doc fix.
+
+ * dispnew.c (syms_of_display): Doc fix.
+
+ * category.c (Fget_unused_category): Doc fix.
+
+ * buffer.c (syms_of_buffer): Doc fixes.
+
+2001-11-14 Eli Zaretskii <[email protected]>
+
+ * print.c (prin1, print): Doc fix.
+
+2001-11-14 Pavel Jan,Am(Bk <[email protected]>
+
+ * fontset.h: Remove declarations of variables
+ `Vhighlight_wrong_size_font' and `Vclip_large_size_font'.
+
+ * fontset.c: Remove variables `Vhighlight_wrong_size_font' and
+ `Vclip_large_size_font'.
+
+2001-11-13 Jason Rumney <[email protected]>
+
+ * w32fns.c: Doc fix.
+
+2001-11-13 Pavel Jan,Am(Bk <[email protected]>
+
+ * xfaces.c (Fface_attributes_as_vector): Doc fix.
+
+ * fns.c: Doc fix.
+
+ * emacs.c: Doc fix.
+
+ * coding.c: Doc fix.
+
+ * cmds.c, composite.c, dired.c, doc.c, filelock.c, floatfns.c,
+ * fontset.c, insdel.c, keymap.c: Change doc-string comments to
+ `new style' [w/`doc:' keyword].
+
+2001-11-12 Richard M. Stallman <[email protected]>
+
+ * xterm.c (XTread_socket): Don't update focus for EnterNotify or
+ LeaveNotify events. Only FocusIn and FocusOut do that now.
+ (x_display_and_set_cursor): Do display hollow cursors in active
+ minibuffer windows when they are not selected.
+
+2001-11-12 Jason Rumney <[email protected]>
+
+ * w32console.c, w32fns.c, w32menu.c, w32proc.c, w32select.c,
+ * w32term.c: Change doc-string comments to `new style'
+ [w/`doc:' keyword]. Doc fixes.
+
+ * w32fns.c: Don't define max.
+ (Fx_open_connection): Only execute once.
+
+2001-11-12 Pavel Jan,Am(Bk <[email protected]>
+
+ * ccl.c: Change macros to use do-while block instead of if-else.
+ Use braces to follow GNU Coding Standards.
+
+2001-11-11 Richard M. Stallman <[email protected]>
+
+ * sysdep.c (child_setup_tty): Don't clear ICRNL or INLCR.
+
+ * lread.c (read_escape): Use end_of_file_error for reporting eof.
+
+ * insdel.c (replace_range): Use adjust_markers_for_replace
+ instead of adjust_markers_for_delete and adjust_markers_for_insert.
+
+ * intervals.h (set_text_properties, set_text_properties_1): Declare.
+
+ * textprop.c (set_text_properties_1): New subroutine
+ broken out of set_text_properties.
+ (set_text_properties): Use set_text_properties_1.
+
+ * intervals.c (graft_intervals_into_buffer):
+ Use set_text_properties_1 to clear out properties.
+
+ * search.c (Freplace_match): Use replace_range to insert
+ and delete. Don't request property inheritance from
+ surrounding text.
+
+2001-11-10 Jason Rumney <[email protected]>
+
+ * w32fns.c (enum_font_cb2): Use leading @ on face name to detect
+ vertical fonts. Allow them if face name is explicitly specified.
+ Do not give up if we find a font that cannot be converted to an xlfd.
+
+2001-11-10 Gerd Moellmann <[email protected]>
+
+ * unexelf.c (unexec): Use mmap/munmap to allocate buffers
+ instead of malloc/free.
+
+2001-11-09 Pavel Jan,Am(Bk <[email protected]>
+
+ * xfaces.c (merge_face_vectors): Use braces to follow GNU
+ Coding Standards.
+ (Finternal_set_lisp_face_attribute): Likewise.
+
+ * buffer.c (Fbury_buffer): Likewise.
+
+ * indent.c (current_column_1): Remove unused variable `prev_col'.
+
+ * coding.c (encode_coding): Use precomputed value of `src'.
+ (encode_coding): Remove unused variable `src_end'.
+ (code_convert_region): Remove unused variables `count'.
+
+2001-11-07 Jason Rumney <[email protected]>
+
+ * w32term.c (x_display_and_set_cursor): Do not move system caret
+ if cursor_glyph is NULL.
+
+2001-11-07 Pavel Jan,Am(Bk <[email protected]>
+
+ * keymap.c (access_keymap): Fix compilation error.
+
+2001-11-07 Miles Bader <[email protected]>
+
+ * xfns.c (x_set_frame_parameters): Avoid infinite recursion.
+
+2001-11-07 Pavel Jan,Am(Bk <[email protected]>
+
+ * intervals.c (graft_intervals_into_buffer):
+ Remove #ifdef'd-out code.
+ (graft_intervals_into_buffer): Remove unused variable `middle'.
+
+ * lread.c (Feval_region): Remove obsolete #ifdef'd-out
+ code (eval-current-buffer).
+ Change doc-string comments to `new style' [w/`doc:' keyword].
+
+2001-11-06 Richard M. Stallman <[email protected]>
+
+ * keymap.c (access_keymap): Don't use initializers on Lisp_Object.
+
+2001-11-06 Stefan Monnier <[email protected]>
+
+ * lread.c (read1): Fix behavior with nested backquoting.
+
+ * keyboard.c (make_lispy_event): Check integerness and fix
+ Lisp_Object/int mixup.
+
+2001-11-06 Pavel Jan,Am(Bk <[email protected]>
+
+ * fns.c (copy_hash_table): Remove unused variable `v'.
+
+ * fontset.c (fontset_font_pattern): Remove unused variable
+ `family_registry'.
+
+ * indent.c (current_column_1): Remove unused variable `prev_col'.
+
+2001-11-05 Richard M. Stallman <[email protected]>
+
+ * m/news-risc.h (BROKEN_PROTOTYPES): Defined.
+
+ * buffer.c (Fkill_buffer): Don't delete auto save file
+ if buffer is modified.
+
+2001-11-05 Andrew Innes <[email protected]>
+
+ * w32proc.c (Fw32_set_keyboard_layout): Use CHECK_NUMBER_CAR and
+ CHECK_NUMBER_CDR.
+
+2001-11-05 Richard M. Stallman <[email protected]>
+
+ * unexelf.c (unexec): Minor changes; clean up comments.
+
+2001-11-05 Sam Steingold <[email protected]>
+
+ * w32term.c (x_display_and_set_cursor): Fix w32 compilation error.
+
+2001-11-05 Andreas Schwab <[email protected]>
+
+ * sound.c (sound_perror): Save errno from being clobbered.
+
+2001-11-05 Dale Hagglund <[email protected]>
+
+ * unexelf.c (unexec): Don't use `mmap'. Instead, read and write
+ the program image directly.
+
+2001-11-05 Pavel Jan,Am(Bk <[email protected]>
+
+ * buffer.h (Fbuffer_local_value): Add prototype.
+
+2001-11-04 Richard M. Stallman <[email protected]>
+
+ * buffer.c (Fbuffer_local_value): Remove extra args from CHECK_SYMBOL
+ and CHECK_BUFFER.
+
+ * keyboard.c (read_char): Use Fcar and Fcdr, not Fnth.
+ (record_char): Likewise.
+
+ * keyboard.c (make_lispy_event): Don't insist a drag event must
+ move to a different buffer position. Instead, check for moving at
+ least double_click_fuzz.
+
+ * fns.c (Fmake_hash_table): Use XCAR and XCDR, not Fnth and Flength.
+
+ * keyboard.c (echo-area-clear-hook): Undo Oct 29 change.
+
+ * indent.c (current_column_1, Fmove_to_column): Separate the code
+ for display-table glyphs from the code for buffer text, to fix
+ bugs in the former.
+
+2001-11-04 Michael Welsh Duggan <[email protected]>
+
+ * buffer.c (Fbuffer_local_value): New function.
+ (syms_of_buffer): Defsubr it.
+
+ * xterm.c, w32term.c (x_display_and_set_cursor): Use buffer-local
+ value of `cursor-in-non-selected-windows'.
+
+ * lisp.h (Qcursor_in_non_selected_windows): New declaration.
+ * xdisp.c (Qcursor_in_non_selected_windows): New variable.
+ (syms_of_xdisp): Initialize it.
+
+2001-11-04 Pavel Jan,Am(Bk <[email protected]>
+
+ * xfns.c (Fx_create_frame): Doc fix.
+
+ * coding.c: Change doc-string comments to `new style' [w/`doc:'
+ keyword].
+
+ * eval.c (top_level_value, top_level_set): Remove commented and
+ #ifdef'd-out code.
+ (Fdefvar): Fix usage in doc-string.
+
+2001-11-03 Richard M. Stallman <[email protected]>
+
+ * xfns.c: Include unistd.h, if it exists.
+
+ * editfns.c: Move the include of ctype.h after unistd.h.
+
+ * gmalloc.c: Test BROKEN_PROTOTYPES.
+
+2001-11-03 Ken Raeburn <[email protected]>
+
+ * lisp.h (CHECK_STRING_CAR): New macro.
+ * lread.c (Fload): Use XSETCARFASTINT, XSETCDRFASTINT instead of
+ treating XCAR and XCDR as lvalues.
+ (openp): Use CHECK_STRING_CAR.
+ (read_list): Use XSETCDR instead of treating XCDR as lvalue.
+
+2001-11-03 Eli Zaretskii <[email protected]>
+
+ * s/sco5.h (sigprocmask_set): Declare as extern SIGMASKTYPE.
+ (SIGMASKTYPE): Define.
+
+ * syssignal.h (sigunblock): Don't define if already defined.
+
+2001-11-02 Pavel Jan,Am(Bk <[email protected]>
+
+ * eval.c (debugger_may_continue, Vdebug_ignored_errors)
+ (call_debugger, Fcondition_case, skip_debugger, unbind_to):
+ Fix typos in comments.
+
+ * mocklisp.c (Fml_defun, Fml_while, Fml_substr): Remove commented
+ and #ifdef'd-out code.
+ Fix and reindent comments.
+
+ * mocklisp.h: Remove comment which is a copy of comment in mocklisp.c.
+
+ * category.h (CHECK_CATEGORY, CHECK_CATEGORY_SET): Remove unused
+ argument `i' in macros.
+
+ * frame.h (CHECK_FRAME, CHECK_LIVE_FRAME): Remove unused argument
+ `i' in macros.
+
+ * lisp.h (CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST)
+ (CHECK_STRING, CHECK_CONS, CHECK_SYMBOL, CHECK_CHAR_TABLE)
+ (CHECK_VECTOR, CHECK_VECTOR_OR_CHAR_TABLE, CHECK_BUFFER)
+ (CHECK_WINDOW, CHECK_LIVE_WINDOW, CHECK_PROCESS, CHECK_NUMBER)
+ (CHECK_NATNUM, CHECK_MARKER, CHECK_NUMBER_COERCE_MARKER)
+ (CHECK_FLOAT, CHECK_NUMBER_OR_FLOAT)
+ (CHECK_NUMBER_OR_FLOAT_COERCE_MARKER, CHECK_OVERLAY)
+ (CHECK_NUMBER_CAR, CHECK_NUMBER_CDR): Remove unused argument `i'
+ in macros.
+
+ * abbrev.c, alloc.c, buffer.c, bytecode.c, callint.c, callproc.c,
+ * casefiddle.c, category.c, ccl.c, charset.c, cmds.c, coding.c,
+ * composite.c, data.c, dired.c, dispnew.c, doc.c, dosfns.c, emacs.c,
+ * eval.c, fileio.c, filelock.c, fns.c, fontset.c, frame.c, frame.h,
+ * indent.c, keyboard.c, keymap.c, lread.c, macros.c, marker.c,
+ * minibuf.c, mocklisp.c, msdos.c, print.c, process.c, search.c,
+ * sunfns.c, syntax.c, textprop.c, undo.c, w16select.c, w32console.c,
+ * w32fns.c, w32menu.c, w32proc.c, w32select.c, window.c, xdisp.c,
+ * xfaces.c, xmenu.c, xselect.c: Update usage of CHECK_ macros
+ (remove unused second argument).
+
+2001-11-02 Stefan Monnier <[email protected]>
+
+ * syntax.c (describe_syntax): New wrapper.
+ (Finternal_describe_syntax_value): Rename from describe_syntax.
+ Don't insert space at front and \n at the end.
+ (syms_of_syntax): Defsubr Sinternal_describe_syntax_value.
+
+ * regex.c (re_wctype): Try to fix some warnings.
+ (regcomp, regexec): Don't forget the __restrict.
+
+2001-11-02 Richard M. Stallman <[email protected]>
+
+ * textprop.c (Fget_char_property): Doc fix.
+
+2001-11-02 Pavel Jan,Am(Bk <[email protected]>
+
+ * process.c (Fstart_process): Add usage to doc-string.
+
+ * data.c (Fsetq_default): Ditto.
+
+ * callint.c (Finteractive): Ditto.
+
+2001-11-01 Stefan Monnier <[email protected]>
+
+ * macros.c: Don't include keymap.h any more.
+
+2001-11-01 Richard M. Stallman <[email protected]>
+
+ * data.c (Fmake_local_variable): Doc fix.
+
+ * eval.c (Frun_hooks, Frun_hook_with_args_until_failure): Doc fix.
+ (Frun_hook_with_args_until_success, Frun_hook_with_args): Doc fix.
+
+ * keymap.c (Fdescribe_buffer_bindings): Print character property
+ bindings along with or instead of the buffer local map.
+ Make the overriding maps override what they should.
+
+2001-11-01 Pavel Jan,Am(Bk <[email protected]>
+
+ * window.c (grow_mini_window): Fix typo in comment.
+
+2001-11-01 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_scroll_bar_create): Check for width and height > 0.
+ (XTset_vertical_scroll_bar): Likewise.
+
+ * xfns.c (x_build_heuristic_mask): Use four_corners_best
+ instead of IMAGE_BACKGROUND.
+
+ * xfns.c (four_corners_best): Reindent.
+
+ * xfaces.c (Finternal_set_lisp_face_attribute_from_resource):
+ Handle :box so that it is possible to specify sexprs.
+
+2001-10-31 Eli Zaretskii <[email protected]>
+
+ * s/hpux11.h: New file.
+
+2001-10-31 Pavel Jan,Am(Bk <[email protected]>
+
+ * emacs.c (USAGE1): Show command line option --no-window-system
+ instead of --no-windows in usage.
+ (standard_args): Rename --no-windows to --no-window-system.
+ (bug_reporting_address): Follow Emacs coding conventions.
+
+ * eval.c (Fcommandp): Doc fix.
+ Change doc-string comments to `new style' [w/`doc:' keyword].
+
+ * frame.c (Fframe_live_p): Doc fix.
+
+ * buffer.c (selective-display-ellipses): Doc fix.
+
+2001-10-31 Gerd Moellmann <[email protected]>
+
+ * lread.c (to_multibyte): Fix computation of new read_buffer_size.
+
+ * xfaces.c (realize_x_face): If C is not a single-byte character,
+ set the face's colors_copied_bitwise_p instead of the defaulted_p
+ members which have a different meaning.
+ (free_face_colors): Do nothing for a face whose colors have been
+ copied bitwise.
+
+ * dispextern.h (struct face) <colors_copied_bitwise_p>: New member.
+
+2001-10-31 Pavel Jan,Am(Bk <[email protected]>
+
+ * marker.c, mocklisp.c: Change doc-string comments to `new style'
+ [w/`doc:' keyword].
+
+2001-10-31 Gerd Moellmann <[email protected]>
+
+ * fns.c (require_unwind): Return Lisp_Object.
+
+2001-10-31 Pavel Jan,Am(Bk <[email protected]>
+
+ * keyboard.c (lucid-menu-bar-dirty-flag): Doc fix.
+ (last-input-char): Revert doc-string to be the same as the
+ doc-string of `last-input-event'.
+
+ * xdisp.c: Fix typos in comments.
+
+2001-10-31 Gerd Moellmann <[email protected]>
+
+ * window.c (grow_mini_window): Handle case that the root
+ window is already smaller than the nominal mininum height.
+
+2001-10-30 Stefan Monnier <[email protected]>
+
+ * emacs.c (main): Don't call keys_of_macros any more.
+
+ * lisp.h (keys_of_macros): Remove.
+
+ * macros.c (keys_of_macros): Remove.
+
+ * xfaces.c (Fface_attribute_relative_p): Declare args.
+
+2001-10-30 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_to_x_charset): Increase size of XLFD charset buffer.
+ (enum_font_cb2): Ignore fonts with vertical orientation.
+
+2001-10-30 Richard M. Stallman <[email protected]>
+
+ * keyboard.c (Finput_pending_p): Doc fix.
+
+2001-10-30 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_after_update_window_line): Don't run the code
+ clearing in borders for rows whose visible height is 0.
+
+ * xdisp.c (clear_garbaged_frames): Redraw the frame only if its
+ resized_p flag is set. If not set, use the much less flickering
+ method previously used.
+
+ * dispnew.c (change_frame_size_1): Set frame's resized_p.
+
+ * frame.h (struct frame) <resized_p>: New member.
+
+ * lread.c (to_multibyte): Ensure read_buffer is at least twice
+ as large as the number of bytes to convert.
+
+ * lread.c (to_multibyte): New function.
+ (read1): Use it.
+
+2001-10-30 Eli Zaretskii <[email protected]>
+
+ * msdos.h (FRAME_LINE_HEIGHT): Define (it's used by xmenu.c).
+
+2001-10-30 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_draw_relief_rect): Correct bottom relief by 1 pixel.
+ (x_set_glyph_string_background_width): Set extends_to_end_of_line_p
+ if the row's fill_line_p is set and drawing the last glyph with
+ DRAW_IMAGE_{RAISED,SUNKEN}.
+
+ * xdisp.c (clear_garbaged_frames): Call Fredraw_frame.
+
+2001-10-29 Stefan Monnier <[email protected]>
+
+ * xmenu.c: Include coding.h and charset.h.
+ (Fx_popup_menu): Use FRAME_PTR and FRAME_FONT and FRAME_LINE_HEIGHT.
+ (Fx_popup_dialog): Use FRAME_PTR and enum scroll_bar_part.
+ (single_submenu, xmenu_show): Use ENCODE_SYSTEM.
+ Explicitly set wv->help. Use `TRUE' rather than `True'.
+ (menu_help_callback): Use empty_string.
+
+ * w32menu.c (Fx_popup_menu): Explicitly init f, xpos, and ypos.
+ (Fx_popup_dialog): Explicitly init f.
+ (w32_menu_display_help): Use empty_string.
+
+2001-10-29 Richard M. Stallman <[email protected]>
+
+ * fns.c (Frequire): Detect recursive try to require the same
+ feature 3 or more levels deep, and get error.
+ (require_unwind): New subroutine.
+ (require_nesting_list): New variable.
+ (syms_of_fns): Init and staticpro it.
+
+ * print.c (print_object): Clarify indication of insertion type.
+
+2001-10-29 Eli Zaretskii <[email protected]>
+
+ * coding.c (syms_of_coding): Document that locale-coding-system is
+ used for decoding input on X.
+
+ * window.c (Fscroll_left, Fscroll_right): Doc fix.
+
+2001-10-29 Pavel Jan,Am(Bk <[email protected]>
+
+ * keyboard.c (Finput_pending_p): Fix typo in doc-string.
+ (echo-area-clear-hook): Properly DEFVAR_LISP and staticpro it.
+
+2001-10-29 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_display_and_set_cursor): If cursor_in_echo_area,
+ use NO_CURSOR if cursor_in_non_selected_windows is false.
+
+ * xfaces.c (Fface_font): Use UNSPECIFIEDP instead of NILP for
+ the slant attribute if FRAME is t.
+
+ * xfns.c (x_set_internal_border_width): Set frame garbaged
+ when X window doesn't exist yet.
+
+ * xterm.c (x_after_update_window_line): Clear internal border
+ in different circumstances.
+
+ * xterm.c (XTread_socket) <KeyPress>: Don't use
+ STRING_CHAR_AND_LENGTH if nchars == nbytes. From Kenichi Handa
+
+2001-10-28 Eli Zaretskii <[email protected]>
+
+ * m/ibms390.h: New file. From Adam Thornton
+
+2001-10-28 Gerd Moellmann <[email protected]>
+
+ * xfns.c (x_build_heuristic_mask): Use x_alloc_image_color.
+
+ * xfns.c (x_build_heuristic_mask): Fix a bug not incrementing
+ a loop counter.
+
+2001-10-28 Pavel Jan,Am(Bk <[email protected]>
+
+ * emacs.c: Use argv[0] instead of "emacs" when -t was specified.
+
+ * keyboard.c: Change doc-string comments to `new style' [w/`doc:'
+ keyword].
+ Fix typos in comments.
+
+ * emacs.c (bug_reporting_address): New function.
+ Use it when displaying usage message.
+
+ * minibuf.c (read_minibuf): Remove unused external declaration of
+ variable `Qread_only'.
+
+ * keymap.c (access_keymap): Remove unused variable `charset'.
+
+2001-10-28 Miles Bader <[email protected]>
+
+ * xfaces.c (merge_face_heights): Handle TO being relative as well.
+ Remove #ifdef'd-out code.
+ (Fface_attribute_relative_p, Fmerge_face_attribute): New functions.
+ (syms_of_xfaces): Initialize them.
+
+2001-10-27 Jason Rumney <[email protected]>
+
+ * w32fns.c (w32_wnd_proc) <WM_KILLFOCUS>: Destroy the system caret.
+ <WM_EMACS_DESTROY_CARET, WM_EMACS_TRACK_CARET>: Track cursor
+ position using the system caret.
+
+ * w32term.c (w32_system_caret_hwnd, w32_system_caret_width)
+ (w32_system_caret_height, w32_system_caret_x)
+ (w32_system_caret_y): New variables for tracking system caret.
+ (w32_initialize): Initialize them.
+ (x_display_and_set_cursor): Make system caret follow the active cursor.
+
+ * w32term.h (WM_EMACS_TRACK_CARET, WM_EMACS_DESTROY_CARET):
+ New messages types.
+
+ * w32term.c (note_mouse_highlight): Clear old help_echo.
+
+2001-10-27 Pavel Jan,Am(Bk <[email protected]>
+
+ * xterm.c: Fix typo in a comment.
+
+ * emacs.c: Fix typos in comments.
+ Remove unnecessary spaces.
+ Change doc-string comments to `new style' [w/`doc:' keyword].
+ (USAGE2): Fix typos in usage string.
+
+ * xterm.c: Fix typo in a comment.
+
+ * lisp.h (gdb_lisp_params): Remove code in #if 0 which is now in
+ emacs.c.
+
+2001-10-27 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (move_it_vertically_backward): Use 2/3 line_height
+ instead of 1/2 line_height in the heuristic for skipping
+ farther backward when target_y was not reached.
+
+ * sound.c (sound_perror): Unblock SIGIO, turn on atimers.
+ Display errno only if non-zero.
+ (sound_warning): New function.
+ (vox_configure): Don't treat failing to set sample rate as error.
+ (various places): Improve error messages.
+
+2001-10-26 Eli Zaretskii <[email protected]>
+
+ * fileio.c (Faccess_file): Run the argument filename through
+ Fexpand_file_name, before using it.
+
+ * dispnew.c (syms_of_display) <visible-bell>: Add a reference to
+ ring-bell-function. Suggested by Alf-Ivar Holm <[email protected]>
+
+2001-10-26 Gerd Moellmann <[email protected]>
+
+ * insdel.c (insert_1_both): Do nothing if NCHARS == 0.
+
+ * xterm.c (XTset_vertical_scroll_bar) [!USE_TOOLKIT_SCROLL_BARS]:
+ Fix clearing in the case of scroll bars on the right.
+
+2001-10-26 Juanma Barranquero <[email protected]>
+
+ * w32gui.h (XImage): Add a dummy typedef.
+
+2001-10-26 Gerd Moellmann <[email protected]>
+
+ * xfns.c (XScreenNumberOfScreen): Fix struct to pointer comparison.
+
+2001-10-25 Eli Zaretskii <[email protected]>
+
+ * frame.c (Fframe_parameter): Fix last change.
+
+ * fileio.c: Revert last change (which removed old commented-out
+ version of expand-file-name). Add a comment that explains why
+ this old version should not be removed.
+
+2001-10-25 Gerd Moellmann <[email protected]>
+
+ * frame.c (Fframe_parameter): Fix a bug whereby some
+ ``artificial'' frame parameters, like `minibuffer' were not
+ obtained by calling Fframe_parameters.
+
+ * xterm.c (show_mouse_face): Clean up. Recognize overwritten
+ cursor differently.
+
+ * xdisp.c (move_it_vertically_backward): Compute line height
+ differently. Add heuristic to try to be more compatible to 20.x.
+
+2001-10-25 Stefan Monnier <[email protected]>
+
+ * lisp.h (make_fixnum_or_float): Coerce double to int explicitly.
+
+ * editfns.c (text_property_stickiness): Fix Lisp_Object used as
+ boolean.
+
+2001-10-25 Miles Bader <[email protected]>
+
+ * xfns.c (png_load): Make sure SPECIFIED_BG is a string.
+ BG is a pointer to a structure, not a structure.
+ (gif_format, png_format): Add missing commas.
+
+2001-10-24 Richard M. Stallman <[email protected]>
+
+ * xfaces.c (Fface_attributes_as_vector): New function.
+ (syms_of_xfaces): Defsubr it.
+
+2001-10-24 Pavel Jan,Am(Bk <[email protected]>
+
+ * dispnew.c (sync_window_with_frame_matrix_rows): Remove unused
+ variable `area'.
+
+2001-10-25 Pavel Jan,Am(Bk <[email protected]>
+
+ * search.c (scan_newline): Remove unused variable `selective_display'.
+
+2001-10-25 Miles Bader <[email protected]>
+
+ * dispextern.h (struct image): Add `background',
+ `background_valid', and `background_transparent' fields.
+ (image_background, image_background_transparent): New declarations.
+ (IMAGE_BACKGROUND, IMAGE_BACKGROUND_TRANSPARENT): New macros.
+ * xfns.c (image_background, image_background_transparent)
+ (four_corners_best): New functions.
+ (xpm_format, png_format, jpeg_format, tiff_format, gif_format)
+ (gs_format): Add `:background' entry.
+ (lookup_image): Set IMG's background color if specified.
+ (pbm_load, xbm_load_image, png_load): Set IMG's background field
+ when appropriate.
+ (x_clear_image_1): Reset `background_valid' and
+ `background_transparent_valid' fields.
+ (x_build_heuristic_mask): Use IMAGE_BACKGROUND instead of
+ calculating it here. Set IMG's background_transparent field.
+ (enum xpm_keyword_index): Add XPM_BACKGROUND.
+ (enum png_keyword_index): Add PNG_BACKGROUND.
+ (enum jpeg_keyword_index): Add JPEG_BACKGROUND.
+ (enum tiff_keyword_index): Add TIFF_BACKGROUND.
+ (enum gif_keyword_index): Add GIF_BACKGROUND.
+ (enum gs_keyword_index): Add GS_BACKGROUND.
+ (pbm_load, png_load, jpeg_load, tiff_load, gif_load):
+ Pre-calculate image background color where necessary.
+ * xterm.c (x_setup_relief_colors): Use `IMAGE_BACKGROUND' and
+ `IMAGE_BACKGROUND_TRANSPARENT' to calculate the correct background
+ color to use for image glyph reliefs.
+
+2001-10-24 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_draw_glyphs): Don't check for cursor overwriting
+ in full-width rows.
+
+ * xterm.c (XTset_vertical_scroll_bar) [!USE_TOOLKIT_SCROLL_BARS]:
+ Fix clearing of area not covered by scroll bar.
+
+2001-10-24 Pavel Jan,Am(Bk <[email protected]>
+
+ * xterm.c (x_insert_glyphs): Remove unused variables `real_end'
+ and `real_start'.
+ (x_draw_image_foreground): Remove unused variables `mask' and `xgcv'.
+ (glyph_rect): Remove unused variable `area'.
+
+2001-10-24 Gerd Moellmann <[email protected]>
+
+ * xdisp.c: Change #ifdef GLYPH_DEBUG to #if.
+
+ * xdisp.c (try_window_reusing_current_matrix): Use row_containing_pos.
+ (row_containing_pos): Take additional argument DY.
+ Treat rows ending in middle of char differently.
+ (display_line): Handle tabs on window systems differently.
+
+ * xterm.c, w32term.c (fast_find_position): Call row_containing_pos
+ with additional argument.
+
+ * dispextern.h (row_containing_pos): Adjust prototype.
+
+ * xdisp.c (inhibit_try_window_id, inhibit_try_window_reusing)
+ (inhibit_try_cursor_movement) [GLYPH_DEBUG]: New variables.
+ (try_window_id, try_window_reusing_current_matrix)
+ (try_cursor_movement) [GLYPH_DEBUG]: Don't run if inhibited.
+ (syms_of_xdisp) [GLYPH_DEBUG]: DEFVAR_BOOL the variables.
+
+2001-10-24 Pavel Jan,Am(Bk <[email protected]>
+
+ * xmenu.c: Spell the name of Emacs properly (GNU Emacs instead of
+ gnuemacs).
+ (HAVE_BOXES): Fix typo in comment.
+ (push_menu_pane): Fix typo in comment.
+
+ * xdisp.c (display_prop_string_p): Remove unused local declaration
+ of `Qwhen'.
+ (single_display_prop_string_p): Remove unused local declarations
+ of `Qwhen' and `Qmargin'.
+ (string_buffer_position): Remove unused variable `around'.
+ (store_frame_title): Remove unused variable `width'.
+
+ * window.c: Don't define max.
+ (coordinates_in_window): Remove unused variable `uy'.
+
+ * widget.c: Don't define max.
+
+ * process.c: Don't define max.
+ (create_process): Remove unused variable `buffer'.
+
+2001-10-23 Gerd Moellmann <[email protected]>
+
+ * xfaces.c (Finternal_set_lisp_face_attribute): Fix compilation error.
+
+2001-10-23 Eli Zaretskii <[email protected]>
+
+ * xfaces.c (Finternal_set_lisp_face_attribute)
+ [HAVE_WINDOW_SYSTEM]: Don't do anything for QCfont unless the
+ frame is on a windowed display.
+
+2001-10-23 Gerd Moellmann <[email protected]>
+
+ * dispnew.c (sync_window_with_frame_matrix_rows):
+ Fix handling of windows which aren't full-width, fix handling
+ of marginal areas.
+
+ * lread.c (syms_of_lread) <recursive-load-depth-limit>: Raise to 50.
+
+2001-10-23 Andreas Schwab <[email protected]>
+
+ * m/macppc.h [LINUX]: Undef LD_SWITCH_SYSTEM_TEMACS and override
+ LD_SWITCH_MACHINE_TEMACS with "-Xlinker -znocombreloc".
+
+2001-10-23 Gerd Moellmann <[email protected]>
+
+ * xterm.c (x_draw_glyphs): Remove parameters READ_START and
+ REAL_END. Notice if cursor gets overwritten.
+ (notice_overwritten_cursor): Take X positions as parameters.
+ (x_draw_phys_cursor_glyph): Save state of w->phys_cursor_on_p
+ around call to x_draw_glyphs.
+
+2001-10-23 Pavel Jan,Am(Bk <[email protected]>
+
+ * syntax.c (modify-syntax-entry): Fix argument names (use CHAR
+ instead of C) and usage.
+
+ * editfns.c (char-to-string): Fix argument names (use CHAR instead
+ of C) and usage.
+
+ * xfns.c (Fx_show_tip): Remove unused variables `buffer', `top',
+ `left', `max_width' and `max_height'.
+
+2001-10-23 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (display_line): For a tab continued to the next line,
+ set row's ends_in_middle_of_char_p.
+
+2001-10-22 Gerd Moellmann <[email protected]>
+
+ * xdisp.c (display_line): Fix computation of continuation lines
+ width for TABs.
+
+2001-10-22 Pavel Jan,Am(Bk <[email protected]>
+
+ * xdisp.c (build_desired_tool_bar_string): Remove unused variable
+ `Qlaplace'.
+
+ * fileio.c: Remove unused code.
+
+2001-10-22 Miles Bader <[email protected]>
+
+ * lisp.h (DEFVAR_LISP, DEFVAR_LISP_NOPRO, DEFVAR_BOOL)
+ (DEFVAR_INT, DEFVAR_PER_BUFFER, DEFVAR_KBOARD):
+ Remove `DOC_STRINGS_IN_COMMENTS' cases.
+
+2001-10-21 Jason Rumney <[email protected]>
+
+ * w32term.c (x_erase_phys_cursor): Remove inverse_p again.
+
+2001-10-21 Eli Zaretskii <[email protected]>
+
+ * mocklisp.c (Fml_if, Fml_provide_prefix_argument)
+ (Finsert_string): Avoid the multi-line string literals warning.
+
+2001-10-22 Miles Bader <[email protected]>
+
+ * doc.c (Vhelp_manyarg_func_alist): Variable removed.
+ (Fdocumentation): Don't use it.
+ (syms_of_doc): Don't initialize it.
+
+ * keyboard.c (Ftrack_mouse): Add usage: string to doc string.
+ * print.c (Fwith_output_to_temp_buffer): Likewise.
+ * window.c (Fsave_window_excursion): Likewise.
+ * editfns.c (Fsave_excursion, Fsave_current_buffer)
+ (Fsave_restriction): Likewise.
+ * eval.c (Frun_hooks, Frun_hook_with_args)
+ (Frun_hook_with_args_until_failure)
+ (Frun_hook_with_args_until_success, Ffuncall, For, Fand, Fif)
+ (Fcond, Fprogn, Fprog1, Fprog2, Fsetq, Fquote, Ffunction, Fdefun)
+ (Fdefmacro, Fdefvar, Fdefconst, FletX, Flet, Fwhile, Fcatch)
+ (Funwind_protect, Fcondition_case): Likewise.
+ * coding.c (Ffind_operation_coding_system): Likewise.
+ * keyboard.c (Ftrack_mouse): Likewise.
+
+2001-10-21 Miles Bader <[email protected]>
+
+ * fns.c (Fappend, Fconcat, Fvconcat, Fnconc, Fwidget_apply)
+ (Fmake_hash_table): Add usage: string to doc string.
+ * editfns.c (Finsert, Finsert_and_inherit, Finsert_before_markers)
+ (Fmessage, Fmessage_box, Fmessage_or_box, Fpropertize, Fformat)
+ (Fencode_time, Finsert_and_inherit_before_markers): Likewise.
+ * mocklisp.c (Finsert_string, Fml_if, Fml_provide_prefix_argument)
+ (Fml_prefix_argument_loop): Likewise.
+
+2001-10-21 Pavel Jan,Am(Bk <[email protected]>
+
+ * fileio.c (Finsert_file_contents): Remove unused variable `gap_size'.
+
+ * sysdep.c (init_sys_modes): Change doc-string comments to `new
+ style' [w/`doc:' keyword].
+
+ * data.c, fileio.c, indent.c, print.c, search.c, sound.c,
+ * sunfns.c, textprop.c, undo.c, xselect.c: Change doc-string
+ comments to `new style' [w/`doc:' keyword].
+
+2001-10-21 Jason Rumney <[email protected]>
+
+ * w32fns.c (Fx_file_dialog): Pass a filter to GetOpenFileName.
+
+ * w32term.c (remember_mouse_glyph): New function.
+ (w32_mouse_position): Use it.
+ (note_mouse_movement): If the mouse moved off the glyph, remember
+ its new position.
+
+ * w32term.h (struct w32_output): Correct spelling of x_compatible.
+ (w32_display_info): Add mouse_face_overlay.
+
+ * w32term.c (notice_overwritten_cursor): Renamed from
+ note_overwritten_text_cursor. Rewritten to take glyph widths into
+ account.
+ (x_y_to_hpos_vpos): Add parameter BUFFER_ONLY_P.
+ (fast_find_string_pos): New function.
+ (fast_find_position): Return the correct vpos. Add parameter
+ STOP. In the final row, stop before glyphs having STOP as object.
+ Don't consider glyphs that are not from a buffer.
+ (fast_find_position) [0]: Add a presumably more correct version
+ for after 21.1.
+ (expose_window_tree, expose_frame): Don't compute intersections here.
+ (expose_window): Do it here instead.
+ (expose_window_tree, expose_window, expose_line): Return 1 when
+ overwriting mouse-face.
+ (expose_window): If W is the window currently being updated, mark
+ the frame garbaged.
+ (expose_frame): If mouse-face was overwritten, redo it.
+ (x_use_underline_position_properties): New variable.
+ (syms_of_xterm): DEFVAR_BOOL it.
+ (x_draw_glyph_string): Add comment to use it in future.
+ (x_draw_glyph_string): Restore clipping after drawing box.
+ Fix a computation of the underline position.
+ (w32_get_glyph_string_clip_rect): Minor cleanup.
+ (x_fill_stretch_glyph_string): Remove an assertion.
+ (x_produce_glyphs): Don't convert multibyte characters
+ to unibyte characters in unibyte buffers.
+ (cursor_in_mouse_face_p): New function.
+ (x_draw_stretch_glyph_string): Use it to choose a different GC
+ when drawing a cursor within highlighted text. Don't draw
+ background again if it has already been drawn.
+ (x_draw_glyph_string_box): Don't draw a full-width
+ box just because the glyph row's full_width_p flag is set.
+ (x_draw_glyphs): Fix computation of rightmost x for
+ full-width rows.
+ (x_dump_glyph_string): Put in #if GLYPH_DEBUG.
+ (w32_draw_relief_rect): Extend left shadow to the bottom and left;
+ change bottom shadow accordingly. Some cleanup.
+ (x_update_window_end): Handle overwritten mouse face
+ also for tool bar windows.
+ (show_mouse_face): Set the glyph row's mouse_face_p flag also when
+ DRAW is DRAW_IMAGE_RAISED.
+ (clear_mouse_face): Return 1 if text with mouse face was
+ actually redrawn. Make the function static.
+ Reset dpyinfo->mouse_face_overlay otherwise note_mouse_highlight might
+ optimize away highlighting if we pass over that same overlay again.
+ (note_mouse_highlight): Call mouse_face_overlay_overlaps
+ to detect a case where we have to highlight a different region
+ despite not having left the currently highlighted region.
+ Set mouse_face_overlay in the x_display_info. Avoid changing the
+ mouse pointer shape when show_mouse_face has already done it, or
+ there is no need. Handle mouse-face and help-echo in strings.
+ (glyph_rect): New function.
+ (w32_mouse_position): Use it to raise the threshold for mouse
+ movement event generation.
+ (w32_initialize_display_info): Initialize the x_display_info's
+ mouse_face_overlay.
+ (w32_set_vertical_scroll_bar): Don't clear a zero height
+ or width area.
+ (w32_set_vertical_scroll_bar, x_scroll_bar_create): Don't configure
+ a widget to zero height.
+
+ * w32menu.c (single_submenu, w32_menu_show) [!HAVE_MULTILINGUAL_MENU]:
+ Protect unibyte strings created by replacing their multibyte
+ equivalents in menu_items.
+ (w32_menu_show): Don't overwrite an item's name with its key
+ description in case the description is a multibyte string.
+ (single_submenu): Some cleanup.
+
+ * w32fns.c (x_laplace_read_row, x_laplace_write_row): Removed.
+ (postprocess_image): New function.
+ (lookup_image): Call it for all image types except PostScript.
+ (x_kill_gs_process): Call postprocess_image.
+ (tiff_error_handler, tiff_warning_handler): New functions.
+ (tiff_load): Install them as handlers.
+ (x_kill_gs_process): Recognize if someone has cleared the image
+ cache under us.
+ (valid_image_p): Protect better against invalid image
+ specifications. Previous code could signal an error.
+ (Fx_hide_tip, Fshow_tip): Doc fix.
+ (Fv_max_tooltip_size): New variable.
+ (syns_of_xfns): DEFVAR_LISP it.
+ (Fx_show_tip): Add parameter TEXT. Set the tip frame's root
+ window buffer to *tip* right after creating the frame. Set frame's
+ window_width. Use a maximum tooltip size specified by
+ Vx_max_tooltip_size, if that has valid contents.
+ (compute_tip_xy): Add parameters WIDTH and HEIGHT.
+ Make sure the tooltip is completely visible.
+ (x_create_tip_frame): Set tooltip buffer's truncate-lines to nil.
+ (Fx_create_frame): Adjust the frame's height for presence
+ of the tool bar before calling x_figure_window_size.
+ (x_set_tool_bar_lines): Clear the tool bar window's current matrix
+ when the window gets smaller.
+ (x_set_foreground_color): Set frame's cursor_pixel.
+ (x_set_foreground_color, x_set_background_color): Cleaned up.
+ (x_set_font): Handle case of x_new_fontset returning the same name
+ as before, although there was a change in fontsets.
+
+2001-10-21 Miles Bader <[email protected]>
+
+ * data.c (Fplus, Fminus, Fmax, Ftimes, Fquo, Flogand, Flogior)
+ (Flogxor): Add usage: string to doc string.
+ * charset.c (Fstring): Likewise.
+ * callproc.c (Fcall_process_region, Fcall_process): Likewise.
+ * alloc.c (Fmake_byte_code, Fvector, Flist): Likewise.
+
+2001-10-21 Pavel Jan,Am(Bk <[email protected]>
+
+ * buffer.c: Reindent DEFUNs and DEFVARs with doc: keywords.
+
+ * alloc.c: Reindent DEFUNs with doc: keywords.
+
+ * abbrev.c (Finsert_abbrev_table_description): Reindent.
+
+ * frame.c: Change doc-string comments to `new style' [w/`doc:'
+ keyword].
+
+See ChangeLog.9 for earlier changes.
+
+;; Local Variables:
+;; coding: iso-2022-7bit
+;; add-log-time-zone-rule: t
+;; End:
+
+ Copyright (C) 2001, 2002, 2003, 2004, 2005,
+ 2006, 2007 Free Software Foundation, Inc.
+
+ This file is part of GNU Emacs.
+
+ GNU Emacs is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 3, or (at your option)
+ any later version.
+
+ GNU Emacs is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with GNU Emacs; see the file COPYING. If not, write to the
+ Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ Boston, MA 02110-1301, USA.
+
+;;; arch-tag: 5dcc435f-4038-4141-b3bf-5be51cd76bd4
diff --git a/src/Makefile.in b/src/Makefile.in
index 217e9846e2..f968fcf459 100644
--- a/src/Makefile.in
+++ b/src/Makefile.in
@@ -76,12 +76,6 @@ SHELL=/bin/sh
#define NOT_C_CODE
#include "config.h"
-/* We will not really call alloca;
- do not let the file name alloca.c get messed up. */
-#ifdef alloca
-#undef alloca
-#endif
-
/* Do not let the file name mktime.c get messed up. */
#ifdef mktime
#undef mktime
@@ -613,7 +607,7 @@ FONTOBJ = font.o
whose initialized data areas should be dumped as pure by dump-emacs. */
obj= dispnew.o frame.o scroll.o xdisp.o $(XMENU_OBJ) window.o \
charset.o coding.o category.o ccl.o character.o chartab.o \
- cm.o term.o xfaces.o $(XOBJ) $(GTK_OBJ)\
+ cm.o term.o terminal.o xfaces.o $(XOBJ) $(GTK_OBJ)\
emacs.o keyboard.o macros.o keymap.o sysdep.o \
buffer.o filelock.o insdel.o marker.o \
minibuf.o fileio.o dired.o filemode.o \
@@ -668,12 +662,6 @@ mallocobj = $(gmallocobj) $(rallocobj) vm-limit.o
#endif /* SYSTEM_MALLOC */
-#ifndef HAVE_ALLOCA
-allocaobj = alloca.o
-#else
-allocaobj =
-#endif
-
#ifdef USE_X_TOOLKIT
widgetobj= widget.o
#else /* not USE_X_TOOLKIT */
@@ -685,9 +673,9 @@ widgetobj=
should not be told about. */
#ifdef CYGWIN
/* Cygwin differs because of its unexec(). */
-otherobj= $(termcapobj) $(gmallocobj) $(rallocobj) lastfile.o vm-limit.o $(allocaobj) $(widgetobj) $(LIBOBJS)
+otherobj= $(termcapobj) $(gmallocobj) $(rallocobj) lastfile.o vm-limit.o $(widgetobj) $(LIBOBJS)
#else
-otherobj= $(termcapobj) lastfile.o $(mallocobj) $(allocaobj) $(widgetobj) $(LIBOBJS)
+otherobj= $(termcapobj) lastfile.o $(mallocobj) $(widgetobj) $(LIBOBJS)
#endif
#ifdef HAVE_MOUSE
@@ -946,7 +934,9 @@ SOME_MACHINE_LISP = ${dotdot}/lisp/mouse.elc \
${dotdot}/lisp/x-dnd.elc \
${dotdot}/lisp/international/ccl.elc \
${dotdot}/lisp/international/codepage.elc \
- ${dotdot}/lisp/international/fontset.elc
+ ${dotdot}/lisp/international/fontset.elc \
+ ${dotdot}/lisp/mouse.elc \
+ ${dotdot}/lisp/term/x-win.elc
/* Construct full set of libraries to be linked.
Note that SunOS needs -lm to come before -lc; otherwise, you get
@@ -1106,12 +1096,6 @@ stamp-oldxmenu:
@echo "Please run the `configure' script again."
exit 1
-/* Some machines have alloca built-in.
- They should define HAVE_ALLOCA.
- Some use the C version in alloca.c (these define C_ALLOCA in config.h).
- */
-alloca.o: alloca.c blockinput.h atimer.h systime.h
-
/* Nearly all the following files depend on lisp.h,
but it is not included as a dependency because
it is so often changed in ways that do not require any recompilation
@@ -1126,7 +1110,7 @@ callint.o: callint.c window.h commands.h buffer.h keymap.h \
keyboard.h dispextern.h $(config_h)
callproc.o: callproc.c epaths.h buffer.h commands.h $(config_h) \
process.h systty.h syssignal.h character.h coding.h ccl.h msdos.h \
- composite.h w32.h blockinput.h atimer.h systime.h
+ composite.h w32.h blockinput.h atimer.h systime.h frame.h termhooks.h
casefiddle.o: casefiddle.c syntax.h commands.h buffer.h character.h \
composite.h \
charset.h keymap.h $(config_h)
@@ -1140,8 +1124,8 @@ charset.o: charset.c charset.h character.h buffer.h coding.h composite.h \
disptab.h $(config_h)
chartab.o: charset.h character.h $(config.h)
coding.o: coding.c coding.h ccl.h buffer.h character.h charset.h intervals.h composite.h \
- window.h dispextern.h $(config_h)
-cm.o: cm.c cm.h termhooks.h $(config_h)
+ window.h dispextern.h frame.h termhooks.h $(config_h)
+cm.o: cm.c frame.h cm.h termhooks.h termchar.h $(config_h)
cmds.o: cmds.c syntax.h buffer.h character.h commands.h window.h $(config_h) \
msdos.h dispextern.h keyboard.h keymap.h
pre-crt0.o: pre-crt0.c
@@ -1171,13 +1155,13 @@ filelock.o: filelock.c buffer.h character.h charset.h coding.h systime.h \
filemode.o: filemode.c $(config_h)
frame.o: frame.c xterm.h window.h frame.h termhooks.h commands.h keyboard.h \
blockinput.h atimer.h systime.h buffer.h character.h fontset.h \
- msdos.h dosfns.h dispextern.h w32term.h macterm.h $(config_h)
-fringe.o: fringe.c dispextern.h frame.h window.h buffer.h $(config_h)
+ msdos.h dosfns.h dispextern.h w32term.h macterm.h termchar.h $(config_h)
+fringe.o: fringe.c dispextern.h frame.h window.h buffer.h termhook.h $(config_h)
font.o: font.c dispextern.h frame.h window.h ccl.h character.h charset.h \
font.h $(config_h)
ftfont.o: dispextern.h frame.h character.h charset.h font.h $(config_h)
fontset.o: dispextern.h fontset.h fontset.c ccl.h buffer.h character.h \
- charset.h frame.h keyboard.h $(FONTSRC) $(config_h)
+ charset.h frame.h keyboard.h termhooks.h $(FONTSRC) $(config_h)
getloadavg.o: getloadavg.c $(config_h)
image.o: image.c frame.h window.h dispextern.h blockinput.h atimer.h \
systime.h xterm.h w32term.h w32gui.h macterm.h macgui.h $(config_h)
@@ -1188,7 +1172,7 @@ insdel.o: insdel.c window.h buffer.h $(INTERVAL_SRC) blockinput.h character.h \
dispextern.h atimer.h systime.h region-cache.h $(config_h)
keyboard.o: keyboard.c termchar.h termhooks.h termopts.h buffer.h character.h \
commands.h frame.h window.h macros.h disptab.h keyboard.h syssignal.h \
- systty.h systime.h dispextern.h syntax.h $(INTERVAL_SRC) blockinput.h \
+ systime.h dispextern.h syntax.h $(INTERVAL_SRC) blockinput.h \
atimer.h xterm.h puresize.h msdos.h keymap.h w32term.h macterm.h $(config_h)
keymap.o: keymap.c buffer.h commands.h keyboard.h termhooks.h blockinput.h \
atimer.h systime.h puresize.h character.h intervals.h keymap.h window.h \
@@ -1203,7 +1187,8 @@ vm-limit.o: vm-limit.c mem-limits.h $(config_h)
marker.o: marker.c buffer.h character.h $(config_h)
md5.o: md5.c md5.h $(config_h)
minibuf.o: minibuf.c syntax.h dispextern.h frame.h window.h keyboard.h \
- buffer.h commands.h character.h msdos.h $(INTERVAL_SRC) keymap.h $(config_h)
+ buffer.h commands.h character.h msdos.h $(INTERVAL_SRC) keymap.h \
+ terhooks.h $(config_h)
mktime.o: mktime.c $(config_h)
msdos.o: msdos.c msdos.h dosfns.h systime.h termhooks.h dispextern.h frame.h \
termopts.h termchar.h character.h coding.h ccl.h disptab.h window.h \
@@ -1216,7 +1201,7 @@ regex.o: regex.c syntax.h buffer.h $(config_h) regex.h category.h character.h \
charset.h
region-cache.o: region-cache.c buffer.h region-cache.h $(config_h)
scroll.o: scroll.c termchar.h dispextern.h frame.h msdos.h keyboard.h \
- $(config_h)
+ termhooks.h $(config_h)
search.o: search.c regex.h commands.h buffer.h region-cache.h syntax.h \
blockinput.h atimer.h systime.h category.h character.h charset.h \
composite.h $(INTERVAL_SRC) \
@@ -1226,11 +1211,13 @@ syntax.o: syntax.c syntax.h buffer.h commands.h category.h character.h \
composite.h keymap.h regex.h $(INTERVAL_SRC) $(config_h)
sysdep.o: sysdep.c syssignal.h systty.h systime.h syswait.h blockinput.h \
process.h dispextern.h termhooks.h termchar.h termopts.h \
- frame.h atimer.h window.h msdos.h dosfns.h keyboard.h $(config_h)
+ frame.h atimer.h window.h msdos.h dosfns.h keyboard.h cm.h $(config_h)
term.o: term.c termchar.h termhooks.h termopts.h $(config_h) cm.h frame.h \
disptab.h dispextern.h keyboard.h character.h charset.h coding.h ccl.h \
msdos.h window.h keymap.h blockinput.h atimer.h systime.h
termcap.o: termcap.c $(config_h)
+terminal.o: terminal.c frame.h termchar.h termhooks.h charset.h coding.h \
+ keyboard.h $(config_h)
terminfo.o: terminfo.c $(config_h)
tparam.o: tparam.c $(config_h)
undo.o: undo.c buffer.h commands.h window.h $(config_h)
@@ -1243,7 +1230,7 @@ w16select.o: w16select.c dispextern.h frame.h blockinput.h atimer.h systime.h \
widget.o: widget.c xterm.h frame.h dispextern.h widgetprv.h \
$(srcdir)/../lwlib/lwlib.h $(config_h)
window.o: window.c indent.h commands.h frame.h window.h buffer.h termchar.h \
- termhooks.h disptab.h keyboard.h dispextern.h msdos.h composite.h \
+ disptab.h keyboard.h dispextern.h msdos.h composite.h \
keymap.h blockinput.h atimer.h systime.h $(INTERVAL_SRC) \
xterm.h w32term.h macterm.h $(config_h)
xdisp.o: xdisp.c macros.h commands.h process.h indent.h buffer.h dispextern.h \
@@ -1254,11 +1241,11 @@ xdisp.o: xdisp.c macros.h commands.h process.h indent.h buffer.h dispextern.h \
xfaces.o: xfaces.c dispextern.h frame.h xterm.h buffer.h blockinput.h \
window.h character.h charset.h msdos.h dosfns.h composite.h atimer.h \
systime.h keyboard.h fontset.h w32term.h macterm.h $(INTERVAL_SRC) \
- $(FONTSRC) $(config_h)
+ termchar.h termhooks.h $(FONTSRC) $(config_h)
xfns.o: xfns.c buffer.h frame.h window.h keyboard.h xterm.h dispextern.h \
$(srcdir)/../lwlib/lwlib.h blockinput.h atimer.h systime.h epaths.h \
character.h charset.h coding.h gtkutil.h $(config_h) termhooks.h \
- fontset.h $(FONTSRC)
+ fontset.h termchar.h $(FONTSRC)
xfont.o: dispextern.h xterm.h frame.h blockinput.h character.h charset.h \
font.h $(config_h)
xftfont.o: dispextern.h xterm.h frame.h blockinput.h character.h charset.h \
@@ -1273,7 +1260,7 @@ xterm.o: xterm.c xterm.h termhooks.h termopts.h termchar.h window.h buffer.h \
keyboard.h gnu.h character.h charset.h ccl.h fontset.h composite.h \
coding.h process.h gtkutil.h $(FONTSRC) $(config_h)
xselect.o: xselect.c process.h dispextern.h frame.h xterm.h blockinput.h \
- buffer.h atimer.h systime.h $(config_h)
+ buffer.h atimer.h systime.h termhooks.h $(config_h)
xrdb.o: xrdb.c $(config_h) epaths.h
xsmfns.o: xsmfns.c $(config_h) systime.h sysselect.h termhooks.h xterm.h \
lisp.h termopts.h
@@ -1293,13 +1280,13 @@ alloc.o: alloc.c process.h frame.h window.h buffer.h puresize.h syssignal.h key
bytecode.o: bytecode.c buffer.h syntax.h character.h window.h dispextern.h \
frame.h xterm.h $(config_h)
data.o: data.c buffer.h puresize.h character.h syssignal.h keyboard.h frame.h \
- $(config_h)
+ termhooks.h $(config_h)
eval.o: eval.c commands.h keyboard.h blockinput.h atimer.h systime.h \
dispextern.h $(config_h)
floatfns.o: floatfns.c $(config_h)
fns.o: fns.c commands.h $(config_h) frame.h buffer.h character.h keyboard.h \
keymap.h frame.h window.h dispextern.h $(INTERVAL_SRC) coding.h md5.h \
- blockinput.h atimer.h systime.h xterm.h
+ blockinput.h atimer.h systime.h xterm.h termhooks.h
print.o: print.c process.h frame.h window.h buffer.h keyboard.h character.h \
$(config_h) dispextern.h termchar.h $(INTERVAL_SRC) msdos.h composite.h \
blockinput.h atimer.h systime.h
@@ -1318,12 +1305,12 @@ composite.o: composite.c buffer.h character.h $(INTERVAL_SRC) $(config_h)
OTHER_FILES and OBJECTS_MACHINE
select which of these should be compiled. */
-sunfns.o: sunfns.c buffer.h window.h dispextern.h $(config_h)
+sunfns.o: sunfns.c buffer.h window.h dispextern.h termhooks.h $(config_h)
#ifdef HAVE_CARBON
abbrev.o buffer.o callint.o cmds.o dispnew.o editfns.o fileio.o frame.o \
fontset.o indent.o insdel.o keyboard.o macros.o minibuf.o msdos.o process.o \
- scroll.o sysdep.o term.o widget.o window.o xdisp.o xfaces.o xfns.o xmenu.o \
+ scroll.o sysdep.o term.o terminal.o widget.o window.o xdisp.o xfaces.o xfns.o xmenu.o \
xterm.o xselect.o sound.o: macgui.h
mac.o: mac.c process.h sysselect.h blockinput.h atimer.h systime.h charset.h \
coding.h ccl.h $(config_h)
@@ -1364,8 +1351,6 @@ ${emacsapp}Contents/MacOS/Emacs: emacs${EXEEXT}
cd ${emacsapp}Contents/MacOS/; cp ../../../../src/emacs${EXEEXT} Emacs${EXEEXT}
#endif
-${libsrc}emacstool${EXEEXT}: ${libsrc}emacstool.c
- cd ${libsrc}; ${MAKE} ${MFLAGS} emacstool${EXEEXT}
bootstrapclean:
rm -f bootstrap-emacs${EXEEXT} emacs-${version}${EXEEXT}
mostlyclean:
@@ -1391,17 +1376,6 @@ versionclean:
extraclean: distclean
-rm -f *~ \#* m/?*~ s/?*~
-/* The rule for the [sm] files has to be written a little funny to
- avoid looking like a C comment to CPP. */
-SOURCES = *.[ch] [sm]/?* COPYING Makefile.in \
- config.in epaths.in README COPYING ChangeLog vms.pp-trans
-unlock:
- chmod u+w $(SOURCES)
-
-relock:
- chmod -w $(SOURCES)
- chmod +w epaths.h
-
/* Arrange to make a tags table TAGS-LISP for ../lisp,
plus TAGS for the C files, which includes ../lisp/TAGS by reference. */
diff --git a/src/abbrev.c b/src/abbrev.c
index a58c4ecbfb..bed7f73d1c 100644
--- a/src/abbrev.c
+++ b/src/abbrev.c
@@ -775,9 +775,6 @@ Calling `expand-abbrev' sets this to nil. */);
Trying to expand an abbrev in any other buffer clears `abbrev-start-location'. */);
Vabbrev_start_location_buffer = Qnil;
- DEFVAR_PER_BUFFER ("local-abbrev-table", &current_buffer->abbrev_table, Qnil,
- doc: /* Local (mode-specific) abbrev table of current buffer. */);
-
DEFVAR_BOOL ("abbrevs-changed", &abbrevs_changed,
doc: /* Set non-nil by defining or altering any word abbrevs.
This causes `save-some-buffers' to offer to save the abbrevs. */);
diff --git a/src/alloc.c b/src/alloc.c
index 2e88afc00a..fccdf2a88a 100644
--- a/src/alloc.c
+++ b/src/alloc.c
@@ -55,6 +55,7 @@ Boston, MA 02110-1301, USA. */
#include "blockinput.h"
#include "character.h"
#include "syssignal.h"
+#include "termhooks.h" /* For struct terminal. */
#include <setjmp.h>
/* GC_MALLOC_CHECK defined means perform validity checks of malloc'd
@@ -341,7 +342,9 @@ Lisp_Object Vgc_elapsed; /* accumulated elapsed time in GC */
EMACS_INT gcs_done; /* accumulated GCs */
static void mark_buffer P_ ((Lisp_Object));
+static void mark_terminals P_ ((void));
extern void mark_kboards P_ ((void));
+extern void mark_ttys P_ ((void));
extern void mark_backtrace P_ ((void));
static void gc_sweep P_ ((void));
static void mark_glyph_matrix P_ ((struct glyph_matrix *));
@@ -373,14 +376,11 @@ enum mem_type
MEM_TYPE_MISC,
MEM_TYPE_SYMBOL,
MEM_TYPE_FLOAT,
- /* Keep the following vector-like types together, with
- MEM_TYPE_WINDOW being the last, and MEM_TYPE_VECTOR the
- first. Or change the code of live_vector_p, for instance. */
- MEM_TYPE_VECTOR,
- MEM_TYPE_PROCESS,
- MEM_TYPE_HASH_TABLE,
- MEM_TYPE_FRAME,
- MEM_TYPE_WINDOW
+ /* We used to keep separate mem_types for subtypes of vectors such as
+ process, hash_table, frame, terminal, and window, but we never made
+ use of the distinction, so it only caused source-code complexity
+ and runtime slowdown. Minor but pointless. */
+ MEM_TYPE_VECTORLIKE
};
static POINTER_TYPE *lisp_align_malloc P_ ((size_t, enum mem_type));
@@ -467,7 +467,7 @@ static struct mem_node mem_z;
#define MEM_NIL &mem_z
static POINTER_TYPE *lisp_malloc P_ ((size_t, enum mem_type));
-static struct Lisp_Vector *allocate_vectorlike P_ ((EMACS_INT, enum mem_type));
+static struct Lisp_Vector *allocate_vectorlike P_ ((EMACS_INT));
static void lisp_free P_ ((POINTER_TYPE *));
static void mark_stack P_ ((void));
static int live_vector_p P_ ((struct mem_node *, void *));
@@ -743,6 +743,15 @@ overrun_check_free (block)
#define free overrun_check_free
#endif
+#ifdef SYNC_INPUT
+/* When using SYNC_INPUT, we don't call malloc from a signal handler, so
+ there's no need to block input around malloc. */
+#define MALLOC_BLOCK_INPUT ((void)0)
+#define MALLOC_UNBLOCK_INPUT ((void)0)
+#else
+#define MALLOC_BLOCK_INPUT BLOCK_INPUT
+#define MALLOC_UNBLOCK_INPUT UNBLOCK_INPUT
+#endif
/* Like malloc but check for no memory and block interrupt input.. */
@@ -752,9 +761,9 @@ xmalloc (size)
{
register POINTER_TYPE *val;
- BLOCK_INPUT;
+ MALLOC_BLOCK_INPUT;
val = (POINTER_TYPE *) malloc (size);
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
if (!val && size)
memory_full ();
@@ -771,14 +780,14 @@ xrealloc (block, size)
{
register POINTER_TYPE *val;
- BLOCK_INPUT;
+ MALLOC_BLOCK_INPUT;
/* We must call malloc explicitly when BLOCK is 0, since some
reallocs don't do this. */
if (! block)
val = (POINTER_TYPE *) malloc (size);
else
val = (POINTER_TYPE *) realloc (block, size);
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
if (!val && size) memory_full ();
return val;
@@ -791,9 +800,9 @@ void
xfree (block)
POINTER_TYPE *block;
{
- BLOCK_INPUT;
+ MALLOC_BLOCK_INPUT;
free (block);
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
/* We don't call refill_memory_reserve here
because that duplicates doing so in emacs_blocked_free
and the criterion should go there. */
@@ -844,7 +853,7 @@ lisp_malloc (nbytes, type)
{
register void *val;
- BLOCK_INPUT;
+ MALLOC_BLOCK_INPUT;
#ifdef GC_MALLOC_CHECK
allocated_mem_type = type;
@@ -874,7 +883,7 @@ lisp_malloc (nbytes, type)
mem_insert (val, (char *) val + nbytes, type);
#endif
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
if (!val && nbytes)
memory_full ();
return val;
@@ -887,12 +896,12 @@ static void
lisp_free (block)
POINTER_TYPE *block;
{
- BLOCK_INPUT;
+ MALLOC_BLOCK_INPUT;
free (block);
#if GC_MARK_STACK && !defined GC_MALLOC_CHECK
mem_delete (mem_find (block));
#endif
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
}
/* Allocation of aligned blocks of memory to store Lisp data. */
@@ -993,7 +1002,7 @@ lisp_align_malloc (nbytes, type)
eassert (nbytes <= BLOCK_BYTES);
- BLOCK_INPUT;
+ MALLOC_BLOCK_INPUT;
#ifdef GC_MALLOC_CHECK
allocated_mem_type = type;
@@ -1025,7 +1034,7 @@ lisp_align_malloc (nbytes, type)
if (base == 0)
{
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
memory_full ();
}
@@ -1051,7 +1060,7 @@ lisp_align_malloc (nbytes, type)
{
lisp_malloc_loser = base;
free (base);
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
memory_full ();
}
}
@@ -1084,7 +1093,7 @@ lisp_align_malloc (nbytes, type)
mem_insert (val, (char *) val + nbytes, type);
#endif
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
if (!val && nbytes)
memory_full ();
@@ -1099,7 +1108,7 @@ lisp_align_free (block)
struct ablock *ablock = block;
struct ablocks *abase = ABLOCK_ABASE (ablock);
- BLOCK_INPUT;
+ MALLOC_BLOCK_INPUT;
#if GC_MARK_STACK && !defined GC_MALLOC_CHECK
mem_delete (mem_find (block));
#endif
@@ -1132,7 +1141,7 @@ lisp_align_free (block)
#endif
free (ABLOCKS_BASE (abase));
}
- UNBLOCK_INPUT;
+ MALLOC_UNBLOCK_INPUT;
}
/* Return a new buffer structure allocated from the heap with
@@ -1161,6 +1170,8 @@ allocate_buffer ()
can use GNU malloc. */
#ifndef SYNC_INPUT
+/* When using SYNC_INPUT, we don't call malloc from a signal handler, so
+ there's no need to block input around malloc. */
#ifndef DOUG_LEA_MALLOC
extern void * (*__malloc_hook) P_ ((size_t, const void *));
@@ -1234,7 +1245,8 @@ emacs_blocked_malloc (size, ptr)
BLOCK_INPUT_ALLOC;
__malloc_hook = old_malloc_hook;
#ifdef DOUG_LEA_MALLOC
- mallopt (M_TOP_PAD, malloc_hysteresis * 4096);
+ /* Segfaults on my system. --lorentey */
+ /* mallopt (M_TOP_PAD, malloc_hysteresis * 4096); */
#else
__malloc_extra_blocks = malloc_hysteresis;
#endif
@@ -1340,9 +1352,9 @@ emacs_blocked_realloc (ptr, size, ptr2)
void
reset_malloc_hooks ()
{
- __free_hook = 0;
- __malloc_hook = 0;
- __realloc_hook = 0;
+ __free_hook = old_free_hook;
+ __malloc_hook = old_malloc_hook;
+ __realloc_hook = old_realloc_hook;
}
#endif /* HAVE_GTK_AND_PTHREAD */
@@ -1444,9 +1456,7 @@ make_interval ()
/* eassert (!handling_signal); */
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
+ MALLOC_BLOCK_INPUT;
if (interval_free_list)
{
@@ -1470,9 +1480,7 @@ make_interval ()
val = &interval_block->intervals[interval_block_index++];
}
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
consing_since_gc += sizeof (struct interval);
intervals_consed++;
@@ -1875,9 +1883,7 @@ allocate_string ()
/* eassert (!handling_signal); */
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
+ MALLOC_BLOCK_INPUT;
/* If the free-list is empty, allocate a new string_block, and
add all the Lisp_Strings in it to the free-list. */
@@ -1908,9 +1914,7 @@ allocate_string ()
s = string_free_list;
string_free_list = NEXT_FREE_LISP_STRING (s);
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
/* Probably not strictly necessary, but play it safe. */
bzero (s, sizeof *s);
@@ -1962,9 +1966,7 @@ allocate_string_data (s, nchars, nbytes)
old_data = s->data ? SDATA_OF_STRING (s) : NULL;
old_nbytes = GC_STRING_BYTES (s);
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
+ MALLOC_BLOCK_INPUT;
if (nbytes > LARGE_STRING_BYTES)
{
@@ -1980,18 +1982,14 @@ allocate_string_data (s, nchars, nbytes)
mmap'ed data typically have an address towards the top of the
address space, which won't fit into an EMACS_INT (at least on
32-bit systems with the current tagging scheme). --fx */
- BLOCK_INPUT;
mallopt (M_MMAP_MAX, 0);
- UNBLOCK_INPUT;
#endif
b = (struct sblock *) lisp_malloc (size + GC_STRING_EXTRA, MEM_TYPE_NON_LISP);
#ifdef DOUG_LEA_MALLOC
/* Back to a reasonable maximum of mmap'ed areas. */
- BLOCK_INPUT;
mallopt (M_MMAP_MAX, MMAP_MAX_AREAS);
- UNBLOCK_INPUT;
#endif
b->next_free = &b->first_data;
@@ -2022,9 +2020,7 @@ allocate_string_data (s, nchars, nbytes)
data = b->next_free;
b->next_free = (struct sdata *) ((char *) data + needed + GC_STRING_EXTRA);
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
data->string = s;
s->data = SDATA_DATA (data);
@@ -2342,11 +2338,13 @@ LENGTH must be a number. INIT matters only in whether it is t or nil. */)
/* We must allocate one more elements than LENGTH_IN_ELTS for the
slot `size' of the struct Lisp_Bool_Vector. */
val = Fmake_vector (make_number (length_in_elts + 1), Qnil);
- p = XBOOL_VECTOR (val);
/* Get rid of any bits that would cause confusion. */
- p->vector_size = 0;
- XSETBOOL_VECTOR (val, p);
+ XVECTOR (val)->size = 0; /* No Lisp_Object to trace in there. */
+ /* Use XVECTOR (val) rather than `p' because p->size is not TRT. */
+ XSETPVECTYPE (XVECTOR (val), PVEC_BOOL_VECTOR);
+
+ p = XBOOL_VECTOR (val);
p->size = XFASTINT (length);
real_init = (NILP (init) ? 0 : -1);
@@ -2355,7 +2353,7 @@ LENGTH must be a number. INIT matters only in whether it is t or nil. */)
/* Clear the extraneous bits in the last byte. */
if (XINT (length) != length_in_chars * BOOL_VECTOR_BITS_PER_CHAR)
- XBOOL_VECTOR (val)->data[length_in_chars - 1]
+ p->data[length_in_chars - 1]
&= (1 << (XINT (length) % BOOL_VECTOR_BITS_PER_CHAR)) - 1;
return val;
@@ -2613,9 +2611,7 @@ make_float (float_value)
/* eassert (!handling_signal); */
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
+ MALLOC_BLOCK_INPUT;
if (float_free_list)
{
@@ -2642,9 +2638,7 @@ make_float (float_value)
float_block_index++;
}
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
XFLOAT_DATA (val) = float_value;
eassert (!FLOAT_MARKED_P (XFLOAT (val)));
@@ -2742,9 +2736,7 @@ DEFUN ("cons", Fcons, Scons, 2, 2, 0,
/* eassert (!handling_signal); */
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
+ MALLOC_BLOCK_INPUT;
if (cons_free_list)
{
@@ -2770,9 +2762,7 @@ DEFUN ("cons", Fcons, Scons, 2, 2, 0,
cons_block_index++;
}
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
XSETCAR (val, car);
XSETCDR (val, cdr);
@@ -2922,48 +2912,39 @@ int n_vectors;
with room for LEN Lisp_Objects. */
static struct Lisp_Vector *
-allocate_vectorlike (len, type)
+allocate_vectorlike (len)
EMACS_INT len;
- enum mem_type type;
{
struct Lisp_Vector *p;
size_t nbytes;
+ MALLOC_BLOCK_INPUT;
+
#ifdef DOUG_LEA_MALLOC
/* Prevent mmap'ing the chunk. Lisp data may not be mmap'ed
because mapped region contents are not preserved in
a dumped Emacs. */
- BLOCK_INPUT;
mallopt (M_MMAP_MAX, 0);
- UNBLOCK_INPUT;
#endif
/* This gets triggered by code which I haven't bothered to fix. --Stef */
/* eassert (!handling_signal); */
nbytes = sizeof *p + (len - 1) * sizeof p->contents[0];
- p = (struct Lisp_Vector *) lisp_malloc (nbytes, type);
+ p = (struct Lisp_Vector *) lisp_malloc (nbytes, MEM_TYPE_VECTORLIKE);
#ifdef DOUG_LEA_MALLOC
/* Back to a reasonable maximum of mmap'ed areas. */
- BLOCK_INPUT;
mallopt (M_MMAP_MAX, MMAP_MAX_AREAS);
- UNBLOCK_INPUT;
#endif
consing_since_gc += nbytes;
vector_cells_consed += len;
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
-
p->next = all_vectors;
all_vectors = p;
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
++n_vectors;
return p;
@@ -2976,7 +2957,7 @@ struct Lisp_Vector *
allocate_vector (nslots)
EMACS_INT nslots;
{
- struct Lisp_Vector *v = allocate_vectorlike (nslots, MEM_TYPE_VECTOR);
+ struct Lisp_Vector *v = allocate_vectorlike (nslots);
v->size = nslots;
return v;
}
@@ -2984,74 +2965,78 @@ allocate_vector (nslots)
/* Allocate other vector-like structures. */
-struct Lisp_Hash_Table *
-allocate_hash_table ()
+static struct Lisp_Vector *
+allocate_pseudovector (memlen, lisplen, tag)
+ int memlen, lisplen;
+ EMACS_INT tag;
{
- EMACS_INT len = VECSIZE (struct Lisp_Hash_Table);
- struct Lisp_Vector *v = allocate_vectorlike (len, MEM_TYPE_HASH_TABLE);
+ struct Lisp_Vector *v = allocate_vectorlike (memlen);
EMACS_INT i;
- v->size = len;
- for (i = 0; i < len; ++i)
+ /* Only the first lisplen slots will be traced normally by the GC. */
+ v->size = lisplen;
+ for (i = 0; i < lisplen; ++i)
v->contents[i] = Qnil;
- return (struct Lisp_Hash_Table *) v;
+ XSETPVECTYPE (v, tag); /* Add the appropriate tag. */
+ return v;
+}
+#define ALLOCATE_PSEUDOVECTOR(typ,field,tag) \
+ ((typ*) \
+ allocate_pseudovector \
+ (VECSIZE (typ), PSEUDOVECSIZE (typ, field), tag))
+
+struct Lisp_Hash_Table *
+allocate_hash_table (void)
+{
+ return ALLOCATE_PSEUDOVECTOR (struct Lisp_Hash_Table, count, PVEC_HASH_TABLE);
}
struct window *
allocate_window ()
{
- EMACS_INT len = VECSIZE (struct window);
- struct Lisp_Vector *v = allocate_vectorlike (len, MEM_TYPE_WINDOW);
- EMACS_INT i;
+ return ALLOCATE_PSEUDOVECTOR(struct window, current_matrix, PVEC_WINDOW);
+}
- for (i = 0; i < len; ++i)
- v->contents[i] = Qnil;
- v->size = len;
- return (struct window *) v;
-}
+struct terminal *
+allocate_terminal ()
+{
+ struct terminal *t = ALLOCATE_PSEUDOVECTOR (struct terminal,
+ next_terminal, PVEC_TERMINAL);
+ /* Zero out the non-GC'd fields. FIXME: This should be made unnecessary. */
+ bzero (&(t->next_terminal),
+ ((char*)(t+1)) - ((char*)&(t->next_terminal)));
+ return t;
+}
struct frame *
allocate_frame ()
{
- EMACS_INT len = VECSIZE (struct frame);
- struct Lisp_Vector *v = allocate_vectorlike (len, MEM_TYPE_FRAME);
- EMACS_INT i;
-
- for (i = 0; i < len; ++i)
- v->contents[i] = make_number (0);
- v->size = len;
- return (struct frame *) v;
+ struct frame *f = ALLOCATE_PSEUDOVECTOR (struct frame,
+ face_cache, PVEC_FRAME);
+ /* Zero out the non-GC'd fields. FIXME: This should be made unnecessary. */
+ bzero (&(f->face_cache),
+ ((char*)(f+1)) - ((char*)&(f->face_cache)));
+ return f;
}
struct Lisp_Process *
allocate_process ()
{
- /* Memory-footprint of the object in nb of Lisp_Object fields. */
- EMACS_INT memlen = VECSIZE (struct Lisp_Process);
- /* Size if we only count the actual Lisp_Object fields (which need to be
- traced by the GC). */
- EMACS_INT lisplen = PSEUDOVECSIZE (struct Lisp_Process, pid);
- struct Lisp_Vector *v = allocate_vectorlike (memlen, MEM_TYPE_PROCESS);
- EMACS_INT i;
-
- for (i = 0; i < lisplen; ++i)
- v->contents[i] = Qnil;
- v->size = lisplen;
-
- return (struct Lisp_Process *) v;
+ return ALLOCATE_PSEUDOVECTOR (struct Lisp_Process, pid, PVEC_PROCESS);
}
+/* Only used for PVEC_WINDOW_CONFIGURATION. */
struct Lisp_Vector *
allocate_other_vector (len)
EMACS_INT len;
{
- struct Lisp_Vector *v = allocate_vectorlike (len, MEM_TYPE_VECTOR);
+ struct Lisp_Vector *v = allocate_vectorlike (len);
EMACS_INT i;
for (i = 0; i < len; ++i)
@@ -3085,6 +3070,51 @@ See also the function `vector'. */)
}
+DEFUN ("make-char-table", Fmake_char_table, Smake_char_table, 1, 2, 0,
+ doc: /* Return a newly created char-table, with purpose PURPOSE.
+Each element is initialized to INIT, which defaults to nil.
+PURPOSE should be a symbol which has a `char-table-extra-slots' property.
+The property's value should be an integer between 0 and 10. */)
+ (purpose, init)
+ register Lisp_Object purpose, init;
+{
+ Lisp_Object vector;
+ Lisp_Object n;
+ CHECK_SYMBOL (purpose);
+ n = Fget (purpose, Qchar_table_extra_slots);
+ CHECK_NUMBER (n);
+ if (XINT (n) < 0 || XINT (n) > 10)
+ args_out_of_range (n, Qnil);
+ /* Add 2 to the size for the defalt and parent slots. */
+ vector = Fmake_vector (make_number (CHAR_TABLE_STANDARD_SLOTS + XINT (n)),
+ init);
+ XSETPVECTYPE (XVECTOR (vector), PVEC_CHAR_TABLE);
+ XCHAR_TABLE (vector)->top = Qt;
+ XCHAR_TABLE (vector)->parent = Qnil;
+ XCHAR_TABLE (vector)->purpose = purpose;
+ XSETCHAR_TABLE (vector, XCHAR_TABLE (vector));
+ return vector;
+}
+
+
+/* Return a newly created sub char table with slots initialized by INIT.
+ Since a sub char table does not appear as a top level Emacs Lisp
+ object, we don't need a Lisp interface to make it. */
+
+Lisp_Object
+make_sub_char_table (init)
+ Lisp_Object init;
+{
+ Lisp_Object vector
+ = Fmake_vector (make_number (SUB_CHAR_TABLE_STANDARD_SLOTS), init);
+ XSETPVECTYPE (XVECTOR (vector), PVEC_CHAR_TABLE);
+ XCHAR_TABLE (vector)->top = Qnil;
+ XCHAR_TABLE (vector)->defalt = Qnil;
+ XSETCHAR_TABLE (vector, XCHAR_TABLE (vector));
+ return vector;
+}
+
+
DEFUN ("vector", Fvector, Svector, 0, MANY, 0,
doc: /* Return a newly created vector with specified arguments as elements.
Any number of arguments, even zero arguments, are allowed.
@@ -3142,6 +3172,7 @@ usage: (make-byte-code ARGLIST BYTE-CODE CONSTANTS DEPTH &optional DOCSTRING INT
args[index] = Fpurecopy (args[index]);
p->contents[index] = args[index];
}
+ XSETPVECTYPE (p, PVEC_COMPILED);
XSETCOMPILED (val, p);
return val;
}
@@ -3206,9 +3237,7 @@ Its value and function definition are void, and its property list is nil. */)
/* eassert (!handling_signal); */
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
+ MALLOC_BLOCK_INPUT;
if (symbol_free_list)
{
@@ -3231,9 +3260,7 @@ Its value and function definition are void, and its property list is nil. */)
symbol_block_index++;
}
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
p = XSYMBOL (val);
p->xname = name;
@@ -3296,9 +3323,7 @@ allocate_misc ()
/* eassert (!handling_signal); */
-#ifndef SYNC_INPUT
- BLOCK_INPUT;
-#endif
+ MALLOC_BLOCK_INPUT;
if (marker_free_list)
{
@@ -3322,9 +3347,7 @@ allocate_misc ()
marker_block_index++;
}
-#ifndef SYNC_INPUT
- UNBLOCK_INPUT;
-#endif
+ MALLOC_UNBLOCK_INPUT;
--total_free_markers;
consing_since_gc += sizeof (union Lisp_Misc);
@@ -4070,9 +4093,7 @@ live_vector_p (m, p)
struct mem_node *m;
void *p;
{
- return (p == m->start
- && m->type >= MEM_TYPE_VECTOR
- && m->type <= MEM_TYPE_WINDOW);
+ return (p == m->start && m->type == MEM_TYPE_VECTORLIKE);
}
@@ -4270,11 +4291,7 @@ mark_maybe_pointer (p)
XSETFLOAT (obj, p);
break;
- case MEM_TYPE_VECTOR:
- case MEM_TYPE_PROCESS:
- case MEM_TYPE_HASH_TABLE:
- case MEM_TYPE_FRAME:
- case MEM_TYPE_WINDOW:
+ case MEM_TYPE_VECTORLIKE:
if (live_vector_p (m, p))
{
Lisp_Object tem;
@@ -4674,11 +4691,7 @@ valid_lisp_object_p (obj)
case MEM_TYPE_FLOAT:
return live_float_p (m, p);
- case MEM_TYPE_VECTOR:
- case MEM_TYPE_PROCESS:
- case MEM_TYPE_HASH_TABLE:
- case MEM_TYPE_FRAME:
- case MEM_TYPE_WINDOW:
+ case MEM_TYPE_VECTORLIKE:
return live_vector_p (m, p);
default:
@@ -5128,7 +5141,9 @@ returns nil, because real GC can't be done. */)
mark_object (bind->symbol);
mark_object (bind->old_value);
}
+ mark_terminals ();
mark_kboards ();
+ mark_ttys ();
#ifdef USE_GTK
{
@@ -5415,6 +5430,29 @@ int last_marked_index;
Normally this is zero and the check never goes off. */
int mark_object_loop_halt;
+/* Return non-zero if the object was not yet marked. */
+static int
+mark_vectorlike (ptr)
+ struct Lisp_Vector *ptr;
+{
+ register EMACS_INT size = ptr->size;
+ register int i;
+
+ if (VECTOR_MARKED_P (ptr))
+ return 0; /* Already marked */
+ VECTOR_MARK (ptr); /* Else mark it */
+ if (size & PSEUDOVECTOR_FLAG)
+ size &= PSEUDOVECTOR_SIZE_MASK;
+
+ /* Note that this size is not the memory-footprint size, but only
+ the number of Lisp_Object fields that we should trace.
+ The distinction is used e.g. by Lisp_Process which places extra
+ non-Lisp_Object fields at the end of the structure. */
+ for (i = 0; i < size; i++) /* and then mark its elements */
+ mark_object (ptr->contents[i]);
+ return 1;
+}
+
void
mark_object (arg)
Lisp_Object arg;
@@ -5544,129 +5582,46 @@ mark_object (arg)
else if (FRAMEP (obj))
{
register struct frame *ptr = XFRAME (obj);
-
- if (VECTOR_MARKED_P (ptr)) break; /* Already marked */
- VECTOR_MARK (ptr); /* Else mark it */
-
- CHECK_LIVE (live_vector_p);
- mark_object (ptr->name);
- mark_object (ptr->icon_name);
- mark_object (ptr->title);
- mark_object (ptr->focus_frame);
- mark_object (ptr->selected_window);
- mark_object (ptr->minibuffer_window);
- mark_object (ptr->param_alist);
- mark_object (ptr->scroll_bars);
- mark_object (ptr->condemned_scroll_bars);
- mark_object (ptr->menu_bar_items);
- mark_object (ptr->face_alist);
- mark_object (ptr->menu_bar_vector);
- mark_object (ptr->buffer_predicate);
- mark_object (ptr->buffer_list);
- mark_object (ptr->menu_bar_window);
- mark_object (ptr->tool_bar_window);
- mark_face_cache (ptr->face_cache);
+ if (mark_vectorlike (XVECTOR (obj)))
+ {
+ mark_face_cache (ptr->face_cache);
#ifdef HAVE_WINDOW_SYSTEM
- mark_image_cache (ptr);
- mark_object (ptr->tool_bar_items);
- mark_object (ptr->desired_tool_bar_string);
- mark_object (ptr->current_tool_bar_string);
+ mark_image_cache (ptr);
#endif /* HAVE_WINDOW_SYSTEM */
- }
- else if (BOOL_VECTOR_P (obj))
- {
- register struct Lisp_Vector *ptr = XVECTOR (obj);
-
- if (VECTOR_MARKED_P (ptr))
- break; /* Already marked */
- CHECK_LIVE (live_vector_p);
- VECTOR_MARK (ptr); /* Else mark it */
+ }
}
else if (WINDOWP (obj))
{
register struct Lisp_Vector *ptr = XVECTOR (obj);
struct window *w = XWINDOW (obj);
- register int i;
-
- /* Stop if already marked. */
- if (VECTOR_MARKED_P (ptr))
- break;
-
- /* Mark it. */
- CHECK_LIVE (live_vector_p);
- VECTOR_MARK (ptr);
-
- /* There is no Lisp data above The member CURRENT_MATRIX in
- struct WINDOW. Stop marking when that slot is reached. */
- for (i = 0;
- (char *) &ptr->contents[i] < (char *) &w->current_matrix;
- i++)
- mark_object (ptr->contents[i]);
-
- /* Mark glyphs for leaf windows. Marking window matrices is
- sufficient because frame matrices use the same glyph
- memory. */
- if (NILP (w->hchild)
- && NILP (w->vchild)
- && w->current_matrix)
+ if (mark_vectorlike (ptr))
{
- mark_glyph_matrix (w->current_matrix);
- mark_glyph_matrix (w->desired_matrix);
+ /* Mark glyphs for leaf windows. Marking window matrices is
+ sufficient because frame matrices use the same glyph
+ memory. */
+ if (NILP (w->hchild)
+ && NILP (w->vchild)
+ && w->current_matrix)
+ {
+ mark_glyph_matrix (w->current_matrix);
+ mark_glyph_matrix (w->desired_matrix);
+ }
}
}
else if (HASH_TABLE_P (obj))
{
struct Lisp_Hash_Table *h = XHASH_TABLE (obj);
-
- /* Stop if already marked. */
- if (VECTOR_MARKED_P (h))
- break;
-
- /* Mark it. */
- CHECK_LIVE (live_vector_p);
- VECTOR_MARK (h);
-
- /* Mark contents. */
- /* Do not mark next_free or next_weak.
- Being in the next_weak chain
- should not keep the hash table alive.
- No need to mark `count' since it is an integer. */
- mark_object (h->test);
- mark_object (h->weak);
- mark_object (h->rehash_size);
- mark_object (h->rehash_threshold);
- mark_object (h->hash);
- mark_object (h->next);
- mark_object (h->index);
- mark_object (h->user_hash_function);
- mark_object (h->user_cmp_function);
-
- /* If hash table is not weak, mark all keys and values.
- For weak tables, mark only the vector. */
- if (NILP (h->weak))
- mark_object (h->key_and_value);
- else
- VECTOR_MARK (XVECTOR (h->key_and_value));
+ if (mark_vectorlike ((struct Lisp_Vector *)h))
+ { /* If hash table is not weak, mark all keys and values.
+ For weak tables, mark only the vector. */
+ if (NILP (h->weak))
+ mark_object (h->key_and_value);
+ else
+ VECTOR_MARK (XVECTOR (h->key_and_value));
+ }
}
else
- {
- register struct Lisp_Vector *ptr = XVECTOR (obj);
- register EMACS_INT size = ptr->size;
- register int i;
-
- if (VECTOR_MARKED_P (ptr)) break; /* Already marked */
- CHECK_LIVE (live_vector_p);
- VECTOR_MARK (ptr); /* Else mark it */
- if (size & PSEUDOVECTOR_FLAG)
- size &= PSEUDOVECTOR_SIZE_MASK;
-
- /* Note that this size is not the memory-footprint size, but only
- the number of Lisp_Object fields that we should trace.
- The distinction is used e.g. by Lisp_Process which places extra
- non-Lisp_Object fields at the end of the structure. */
- for (i = 0; i < size; i++) /* and then mark its elements */
- mark_object (ptr->contents[i]);
- }
+ mark_vectorlike (XVECTOR (obj));
break;
case Lisp_Symbol:
@@ -5857,6 +5812,21 @@ mark_buffer (buf)
}
}
+/* Mark the Lisp pointers in the terminal objects.
+ Called by the Fgarbage_collector. */
+
+static void
+mark_terminals (void)
+{
+ struct terminal *t;
+ for (t = terminal_list; t; t = t->next_terminal)
+ {
+ eassert (t->name != NULL);
+ mark_vectorlike ((struct Lisp_Vector *)t);
+ }
+}
+
+
/* Value is non-zero if OBJ will survive the current GC because it's
either marked or does not need to be marked to survive. */
@@ -5932,23 +5902,51 @@ gc_sweep ()
for (cblk = cons_block; cblk; cblk = *cprev)
{
- register int i;
+ register int i = 0;
int this_free = 0;
- for (i = 0; i < lim; i++)
- if (!CONS_MARKED_P (&cblk->conses[i]))
- {
- this_free++;
- cblk->conses[i].u.chain = cons_free_list;
- cons_free_list = &cblk->conses[i];
+ int ilim = (lim + BITS_PER_INT - 1) / BITS_PER_INT;
+
+ /* Scan the mark bits an int at a time. */
+ for (i = 0; i <= ilim; i++)
+ {
+ if (cblk->gcmarkbits[i] == -1)
+ {
+ /* Fast path - all cons cells for this int are marked. */
+ cblk->gcmarkbits[i] = 0;
+ num_used += BITS_PER_INT;
+ }
+ else
+ {
+ /* Some cons cells for this int are not marked.
+ Find which ones, and free them. */
+ int start, pos, stop;
+
+ start = i * BITS_PER_INT;
+ stop = lim - start;
+ if (stop > BITS_PER_INT)
+ stop = BITS_PER_INT;
+ stop += start;
+
+ for (pos = start; pos < stop; pos++)
+ {
+ if (!CONS_MARKED_P (&cblk->conses[pos]))
+ {
+ this_free++;
+ cblk->conses[pos].u.chain = cons_free_list;
+ cons_free_list = &cblk->conses[pos];
#if GC_MARK_STACK
- cons_free_list->car = Vdead;
+ cons_free_list->car = Vdead;
#endif
- }
- else
- {
- num_used++;
- CONS_UNMARK (&cblk->conses[i]);
- }
+ }
+ else
+ {
+ num_used++;
+ CONS_UNMARK (&cblk->conses[pos]);
+ }
+ }
+ }
+ }
+
lim = CONS_BLOCK_SIZE;
/* If this block contains only free conses and we have already
seen more than two blocks worth of free conses then deallocate
diff --git a/src/alloca.c b/src/alloca.c
deleted file mode 100644
index e8c8319adc..0000000000
--- a/src/alloca.c
+++ /dev/null
@@ -1,517 +0,0 @@
-/* alloca.c -- allocate automatically reclaimed memory
- (Mostly) portable public-domain implementation -- D A Gwyn
-
- NOTE: The canonical source of this file is maintained with gnulib.
- Bugs can be reported to [email protected].
-
- This implementation of the PWB library alloca function,
- which is used to allocate space off the run-time stack so
- that it is automatically reclaimed upon procedure exit,
- was inspired by discussions with J. Q. Johnson of Cornell.
- J.Otto Tennant <[email protected]> contributed the Cray support.
-
- There are some preprocessor constants that can
- be defined when compiling for your specific system, for
- improved efficiency; however, the defaults should be okay.
-
- The general concept of this implementation is to keep
- track of all alloca-allocated blocks, and reclaim any
- that are found to be deeper in the stack than the current
- invocation. This heuristic does not reclaim storage as
- soon as it becomes invalid, but it will do so eventually.
-
- As a special case, alloca(0) reclaims storage without
- allocating any. It is a good idea to use alloca(0) in
- your main control loop, etc. to force garbage collection. */
-
-#ifdef HAVE_CONFIG_H
-# include <config.h>
-#endif
-
-#ifdef HAVE_STRING_H
-# include <string.h>
-#endif
-#ifdef HAVE_STDLIB_H
-# include <stdlib.h>
-#endif
-
-#ifdef DO_BLOCK_INPUT
-# include "blockinput.h"
-#endif
-
-/* If compiling with GCC 2, this file's not needed. */
-#if !defined (__GNUC__) || __GNUC__ < 2
-
-/* If someone has defined alloca as a macro,
- there must be some other way alloca is supposed to work. */
-# ifndef alloca
-
-# ifdef emacs
-# ifdef static
-/* actually, only want this if static is defined as ""
- -- this is for usg, in which emacs must undefine static
- in order to make unexec workable
- */
-# ifndef STACK_DIRECTION
-you
-lose
--- must know STACK_DIRECTION at compile-time
-/* Using #error here is not wise since this file should work for
- old and obscure compilers.
-
- As far as I know, using it is OK if it's indented -- at least for
- pcc-based processors. -- fx */
-# endif /* STACK_DIRECTION undefined */
-# endif /* static */
-# endif /* emacs */
-
-/* If your stack is a linked list of frames, you have to
- provide an "address metric" ADDRESS_FUNCTION macro. */
-
-# if defined (CRAY) && defined (CRAY_STACKSEG_END)
-long i00afunc ();
-# define ADDRESS_FUNCTION(arg) (char *) i00afunc (&(arg))
-# else
-# define ADDRESS_FUNCTION(arg) &(arg)
-# endif
-
-# ifndef POINTER_TYPE
-# ifdef __STDC__
-# define POINTER_TYPE void
-# else
-# define POINTER_TYPE char
-# endif
-# endif
-typedef POINTER_TYPE *pointer;
-
-# ifndef NULL
-# define NULL 0
-# endif
-
-/* The Emacs executable needs alloca to call xmalloc, because ordinary
- malloc isn't protected from input signals. xmalloc also checks for
- out-of-memory errors, so we should use it generally.
-
- Callers below should use malloc. */
-
-# undef malloc
-# define malloc xmalloc
-# undef free
-# define free xfree
-
-void *xmalloc _P ((size_t));
-void xfree _P ((void *));
-
-/* Define STACK_DIRECTION if you know the direction of stack
- growth for your system; otherwise it will be automatically
- deduced at run-time.
-
- STACK_DIRECTION > 0 => grows toward higher addresses
- STACK_DIRECTION < 0 => grows toward lower addresses
- STACK_DIRECTION = 0 => direction of growth unknown */
-
-# ifndef STACK_DIRECTION
-# define STACK_DIRECTION 0 /* Direction unknown. */
-# endif
-
-# if STACK_DIRECTION != 0
-
-# define STACK_DIR STACK_DIRECTION /* Known at compile-time. */
-
-# else /* STACK_DIRECTION == 0; need run-time code. */
-
-static int stack_dir; /* 1 or -1 once known. */
-# define STACK_DIR stack_dir
-
-static void
-find_stack_direction ()
-{
- static char *addr = NULL; /* Address of first `dummy', once known. */
- auto char dummy; /* To get stack address. */
-
- if (addr == NULL)
- { /* Initial entry. */
- addr = ADDRESS_FUNCTION (dummy);
-
- find_stack_direction (); /* Recurse once. */
- }
- else
- {
- /* Second entry. */
- if (ADDRESS_FUNCTION (dummy) > addr)
- stack_dir = 1; /* Stack grew upward. */
- else
- stack_dir = -1; /* Stack grew downward. */
- }
-}
-
-# endif /* STACK_DIRECTION == 0 */
-
-/* An "alloca header" is used to:
- (a) chain together all alloca'ed blocks;
- (b) keep track of stack depth.
-
- It is very important that sizeof(header) agree with malloc
- alignment chunk size. The following default should work okay. */
-
-# ifndef ALIGN_SIZE
-# define ALIGN_SIZE sizeof(double)
-# endif
-
-typedef union hdr
-{
- char align[ALIGN_SIZE]; /* To force sizeof(header). */
- struct
- {
- union hdr *next; /* For chaining headers. */
- char *deep; /* For stack depth measure. */
- } h;
-} header;
-
-static header *last_alloca_header = NULL; /* -> last alloca header. */
-
-/* Return a pointer to at least SIZE bytes of storage,
- which will be automatically reclaimed upon exit from
- the procedure that called alloca. Originally, this space
- was supposed to be taken from the current stack frame of the
- caller, but that method cannot be made to work for some
- implementations of C, for example under Gould's UTX/32. */
-
-pointer
-alloca (size)
- size_t size;
-{
- auto char probe; /* Probes stack depth: */
- register char *depth = ADDRESS_FUNCTION (probe);
-
-# if STACK_DIRECTION == 0
- if (STACK_DIR == 0) /* Unknown growth direction. */
- find_stack_direction ();
-# endif
-
- /* Reclaim garbage, defined as all alloca'd storage that
- was allocated from deeper in the stack than currently. */
-
- {
- register header *hp; /* Traverses linked list. */
-
-# ifdef DO_BLOCK_INPUT
- BLOCK_INPUT;
-# endif
-
- for (hp = last_alloca_header; hp != NULL;)
- if ((STACK_DIR > 0 && hp->h.deep > depth)
- || (STACK_DIR < 0 && hp->h.deep < depth))
- {
- register header *np = hp->h.next;
-
- free ((pointer) hp); /* Collect garbage. */
-
- hp = np; /* -> next header. */
- }
- else
- break; /* Rest are not deeper. */
-
- last_alloca_header = hp; /* -> last valid storage. */
-
-# ifdef DO_BLOCK_INPUT
- UNBLOCK_INPUT;
-# endif
- }
-
- if (size == 0)
- return NULL; /* No allocation required. */
-
- /* Allocate combined header + user data storage. */
-
- {
- /* Address of header. */
- register pointer new = malloc (sizeof (header) + size);
-
- if (new == 0)
- abort();
-
- ((header *) new)->h.next = last_alloca_header;
- ((header *) new)->h.deep = depth;
-
- last_alloca_header = (header *) new;
-
- /* User storage begins just after header. */
-
- return (pointer) ((char *) new + sizeof (header));
- }
-}
-
-# if defined (CRAY) && defined (CRAY_STACKSEG_END)
-
-# ifdef DEBUG_I00AFUNC
-# include <stdio.h>
-# endif
-
-# ifndef CRAY_STACK
-# define CRAY_STACK
-# ifndef CRAY2
-/* Stack structures for CRAY-1, CRAY X-MP, and CRAY Y-MP */
-struct stack_control_header
- {
- long shgrow:32; /* Number of times stack has grown. */
- long shaseg:32; /* Size of increments to stack. */
- long shhwm:32; /* High water mark of stack. */
- long shsize:32; /* Current size of stack (all segments). */
- };
-
-/* The stack segment linkage control information occurs at
- the high-address end of a stack segment. (The stack
- grows from low addresses to high addresses.) The initial
- part of the stack segment linkage control information is
- 0200 (octal) words. This provides for register storage
- for the routine which overflows the stack. */
-
-struct stack_segment_linkage
- {
- long ss[0200]; /* 0200 overflow words. */
- long sssize:32; /* Number of words in this segment. */
- long ssbase:32; /* Offset to stack base. */
- long:32;
- long sspseg:32; /* Offset to linkage control of previous
- segment of stack. */
- long:32;
- long sstcpt:32; /* Pointer to task common address block. */
- long sscsnm; /* Private control structure number for
- microtasking. */
- long ssusr1; /* Reserved for user. */
- long ssusr2; /* Reserved for user. */
- long sstpid; /* Process ID for pid based multi-tasking. */
- long ssgvup; /* Pointer to multitasking thread giveup. */
- long sscray[7]; /* Reserved for Cray Research. */
- long ssa0;
- long ssa1;
- long ssa2;
- long ssa3;
- long ssa4;
- long ssa5;
- long ssa6;
- long ssa7;
- long sss0;
- long sss1;
- long sss2;
- long sss3;
- long sss4;
- long sss5;
- long sss6;
- long sss7;
- };
-
-# else /* CRAY2 */
-/* The following structure defines the vector of words
- returned by the STKSTAT library routine. */
-struct stk_stat
- {
- long now; /* Current total stack size. */
- long maxc; /* Amount of contiguous space which would
- be required to satisfy the maximum
- stack demand to date. */
- long high_water; /* Stack high-water mark. */
- long overflows; /* Number of stack overflow ($STKOFEN) calls. */
- long hits; /* Number of internal buffer hits. */
- long extends; /* Number of block extensions. */
- long stko_mallocs; /* Block allocations by $STKOFEN. */
- long underflows; /* Number of stack underflow calls ($STKRETN). */
- long stko_free; /* Number of deallocations by $STKRETN. */
- long stkm_free; /* Number of deallocations by $STKMRET. */
- long segments; /* Current number of stack segments. */
- long maxs; /* Maximum number of stack segments so far. */
- long pad_size; /* Stack pad size. */
- long current_address; /* Current stack segment address. */
- long current_size; /* Current stack segment size. This
- number is actually corrupted by STKSTAT to
- include the fifteen word trailer area. */
- long initial_address; /* Address of initial segment. */
- long initial_size; /* Size of initial segment. */
- };
-
-/* The following structure describes the data structure which trails
- any stack segment. I think that the description in 'asdef' is
- out of date. I only describe the parts that I am sure about. */
-
-struct stk_trailer
- {
- long this_address; /* Address of this block. */
- long this_size; /* Size of this block (does not include
- this trailer). */
- long unknown2;
- long unknown3;
- long link; /* Address of trailer block of previous
- segment. */
- long unknown5;
- long unknown6;
- long unknown7;
- long unknown8;
- long unknown9;
- long unknown10;
- long unknown11;
- long unknown12;
- long unknown13;
- long unknown14;
- };
-
-# endif /* CRAY2 */
-# endif /* not CRAY_STACK */
-
-# ifdef CRAY2
-/* Determine a "stack measure" for an arbitrary ADDRESS.
- I doubt that "lint" will like this much. */
-
-static long
-i00afunc (long *address)
-{
- struct stk_stat status;
- struct stk_trailer *trailer;
- long *block, size;
- long result = 0;
-
- /* We want to iterate through all of the segments. The first
- step is to get the stack status structure. We could do this
- more quickly and more directly, perhaps, by referencing the
- $LM00 common block, but I know that this works. */
-
- STKSTAT (&status);
-
- /* Set up the iteration. */
-
- trailer = (struct stk_trailer *) (status.current_address
- + status.current_size
- - 15);
-
- /* There must be at least one stack segment. Therefore it is
- a fatal error if "trailer" is null. */
-
- if (trailer == 0)
- abort ();
-
- /* Discard segments that do not contain our argument address. */
-
- while (trailer != 0)
- {
- block = (long *) trailer->this_address;
- size = trailer->this_size;
- if (block == 0 || size == 0)
- abort ();
- trailer = (struct stk_trailer *) trailer->link;
- if ((block <= address) && (address < (block + size)))
- break;
- }
-
- /* Set the result to the offset in this segment and add the sizes
- of all predecessor segments. */
-
- result = address - block;
-
- if (trailer == 0)
- {
- return result;
- }
-
- do
- {
- if (trailer->this_size <= 0)
- abort ();
- result += trailer->this_size;
- trailer = (struct stk_trailer *) trailer->link;
- }
- while (trailer != 0);
-
- /* We are done. Note that if you present a bogus address (one
- not in any segment), you will get a different number back, formed
- from subtracting the address of the first block. This is probably
- not what you want. */
-
- return (result);
-}
-
-# else /* not CRAY2 */
-/* Stack address function for a CRAY-1, CRAY X-MP, or CRAY Y-MP.
- Determine the number of the cell within the stack,
- given the address of the cell. The purpose of this
- routine is to linearize, in some sense, stack addresses
- for alloca. */
-
-static long
-i00afunc (long address)
-{
- long stkl = 0;
-
- long size, pseg, this_segment, stack;
- long result = 0;
-
- struct stack_segment_linkage *ssptr;
-
- /* Register B67 contains the address of the end of the
- current stack segment. If you (as a subprogram) store
- your registers on the stack and find that you are past
- the contents of B67, you have overflowed the segment.
-
- B67 also points to the stack segment linkage control
- area, which is what we are really interested in. */
-
- stkl = CRAY_STACKSEG_END ();
- ssptr = (struct stack_segment_linkage *) stkl;
-
- /* If one subtracts 'size' from the end of the segment,
- one has the address of the first word of the segment.
-
- If this is not the first segment, 'pseg' will be
- nonzero. */
-
- pseg = ssptr->sspseg;
- size = ssptr->sssize;
-
- this_segment = stkl - size;
-
- /* It is possible that calling this routine itself caused
- a stack overflow. Discard stack segments which do not
- contain the target address. */
-
- while (!(this_segment <= address && address <= stkl))
- {
-# ifdef DEBUG_I00AFUNC
- fprintf (stderr, "%011o %011o %011o\n", this_segment, address, stkl);
-# endif
- if (pseg == 0)
- break;
- stkl = stkl - pseg;
- ssptr = (struct stack_segment_linkage *) stkl;
- size = ssptr->sssize;
- pseg = ssptr->sspseg;
- this_segment = stkl - size;
- }
-
- result = address - this_segment;
-
- /* If you subtract pseg from the current end of the stack,
- you get the address of the previous stack segment's end.
- This seems a little convoluted to me, but I'll bet you save
- a cycle somewhere. */
-
- while (pseg != 0)
- {
-# ifdef DEBUG_I00AFUNC
- fprintf (stderr, "%011o %011o\n", pseg, size);
-# endif
- stkl = stkl - pseg;
- ssptr = (struct stack_segment_linkage *) stkl;
- size = ssptr->sssize;
- pseg = ssptr->sspseg;
- result += size;
- }
- return (result);
-}
-
-# endif /* not CRAY2 */
-# endif /* CRAY */
-
-# endif /* no alloca */
-#endif /* not GCC version 2 */
-
-/* arch-tag: 5c9901c8-3cd4-453e-bd66-d9035a175ee3
- (do not change this comment) */
diff --git a/src/buffer.c b/src/buffer.c
index 3a2b9460c1..237c549df8 100644
--- a/src/buffer.c
+++ b/src/buffer.c
@@ -216,25 +216,38 @@ frame parameter come first, followed by the rest of the buffers. */)
(frame)
Lisp_Object frame;
{
- Lisp_Object framelist, general;
+ Lisp_Object general;
general = Fmapcar (Qcdr, Vbuffer_alist);
if (FRAMEP (frame))
{
- Lisp_Object tail;
+ Lisp_Object framelist, prevlist, tail;
+ Lisp_Object args[3];
CHECK_FRAME (frame);
framelist = Fcopy_sequence (XFRAME (frame)->buffer_list);
+ prevlist = Fnreverse (Fcopy_sequence (XFRAME (frame)->buried_buffer_list));
- /* Remove from GENERAL any buffer that duplicates one in FRAMELIST. */
+ /* Remove from GENERAL any buffer that duplicates one in
+ FRAMELIST or PREVLIST. */
tail = framelist;
- while (! NILP (tail))
+ while (CONSP (tail))
{
general = Fdelq (XCAR (tail), general);
tail = XCDR (tail);
}
- return nconc2 (framelist, general);
+ tail = prevlist;
+ while (CONSP (tail))
+ {
+ general = Fdelq (XCAR (tail), general);
+ tail = XCDR (tail);
+ }
+
+ args[0] = framelist;
+ args[1] = general;
+ args[2] = prevlist;
+ return Fnconc (3, args);
}
return general;
@@ -417,6 +430,7 @@ The value is never nil. */)
b->name = name;
/* Put this in the alist of all live buffers. */
+ XSETPVECTYPE (b, PVEC_BUFFER);
XSETBUFFER (buf, b);
Vbuffer_alist = nconc2 (Vbuffer_alist, Fcons (Fcons (name, buf), Qnil));
@@ -1584,6 +1598,23 @@ record_buffer (buf)
XSETCDR (link, Vbuffer_alist);
Vbuffer_alist = link;
+ /* Effectively do a delq on buried_buffer_list. */
+
+ prev = Qnil;
+ for (link = XFRAME (frame)->buried_buffer_list; CONSP (link);
+ link = XCDR (link))
+ {
+ if (EQ (XCAR (link), buf))
+ {
+ if (NILP (prev))
+ XFRAME (frame)->buried_buffer_list = XCDR (link);
+ else
+ XSETCDR (prev, XCDR (XCDR (prev)));
+ break;
+ }
+ prev = link;
+ }
+
/* Now move this buffer to the front of frame_buffer_list also. */
prev = Qnil;
@@ -2066,10 +2097,10 @@ selected window if it is displayed there. */)
XSETCDR (link, Qnil);
Vbuffer_alist = nconc2 (Vbuffer_alist, link);
- /* Removing BUFFER from frame-specific lists
- has the effect of putting BUFFER at the end
- of the combined list in each frame. */
- frames_discard_buffer (buffer);
+ XFRAME (selected_frame)->buffer_list
+ = Fdelq (buffer, XFRAME (selected_frame)->buffer_list);
+ XFRAME (selected_frame)->buried_buffer_list
+ = Fcons (buffer, Fdelq (buffer, XFRAME (selected_frame)->buried_buffer_list));
}
return Qnil;
@@ -3953,7 +3984,7 @@ OVERLAY. */)
DEFUN ("overlays-at", Foverlays_at, Soverlays_at, 1, 1, 0,
- doc: /* Return a list of the overlays that contain position POS. */)
+ doc: /* Return a list of the overlays that contain the character at POS. */)
(pos)
Lisp_Object pos;
{
@@ -5022,7 +5053,9 @@ init_buffer_once ()
buffer_local_symbols.text = &buffer_local_symbols.own_text;
BUF_INTERVALS (&buffer_defaults) = 0;
BUF_INTERVALS (&buffer_local_symbols) = 0;
+ XSETPVECTYPE (&buffer_defaults, PVEC_BUFFER);
XSETBUFFER (Vbuffer_defaults, &buffer_defaults);
+ XSETPVECTYPE (&buffer_local_symbols, PVEC_BUFFER);
XSETBUFFER (Vbuffer_local_symbols, &buffer_local_symbols);
/* Set up the default values of various buffer slots. */
@@ -5261,6 +5294,46 @@ init_buffer ()
free (pwd);
}
+/* Similar to defvar_lisp but define a variable whose value is the Lisp
+ Object stored in the current buffer. address is the address of the slot
+ in the buffer that is current now. */
+
+/* TYPE is nil for a general Lisp variable.
+ An integer specifies a type; then only LIsp values
+ with that type code are allowed (except that nil is allowed too).
+ LNAME is the LIsp-level variable name.
+ VNAME is the name of the buffer slot.
+ DOC is a dummy where you write the doc string as a comment. */
+#define DEFVAR_PER_BUFFER(lname, vname, type, doc) \
+ defvar_per_buffer (lname, vname, type, 0)
+
+static void
+defvar_per_buffer (namestring, address, type, doc)
+ char *namestring;
+ Lisp_Object *address;
+ Lisp_Object type;
+ char *doc;
+{
+ Lisp_Object sym, val;
+ int offset;
+
+ sym = intern (namestring);
+ val = allocate_misc ();
+ offset = (char *)address - (char *)current_buffer;
+
+ XMISCTYPE (val) = Lisp_Misc_Buffer_Objfwd;
+ XBUFFER_OBJFWD (val)->offset = offset;
+ SET_SYMBOL_VALUE (sym, val);
+ PER_BUFFER_SYMBOL (offset) = sym;
+ PER_BUFFER_TYPE (offset) = type;
+
+ if (PER_BUFFER_IDX (offset) == 0)
+ /* Did a DEFVAR_PER_BUFFER without initializing the corresponding
+ slot of buffer_local_flags */
+ abort ();
+}
+
+
/* initialize the buffer routines */
void
syms_of_buffer ()
@@ -5546,6 +5619,9 @@ its hooks should not expect certain variables such as
Qnil,
doc: /* Pretty name of current buffer's major mode (a string). */);
+ DEFVAR_PER_BUFFER ("local-abbrev-table", &current_buffer->abbrev_table, Qnil,
+ doc: /* Local (mode-specific) abbrev table of current buffer. */);
+
DEFVAR_PER_BUFFER ("abbrev-mode", &current_buffer->abbrev_mode, Qnil,
doc: /* Non-nil turns on automatic expansion of abbrevs as they are inserted. */);
diff --git a/src/buffer.h b/src/buffer.h
index 3935a675c4..d9e82d62b1 100644
--- a/src/buffer.h
+++ b/src/buffer.h
@@ -464,7 +464,7 @@ struct buffer
Check out mark_buffer (alloc.c) to see why. */
- EMACS_INT size;
+ EMACS_UINT size;
/* Next buffer, in chain of all buffers including killed buffers.
This chain is used only for garbage collection, in order to
diff --git a/src/callint.c b/src/callint.c
index 9b3535474c..a19c424c89 100644
--- a/src/callint.c
+++ b/src/callint.c
@@ -263,7 +263,6 @@ invoke it. If KEYS is omitted or nil, the return value of
Lisp_Object function, record_flag, keys;
{
Lisp_Object *args, *visargs;
- Lisp_Object fun;
Lisp_Object specs;
Lisp_Object filter_specs;
Lisp_Object teml;
@@ -317,8 +316,6 @@ invoke it. If KEYS is omitted or nil, the return value of
else
enable = Qnil;
- fun = indirect_function (function);
-
specs = Qnil;
string = 0;
/* The idea of FILTER_SPECS is to provide away to
@@ -329,37 +326,19 @@ invoke it. If KEYS is omitted or nil, the return value of
/* If k or K discard an up-event, save it here so it can be retrieved with U */
up_event = Qnil;
- /* Decode the kind of function. Either handle it and return,
- or go to `lose' if not interactive, or set either STRING or SPECS. */
-
- if (SUBRP (fun))
- {
- string = (unsigned char *) XSUBR (fun)->prompt;
- if (!string)
- {
- lose:
- wrong_type_argument (Qcommandp, function);
- }
- }
- else if (COMPILEDP (fun))
- {
- if ((XVECTOR (fun)->size & PSEUDOVECTOR_SIZE_MASK) <= COMPILED_INTERACTIVE)
- goto lose;
- specs = XVECTOR (fun)->contents[COMPILED_INTERACTIVE];
- }
- else
- {
- Lisp_Object form;
- GCPRO2 (function, prefix_arg);
- form = Finteractive_form (function);
- UNGCPRO;
- if (CONSP (form))
- specs = filter_specs = Fcar (XCDR (form));
- else
- goto lose;
- }
+ /* Set SPECS to the interactive form, or barf if not interactive. */
+ {
+ Lisp_Object form;
+ GCPRO2 (function, prefix_arg);
+ form = Finteractive_form (function);
+ UNGCPRO;
+ if (CONSP (form))
+ specs = filter_specs = Fcar (XCDR (form));
+ else
+ wrong_type_argument (Qcommandp, function);
+ }
- /* If either SPECS or STRING is set to a string, use it. */
+ /* If SPECS is set to a string, use it as an interactive prompt. */
if (STRINGP (specs))
{
/* Make a copy of string so that if a GC relocates specs,
@@ -368,7 +347,7 @@ invoke it. If KEYS is omitted or nil, the return value of
bcopy (SDATA (specs), string,
SBYTES (specs) + 1);
}
- else if (string == 0)
+ else
{
Lisp_Object input;
i = num_input_events;
@@ -402,8 +381,8 @@ invoke it. If KEYS is omitted or nil, the return value of
real_this_command= save_real_this_command;
current_kboard->Vlast_command = save_last_command;
- single_kboard_state ();
- return apply1 (function, specs);
+ temporarily_switch_to_single_kboard (NULL);
+ return unbind_to (speccount, apply1 (function, specs));
}
/* Here if function specifies a string to control parsing the defaults */
@@ -854,12 +833,11 @@ invoke it. If KEYS is omitted or nil, the return value of
real_this_command= save_real_this_command;
current_kboard->Vlast_command = save_last_command;
- single_kboard_state ();
-
{
Lisp_Object val;
specbind (Qcommand_debug_status, Qnil);
+ temporarily_switch_to_single_kboard (NULL);
val = Ffuncall (count + 1, args);
UNGCPRO;
return unbind_to (speccount, val);
diff --git a/src/callproc.c b/src/callproc.c
index d86113cfdb..5560f32173 100644
--- a/src/callproc.c
+++ b/src/callproc.c
@@ -84,6 +84,8 @@ extern int errno;
#include "syssignal.h"
#include "systty.h"
#include "blockinput.h"
+#include "frame.h"
+#include "termhooks.h"
#ifdef MSDOS
#include "msdos.h"
@@ -111,7 +113,7 @@ Lisp_Object Vtemp_file_name_pattern;
Lisp_Object Vshell_file_name;
-Lisp_Object Vprocess_environment;
+Lisp_Object Vprocess_environment, Vinitial_environment;
#ifdef DOS_NT
Lisp_Object Qbuffer_file_type;
@@ -130,6 +132,7 @@ int synch_process_termsig;
/* If synch_process_death is zero,
this is exit code of synchronous subprocess. */
int synch_process_retcode;
+
/* Clean up when exiting Fcall_process.
On MSDOS, delete the temporary file on any kind of termination.
@@ -138,6 +141,8 @@ int synch_process_retcode;
/* Nonzero if this is termination due to exit. */
static int call_process_exited;
+EXFUN (Fgetenv_internal, 2);
+
#ifndef VMS /* VMS version is in vmsproc.c. */
static Lisp_Object
@@ -1069,6 +1074,40 @@ usage: (call-process-region START END PROGRAM &optional DELETE BUFFER DISPLAY &r
static int relocate_fd ();
+static char **
+add_env (char **env, char **new_env, char *string)
+{
+ char **ep;
+ int ok = 1;
+ if (string == NULL)
+ return new_env;
+
+ /* See if this string duplicates any string already in the env.
+ If so, don't put it in.
+ When an env var has multiple definitions,
+ we keep the definition that comes first in process-environment. */
+ for (ep = env; ok && ep != new_env; ep++)
+ {
+ char *p = *ep, *q = string;
+ while (ok)
+ {
+ if (*q != *p)
+ break;
+ if (*q == 0)
+ /* The string is a lone variable name; keep it for now, we
+ will remove it later. It is a placeholder for a
+ variable that is not to be included in the environment. */
+ break;
+ if (*q == '=')
+ ok = 0;
+ p++, q++;
+ }
+ }
+ if (ok)
+ *new_env++ = string;
+ return new_env;
+}
+
/* This is the last thing run in a newly forked inferior
either synchronous or asynchronous.
Copy descriptors IN, OUT and ERR as descriptors 0, 1 and 2.
@@ -1124,9 +1163,10 @@ child_setup (in, out, err, new_argv, set_pgrp, current_dir)
/* Note that use of alloca is always safe here. It's obvious for systems
that do not have true vfork or that have true (stack) alloca.
- If using vfork and C_ALLOCA it is safe because that changes
- the superior's static variables as if the superior had done alloca
- and will be cleaned up in the usual way. */
+ If using vfork and C_ALLOCA (when Emacs used to include
+ src/alloca.c) it is safe because that changes the superior's
+ static variables as if the superior had done alloca and will be
+ cleaned up in the usual way. */
{
register char *temp;
register int i;
@@ -1170,57 +1210,80 @@ child_setup (in, out, err, new_argv, set_pgrp, current_dir)
temp[--i] = 0;
}
- /* Set `env' to a vector of the strings in Vprocess_environment. */
+ /* Set `env' to a vector of the strings in the environment. */
{
register Lisp_Object tem;
register char **new_env;
+ char **p, **q;
register int new_length;
-
+ Lisp_Object display = Qnil;
+
new_length = 0;
+
for (tem = Vprocess_environment;
- CONSP (tem) && STRINGP (XCAR (tem));
- tem = XCDR (tem))
- new_length++;
+ CONSP (tem) && STRINGP (XCAR (tem));
+ tem = XCDR (tem))
+ {
+ if (strncmp (SDATA (XCAR (tem)), "DISPLAY", 7) == 0
+ && (SDATA (XCAR (tem)) [7] == '\0'
+ || SDATA (XCAR (tem)) [7] == '='))
+ /* DISPLAY is specified in process-environment. */
+ display = Qt;
+ new_length++;
+ }
+
+ /* If not provided yet, use the frame's DISPLAY. */
+ if (NILP (display))
+ {
+ Lisp_Object tmp = Fframe_parameter (selected_frame, Qdisplay);
+ if (!STRINGP (tmp) && CONSP (Vinitial_environment))
+ /* If still not found, Look for DISPLAY in Vinitial_environment. */
+ tmp = Fgetenv_internal (build_string ("DISPLAY"),
+ Vinitial_environment);
+ if (STRINGP (tmp))
+ {
+ display = tmp;
+ new_length++;
+ }
+ }
/* new_length + 2 to include PWD and terminating 0. */
env = new_env = (char **) alloca ((new_length + 2) * sizeof (char *));
-
/* If we have a PWD envvar, pass one down,
but with corrected value. */
- if (getenv ("PWD"))
+ if (egetenv ("PWD"))
*new_env++ = pwd_var;
+
+ if (STRINGP (display))
+ {
+ int vlen = strlen ("DISPLAY=") + strlen (SDATA (display)) + 1;
+ char *vdata = (char *) alloca (vlen);
+ strcpy (vdata, "DISPLAY=");
+ strcat (vdata, SDATA (display));
+ new_env = add_env (env, new_env, vdata);
+ }
- /* Copy the Vprocess_environment strings into new_env. */
+ /* Overrides. */
for (tem = Vprocess_environment;
CONSP (tem) && STRINGP (XCAR (tem));
tem = XCDR (tem))
+ new_env = add_env (env, new_env, SDATA (XCAR (tem)));
+
+ *new_env = 0;
+
+ /* Remove variable names without values. */
+ p = q = env;
+ while (*p != 0)
{
- char **ep = env;
- char *string = (char *) SDATA (XCAR (tem));
- /* See if this string duplicates any string already in the env.
- If so, don't put it in.
- When an env var has multiple definitions,
- we keep the definition that comes first in process-environment. */
- for (; ep != new_env; ep++)
- {
- char *p = *ep, *q = string;
- while (1)
- {
- if (*q == 0)
- /* The string is malformed; might as well drop it. */
- goto duplicate;
- if (*q != *p)
- break;
- if (*q == '=')
- goto duplicate;
- p++, q++;
- }
- }
- *new_env++ = string;
- duplicate: ;
+ while (*q != 0 && strchr (*q, '=') == NULL)
+ *q++;
+ *p = *q++;
+ if (*p != 0)
+ p++;
}
- *new_env = 0;
}
+
+
#ifdef WINDOWSNT
prepare_standard_handles (in, out, err, handles);
set_process_dir (SDATA (current_dir));
@@ -1334,22 +1397,18 @@ relocate_fd (fd, minfd)
}
static int
-getenv_internal (var, varlen, value, valuelen)
+getenv_internal_1 (var, varlen, value, valuelen, env)
char *var;
int varlen;
char **value;
int *valuelen;
+ Lisp_Object env;
{
- Lisp_Object scan;
-
- for (scan = Vprocess_environment; CONSP (scan); scan = XCDR (scan))
+ for (; CONSP (env); env = XCDR (env))
{
- Lisp_Object entry;
-
- entry = XCAR (scan);
+ Lisp_Object entry = XCAR (env);
if (STRINGP (entry)
- && SBYTES (entry) > varlen
- && SREF (entry, varlen) == '='
+ && SBYTES (entry) >= varlen
#ifdef WINDOWSNT
/* NT environment variables are case insensitive. */
&& ! strnicmp (SDATA (entry), var, varlen)
@@ -1358,35 +1417,95 @@ getenv_internal (var, varlen, value, valuelen)
#endif /* not WINDOWSNT */
)
{
- *value = (char *) SDATA (entry) + (varlen + 1);
- *valuelen = SBYTES (entry) - (varlen + 1);
+ if (SBYTES (entry) > varlen && SREF (entry, varlen) == '=')
+ {
+ *value = (char *) SDATA (entry) + (varlen + 1);
+ *valuelen = SBYTES (entry) - (varlen + 1);
+ return 1;
+ }
+ else if (SBYTES (entry) == varlen)
+ {
+ /* Lone variable names in Vprocess_environment mean that
+ variable should be removed from the environment. */
+ *value = NULL;
+ return 1;
+ }
+ }
+ }
+ return 0;
+}
+
+static int
+getenv_internal (var, varlen, value, valuelen, frame)
+ char *var;
+ int varlen;
+ char **value;
+ int *valuelen;
+ Lisp_Object frame;
+{
+ /* Try to find VAR in Vprocess_environment first. */
+ if (getenv_internal_1 (var, varlen, value, valuelen,
+ Vprocess_environment))
+ return *value ? 1 : 0;
+
+ /* For DISPLAY try to get the values from the frame or the initial env. */
+ if (strcmp (var, "DISPLAY") == 0)
+ {
+ Lisp_Object display
+ = Fframe_parameter (NILP (frame) ? selected_frame : frame, Qdisplay);
+ if (STRINGP (display))
+ {
+ *value = (char *) SDATA (display);
+ *valuelen = SBYTES (display);
return 1;
}
+ /* If still not found, Look for DISPLAY in Vinitial_environment. */
+ if (getenv_internal_1 (var, varlen, value, valuelen,
+ Vinitial_environment))
+ return *value ? 1 : 0;
}
return 0;
}
-DEFUN ("getenv-internal", Fgetenv_internal, Sgetenv_internal, 1, 1, 0,
- doc: /* Return the value of environment variable VAR, as a string.
-VAR should be a string. Value is nil if VAR is undefined in the environment.
-This function consults the variable `process-environment' for its value. */)
- (var)
- Lisp_Object var;
+DEFUN ("getenv-internal", Fgetenv_internal, Sgetenv_internal, 1, 2, 0,
+ doc: /* Get the value of environment variable VARIABLE.
+VARIABLE should be a string. Value is nil if VARIABLE is undefined in
+the environment. Otherwise, value is a string.
+
+This function searches `process-environment' for VARIABLE. If it is
+not found there, then it continues the search in the environment list
+of the selected frame.
+
+If optional parameter ENV is a list, then search this list instead of
+`process-environment', and return t when encountering a negative entry.
+
+If it is a frame, then this function will ignore `process-environment' and
+will simply look up the variable in that frame's environment. */)
+ (variable, env)
+ Lisp_Object variable, env;
{
char *value;
int valuelen;
- CHECK_STRING (var);
- if (getenv_internal (SDATA (var), SBYTES (var),
- &value, &valuelen))
+ CHECK_STRING (variable);
+ if (CONSP (env))
+ {
+ if (getenv_internal_1 (SDATA (variable), SBYTES (variable),
+ &value, &valuelen, env))
+ return value ? make_string (value, valuelen) : Qt;
+ else
+ return Qnil;
+ }
+ else if (getenv_internal (SDATA (variable), SBYTES (variable),
+ &value, &valuelen, env))
return make_string (value, valuelen);
else
return Qnil;
}
-/* A version of getenv that consults process_environment, easily
- callable from C. */
+/* A version of getenv that consults the Lisp environment lists,
+ easily callable from C. */
char *
egetenv (var)
char *var;
@@ -1394,7 +1513,7 @@ egetenv (var)
char *value;
int valuelen;
- if (getenv_internal (var, strlen (var), &value, &valuelen))
+ if (getenv_internal (var, strlen (var), &value, &valuelen, Qnil))
return value;
else
return 0;
@@ -1517,8 +1636,8 @@ init_callproc ()
{
char *dir = getenv ("TMPDIR");
Vtemp_file_name_pattern
- = Fexpand_file_name (build_string ("emacsXXXXXX"),
- build_string (dir));
+ = Fexpand_file_name (build_string ("emacsXXXXXX"),
+ build_string (dir));
}
else
Vtemp_file_name_pattern = build_string ("/tmp/emacsXXXXXX");
@@ -1534,17 +1653,21 @@ init_callproc ()
}
void
-set_process_environment ()
+set_initial_environment ()
{
register char **envp;
-
- Vprocess_environment = Qnil;
#ifndef CANNOT_DUMP
if (initialized)
#endif
- for (envp = environ; *envp; envp++)
- Vprocess_environment = Fcons (build_string (*envp),
- Vprocess_environment);
+ {
+ for (envp = environ; *envp; envp++)
+ Vprocess_environment = Fcons (build_string (*envp),
+ Vprocess_environment);
+ store_frame_param (SELECTED_FRAME(), Qenvironment, Vprocess_environment);
+ /* Ideally, the `copy' shouldn't be necessary, but it seems it's frequent
+ to use `delete' and friends on process-environment. */
+ Vinitial_environment = Fcopy_sequence (Vprocess_environment);
+ }
}
void
@@ -1603,16 +1726,34 @@ If this variable is nil, then Emacs is unable to use a shared directory. */);
This is used by `call-process-region'. */);
/* This variable is initialized in init_callproc. */
+ DEFVAR_LISP ("initial-environment", &Vinitial_environment,
+ doc: /* List of environment variables inherited from the parent process.
+Each element should be a string of the form ENVVARNAME=VALUE.
+The elements must normally be decoded (using `locale-coding-system') for use. */);
+ Vinitial_environment = Qnil;
+
DEFVAR_LISP ("process-environment", &Vprocess_environment,
- doc: /* List of environment variables for subprocesses to inherit.
+ doc: /* List of overridden environment variables for subprocesses to inherit.
Each element should be a string of the form ENVVARNAME=VALUE.
+
+Entries in this list take precedence to those in the frame-local
+environments. Therefore, let-binding `process-environment' is an easy
+way to temporarily change the value of an environment variable,
+irrespective of where it comes from. To use `process-environment' to
+remove an environment variable, include only its name in the list,
+without "=VALUE".
+
+This variable is set to nil when Emacs starts.
+
If multiple entries define the same variable, the first one always
takes precedence.
-The environment which Emacs inherits is placed in this variable
-when Emacs starts.
+
Non-ASCII characters are encoded according to the initial value of
-`locale-coding-system', i.e. the elements must normally be decoded for use.
+`locale-coding-system', i.e. the elements must normally be decoded for
+use.
+
See `setenv' and `getenv'. */);
+ Vprocess_environment = Qnil;
#ifndef VMS
defsubr (&Scall_process);
diff --git a/src/cm.c b/src/cm.c
index 1833121677..ad8ec080c9 100644
--- a/src/cm.c
+++ b/src/cm.c
@@ -23,8 +23,13 @@ Boston, MA 02110-1301, USA. */
#include <config.h>
#include <stdio.h>
+
+#include "lisp.h"
+#include "frame.h"
#include "cm.h"
#include "termhooks.h"
+#include "termchar.h"
+
/* For now, don't try to include termcap.h. On some systems,
configure finds a non-standard termcap.h that the main build
@@ -53,13 +58,16 @@ evalcost (c)
return c;
}
+/* The terminal to use for low-level output. */
+struct tty_display_info *current_tty;
+
int
cmputc (c)
char c;
{
- if (termscript)
- fputc (c & 0177, termscript);
- putchar (c & 0177);
+ if (current_tty->termscript)
+ putc (c & 0177, current_tty->termscript);
+ putc (c & 0177, current_tty->output);
return c;
}
@@ -72,9 +80,9 @@ cmputc (c)
*/
static
-at (row, col) {
- curY = row;
- curX = col;
+at (tty, row, col) {
+ curY (tty) = row;
+ curX (tty) = col;
}
/*
@@ -82,8 +90,8 @@ at (row, col) {
*/
static
-addcol (n) {
- curX += n;
+addcol (tty, n) {
+ curX (tty) += n;
/*
* If cursor hit edge of screen, what happened?
@@ -93,21 +101,21 @@ addcol (n) {
* of the last line.
*/
- if (curX == Wcm.cm_cols) {
+ if (curX (tty) == tty->Wcm->cm_cols) {
/*
* Well, if magicwrap, still there, past the edge of the
* screen (!). If autowrap, on the col 0 of the next line.
* Otherwise on last column.
*/
- if (Wcm.cm_magicwrap)
+ if (tty->Wcm->cm_magicwrap)
; /* "limbo" */
- else if (Wcm.cm_autowrap) {
- curX = 0;
- curY++; /* Beware end of screen! */
+ else if (tty->Wcm->cm_autowrap) {
+ curX (tty) = 0;
+ curY (tty) ++; /* Beware end of screen! */
}
else
- curX--;
+ curX (tty)--;
}
}
#endif
@@ -123,20 +131,20 @@ addcol (n) {
* after we reach the last column; this takes us to a known state.
*/
void
-cmcheckmagic ()
+cmcheckmagic (struct tty_display_info *tty)
{
- if (curX == FrameCols)
+ if (curX (tty) == FrameCols (tty))
{
- if (!MagicWrap || curY >= FrameRows - 1)
+ if (!MagicWrap (tty) || curY (tty) >= FrameRows (tty) - 1)
abort ();
- if (termscript)
- putc ('\r', termscript);
- putchar ('\r');
- if (termscript)
- putc ('\n', termscript);
- putchar ('\n');
- curX = 0;
- curY++;
+ if (tty->termscript)
+ putc ('\r', tty->termscript);
+ putc ('\r', tty->output);
+ if (tty->termscript)
+ putc ('\n', tty->termscript);
+ putc ('\n', tty->output);
+ curX (tty) = 0;
+ curY (tty)++;
}
}
@@ -148,21 +156,21 @@ cmcheckmagic ()
*/
void
-cmcostinit ()
+cmcostinit (struct tty_display_info *tty)
{
char *p;
#define COST(x,e) (x ? (cost = 0, tputs (x, 1, e), cost) : BIG)
#define CMCOST(x,e) ((x == 0) ? BIG : (p = tgoto(x, 0, 0), COST(p ,e)))
- Wcm.cc_up = COST (Wcm.cm_up, evalcost);
- Wcm.cc_down = COST (Wcm.cm_down, evalcost);
- Wcm.cc_left = COST (Wcm.cm_left, evalcost);
- Wcm.cc_right = COST (Wcm.cm_right, evalcost);
- Wcm.cc_home = COST (Wcm.cm_home, evalcost);
- Wcm.cc_cr = COST (Wcm.cm_cr, evalcost);
- Wcm.cc_ll = COST (Wcm.cm_ll, evalcost);
- Wcm.cc_tab = Wcm.cm_tabwidth ? COST (Wcm.cm_tab, evalcost) : BIG;
+ tty->Wcm->cc_up = COST (tty->Wcm->cm_up, evalcost);
+ tty->Wcm->cc_down = COST (tty->Wcm->cm_down, evalcost);
+ tty->Wcm->cc_left = COST (tty->Wcm->cm_left, evalcost);
+ tty->Wcm->cc_right = COST (tty->Wcm->cm_right, evalcost);
+ tty->Wcm->cc_home = COST (tty->Wcm->cm_home, evalcost);
+ tty->Wcm->cc_cr = COST (tty->Wcm->cm_cr, evalcost);
+ tty->Wcm->cc_ll = COST (tty->Wcm->cm_ll, evalcost);
+ tty->Wcm->cc_tab = tty->Wcm->cm_tabwidth ? COST (tty->Wcm->cm_tab, evalcost) : BIG;
/*
* These last three are actually minimum costs. When (if) they are
@@ -173,9 +181,9 @@ cmcostinit ()
* cursor motion seem to take straight numeric values. --ACT)
*/
- Wcm.cc_abs = CMCOST (Wcm.cm_abs, evalcost);
- Wcm.cc_habs = CMCOST (Wcm.cm_habs, evalcost);
- Wcm.cc_vabs = CMCOST (Wcm.cm_vabs, evalcost);
+ tty->Wcm->cc_abs = CMCOST (tty->Wcm->cm_abs, evalcost);
+ tty->Wcm->cc_habs = CMCOST (tty->Wcm->cm_habs, evalcost);
+ tty->Wcm->cc_vabs = CMCOST (tty->Wcm->cm_vabs, evalcost);
#undef CMCOST
#undef COST
@@ -188,8 +196,8 @@ cmcostinit ()
*/
static int
-calccost (srcy, srcx, dsty, dstx, doit)
- int srcy, srcx, dsty, dstx, doit;
+calccost (struct tty_display_info *tty,
+ int srcy, int srcx, int dsty, int dstx, int doit)
{
register int deltay,
deltax,
@@ -206,16 +214,16 @@ calccost (srcy, srcx, dsty, dstx, doit)
don't believe the cursor position: give up here
and force use of absolute positioning. */
- if (curX == Wcm.cm_cols)
+ if (curX (tty) == tty->Wcm->cm_cols)
goto fail;
totalcost = 0;
if ((deltay = dsty - srcy) == 0)
goto x;
if (deltay < 0)
- p = Wcm.cm_up, c = Wcm.cc_up, deltay = -deltay;
+ p = tty->Wcm->cm_up, c = tty->Wcm->cc_up, deltay = -deltay;
else
- p = Wcm.cm_down, c = Wcm.cc_down;
+ p = tty->Wcm->cm_down, c = tty->Wcm->cc_down;
if (c == BIG) { /* caint get thar from here */
if (doit)
printf ("OOPS");
@@ -224,16 +232,16 @@ calccost (srcy, srcx, dsty, dstx, doit)
totalcost = c * deltay;
if (doit)
while (--deltay >= 0)
- tputs (p, 1, cmputc);
+ emacs_tputs (tty, p, 1, cmputc);
x:
if ((deltax = dstx - srcx) == 0)
goto done;
if (deltax < 0) {
- p = Wcm.cm_left, c = Wcm.cc_left, deltax = -deltax;
+ p = tty->Wcm->cm_left, c = tty->Wcm->cc_left, deltax = -deltax;
goto dodelta; /* skip all the tab junk */
}
/* Tabs (the toughie) */
- if (Wcm.cc_tab >= BIG || !Wcm.cm_usetabs)
+ if (tty->Wcm->cc_tab >= BIG || !tty->Wcm->cm_usetabs)
goto olddelta; /* forget it! */
/*
@@ -244,12 +252,12 @@ x:
* we will put into tabx (for ntabs) and tab2x (for n2tabs)).
*/
- ntabs = (deltax + srcx % Wcm.cm_tabwidth) / Wcm.cm_tabwidth;
+ ntabs = (deltax + srcx % tty->Wcm->cm_tabwidth) / tty->Wcm->cm_tabwidth;
n2tabs = ntabs + 1;
- tabx = (srcx / Wcm.cm_tabwidth + ntabs) * Wcm.cm_tabwidth;
- tab2x = tabx + Wcm.cm_tabwidth;
+ tabx = (srcx / tty->Wcm->cm_tabwidth + ntabs) * tty->Wcm->cm_tabwidth;
+ tab2x = tabx + tty->Wcm->cm_tabwidth;
- if (tab2x >= Wcm.cm_cols) /* too far (past edge) */
+ if (tab2x >= tty->Wcm->cm_cols) /* too far (past edge) */
n2tabs = 0;
/*
@@ -257,12 +265,12 @@ x:
* for using n2tabs, then pick the minimum.
*/
- /* cost for ntabs + cost for right motion */
- tabcost = ntabs ? ntabs * Wcm.cc_tab + (dstx - tabx) * Wcm.cc_right
+ /* cost for ntabs + cost for right motion */
+ tabcost = ntabs ? ntabs * tty->Wcm->cc_tab + (dstx - tabx) * tty->Wcm->cc_right
: BIG;
- /* cost for n2tabs + cost for left motion */
- c = n2tabs ? n2tabs * Wcm.cc_tab + (tab2x - dstx) * Wcm.cc_left
+ /* cost for n2tabs + cost for left motion */
+ c = n2tabs ? n2tabs * tty->Wcm->cc_tab + (tab2x - dstx) * tty->Wcm->cc_left
: BIG;
if (c < tabcost) /* then cheaper to overshoot & back up */
@@ -275,11 +283,11 @@ x:
* See if tabcost is less than just moving right
*/
- if (tabcost < (deltax * Wcm.cc_right)) {
+ if (tabcost < (deltax * tty->Wcm->cc_right)) {
totalcost += tabcost; /* use the tabs */
if (doit)
while (--ntabs >= 0)
- tputs (Wcm.cm_tab, 1, cmputc);
+ emacs_tputs (tty, tty->Wcm->cm_tab, 1, cmputc);
srcx = tabx;
}
@@ -292,9 +300,9 @@ newdelta:
goto done;
olddelta:
if (deltax > 0)
- p = Wcm.cm_right, c = Wcm.cc_right;
+ p = tty->Wcm->cm_right, c = tty->Wcm->cc_right;
else
- p = Wcm.cm_left, c = Wcm.cc_left, deltax = -deltax;
+ p = tty->Wcm->cm_left, c = tty->Wcm->cc_left, deltax = -deltax;
dodelta:
if (c == BIG) { /* caint get thar from here */
@@ -306,7 +314,7 @@ fail:
totalcost += c * deltax;
if (doit)
while (--deltax >= 0)
- tputs (p, 1, cmputc);
+ emacs_tputs (tty, p, 1, cmputc);
done:
return totalcost;
}
@@ -324,7 +332,8 @@ losecursor ()
#define USECR 3
void
-cmgoto (row, col)
+cmgoto (tty, row, col)
+ struct tty_display_info *tty;
int row, col;
{
int homecost,
@@ -337,47 +346,47 @@ cmgoto (row, col)
*dcm;
/* First the degenerate case */
- if (row == curY && col == curX) /* already there */
+ if (row == curY (tty) && col == curX (tty)) /* already there */
return;
- if (curY >= 0 && curX >= 0)
+ if (curY (tty) >= 0 && curX (tty) >= 0)
{
/* We may have quick ways to go to the upper-left, bottom-left,
* start-of-line, or start-of-next-line. Or it might be best to
* start where we are. Examine the options, and pick the cheapest.
*/
- relcost = calccost (curY, curX, row, col, 0);
+ relcost = calccost (tty, curY (tty), curX (tty), row, col, 0);
use = USEREL;
- if ((homecost = Wcm.cc_home) < BIG)
- homecost += calccost (0, 0, row, col, 0);
+ if ((homecost = tty->Wcm->cc_home) < BIG)
+ homecost += calccost (tty, 0, 0, row, col, 0);
if (homecost < relcost)
- relcost = homecost, use = USEHOME;
- if ((llcost = Wcm.cc_ll) < BIG)
- llcost += calccost (Wcm.cm_rows - 1, 0, row, col, 0);
+ relcost = homecost, use = USEHOME;
+ if ((llcost = tty->Wcm->cc_ll) < BIG)
+ llcost += calccost (tty, tty->Wcm->cm_rows - 1, 0, row, col, 0);
if (llcost < relcost)
- relcost = llcost, use = USELL;
- if ((crcost = Wcm.cc_cr) < BIG) {
- if (Wcm.cm_autolf)
- if (curY + 1 >= Wcm.cm_rows)
- crcost = BIG;
+ relcost = llcost, use = USELL;
+ if ((crcost = tty->Wcm->cc_cr) < BIG) {
+ if (tty->Wcm->cm_autolf)
+ if (curY (tty) + 1 >= tty->Wcm->cm_rows)
+ crcost = BIG;
else
- crcost += calccost (curY + 1, 0, row, col, 0);
+ crcost += calccost (tty, curY (tty) + 1, 0, row, col, 0);
else
- crcost += calccost (curY, 0, row, col, 0);
+ crcost += calccost (tty, curY (tty), 0, row, col, 0);
}
if (crcost < relcost)
relcost = crcost, use = USECR;
- directcost = Wcm.cc_abs, dcm = Wcm.cm_abs;
- if (row == curY && Wcm.cc_habs < BIG)
- directcost = Wcm.cc_habs, dcm = Wcm.cm_habs;
- else if (col == curX && Wcm.cc_vabs < BIG)
- directcost = Wcm.cc_vabs, dcm = Wcm.cm_vabs;
+ directcost = tty->Wcm->cc_abs, dcm = tty->Wcm->cm_abs;
+ if (row == curY (tty) && tty->Wcm->cc_habs < BIG)
+ directcost = tty->Wcm->cc_habs, dcm = tty->Wcm->cm_habs;
+ else if (col == curX (tty) && tty->Wcm->cc_vabs < BIG)
+ directcost = tty->Wcm->cc_vabs, dcm = tty->Wcm->cm_vabs;
}
else
{
directcost = 0, relcost = 100000;
- dcm = Wcm.cm_abs;
+ dcm = tty->Wcm->cm_abs;
}
/*
@@ -388,13 +397,14 @@ cmgoto (row, col)
{
/* compute REAL direct cost */
cost = 0;
- p = dcm == Wcm.cm_habs ? tgoto (dcm, row, col) :
- tgoto (dcm, col, row);
- tputs (p, 1, evalcost);
+ p = (dcm == tty->Wcm->cm_habs
+ ? tgoto (dcm, row, col)
+ : tgoto (dcm, col, row));
+ emacs_tputs (tty, p, 1, evalcost);
if (cost <= relcost)
{ /* really is cheaper */
- tputs (p, 1, cmputc);
- curY = row, curX = col;
+ emacs_tputs (tty, p, 1, cmputc);
+ curY (tty) = row, curX (tty) = col;
return;
}
}
@@ -402,25 +412,25 @@ cmgoto (row, col)
switch (use)
{
case USEHOME:
- tputs (Wcm.cm_home, 1, cmputc);
- curY = 0, curX = 0;
+ emacs_tputs (tty, tty->Wcm->cm_home, 1, cmputc);
+ curY (tty) = 0, curX (tty) = 0;
break;
case USELL:
- tputs (Wcm.cm_ll, 1, cmputc);
- curY = Wcm.cm_rows - 1, curX = 0;
+ emacs_tputs (tty, tty->Wcm->cm_ll, 1, cmputc);
+ curY (tty) = tty->Wcm->cm_rows - 1, curX (tty) = 0;
break;
case USECR:
- tputs (Wcm.cm_cr, 1, cmputc);
- if (Wcm.cm_autolf)
- curY++;
- curX = 0;
+ emacs_tputs (tty, tty->Wcm->cm_cr, 1, cmputc);
+ if (tty->Wcm->cm_autolf)
+ curY (tty)++;
+ curX (tty) = 0;
break;
}
- (void) calccost (curY, curX, row, col, 1);
- curY = row, curX = col;
+ (void) calccost (tty, curY (tty), curX (tty), row, col, 1);
+ curY (tty) = row, curX (tty) = col;
}
/* Clear out all terminal info.
@@ -428,9 +438,9 @@ cmgoto (row, col)
*/
void
-Wcm_clear ()
+Wcm_clear (struct tty_display_info *tty)
{
- bzero (&Wcm, sizeof Wcm);
+ bzero (tty->Wcm, sizeof (struct cm));
UP = 0;
BC = 0;
}
@@ -443,21 +453,21 @@ Wcm_clear ()
*/
int
-Wcm_init ()
+Wcm_init (struct tty_display_info *tty)
{
#if 0
- if (Wcm.cm_abs && !Wcm.cm_ds)
+ if (tty->Wcm->cm_abs && !tty->Wcm->cm_ds)
return 0;
#endif
- if (Wcm.cm_abs)
+ if (tty->Wcm->cm_abs)
return 0;
/* Require up and left, and, if no absolute, down and right */
- if (!Wcm.cm_up || !Wcm.cm_left)
+ if (!tty->Wcm->cm_up || !tty->Wcm->cm_left)
return - 1;
- if (!Wcm.cm_abs && (!Wcm.cm_down || !Wcm.cm_right))
+ if (!tty->Wcm->cm_abs && (!tty->Wcm->cm_down || !tty->Wcm->cm_right))
return - 1;
/* Check that we know the size of the screen.... */
- if (Wcm.cm_rows <= 0 || Wcm.cm_cols <= 0)
+ if (tty->Wcm->cm_rows <= 0 || tty->Wcm->cm_cols <= 0)
return - 2;
return 0;
}
diff --git a/src/cm.h b/src/cm.h
index 7c26a9ce66..36413703a9 100644
--- a/src/cm.h
+++ b/src/cm.h
@@ -99,76 +99,78 @@ struct cm
int cc_vabs;
};
-extern struct cm Wcm; /* Terminal capabilities */
extern char PC; /* Pad character */
/* Shorthand */
#ifndef NoCMShortHand
-#define curY Wcm.cm_curY
-#define curX Wcm.cm_curX
-#define Up Wcm.cm_up
-#define Down Wcm.cm_down
-#define Left Wcm.cm_left
-#define Right Wcm.cm_right
-#define Tab Wcm.cm_tab
-#define BackTab Wcm.cm_backtab
-#define TabWidth Wcm.cm_tabwidth
-#define CR Wcm.cm_cr
-#define Home Wcm.cm_home
-#define LastLine Wcm.cm_ll
-#define AbsPosition Wcm.cm_abs
-#define ColPosition Wcm.cm_habs
-#define RowPosition Wcm.cm_vabs
-#define MultiUp Wcm.cm_multiup
-#define MultiDown Wcm.cm_multidown
-#define MultiLeft Wcm.cm_multileft
-#define MultiRight Wcm.cm_multiright
-#define AutoWrap Wcm.cm_autowrap
-#define MagicWrap Wcm.cm_magicwrap
-#define UseTabs Wcm.cm_usetabs
-#define FrameRows Wcm.cm_rows
-#define FrameCols Wcm.cm_cols
-
-#define UpCost Wcm.cc_up
-#define DownCost Wcm.cc_down
-#define LeftCost Wcm.cc_left
-#define RightCost Wcm.cc_right
-#define HomeCost Wcm.cc_home
-#define CRCost Wcm.cc_cr
-#define LastLineCost Wcm.cc_ll
-#define TabCost Wcm.cc_tab
-#define BackTabCost Wcm.cc_backtab
-#define AbsPositionCost Wcm.cc_abs
-#define ColPositionCost Wcm.cc_habs
-#define RowPositionCost Wcm.cc_vabs
-#define MultiUpCost Wcm.cc_multiup
-#define MultiDownCost Wcm.cc_multidown
-#define MultiLeftCost Wcm.cc_multileft
-#define MultiRightCost Wcm.cc_multiright
+#define curY(tty) (tty)->Wcm->cm_curY
+#define curX(tty) (tty)->Wcm->cm_curX
+#define Up(tty) (tty)->Wcm->cm_up
+#define Down(tty) (tty)->Wcm->cm_down
+#define Left(tty) (tty)->Wcm->cm_left
+#define Right(tty) (tty)->Wcm->cm_right
+#define Tab(tty) (tty)->Wcm->cm_tab
+#define BackTab(tty) (tty)->Wcm->cm_backtab
+#define TabWidth(tty) (tty)->Wcm->cm_tabwidth
+#define CR(tty) (tty)->Wcm->cm_cr
+#define Home(tty) (tty)->Wcm->cm_home
+#define LastLine(tty) (tty)->Wcm->cm_ll
+#define AbsPosition(tty) (tty)->Wcm->cm_abs
+#define ColPosition(tty) (tty)->Wcm->cm_habs
+#define RowPosition(tty) (tty)->Wcm->cm_vabs
+#define MultiUp(tty) (tty)->Wcm->cm_multiup
+#define MultiDown(tty) (tty)->Wcm->cm_multidown
+#define MultiLeft(tty) (tty)->Wcm->cm_multileft
+#define MultiRight(tty) (tty)->Wcm->cm_multiright
+#define AutoWrap(tty) (tty)->Wcm->cm_autowrap
+#define MagicWrap(tty) (tty)->Wcm->cm_magicwrap
+#define UseTabs(tty) (tty)->Wcm->cm_usetabs
+#define FrameRows(tty) (tty)->Wcm->cm_rows
+#define FrameCols(tty) (tty)->Wcm->cm_cols
+
+#define UpCost(tty) (tty)->Wcm->cc_up
+#define DownCost(tty) (tty)->Wcm->cc_down
+#define LeftCost(tty) (tty)->Wcm->cc_left
+#define RightCost(tty) (tty)->Wcm->cc_right
+#define HomeCost(tty) (tty)->Wcm->cc_home
+#define CRCost(tty) (tty)->Wcm->cc_cr
+#define LastLineCost(tty) (tty)->Wcm->cc_ll
+#define TabCost(tty) (tty)->Wcm->cc_tab
+#define BackTabCost(tty) (tty)->Wcm->cc_backtab
+#define AbsPositionCost(tty) (tty)->Wcm->cc_abs
+#define ColPositionCost(tty) (tty)->Wcm->cc_habs
+#define RowPositionCost(tty) (tty)->Wcm->cc_vabs
+#define MultiUpCost(tty) (tty)->Wcm->cc_multiup
+#define MultiDownCost(tty) (tty)->Wcm->cc_multidown
+#define MultiLeftCost(tty) (tty)->Wcm->cc_multileft
+#define MultiRightCost(tty) (tty)->Wcm->cc_multiright
#endif
-#define cmat(row,col) (curY = (row), curX = (col))
-#define cmplus(n) \
- { \
- if ((curX += (n)) >= FrameCols && !MagicWrap) \
- { \
- if (Wcm.cm_losewrap) losecursor (); \
- else if (AutoWrap) curX = 0, curY++; \
- else curX--; \
- } \
+#define cmat(tty,row,col) (curY(tty) = (row), curX(tty) = (col))
+#define cmplus(tty,n) \
+ { \
+ if ((curX (tty) += (n)) >= FrameCols (tty) && !MagicWrap (tty)) \
+ { \
+ if ((tty)->Wcm->cm_losewrap) losecursor (tty); \
+ else if (AutoWrap (tty)) curX (tty) = 0, curY (tty)++; \
+ else curX (tty)--; \
+ } \
}
-#define losecursor() (curX = -1, curY = -1)
+#define losecursor(tty) (curX(tty) = -1, curY(tty) = -1)
extern int cost;
extern int evalcost ();
-extern void cmcheckmagic ();
-extern int cmputc ();
-extern void cmcostinit ();
-extern void cmgoto ();
-extern void Wcm_clear ();
-extern int Wcm_init ();
+#define emacs_tputs(tty, str, affcnt, putc) (current_tty = (tty), tputs (str, affcnt, putc))
+
+extern struct tty_display_info *current_tty;
+extern void cmcheckmagic P_ ((struct tty_display_info *));
+extern int cmputc P_ ((int));
+extern void cmcostinit P_ ((struct tty_display_info *));
+extern void cmgoto P_ ((struct tty_display_info *, int, int));
+extern void Wcm_clear P_ ((struct tty_display_info *));
+extern int Wcm_init P_ ((struct tty_display_info *));
/* arch-tag: acc1535a-7136-49d6-b22d-9bc85702251b
(do not change this comment) */
diff --git a/src/coding.c b/src/coding.c
index 20c6c000c7..8ab5a1107a 100644
--- a/src/coding.c
+++ b/src/coding.c
@@ -300,6 +300,8 @@ encode_coding_XXX (coding)
#include "composite.h"
#include "coding.h"
#include "window.h"
+#include "frame.h"
+#include "termhooks.h"
Lisp_Object Vcoding_system_hash_table;
@@ -381,15 +383,12 @@ int inhibit_iso_escape_detection;
/* Flag to make buffer-file-coding-system inherit from process-coding. */
int inherit_process_coding_system;
-/* Coding system to be used to encode text for terminal display. */
-struct coding_system terminal_coding;
-
/* Coding system to be used to encode text for terminal display when
terminal coding system is nil. */
struct coding_system safe_terminal_coding;
-/* Coding system of what is sent from terminal keyboard. */
-struct coding_system keyboard_coding;
+/* Default coding system to be used to write a file. */
+struct coding_system default_buffer_file_coding;
Lisp_Object Vfile_coding_system_alist;
Lisp_Object Vprocess_coding_system_alist;
@@ -8286,23 +8285,22 @@ Return the corresponding character code in Big5. */)
}
-DEFUN ("set-terminal-coding-system-internal",
- Fset_terminal_coding_system_internal,
- Sset_terminal_coding_system_internal, 1, 1, 0,
+DEFUN ("set-terminal-coding-system-internal", Fset_terminal_coding_system_internal,
+ Sset_terminal_coding_system_internal, 1, 2, 0,
doc: /* Internal use only. */)
- (coding_system)
+ (coding_system, terminal)
Lisp_Object coding_system;
+ Lisp_Object terminal;
{
+ struct coding_system *terminal_coding = TERMINAL_TERMINAL_CODING (get_terminal (terminal, 1));
CHECK_SYMBOL (coding_system);
- setup_coding_system (Fcheck_coding_system (coding_system),
- &terminal_coding);
-
+ setup_coding_system (Fcheck_coding_system (coding_system), terminal_coding);
/* We had better not send unsafe characters to terminal. */
- terminal_coding.mode |= CODING_MODE_SAFE_ENCODING;
+ terminal_coding->mode |= CODING_MODE_SAFE_ENCODING;
/* Characer composition should be disabled. */
- terminal_coding.common_flags &= ~CODING_ANNOTATE_COMPOSITION_MASK;
- terminal_coding.src_multibyte = 1;
- terminal_coding.dst_multibyte = 0;
+ terminal_coding->common_flags &= ~CODING_ANNOTATE_COMPOSITION_MASK;
+ terminal_coding->src_multibyte = 1;
+ terminal_coding->dst_multibyte = 0;
return Qnil;
}
@@ -8323,30 +8321,35 @@ DEFUN ("set-safe-terminal-coding-system-internal",
return Qnil;
}
-DEFUN ("terminal-coding-system",
- Fterminal_coding_system, Sterminal_coding_system, 0, 0, 0,
- doc: /* Return coding system specified for terminal output. */)
- ()
+DEFUN ("terminal-coding-system", Fterminal_coding_system,
+ Sterminal_coding_system, 0, 1, 0,
+ doc: /* Return coding system specified for terminal output on the given terminal.
+TERMINAL may be a terminal id, a frame, or nil for the selected
+frame's terminal device. */)
+ (terminal)
+ Lisp_Object terminal;
{
Lisp_Object coding_system;
- coding_system = CODING_ID_NAME (terminal_coding.id);
+ coding_system = TERMINAL_TERMINAL_CODING (get_terminal (terminal, 1))->symbol;
/* For backward compatibility, return nil if it is `undecided'. */
return (! EQ (coding_system, Qundecided) ? coding_system : Qnil);
}
-DEFUN ("set-keyboard-coding-system-internal",
- Fset_keyboard_coding_system_internal,
- Sset_keyboard_coding_system_internal, 1, 1, 0,
+DEFUN ("set-keyboard-coding-system-internal", Fset_keyboard_coding_system_internal,
+ Sset_keyboard_coding_system_internal, 1, 2, 0,
doc: /* Internal use only. */)
- (coding_system)
+ (coding_system, terminal)
Lisp_Object coding_system;
+ Lisp_Object terminal;
{
+ struct terminal *t = get_terminal (terminal, 1);
CHECK_SYMBOL (coding_system);
setup_coding_system (Fcheck_coding_system (coding_system),
- &keyboard_coding);
+ TERMINAL_KEYBOARD_CODING (t));
/* Characer composition should be disabled. */
- keyboard_coding.common_flags &= ~CODING_ANNOTATE_COMPOSITION_MASK;
+ TERMINAL_KEYBOARD_CODING (t)->common_flags
+ &= ~CODING_ANNOTATE_COMPOSITION_MASK;
return Qnil;
}
diff --git a/src/coding.h b/src/coding.h
index 134402f325..573632abb9 100644
--- a/src/coding.h
+++ b/src/coding.h
@@ -742,19 +742,12 @@ extern Lisp_Object Vlocale_coding_system;
the subprocess output. */
extern int inherit_process_coding_system;
-/* Coding-system to be used for encoding terminal output. This
- structure contains information of a coding-system specified by the
- function `set-terminal-coding-system'. */
-extern struct coding_system terminal_coding;
-
/* Coding system to be used to encode text for terminal display when
terminal coding system is nil. */
extern struct coding_system safe_terminal_coding;
-/* Coding-system of what is sent from terminal keyboard. This
- structure contains information of a coding-system specified by the
- function `set-keyboard-coding-system'. */
-extern struct coding_system keyboard_coding;
+/* Default coding system to be used to write a file. */
+extern struct coding_system default_buffer_file_coding;
/* Default coding systems used for process I/O. */
extern Lisp_Object Vdefault_process_coding_system;
diff --git a/src/config.in b/src/config.in
index f2636c5062..60be3c2200 100644
--- a/src/config.in
+++ b/src/config.in
@@ -941,6 +941,13 @@ Boston, MA 02110-1301, USA. */
#define HAVE_MOUSE
#endif
+/* Multi-tty support relies on MULTI_KBOARD. It seems safe to turn it
+ on unconditionally. Note that src/s/darwin.h disables this at
+ present. */
+#ifndef MULTI_KBOARD
+#define MULTI_KBOARD
+#endif
+
/* If we're using the Carbon API on Mac OS X, define a few more
variables as well. */
#ifdef HAVE_CARBON
diff --git a/src/data.c b/src/data.c
index b262f6e2b9..6439686dcd 100644
--- a/src/data.c
+++ b/src/data.c
@@ -30,6 +30,7 @@ Boston, MA 02110-1301, USA. */
#include "keyboard.h"
#include "frame.h"
#include "syssignal.h"
+#include "termhooks.h" /* For FRAME_KBOARD reference in y-or-n-p. */
#ifdef STDC_HEADERS
#include <float.h>
@@ -769,8 +770,11 @@ Value, if non-nil, is a list \(interactive SPEC). */)
if (SUBRP (fun))
{
- if (XSUBR (fun)->prompt)
- return list2 (Qinteractive, build_string (XSUBR (fun)->prompt));
+ char *spec = XSUBR (fun)->intspec;
+ if (spec)
+ return list2 (Qinteractive,
+ (*spec != '(') ? build_string (spec) :
+ Fcar (Fread_from_string (build_string (spec), Qnil, Qnil)));
}
else if (COMPILEDP (fun))
{
@@ -873,7 +877,18 @@ do_symval_forwarding (valcontents)
case Lisp_Misc_Kboard_Objfwd:
offset = XKBOARD_OBJFWD (valcontents)->offset;
- return *(Lisp_Object *)(offset + (char *)current_kboard);
+ /* We used to simply use current_kboard here, but from Lisp
+ code, it's value is often unexpected. It seems nicer to
+ allow constructions like this to work as intuitively expected:
+
+ (with-selected-frame frame
+ (define-key local-function-map "\eOP" [f1]))
+
+ On the other hand, this affects the semantics of
+ last-command and real-last-command, and people may rely on
+ that. I took a quick look at the Lisp codebase, and I
+ don't think anything will break. --lorentey */
+ return *(Lisp_Object *)(offset + (char *)FRAME_KBOARD (SELECTED_FRAME ()));
}
return valcontents;
}
@@ -961,7 +976,7 @@ store_symval_forwarding (symbol, valcontents, newval, buf)
case Lisp_Misc_Kboard_Objfwd:
{
- char *base = (char *) current_kboard;
+ char *base = (char *) FRAME_KBOARD (SELECTED_FRAME ());
char *p = base + XKBOARD_OBJFWD (valcontents)->offset;
*(Lisp_Object *) p = newval;
}
@@ -1107,7 +1122,7 @@ find_symbol_value (symbol)
case Lisp_Misc_Kboard_Objfwd:
return *(Lisp_Object *)(XKBOARD_OBJFWD (valcontents)->offset
- + (char *)current_kboard);
+ + (char *)FRAME_KBOARD (SELECTED_FRAME ()));
}
}
@@ -1868,6 +1883,51 @@ If the current binding is global (the default), the value is nil. */)
return Qnil;
}
+
+/* This code is disabled now that we use the selected frame to return
+ keyboard-local-values. */
+#if 0
+extern struct terminal *get_terminal P_ ((Lisp_Object display, int));
+
+DEFUN ("terminal-local-value", Fterminal_local_value, Sterminal_local_value, 2, 2, 0,
+ doc: /* Return the terminal-local value of SYMBOL on TERMINAL.
+If SYMBOL is not a terminal-local variable, then return its normal
+value, like `symbol-value'.
+
+TERMINAL may be a terminal id, a frame, or nil (meaning the
+selected frame's terminal device). */)
+ (symbol, terminal)
+ Lisp_Object symbol;
+ Lisp_Object terminal;
+{
+ Lisp_Object result;
+ struct terminal *t = get_terminal (terminal, 1);
+ push_kboard (t->kboard);
+ result = Fsymbol_value (symbol);
+ pop_kboard ();
+ return result;
+}
+
+DEFUN ("set-terminal-local-value", Fset_terminal_local_value, Sset_terminal_local_value, 3, 3, 0,
+ doc: /* Set the terminal-local binding of SYMBOL on TERMINAL to VALUE.
+If VARIABLE is not a terminal-local variable, then set its normal
+binding, like `set'.
+
+TERMINAL may be a terminal id, a frame, or nil (meaning the
+selected frame's terminal device). */)
+ (symbol, terminal, value)
+ Lisp_Object symbol;
+ Lisp_Object terminal;
+ Lisp_Object value;
+{
+ Lisp_Object result;
+ struct terminal *t = get_terminal (terminal, 1);
+ push_kboard (d->kboard);
+ result = Fset (symbol, value);
+ pop_kboard ();
+ return result;
+}
+#endif
/* Find the function at the end of a chain of symbol function indirections. */
@@ -3173,6 +3233,10 @@ syms_of_data ()
defsubr (&Slocal_variable_p);
defsubr (&Slocal_variable_if_set_p);
defsubr (&Svariable_binding_locus);
+#if 0 /* XXX Remove this. --lorentey */
+ defsubr (&Sterminal_local_value);
+ defsubr (&Sset_terminal_local_value);
+#endif
defsubr (&Saref);
defsubr (&Saset);
defsubr (&Snumber_to_string);
diff --git a/src/dispextern.h b/src/dispextern.h
index 6241b5aa2c..1ba2955fcb 100644
--- a/src/dispextern.h
+++ b/src/dispextern.h
@@ -1033,13 +1033,8 @@ extern int fonts_changed_p;
extern struct glyph space_glyph;
-/* Frame being updated by update_window/update_frame. */
-
-extern struct frame *updating_frame;
-
/* Window being updated by update_window. This is non-null as long as
- update_window has not finished, and null otherwise. It's role is
- analogous to updating_frame. */
+ update_window has not finished, and null otherwise. */
extern struct window *updated_window;
@@ -1367,7 +1362,7 @@ struct glyph_string
DESCENT = FONT->descent
HEIGHT = FONT_HEIGHT (FONT)
F_DESCENT = (FRAME_FONT (F)->descent
- - F->output_data.x->baseline_offset)
+ - F->terminal->output_data.x->baseline_offset)
F_HEIGHT = FRAME_LINE_HEIGHT (F)
*/
@@ -2199,16 +2194,16 @@ struct it
/* Call produce_glyphs or produce_glyphs_hook, if set. Shortcut to
avoid the function call overhead. */
-#define PRODUCE_GLYPHS(IT) \
- do { \
- extern int inhibit_free_realized_faces; \
- if (rif != NULL) \
- rif->produce_glyphs ((IT)); \
- else \
- produce_glyphs ((IT)); \
- if ((IT)->glyph_row != NULL) \
- inhibit_free_realized_faces = 1; \
- } while (0)
+#define PRODUCE_GLYPHS(IT) \
+ do { \
+ extern int inhibit_free_realized_faces; \
+ if (FRAME_RIF ((IT)->f) != NULL) \
+ FRAME_RIF ((IT)->f)->produce_glyphs ((IT)); \
+ else \
+ produce_glyphs ((IT)); \
+ if ((IT)->glyph_row != NULL) \
+ inhibit_free_realized_faces = 1; \
+ } while (0)
/* Bit-flags indicating what operation move_it_to should perform. */
@@ -2384,10 +2379,6 @@ struct redisplay_interface
#endif /* HAVE_WINDOW_SYSTEM */
};
-/* The current interface for window-based redisplay. */
-
-extern struct redisplay_interface *rif;
-
/***********************************************************************
Images
@@ -2691,8 +2682,6 @@ void init_iterator_to_row_start P_ ((struct it *, struct window *,
struct glyph_row *));
int get_next_display_element P_ ((struct it *));
void set_iterator_to_next P_ ((struct it *, int));
-void produce_glyphs P_ ((struct it *));
-void produce_special_glyphs P_ ((struct it *, enum display_element_type));
void start_display P_ ((struct it *, struct window *, struct text_pos));
void move_it_to P_ ((struct it *, int, int, int, int, int));
void move_it_vertically P_ ((struct it *, int));
@@ -2790,11 +2779,11 @@ int update_window_fringes P_ ((struct window *, int));
void compute_fringe_widths P_ ((struct frame *, int));
#ifdef WINDOWS_NT
-void w32_init_fringe P_ ((void));
+void w32_init_fringe P_ ((struct redisplay_interface *));
void w32_reset_fringes P_ ((void));
#endif
#ifdef MAC_OS
-void mac_init_fringe P_ ((void));
+void mac_init_fringe P_ ((struct redisplay_interface *));
#endif
/* Defined in image.c */
@@ -2839,11 +2828,11 @@ int image_ascent P_ ((struct image *, struct face *, struct glyph_slice *));
/* Defined in sysdep.c */
-void get_frame_size P_ ((int *, int *));
+void get_tty_size P_ ((int, int *, int *));
void request_sigio P_ ((void));
void unrequest_sigio P_ ((void));
-int tabs_safe_p P_ ((void));
-void init_baud_rate P_ ((void));
+int tabs_safe_p P_ ((int));
+void init_baud_rate P_ ((int));
void init_sigio P_ ((int));
/* Defined in xfaces.c */
@@ -2986,8 +2975,6 @@ void clear_glyph_row P_ ((struct glyph_row *));
void prepare_desired_row P_ ((struct glyph_row *));
int line_hash_code P_ ((struct glyph_row *));
void set_window_update_flags P_ ((struct window *, int));
-void write_glyphs P_ ((struct glyph *, int));
-void insert_glyphs P_ ((struct glyph *, int));
void redraw_frame P_ ((struct frame *));
void redraw_garbaged_frames P_ ((void));
int scroll_cost P_ ((struct frame *, int, int, int));
@@ -3004,31 +2991,44 @@ void syms_of_display P_ ((void));
extern Lisp_Object Qredisplay_dont_pause;
GLYPH spec_glyph_lookup_face P_ ((struct window *, GLYPH));
-/* Defined in term.c */
+/* Defined in terminal.c */
-extern void ring_bell P_ ((void));
-extern void set_terminal_modes P_ ((void));
-extern void reset_terminal_modes P_ ((void));
+extern void ring_bell P_ ((struct frame *));
extern void update_begin P_ ((struct frame *));
extern void update_end P_ ((struct frame *));
-extern void set_terminal_window P_ ((int));
-extern void set_scroll_region P_ ((int, int));
-extern void turn_off_insert P_ ((void));
-extern void turn_off_highlight P_ ((void));
-extern void background_highlight P_ ((void));
-extern void clear_frame P_ ((void));
-extern void clear_end_of_line P_ ((int));
-extern void clear_end_of_line_raw P_ ((int));
-extern void delete_glyphs P_ ((int));
-extern void ins_del_lines P_ ((int, int));
+extern void set_terminal_window P_ ((struct frame *, int));
+extern void cursor_to P_ ((struct frame *, int, int));
+extern void raw_cursor_to P_ ((struct frame *, int, int));
+extern void clear_to_end P_ ((struct frame *));
+extern void clear_frame P_ ((struct frame *));
+extern void clear_end_of_line P_ ((struct frame *, int));
+extern void write_glyphs P_ ((struct frame *, struct glyph *, int));
+extern void insert_glyphs P_ ((struct frame *, struct glyph *, int));
+extern void delete_glyphs P_ ((struct frame *, int));
+extern void ins_del_lines P_ ((struct frame *, int, int));
+
+extern struct terminal *init_initial_terminal P_ ((void));
+
+
+/* Defined in term.c */
+
+extern void tty_set_terminal_modes P_ ((struct terminal *));
+extern void tty_reset_terminal_modes P_ ((struct terminal *));
+extern void tty_turn_off_insert P_ ((struct tty_display_info *));
+extern void tty_turn_off_highlight P_ ((struct tty_display_info *));
extern int string_cost P_ ((char *));
extern int per_line_cost P_ ((char *));
extern void calculate_costs P_ ((struct frame *));
+extern void produce_glyphs P_ ((struct it *));
+extern void produce_special_glyphs P_ ((struct it *, enum display_element_type));
+extern int tty_capable_p P_ ((struct tty_display_info *, unsigned, unsigned long, unsigned long));
extern void set_tty_color_mode P_ ((struct frame *, Lisp_Object));
-extern void tty_setup_colors P_ ((int));
-extern void term_init P_ ((char *));
-void cursor_to P_ ((int, int));
-extern int tty_capable_p P_ ((struct frame *, unsigned, unsigned long, unsigned long));
+extern struct terminal *get_tty_terminal P_ ((Lisp_Object, int));
+extern struct terminal *get_named_tty P_ ((char *));
+EXFUN (Ftty_type, 1);
+extern void create_tty_output P_ ((struct frame *));
+extern struct terminal *init_tty P_ ((char *, char *, int));
+
/* Defined in scroll.c */
diff --git a/src/dispnew.c b/src/dispnew.c
index 02d0663b56..ab2c1518dc 100644
--- a/src/dispnew.c
+++ b/src/dispnew.c
@@ -32,7 +32,6 @@ Boston, MA 02110-1301, USA. */
#include "lisp.h"
#include "termchar.h"
#include "termopts.h"
-#include "termhooks.h"
/* cm.h must come after dispextern.h on Windows. */
#include "dispextern.h"
#include "cm.h"
@@ -40,6 +39,7 @@ Boston, MA 02110-1301, USA. */
#include "character.h"
#include "keyboard.h"
#include "frame.h"
+#include "termhooks.h"
#include "window.h"
#include "commands.h"
#include "disptab.h"
@@ -238,9 +238,9 @@ int inverse_video;
EMACS_INT baud_rate;
/* Either nil or a symbol naming the window system under which Emacs
- is running. */
+ creates the first frame. */
-Lisp_Object Vwindow_system;
+Lisp_Object Vinitial_window_system;
/* Version number of X windows: 10, 11 or nil. */
@@ -282,14 +282,6 @@ Lisp_Object selected_frame;
struct frame *last_nonminibuf_frame;
-/* Stdio stream being used for copy of all output. */
-
-FILE *termscript;
-
-/* Structure for info on cursor positioning. */
-
-struct cm Wcm;
-
/* 1 means SIGWINCH happened when not safe. */
int delayed_size_change;
@@ -328,11 +320,6 @@ int glyph_pool_count;
static struct frame *frame_matrix_frame;
-/* Current interface for window-based redisplay. Set from init_xterm.
- A null value means we are not using window-based redisplay. */
-
-struct redisplay_interface *rif;
-
/* Non-zero means that fonts have been loaded since the last glyph
matrix adjustments. Redisplay must stop, and glyph matrices must
be adjusted when this flag becomes non-zero during display. The
@@ -1423,7 +1410,7 @@ line_hash_code (row)
{
int c = glyph->u.ch;
int face_id = glyph->face_id;
- if (must_write_spaces)
+ if (FRAME_MUST_WRITE_SPACES (SELECTED_FRAME ())) /* XXX Is SELECTED_FRAME OK here? */
c -= SPACEGLYPH;
hash = (((hash << 4) + (hash >> 24)) & 0x0fffffff) + c;
hash = (((hash << 4) + (hash >> 24)) & 0x0fffffff) + face_id;
@@ -1455,7 +1442,7 @@ line_draw_cost (matrix, vpos)
int glyph_table_len = GLYPH_TABLE_LENGTH;
/* Ignore trailing and leading spaces if we can. */
- if (!must_write_spaces)
+ if (!FRAME_MUST_WRITE_SPACES (SELECTED_FRAME ())) /* XXX Is SELECTED_FRAME OK here? */
{
/* Skip from the end over trailing spaces. */
while (end > beg && CHAR_GLYPH_SPACE_P (*(end - 1)))
@@ -1671,8 +1658,10 @@ realloc_glyph_pool (pool, matrix_dim)
#if GLYPH_DEBUG
-/* Flush standard output. This is sometimes useful to call from
- the debugger. */
+/* Flush standard output. This is sometimes useful to call from the debugger.
+ XXX Maybe this should be changed to flush the current terminal instead of
+ stdout.
+*/
void
flush_stdout ()
@@ -3393,12 +3382,15 @@ DEFUN ("redraw-frame", Fredraw_frame, Sredraw_frame, 1, 1, 0,
return Qnil;
update_begin (f);
+#ifdef MSDOS
if (FRAME_MSDOS_P (f))
- set_terminal_modes ();
- clear_frame ();
+ set_terminal_modes (FRAME_TERMINAL (f));
+#endif
+ clear_frame (f);
clear_current_matrices (f);
update_end (f);
- fflush (stdout);
+ if (FRAME_TERMCAP_P (f))
+ fflush (FRAME_TTY (f)->output);
windows_or_buffers_changed++;
/* Mark all windows as inaccurate, so that every window will have
its redisplay done. */
@@ -3539,7 +3531,7 @@ direct_output_for_insert (g)
/* If we can't insert glyphs, we can use this method only
at the end of a line. */
- if (!char_ins_del_ok)
+ if (!FRAME_CHAR_INS_DEL_OK (f))
if (PT != ZV && FETCH_BYTE (PT_BYTE) != '\n')
return 0;
@@ -3689,24 +3681,24 @@ direct_output_for_insert (g)
updated_row = glyph_row;
updated_area = TEXT_AREA;
update_begin (f);
- if (rif)
+ if (FRAME_RIF (f))
{
- rif->update_window_begin_hook (w);
+ FRAME_RIF (f)->update_window_begin_hook (w);
if (glyphs == end - n
/* In front of a space added by append_space. */
|| (glyphs == end - n - 1
&& (end - n)->charpos <= 0))
- rif->write_glyphs (glyphs, n);
+ FRAME_RIF (f)->write_glyphs (glyphs, n);
else
- rif->insert_glyphs (glyphs, n);
+ FRAME_RIF (f)->insert_glyphs (glyphs, n);
}
else
{
if (glyphs == end - n)
- write_glyphs (glyphs, n);
+ write_glyphs (f, glyphs, n);
else
- insert_glyphs (glyphs, n);
+ insert_glyphs (f, glyphs, n);
}
w->cursor.hpos += n;
@@ -3719,8 +3711,8 @@ direct_output_for_insert (g)
a frame matrix is used, cursor_to expects frame coordinates,
and the X and Y parameters are not used. */
if (window_redisplay_p)
- rif->cursor_to (w->cursor.vpos, w->cursor.hpos,
- w->cursor.y, w->cursor.x);
+ FRAME_RIF (f)->cursor_to (w->cursor.vpos, w->cursor.hpos,
+ w->cursor.y, w->cursor.x);
else
{
int x, y;
@@ -3729,18 +3721,19 @@ direct_output_for_insert (g)
? XFASTINT (w->left_margin_cols)
: 0));
y = WINDOW_TO_FRAME_VPOS (w, w->cursor.vpos);
- cursor_to (y, x);
+ cursor_to (f, y, x);
}
#ifdef HAVE_WINDOW_SYSTEM
update_window_fringes (w, 0);
#endif
- if (rif)
- rif->update_window_end_hook (w, 1, 0);
+ if (FRAME_RIF (f))
+ FRAME_RIF (f)->update_window_end_hook (w, 1, 0);
update_end (f);
updated_row = NULL;
- fflush (stdout);
+ if (FRAME_TERMCAP_P (f))
+ fflush (FRAME_TTY (f)->output);
TRACE ((stderr, "direct output for insert\n"));
mark_window_display_accurate (it.window, 1);
@@ -3818,8 +3811,8 @@ direct_output_forward_char (n)
&& w->cursor.hpos < w->desired_matrix->matrix_w);
if (FRAME_WINDOW_P (f))
- rif->cursor_to (w->cursor.vpos, w->cursor.hpos,
- w->cursor.y, w->cursor.x);
+ FRAME_RIF (f)->cursor_to (w->cursor.vpos, w->cursor.hpos,
+ w->cursor.y, w->cursor.x);
else
{
int x, y;
@@ -3828,10 +3821,11 @@ direct_output_forward_char (n)
? XFASTINT (w->left_margin_cols)
: 0));
y = WINDOW_TO_FRAME_VPOS (w, w->cursor.vpos);
- cursor_to (y, x);
+ cursor_to (f, y, x);
}
- fflush (stdout);
+ if (FRAME_TERMCAP_P (f))
+ fflush (FRAME_TTY (f)->output);
redisplay_performed_directly_p = 1;
return 1;
}
@@ -3930,14 +3924,14 @@ update_frame (f, force_p, inhibit_hairy_id_p)
update_end (f);
/* This flush is a performance bottleneck under X,
- and it doesn't seem to be necessary anyway (in general).
+ and it doesn't seem to be necessary anyway (in general).
It is necessary when resizing the window with the mouse, or
- at least the fringes are not redrawn in a timely manner. ++kfs */
+ at least the fringes are not redrawn in a timely manner. ++kfs */
if (f->force_flush_display_p)
- {
- rif->flush_display (f);
- f->force_flush_display_p = 0;
- }
+ {
+ FRAME_RIF (f)->flush_display (f);
+ f->force_flush_display_p = 0;
+ }
}
else
{
@@ -3953,9 +3947,12 @@ update_frame (f, force_p, inhibit_hairy_id_p)
paused_p = update_frame_1 (f, force_p, inhibit_hairy_id_p);
update_end (f);
- if (termscript)
- fflush (termscript);
- fflush (stdout);
+ if (FRAME_TERMCAP_P (f))
+ {
+ if (FRAME_TTY (f)->termscript)
+ fflush (FRAME_TTY (f)->termscript);
+ fflush (FRAME_TTY (f)->output);
+ }
/* Check window matrices for lost pointers. */
#if GLYPH_DEBUG
@@ -4060,7 +4057,8 @@ redraw_overlapped_rows (w, yb)
int yb;
{
int i;
-
+ struct frame *f = XFRAME (WINDOW_FRAME (w));
+
/* If rows overlapping others have been changed, the rows being
overlapped have to be redrawn. This won't draw lines that have
already been drawn in update_window_line because overlapped_p in
@@ -4083,10 +4081,12 @@ redraw_overlapped_rows (w, yb)
{
updated_row = row;
updated_area = area;
- rif->cursor_to (i, 0, row->y, area == TEXT_AREA ? row->x : 0);
+ FRAME_RIF (f)->cursor_to (i, 0, row->y,
+ area == TEXT_AREA ? row->x : 0);
if (row->used[area])
- rif->write_glyphs (row->glyphs[area], row->used[area]);
- rif->clear_end_of_line (-1);
+ FRAME_RIF (f)->write_glyphs (row->glyphs[area],
+ row->used[area]);
+ FRAME_RIF (f)->clear_end_of_line (-1);
}
row->overlapped_p = 0;
@@ -4108,7 +4108,8 @@ redraw_overlapping_rows (w, yb)
{
int i, bottom_y;
struct glyph_row *row;
-
+ struct redisplay_interface *rif = FRAME_RIF (XFRAME (WINDOW_FRAME (w)));
+
for (i = 0; i < w->current_matrix->nrows; ++i)
{
row = w->current_matrix->rows + i;
@@ -4199,10 +4200,10 @@ update_window (w, force_p)
#endif
extern int input_pending;
extern Lisp_Object do_mouse_tracking;
+ struct redisplay_interface *rif = FRAME_RIF (XFRAME (WINDOW_FRAME (w)));
#if GLYPH_DEBUG
/* Check that W's frame doesn't have glyph matrices. */
xassert (FRAME_WINDOW_P (XFRAME (WINDOW_FRAME (w))));
- xassert (updating_frame != NULL);
#endif
/* Check pending input the first time so that we can quickly return. */
@@ -4387,6 +4388,7 @@ update_marginal_area (w, area, vpos)
int area, vpos;
{
struct glyph_row *desired_row = MATRIX_ROW (w->desired_matrix, vpos);
+ struct redisplay_interface *rif = FRAME_RIF (XFRAME (WINDOW_FRAME (w)));
/* Let functions in xterm.c know what area subsequent X positions
will be relative to. */
@@ -4412,6 +4414,7 @@ update_text_area (w, vpos)
{
struct glyph_row *current_row = MATRIX_ROW (w->current_matrix, vpos);
struct glyph_row *desired_row = MATRIX_ROW (w->desired_matrix, vpos);
+ struct redisplay_interface *rif = FRAME_RIF (XFRAME (WINDOW_FRAME (w)));
int changed_p = 0;
/* Let functions in xterm.c know what area subsequent X positions
@@ -4647,6 +4650,7 @@ update_window_line (w, vpos, mouse_face_overwritten_p)
{
struct glyph_row *current_row = MATRIX_ROW (w->current_matrix, vpos);
struct glyph_row *desired_row = MATRIX_ROW (w->desired_matrix, vpos);
+ struct redisplay_interface *rif = FRAME_RIF (XFRAME (WINDOW_FRAME (w)));
int changed_p = 0;
/* Set the row being updated. This is important to let xterm.c
@@ -4715,6 +4719,7 @@ set_window_cursor_after_update (w)
struct window *w;
{
struct frame *f = XFRAME (w->frame);
+ struct redisplay_interface *rif = FRAME_RIF (f);
int cx, cy, vpos, hpos;
/* Not intended for frame matrix updates. */
@@ -4938,6 +4943,7 @@ scrolling_window (w, header_line_p)
int i, j, first_old, first_new, last_old, last_new;
int nruns, nbytes, n, run_idx;
struct row_entry *entry;
+ struct redisplay_interface *rif = FRAME_RIF (XFRAME (WINDOW_FRAME (w)));
/* Skip over rows equal at the start. */
for (i = header_line_p ? 1 : 0; i < current_matrix->nrows - 1; ++i)
@@ -5262,7 +5268,7 @@ update_frame_1 (f, force_p, inhibit_id_p)
#endif
/* If we cannot insert/delete lines, it's no use trying it. */
- if (!line_ins_del_ok)
+ if (!FRAME_LINE_INS_DEL_OK (f))
inhibit_id_p = 1;
/* See if any of the desired lines are enabled; don't compute for
@@ -5290,18 +5296,18 @@ update_frame_1 (f, force_p, inhibit_id_p)
Also flush out if likely to have more than 1k buffered
otherwise. I'm told that some telnet connections get
really screwed by more than 1k output at once. */
- int outq = PENDING_OUTPUT_COUNT (stdout);
+ int outq = PENDING_OUTPUT_COUNT (FRAME_TTY (f)->output);
if (outq > 900
|| (outq > 20 && ((i - 1) % preempt_count == 0)))
{
- fflush (stdout);
+ fflush (FRAME_TTY (f)->output);
if (preempt_count == 1)
{
#ifdef EMACS_OUTQSIZE
if (EMACS_OUTQSIZE (0, &outq) < 0)
/* Probably not a tty. Ignore the error and reset
the outq count. */
- outq = PENDING_OUTPUT_COUNT (stdout);
+ outq = PENDING_OUTPUT_COUNT (FRAME_TTY (f->output));
#endif
outq *= 10;
if (baud_rate <= outq && baud_rate > 0)
@@ -5404,7 +5410,7 @@ update_frame_1 (f, force_p, inhibit_id_p)
}
}
- cursor_to (row, col);
+ cursor_to (f, row, col);
}
else
{
@@ -5426,7 +5432,7 @@ update_frame_1 (f, force_p, inhibit_id_p)
x += XFASTINT (w->left_margin_cols);
/* x = max (min (x, FRAME_TOTAL_COLS (f) - 1), 0); */
- cursor_to (y, x);
+ cursor_to (f, y, x);
}
}
}
@@ -5495,21 +5501,23 @@ scrolling (frame)
}
/* If changed lines are few, don't allow preemption, don't scroll. */
- if ((!scroll_region_ok && changed_lines < baud_rate / 2400)
+ if ((!FRAME_SCROLL_REGION_OK (frame)
+ && changed_lines < baud_rate / 2400)
|| unchanged_at_bottom == FRAME_LINES (frame))
return 1;
window_size = (FRAME_LINES (frame) - unchanged_at_top
- unchanged_at_bottom);
- if (scroll_region_ok)
+ if (FRAME_SCROLL_REGION_OK (frame))
free_at_end_vpos -= unchanged_at_bottom;
- else if (memory_below_frame)
+ else if (FRAME_MEMORY_BELOW_FRAME (frame))
free_at_end_vpos = -1;
/* If large window, fast terminal and few lines in common between
current frame and desired frame, don't bother with i/d calc. */
- if (!scroll_region_ok && window_size >= 18 && baud_rate > 2400
+ if (!FRAME_SCROLL_REGION_OK (frame)
+ && window_size >= 18 && baud_rate > 2400
&& (window_size >=
10 * scrolling_max_lines_saved (unchanged_at_top,
FRAME_LINES (frame) - unchanged_at_bottom,
@@ -5589,7 +5597,7 @@ update_frame_line (f, vpos)
struct glyph_row *current_row = MATRIX_ROW (current_matrix, vpos);
struct glyph_row *desired_row = MATRIX_ROW (desired_matrix, vpos);
int must_write_whole_line_p;
- int write_spaces_p = must_write_spaces;
+ int write_spaces_p = FRAME_MUST_WRITE_SPACES (f);
int colored_spaces_p = (FACE_FROM_ID (f, DEFAULT_FACE_ID)->background
!= FACE_TTY_DEFAULT_BG_COLOR);
@@ -5640,8 +5648,8 @@ update_frame_line (f, vpos)
/* Write the contents of the desired line. */
if (nlen)
{
- cursor_to (vpos, 0);
- write_glyphs (nbody, nlen);
+ cursor_to (f, vpos, 0);
+ write_glyphs (f, nbody, nlen);
}
/* Don't call clear_end_of_line if we already wrote the whole
@@ -5649,13 +5657,13 @@ update_frame_line (f, vpos)
case but in the line below. */
if (nlen < FRAME_TOTAL_COLS (f))
{
- cursor_to (vpos, nlen);
- clear_end_of_line (FRAME_TOTAL_COLS (f));
+ cursor_to (f, vpos, nlen);
+ clear_end_of_line (f, FRAME_TOTAL_COLS (f));
}
else
/* Make sure we are in the right row, otherwise cursor movement
with cmgoto might use `ch' in the wrong row. */
- cursor_to (vpos, 0);
+ cursor_to (f, vpos, 0);
make_current (desired_matrix, current_matrix, vpos);
return;
@@ -5668,7 +5676,7 @@ update_frame_line (f, vpos)
nlen--;
/* If there's no i/d char, quickly do the best we can without it. */
- if (!char_ins_del_ok)
+ if (!FRAME_CHAR_INS_DEL_OK (f))
{
int i, j;
@@ -5687,8 +5695,8 @@ update_frame_line (f, vpos)
++j;
/* Output this run of non-matching chars. */
- cursor_to (vpos, i);
- write_glyphs (nbody + i, j - i);
+ cursor_to (f, vpos, i);
+ write_glyphs (f, nbody + i, j - i);
i = j - 1;
/* Now find the next non-match. */
@@ -5698,8 +5706,8 @@ update_frame_line (f, vpos)
/* Clear the rest of the line, or the non-clear part of it. */
if (olen > nlen)
{
- cursor_to (vpos, nlen);
- clear_end_of_line (olen);
+ cursor_to (f, vpos, nlen);
+ clear_end_of_line (f, olen);
}
/* Make current row = desired row. */
@@ -5721,8 +5729,8 @@ update_frame_line (f, vpos)
if (nlen > nsp)
{
- cursor_to (vpos, nsp);
- write_glyphs (nbody + nsp, nlen - nsp);
+ cursor_to (f, vpos, nsp);
+ write_glyphs (f, nbody + nsp, nlen - nsp);
}
/* Exchange contents between current_frame and new_frame. */
@@ -5771,7 +5779,8 @@ update_frame_line (f, vpos)
tem = (nlen - nsp) - (olen - osp);
if (endmatch && tem
- && (!char_ins_del_ok || endmatch <= char_ins_del_cost (f)[tem]))
+ && (!FRAME_CHAR_INS_DEL_OK (f)
+ || endmatch <= char_ins_del_cost (f)[tem]))
endmatch = 0;
/* nsp - osp is the distance to insert or delete.
@@ -5780,7 +5789,7 @@ update_frame_line (f, vpos)
Is it worth it? */
if (nsp != osp
- && (!char_ins_del_ok
+ && (!FRAME_CHAR_INS_DEL_OK (f)
|| begmatch + endmatch <= char_ins_del_cost (f)[nsp - osp]))
{
begmatch = 0;
@@ -5793,8 +5802,8 @@ update_frame_line (f, vpos)
if (osp > nsp)
{
- cursor_to (vpos, nsp);
- delete_glyphs (osp - nsp);
+ cursor_to (f, vpos, nsp);
+ delete_glyphs (f, osp - nsp);
}
else if (nsp > osp)
{
@@ -5803,12 +5812,12 @@ update_frame_line (f, vpos)
must delete first to avoid losing data in the insert */
if (endmatch && nlen < olen + nsp - osp)
{
- cursor_to (vpos, nlen - endmatch + osp - nsp);
- delete_glyphs (olen + nsp - osp - nlen);
+ cursor_to (f, vpos, nlen - endmatch + osp - nsp);
+ delete_glyphs (f, olen + nsp - osp - nlen);
olen = nlen - (nsp - osp);
}
- cursor_to (vpos, osp);
- insert_glyphs (0, nsp - osp);
+ cursor_to (f, vpos, osp);
+ insert_glyphs (f, 0, nsp - osp);
}
olen += nsp - osp;
@@ -5829,8 +5838,8 @@ update_frame_line (f, vpos)
unnecessary cursor movement. */
if (nlen - tem > 0)
{
- cursor_to (vpos, nsp + begmatch);
- write_glyphs (nbody + nsp + begmatch, nlen - tem);
+ cursor_to (f, vpos, nsp + begmatch);
+ write_glyphs (f, nbody + nsp + begmatch, nlen - tem);
}
}
else if (nlen > olen)
@@ -5845,27 +5854,27 @@ update_frame_line (f, vpos)
int out = olen - tem; /* Columns to be overwritten originally. */
int del;
- cursor_to (vpos, nsp + begmatch);
+ cursor_to (f, vpos, nsp + begmatch);
/* Calculate columns we can actually overwrite. */
while (CHAR_GLYPH_PADDING_P (nbody[nsp + begmatch + out]))
out--;
- write_glyphs (nbody + nsp + begmatch, out);
+ write_glyphs (f, nbody + nsp + begmatch, out);
/* If we left columns to be overwritten, we must delete them. */
del = olen - tem - out;
if (del > 0)
- delete_glyphs (del);
+ delete_glyphs (f, del);
/* At last, we insert columns not yet written out. */
- insert_glyphs (nbody + nsp + begmatch + out, nlen - olen + del);
+ insert_glyphs (f, nbody + nsp + begmatch + out, nlen - olen + del);
olen = nlen;
}
else if (olen > nlen)
{
- cursor_to (vpos, nsp + begmatch);
- write_glyphs (nbody + nsp + begmatch, nlen - tem);
- delete_glyphs (olen - nlen);
+ cursor_to (f, vpos, nsp + begmatch);
+ write_glyphs (f, nbody + nsp + begmatch, nlen - tem);
+ delete_glyphs (f, olen - nlen);
olen = nlen;
}
}
@@ -5874,8 +5883,8 @@ update_frame_line (f, vpos)
/* If any unerased characters remain after the new line, erase them. */
if (olen > nlen)
{
- cursor_to (vpos, nlen);
- clear_end_of_line (olen);
+ cursor_to (f, vpos, nlen);
+ clear_end_of_line (f, olen);
}
/* Exchange contents between current_frame and new_frame. */
@@ -6172,31 +6181,34 @@ window_change_signal (signalnum) /* If we don't have an argument, */
#endif
int old_errno = errno;
+ struct tty_display_info *tty;
+
signal (SIGWINCH, window_change_signal);
SIGNAL_THREAD_CHECK (signalnum);
- get_frame_size (&width, &height);
-
- /* The frame size change obviously applies to a termcap-controlled
- frame. Find such a frame in the list, and assume it's the only
- one (since the redisplay code always writes to stdout, not a
- FILE * specified in the frame structure). Record the new size,
- but don't reallocate the data structures now. Let that be done
- later outside of the signal handler. */
+ /* The frame size change obviously applies to a single
+ termcap-controlled terminal, but we can't decide which.
+ Therefore, we resize the frames corresponding to each tty.
+ */
+ for (tty = tty_list; tty; tty = tty->next) {
- {
- Lisp_Object tail, frame;
+ if (! tty->term_initted)
+ continue;
- FOR_EACH_FRAME (tail, frame)
- {
- if (FRAME_TERMCAP_P (XFRAME (frame)))
- {
- change_frame_size (XFRAME (frame), height, width, 0, 1, 0);
- break;
- }
- }
+ get_tty_size (fileno (tty->input), &width, &height);
+
+ if (width > 5 && height > 2) {
+ Lisp_Object tail, frame;
+
+ FOR_EACH_FRAME (tail, frame)
+ if (FRAME_TERMCAP_P (XFRAME (frame)) && FRAME_TTY (XFRAME (frame)) == tty)
+ /* Record the new sizes, but don't reallocate the data
+ structures now. Let that be done later outside of the
+ signal handler. */
+ change_frame_size (XFRAME (frame), height, width, 0, 1, 0);
+ }
}
-
+
errno = old_errno;
}
#endif /* SIGWINCH */
@@ -6250,10 +6262,11 @@ change_frame_size (f, newheight, newwidth, pretend, delay, safe)
{
Lisp_Object tail, frame;
- if (! FRAME_WINDOW_P (f))
+ if (FRAME_MSDOS_P (f))
{
- /* When using termcap, or on MS-DOS, all frames use
- the same screen, so a change in size affects all frames. */
+ /* On MS-DOS, all frames use the same screen, so a change in
+ size affects all frames. Termcap now supports multiple
+ ttys. */
FOR_EACH_FRAME (tail, frame)
if (! FRAME_WINDOW_P (XFRAME (frame)))
change_frame_size_1 (XFRAME (frame), newheight, newwidth,
@@ -6333,7 +6346,7 @@ change_frame_size_1 (f, newheight, newwidth, pretend, delay, safe)
newheight - FRAME_TOP_MARGIN (f), 0);
if (FRAME_TERMCAP_P (f) && !pretend)
- FrameRows = newheight;
+ FrameRows (FRAME_TTY (f)) = newheight;
}
if (new_frame_total_cols != FRAME_TOTAL_COLS (f))
@@ -6343,7 +6356,7 @@ change_frame_size_1 (f, newheight, newwidth, pretend, delay, safe)
set_window_width (FRAME_MINIBUF_WINDOW (f), new_frame_total_cols, 0);
if (FRAME_TERMCAP_P (f) && !pretend)
- FrameCols = newwidth;
+ FrameCols (FRAME_TTY (f)) = newwidth;
if (WINDOWP (f->tool_bar_window))
XSETFASTINT (XWINDOW (f->tool_bar_window)->total_cols, newwidth);
@@ -6393,19 +6406,26 @@ FILE = nil means just close any termscript file currently open. */)
(file)
Lisp_Object file;
{
- if (termscript != 0)
- {
- BLOCK_INPUT;
- fclose (termscript);
- UNBLOCK_INPUT;
- }
- termscript = 0;
+ struct tty_display_info *tty;
+
+ if (! FRAME_TERMCAP_P (SELECTED_FRAME ()))
+ error ("Current frame is not on a tty device");
+
+ tty = CURTTY ();
+
+ if (tty->termscript != 0)
+ {
+ BLOCK_INPUT;
+ fclose (tty->termscript);
+ UNBLOCK_INPUT;
+ }
+ tty->termscript = 0;
if (! NILP (file))
{
file = Fexpand_file_name (file, Qnil);
- termscript = fopen (SDATA (file), "w");
- if (termscript == 0)
+ tty->termscript = fopen (SDATA (file), "w");
+ if (tty->termscript == 0)
report_file_error ("Opening termscript", Fcons (file, Qnil));
}
return Qnil;
@@ -6413,23 +6433,36 @@ FILE = nil means just close any termscript file currently open. */)
DEFUN ("send-string-to-terminal", Fsend_string_to_terminal,
- Ssend_string_to_terminal, 1, 1, 0,
+ Ssend_string_to_terminal, 1, 2, 0,
doc: /* Send STRING to the terminal without alteration.
-Control characters in STRING will have terminal-dependent effects. */)
- (string)
+Control characters in STRING will have terminal-dependent effects.
+
+Optional parameter TERMINAL specifies the tty terminal device to use.
+It may be a terminal id, a frame, or nil for the terminal used by the
+currently selected frame. */)
+ (string, terminal)
Lisp_Object string;
+ Lisp_Object terminal;
{
+ struct terminal *t = get_tty_terminal (terminal, 1);
+ struct tty_display_info *tty;
+
/* ??? Perhaps we should do something special for multibyte strings here. */
CHECK_STRING (string);
BLOCK_INPUT;
- fwrite (SDATA (string), 1, SBYTES (string), stdout);
- fflush (stdout);
- if (termscript)
+
+ if (!t)
+ error ("Unknown terminal device");
+
+ tty = t->display_info.tty;
+
+ if (tty->termscript)
{
- fwrite (SDATA (string), 1, SBYTES (string),
- termscript);
- fflush (termscript);
+ fwrite (SDATA (string), 1, SBYTES (string), tty->termscript);
+ fflush (tty->termscript);
}
+ fwrite (SDATA (string), 1, SBYTES (string), tty->output);
+ fflush (tty->output);
UNBLOCK_INPUT;
return Qnil;
}
@@ -6447,8 +6480,7 @@ terminate any keyboard macro currently executing. */)
if (noninteractive)
putchar (07);
else
- ring_bell ();
- fflush (stdout);
+ ring_bell (XFRAME (selected_frame));
}
else
bitch_at_user ();
@@ -6464,8 +6496,7 @@ bitch_at_user ()
else if (!INTERACTIVE) /* Stop executing a keyboard macro. */
error ("Keyboard macro terminated by a command ringing the bell");
else
- ring_bell ();
- fflush (stdout);
+ ring_bell (XFRAME (selected_frame));
}
@@ -6748,8 +6779,6 @@ pass nil for VARIABLE. */)
Initialization
***********************************************************************/
-char *terminal_type;
-
/* Initialization done when Emacs fork is started, before doing stty.
Determine terminal type and set terminal_driver. Then invoke its
decoding routine to set up variables in the terminal package. */
@@ -6757,6 +6786,8 @@ char *terminal_type;
void
init_display ()
{
+ char *terminal_type;
+
#ifdef HAVE_X_WINDOWS
extern int display_arg;
#endif
@@ -6766,14 +6797,23 @@ init_display ()
SET_CHAR_GLYPH_FROM_GLYPH (space_glyph, ' ');
space_glyph.charpos = -1;
- meta_key = 0;
inverse_video = 0;
cursor_in_echo_area = 0;
terminal_type = (char *) 0;
/* Now is the time to initialize this; it's used by init_sys_modes
during startup. */
- Vwindow_system = Qnil;
+ Vinitial_window_system = Qnil;
+
+ /* SIGWINCH needs to be handled no matter what display we start
+ with. Otherwise newly opened tty frames will not resize
+ automatically. */
+#ifdef SIGWINCH
+#ifndef CANNOT_DUMP
+ if (initialized)
+#endif /* CANNOT_DUMP */
+ signal (SIGWINCH, window_change_signal);
+#endif /* SIGWINCH */
/* If the user wants to use a window system, we shouldn't bother
initializing the terminal. This is especially important when the
@@ -6809,7 +6849,7 @@ init_display ()
#endif
)
{
- Vwindow_system = intern ("x");
+ Vinitial_window_system = intern ("x");
#ifdef HAVE_X11
Vwindow_system_version = make_number (11);
#else
@@ -6829,7 +6869,7 @@ init_display ()
#ifdef HAVE_NTGUI
if (!inhibit_window_system)
{
- Vwindow_system = intern ("w32");
+ Vinitial_window_system = intern ("w32");
Vwindow_system_version = make_number (1);
adjust_frame_glyphs_initially ();
return;
@@ -6839,7 +6879,7 @@ init_display ()
#ifdef MAC_OS
if (!inhibit_window_system)
{
- Vwindow_system = intern ("mac");
+ Vinitial_window_system = intern ("mac");
Vwindow_system_version = make_number (1);
adjust_frame_glyphs_initially ();
return;
@@ -6891,8 +6931,38 @@ For types not defined in VMS, use define emacs_term \"TYPE\".\n\
}
#endif /* VMS */
- term_init (terminal_type);
-
+ {
+ struct terminal *t;
+ struct frame *f = XFRAME (selected_frame);
+
+ /* Open a display on the controlling tty. */
+ t = init_tty (0, terminal_type, 1); /* Errors are fatal. */
+
+ /* Convert the initial frame to use the new display. */
+ if (f->output_method != output_initial)
+ abort ();
+ f->output_method = t->type;
+ f->terminal = t;
+
+ t->reference_count++;
+ t->display_info.tty->top_frame = selected_frame;
+ change_frame_size (XFRAME (selected_frame),
+ FrameRows (t->display_info.tty),
+ FrameCols (t->display_info.tty), 0, 0, 1);
+
+ /* Delete the initial terminal. */
+ if (--initial_terminal->reference_count == 0
+ && initial_terminal->delete_terminal_hook)
+ (*initial_terminal->delete_terminal_hook) (initial_terminal);
+
+ /* Update frame parameters to reflect the new type. */
+ Fmodify_frame_parameters (selected_frame, Fcons (Fcons (Qwindow_system, Qnil), Qnil));
+ Fmodify_frame_parameters
+ (selected_frame, Fcons (Fcons (Qtty_type,
+ Ftty_type (selected_frame)), Qnil));
+ Fmodify_frame_parameters (selected_frame, Fcons (Fcons (Qtty, Qnil), Qnil));
+ }
+
{
struct frame *sf = SELECTED_FRAME ();
int width = FRAME_TOTAL_COLS (sf);
@@ -6909,13 +6979,6 @@ For types not defined in VMS, use define emacs_term \"TYPE\".\n\
adjust_frame_glyphs_initially ();
calculate_costs (XFRAME (selected_frame));
-#ifdef SIGWINCH
-#ifndef CANNOT_DUMP
- if (initialized)
-#endif /* CANNOT_DUMP */
- signal (SIGWINCH, window_change_signal);
-#endif /* SIGWINCH */
-
/* Set up faces of the initial terminal frame of a dumped Emacs. */
if (initialized
&& !noninteractive
@@ -6926,7 +6989,7 @@ For types not defined in VMS, use define emacs_term \"TYPE\".\n\
and internal_terminal_init. */
&& (strcmp (terminal_type, "internal") != 0 || inhibit_window_system)
#endif
- && NILP (Vwindow_system))
+ && NILP (Vinitial_window_system))
{
/* For the initial frame, we don't have any way of knowing what
are the foreground and background colors of the terminal. */
@@ -7038,8 +7101,8 @@ A non-nil value is useful if the terminal can automatically preserve
Emacs's frame display when you reenter Emacs.
It is up to you to set this variable if your terminal can do that. */);
- DEFVAR_LISP ("window-system", &Vwindow_system,
- doc: /* Name of window system that Emacs is displaying through.
+ DEFVAR_LISP ("initial-window-system", &Vinitial_window_system,
+ doc: /* Name of the window system that Emacs uses for the first frame.
The value is a symbol--for instance, `x' for X windows.
The value is nil if Emacs is using a text-only terminal. */);
@@ -7082,7 +7145,7 @@ If nil, never pre-empt redisplay. */);
if (noninteractive)
#endif
{
- Vwindow_system = Qnil;
+ Vinitial_window_system = Qnil;
Vwindow_system_version = Qnil;
}
}
diff --git a/src/emacs.c b/src/emacs.c
index dc3055f8b1..dfe950631b 100644
--- a/src/emacs.c
+++ b/src/emacs.c
@@ -57,6 +57,7 @@ Boston, MA 02110-1301, USA. */
#include "blockinput.h"
#include "syssignal.h"
#include "process.h"
+#include "frame.h"
#include "termhooks.h"
#include "keyboard.h"
#include "keymap.h"
@@ -214,7 +215,7 @@ static unsigned long heap_bss_diff;
#ifdef HAVE_WINDOW_SYSTEM
-extern Lisp_Object Vwindow_system;
+extern Lisp_Object Vinitial_window_system;
#endif /* HAVE_WINDOW_SYSTEM */
extern Lisp_Object Vauto_save_list_file_name;
@@ -1300,6 +1301,9 @@ main (argc, argv
faces, and the face implementation uses some symbols as
face names. */
syms_of_xfaces ();
+ /* XXX syms_of_keyboard uses some symbols in keymap.c. It would
+ be better to arrange things not to have this dependency. */
+ syms_of_keymap ();
/* Call syms_of_keyboard before init_window_once because
keyboard sets up symbols that include some face names that
the X support will want to use. This can happen when
@@ -1510,10 +1514,10 @@ main (argc, argv
/* egetenv is a pretty low-level facility, which may get called in
many circumstances; it seems flimsy to put off initializing it
until calling init_callproc. */
- set_process_environment ();
+ set_initial_environment ();
/* AIX crashes are reported in system versions 3.2.3 and 3.2.4
- if this is not done. Do it after set_process_environment so that we
- don't pollute Vprocess_environment. */
+ if this is not done. Do it after set_global_environment so that we
+ don't pollute Vglobal_environment. */
/* Setting LANG here will defeat the startup locale processing... */
#ifdef AIX3_2
putenv ("LANG=C");
@@ -1586,7 +1590,7 @@ main (argc, argv
#endif /* CLASH_DETECTION */
syms_of_indent ();
syms_of_insdel ();
- syms_of_keymap ();
+ /* syms_of_keymap (); */
syms_of_macros ();
syms_of_marker ();
syms_of_minibuf ();
@@ -1597,6 +1601,7 @@ main (argc, argv
syms_of_frame ();
#endif
syms_of_syntax ();
+ syms_of_terminal ();
syms_of_term ();
syms_of_undo ();
#ifdef HAVE_SOUND
@@ -1686,13 +1691,7 @@ main (argc, argv
init_charset ();
- if (!noninteractive)
- {
-#ifdef VMS
- init_vms_input ();/* init_display calls get_frame_size, that needs this. */
-#endif /* VMS */
- init_display (); /* Determine terminal type. init_sys_modes uses results. */
- }
+ init_process (); /* init_display uses add_keyboard_wait_descriptor. */
#ifndef MAC_OS8
/* Called before init_window_once for Mac OS Classic. */
init_keyboard (); /* This too must precede init_sys_modes. */
@@ -1700,7 +1699,13 @@ main (argc, argv
#ifdef VMS
init_vmsproc (); /* And this too. */
#endif /* VMS */
- init_sys_modes (); /* Init system terminal modes (RAW or CBREAK, etc.). */
+ if (!noninteractive)
+ {
+#ifdef VMS
+ init_vms_input ();/* init_display calls get_tty_size, that needs this. */
+#endif /* VMS */
+ init_display (); /* Determine terminal type. Calls init_sys_modes. */
+ }
init_fns ();
init_xdisp ();
#ifdef HAVE_WINDOW_SYSTEM
@@ -1713,7 +1718,6 @@ main (argc, argv
#ifdef VMS
init_vmsfns ();
#endif /* VMS */
- init_process ();
#ifdef HAVE_SOUND
init_sound ();
#endif
@@ -1844,7 +1848,6 @@ struct standard_args standard_args[] =
{ "-q", "--no-init-file", 50, 0 },
{ "-no-init-file", 0, 50, 0 },
{ "-no-site-file", "--no-site-file", 40, 0 },
- { "-no-splash", "--no-splash", 40, 0 },
{ "-u", "--user", 30, 1 },
{ "-user", 0, 30, 1 },
{ "-debug-init", "--debug-init", 20, 0 },
@@ -1879,6 +1882,8 @@ struct standard_args standard_args[] =
{ "-hb", "--horizontal-scroll-bars", 5, 0 },
{ "-vb", "--vertical-scroll-bars", 5, 0 },
{ "-color", "--color", 5, 0},
+ { "-no-splash", "--no-splash", 3, 0 },
+ { "-no-desktop", "--no-desktop", 3, 0 },
/* These have the same priority as ordinary file name args,
so they are not reordered with respect to those. */
{ "-L", "--directory", 0, 1 },
@@ -2128,15 +2133,14 @@ shut_down_emacs (sig, no_x, stuff)
if (EMACS_GET_TTY_PGRP (0, &tpgrp) != -1
&& tpgrp == pgrp)
{
- fflush (stdout);
- reset_sys_modes ();
+ reset_all_sys_modes ();
if (sig && sig != SIGTERM)
fprintf (stderr, "Fatal error (%d)", sig);
}
}
#else
fflush (stdout);
- reset_sys_modes ();
+ reset_all_sys_modes ();
#endif
stuff_buffered_input (stuff);
@@ -2158,9 +2162,9 @@ shut_down_emacs (sig, no_x, stuff)
#if 0 /* This triggers a bug in XCloseDisplay and is not needed. */
#ifdef HAVE_X_WINDOWS
/* It's not safe to call intern here. Maybe we are crashing. */
- if (!noninteractive && SYMBOLP (Vwindow_system)
- && SCHARS (SYMBOL_NAME (Vwindow_system)) == 1
- && SREF (SYMBOL_NAME (Vwindow_system), 0) == 'x'
+ if (!noninteractive && SYMBOLP (Vinitial_window_system)
+ && SCHARS (SYMBOL_NAME (Vinitial_window_system)) == 1
+ && SREF (SYMBOL_NAME (Vinitial_window_system), 0) == 'x'
&& ! no_x)
Fx_close_current_connection ();
#endif /* HAVE_X_WINDOWS */
diff --git a/src/eval.c b/src/eval.c
index 20be847f27..77abe5046d 100644
--- a/src/eval.c
+++ b/src/eval.c
@@ -1280,8 +1280,12 @@ unwind_to_catch (catch, value)
#if HAVE_X_WINDOWS
/* If x_catch_errors was done, turn it off now.
(First we give unbind_to a chance to do that.) */
+#if 0 /* This would disable x_catch_errors after x_connection_closed.
+ * The catch must remain in effect during that delicate
+ * state. --lorentey */
x_fully_uncatch_errors ();
#endif
+#endif
byte_stack_list = catch->byte_stack;
gcprolist = catch->gcpro;
@@ -1351,14 +1355,15 @@ if CONDITION-NAME is one of the error's condition names.
If an error happens, the first applicable handler is run.
The car of a handler may be a list of condition names
-instead of a single condition name.
+instead of a single condition name. Then it handles all of them.
-When a handler handles an error,
-control returns to the condition-case and the handler BODY... is executed
-with VAR bound to (SIGNALED-CONDITIONS . SIGNAL-DATA).
-VAR may be nil; then you do not get access to the signal information.
+When a handler handles an error, control returns to the `condition-case'
+and it executes the handler's BODY...
+with VAR bound to (SIGNALED-CONDITIONS . SIGNAL-DATA) from the error.
+(If VAR is nil, the handler can't access that information.)
+Then the value of the last BODY form is returned from the `condition-case'
+expression.
-The value of the last BODY form is returned from the condition-case.
See also the function `signal' for more info.
usage: (condition-case VAR BODYFORM &rest HANDLERS) */)
(args)
@@ -2068,7 +2073,7 @@ then strings and vectors are not accepted. */)
/* Emacs primitives are interactive if their DEFUN specifies an
interactive spec. */
if (SUBRP (fun))
- return XSUBR (fun)->prompt ? Qt : if_prop;
+ return XSUBR (fun)->intspec ? Qt : if_prop;
/* Bytecode objects are interactive if they are long enough to
have an element whose index is COMPILED_INTERACTIVE, which is
@@ -2192,7 +2197,7 @@ do_autoload (fundef, funname)
/* Value saved here is to be restored into Vautoload_queue. */
record_unwind_protect (un_autoload, Vautoload_queue);
Vautoload_queue = Qt;
- Fload (Fcar (Fcdr (fundef)), Qnil, noninteractive ? Qt : Qnil, Qnil, Qt);
+ Fload (Fcar (Fcdr (fundef)), Qnil, Qt, Qnil, Qt);
/* Save the old autoloads, in case we ever do an unload. */
queue = Vautoload_queue;
diff --git a/src/fileio.c b/src/fileio.c
index 58c3e75111..c9b6462e4a 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -78,6 +78,8 @@ extern int errno;
#include "coding.h"
#include "window.h"
#include "blockinput.h"
+#include "frame.h"
+#include "dispextern.h"
#ifdef WINDOWSNT
#define NOMINMAX 1
@@ -3438,7 +3440,9 @@ Return nil, if file does not exist or is not accessible. */)
return make_number (st.st_mode & 07777);
}
-DEFUN ("set-file-modes", Fset_file_modes, Sset_file_modes, 2, 2, 0,
+DEFUN ("set-file-modes", Fset_file_modes, Sset_file_modes, 2, 2,
+ "(let ((file (read-file-name \"File: \"))) \
+ (list file (read-file-modes nil file)))",
doc: /* Set mode bits of file named FILENAME to MODE (an integer).
Only the 12 low bits of MODE are used. */)
(filename, mode)
@@ -5299,8 +5303,10 @@ This does code conversion according to the value of
it, and that means the fsync here is not crucial for autosave files. */
if (!auto_saving && !write_region_inhibit_fsync && fsync (desc) < 0)
{
- /* If fsync fails with EINTR, don't treat that as serious. */
- if (errno != EINTR)
+ /* If fsync fails with EINTR, don't treat that as serious. Also
+ ignore EINVAL which happens when fsync is not supported on this
+ file. */
+ if (errno != EINTR && errno != EINVAL)
failure = 1, save_errno = errno;
}
#endif
@@ -5741,7 +5747,7 @@ auto_save_error (error)
char *msgbuf;
USE_SAFE_ALLOCA;
- ring_bell ();
+ ring_bell (XFRAME (selected_frame));
args[0] = build_string ("Auto-saving %s: %s");
args[1] = current_buffer->name;
@@ -6303,7 +6309,7 @@ and `read-file-name-function'. */)
/* If dir starts with user's homedir, change that to ~. */
homedir = (char *) egetenv ("HOME");
#ifdef DOS_NT
- /* homedir can be NULL in temacs, since Vprocess_environment is not
+ /* homedir can be NULL in temacs, since Vglobal_environment is not
yet set up. We shouldn't crash in that case. */
if (homedir != 0)
{
diff --git a/src/floatfns.c b/src/floatfns.c
index 6ad9b95686..a20f7981bf 100644
--- a/src/floatfns.c
+++ b/src/floatfns.c
@@ -454,7 +454,7 @@ DEFUN ("expt", Fexpt, Sexpt, 2, 2, 0,
(arg1, arg2)
register Lisp_Object arg1, arg2;
{
- double f1, f2;
+ double f1, f2, f3;
CHECK_NUMBER_OR_FLOAT (arg1);
CHECK_NUMBER_OR_FLOAT (arg2);
@@ -500,8 +500,11 @@ DEFUN ("expt", Fexpt, Sexpt, 2, 2, 0,
else if ((f1 == 0.0 && f2 < 0.0) || (f1 < 0 && f2 != floor(f2)))
domain_error2 ("expt", arg1, arg2);
#endif
- IN_FLOAT2 (f1 = pow (f1, f2), "expt", arg1, arg2);
- return make_float (f1);
+ IN_FLOAT2 (f3 = pow (f1, f2), "expt", arg1, arg2);
+ /* Check for overflow in the result. */
+ if (f1 != 0.0 && f3 == 0.0)
+ range_error ("expt", arg1);
+ return make_float (f3);
}
DEFUN ("log", Flog, Slog, 1, 2, 0,
diff --git a/src/fns.c b/src/fns.c
index 67f3a38055..9f7e422d75 100644
--- a/src/fns.c
+++ b/src/fns.c
@@ -1995,7 +1995,7 @@ The PLIST is modified by side effects. */)
prev = tail;
QUIT;
}
- newcell = Fcons (prop, Fcons (val, Qnil));
+ newcell = Fcons (prop, Fcons (val, NILP (prev) ? plist : XCDR (XCDR (prev))));
if (NILP (prev))
return newcell;
else
@@ -2603,7 +2603,8 @@ is nil and `use-dialog-box' is non-nil. */)
{
#ifdef HAVE_MENUS
- if ((NILP (last_nonmenu_event) || CONSP (last_nonmenu_event))
+ if (FRAME_WINDOW_P (SELECTED_FRAME ())
+ && (NILP (last_nonmenu_event) || CONSP (last_nonmenu_event))
&& use_dialog_box
&& have_menus_p ())
{
@@ -2642,6 +2643,7 @@ is nil and `use-dialog-box' is non-nil. */)
Fraise_frame (mini_frame);
}
+ temporarily_switch_to_single_kboard (SELECTED_FRAME ());
obj = read_filtered_event (1, 0, 0, 0, Qnil);
cursor_in_echo_area = 0;
/* If we need to quit, quit with cursor_in_echo_area = 0. */
@@ -2734,7 +2736,8 @@ is nil, and `use-dialog-box' is non-nil. */)
CHECK_STRING (prompt);
#ifdef HAVE_MENUS
- if ((NILP (last_nonmenu_event) || CONSP (last_nonmenu_event))
+ if (FRAME_WINDOW_P (SELECTED_FRAME ())
+ && (NILP (last_nonmenu_event) || CONSP (last_nonmenu_event))
&& use_dialog_box
&& have_menus_p ())
{
@@ -3968,7 +3971,7 @@ make_hash_table (test, size, rehash_size, rehash_threshold, weak,
h->weak = weak;
h->rehash_threshold = rehash_threshold;
h->rehash_size = rehash_size;
- h->count = make_number (0);
+ h->count = 0;
h->key_and_value = Fmake_vector (make_number (2 * sz), Qnil);
h->hash = Fmake_vector (size, Qnil);
h->next = Fmake_vector (size, Qnil);
@@ -4148,7 +4151,7 @@ hash_put (h, key, value, hash)
/* Increment count after resizing because resizing may fail. */
maybe_resize_hash_table (h);
- h->count = make_number (XFASTINT (h->count) + 1);
+ h->count++;
/* Store key/value in the key_and_value vector. */
i = XFASTINT (h->next_free);
@@ -4204,8 +4207,8 @@ hash_remove (h, key)
HASH_KEY (h, i) = HASH_VALUE (h, i) = HASH_HASH (h, i) = Qnil;
HASH_NEXT (h, i) = h->next_free;
h->next_free = make_number (i);
- h->count = make_number (XFASTINT (h->count) - 1);
- xassert (XINT (h->count) >= 0);
+ h->count--;
+ xassert (h->count >= 0);
break;
}
else
@@ -4223,7 +4226,7 @@ void
hash_clear (h)
struct Lisp_Hash_Table *h;
{
- if (XFASTINT (h->count) > 0)
+ if (h->count > 0)
{
int i, size = HASH_TABLE_SIZE (h);
@@ -4239,7 +4242,7 @@ hash_clear (h)
AREF (h->index, i) = Qnil;
h->next_free = make_number (0);
- h->count = make_number (0);
+ h->count = 0;
}
}
@@ -4309,7 +4312,7 @@ sweep_weak_table (h, remove_entries_p)
HASH_KEY (h, i) = HASH_VALUE (h, i) = Qnil;
HASH_HASH (h, i) = Qnil;
- h->count = make_number (XFASTINT (h->count) - 1);
+ h->count--;
}
else
{
@@ -4375,7 +4378,7 @@ sweep_weak_hash_tables ()
if (h->size & ARRAY_MARK_FLAG)
{
/* TABLE is marked as used. Sweep its contents. */
- if (XFASTINT (h->count) > 0)
+ if (h->count > 0)
sweep_weak_table (h, 1);
/* Add table to the list of used weak hash tables. */
@@ -4710,7 +4713,7 @@ DEFUN ("hash-table-count", Fhash_table_count, Shash_table_count, 1, 1, 0,
(table)
Lisp_Object table;
{
- return check_hash_table (table)->count;
+ return make_number (check_hash_table (table)->count);
}
diff --git a/src/fontset.c b/src/fontset.c
index 47a682cc97..9b9fc79b91 100644
--- a/src/fontset.c
+++ b/src/fontset.c
@@ -55,6 +55,7 @@ Boston, MA 02110-1301, USA. */
#ifdef MAC_OS
#include "macterm.h"
#endif
+#include "termhooks.h"
#ifdef USE_FONT_BACKEND
#include "font.h"
@@ -2144,7 +2145,7 @@ DEFUN ("internal-char-font", Finternal_char_font, Sinternal_char_font, 1, 2, 0,
return (Fcons (AREF (rfont_def, 3), Qnil));
STORE_XCHAR2B (&char2b, ((code >> 8) & 0xFF), (code & 0xFF));
fontp = (*get_font_info_func) (f, XINT (AREF (rfont_def, 1)));
- rif->encode_char (c, &char2b, fontp, charset, NULL);
+ FRAME_RIF (f)->encode_char (c, &char2b, fontp, charset, NULL);
code = (XCHAR2B_BYTE1 (&char2b) << 8) | XCHAR2B_BYTE2 (&char2b);
return (Fcons (AREF (rfont_def, 3), make_number (code)));
}
diff --git a/src/frame.c b/src/frame.c
index 7f89adb66d..8314ad7a39 100644
--- a/src/frame.c
+++ b/src/frame.c
@@ -42,6 +42,7 @@ Boston, MA 02110-1301, USA. */
#include "fontset.h"
#endif
#include "blockinput.h"
+#include "termchar.h"
#include "termhooks.h"
#include "dispextern.h"
#include "window.h"
@@ -78,6 +79,8 @@ Lisp_Object Qbackground_mode;
Lisp_Object Qx_frame_parameter;
Lisp_Object Qx_resource_name;
+Lisp_Object Qterminal;
+Lisp_Object Qterminal_live_p;
/* Frame parameters (set or reported). */
@@ -107,8 +110,11 @@ Lisp_Object Qtitle, Qname;
Lisp_Object Qunsplittable;
Lisp_Object Qmenu_bar_lines, Qtool_bar_lines;
Lisp_Object Qleft_fringe, Qright_fringe;
-Lisp_Object Qbuffer_predicate, Qbuffer_list;
+Lisp_Object Qbuffer_predicate, Qbuffer_list, Qburied_buffer_list;
Lisp_Object Qtty_color_mode;
+Lisp_Object Qtty, Qtty_type;
+Lisp_Object Qwindow_system;
+Lisp_Object Qenvironment;
Lisp_Object Qfullscreen, Qfullwidth, Qfullheight, Qfullboth;
#ifdef USE_FONT_BACKEND
@@ -118,18 +124,19 @@ Lisp_Object Qfont_backend;
Lisp_Object Qinhibit_face_set_after_frame_default;
Lisp_Object Qface_set_after_frame_default;
-
Lisp_Object Vterminal_frame;
Lisp_Object Vdefault_frame_alist;
Lisp_Object Vdefault_frame_scroll_bars;
Lisp_Object Vmouse_position_function;
Lisp_Object Vmouse_highlight;
Lisp_Object Vdelete_frame_functions;
+
+int focus_follows_mouse;
static void
set_menu_bar_lines_1 (window, n)
- Lisp_Object window;
- int n;
+ Lisp_Object window;
+ int n;
{
struct window *w = XWINDOW (window);
@@ -187,8 +194,6 @@ set_menu_bar_lines (f, value, oldval)
Lisp_Object Vemacs_iconified;
Lisp_Object Vframe_list;
-struct x_output tty_display;
-
extern Lisp_Object Vminibuffer_list;
extern Lisp_Object get_minibuffer ();
extern Lisp_Object Fhandle_switch_frame ();
@@ -210,6 +215,7 @@ See also `frame-live-p'. */)
return Qnil;
switch (XFRAME (object)->output_method)
{
+ case output_initial: /* The initial frame is like a termcap frame. */
case output_termcap:
return Qt;
case output_x_window:
@@ -228,7 +234,7 @@ See also `frame-live-p'. */)
DEFUN ("frame-live-p", Fframe_live_p, Sframe_live_p, 1, 1, 0,
doc: /* Return non-nil if OBJECT is a frame which has not been deleted.
Value is nil if OBJECT is not a live frame. If object is a live
-frame, the return value indicates what sort of output device it is
+frame, the return value indicates what sort of terminal device it is
displayed on. See the documentation of `framep' for possible
return values. */)
(object)
@@ -240,6 +246,30 @@ return values. */)
: Qnil);
}
+DEFUN ("window-system", Fwindow_system, Swindow_system, 0, 1, 0,
+ doc: /* The name of the window system that FRAME is displaying through.
+The value is a symbol---for instance, 'x' for X windows.
+The value is nil if Emacs is using a text-only terminal.
+
+FRAME defaults to the currently selected frame. */)
+ (frame)
+ Lisp_Object frame;
+{
+ Lisp_Object type;
+ if (NILP (frame))
+ frame = selected_frame;
+
+ type = Fframep (frame);
+
+ if (NILP (type))
+ wrong_type_argument (Qframep, frame);
+
+ if (EQ (type, Qt))
+ return Qnil;
+ else
+ return type;
+}
+
struct frame *
make_frame (mini_p)
int mini_p;
@@ -283,9 +313,7 @@ make_frame (mini_p)
f->menu_bar_items_used = 0;
f->buffer_predicate = Qnil;
f->buffer_list = Qnil;
-#ifdef MULTI_KBOARD
- f->kboard = initial_kboard;
-#endif
+ f->buried_buffer_list = Qnil;
f->namebuf = 0;
f->title = Qnil;
f->menu_bar_window = Qnil;
@@ -408,8 +436,8 @@ make_frame_without_minibuffer (mini_window, kb, display)
#ifdef MULTI_KBOARD
if (!NILP (mini_window)
- && XFRAME (XWINDOW (mini_window)->frame)->kboard != kb)
- error ("Frame and minibuffer must be on the same display");
+ && FRAME_KBOARD (XFRAME (XWINDOW (mini_window)->frame)) != kb)
+ error ("Frame and minibuffer must be on the same terminal");
#endif
/* Make a frame containing just a root window. */
@@ -485,18 +513,19 @@ make_minibuffer_frame ()
}
#endif /* HAVE_WINDOW_SYSTEM */
-/* Construct a frame that refers to the terminal (stdin and stdout). */
+/* Construct a frame that refers to a terminal. */
-static int terminal_frame_count;
+static int tty_frame_count;
struct frame *
-make_terminal_frame ()
+make_initial_frame (void)
{
- register struct frame *f;
+ struct frame *f;
+ struct terminal *terminal;
Lisp_Object frame;
- char name[20];
#ifdef MULTI_KBOARD
+ /* Create the initial keyboard. */
if (!initial_kboard)
{
initial_kboard = (KBOARD *) xmalloc (sizeof (KBOARD));
@@ -510,13 +539,51 @@ make_terminal_frame ()
if (! (NILP (Vframe_list) || CONSP (Vframe_list)))
Vframe_list = Qnil;
+ terminal = init_initial_terminal ();
+
+ f = make_frame (1);
+ XSETFRAME (frame, f);
+
+ Vframe_list = Fcons (frame, Vframe_list);
+
+ tty_frame_count = 1;
+ f->name = build_string ("F1");
+
+ f->visible = 1;
+ f->async_visible = 1;
+
+ f->output_method = terminal->type;
+ f->terminal = terminal;
+ f->terminal->reference_count++;
+ f->output_data.nothing = 0;
+
+ FRAME_FOREGROUND_PIXEL (f) = FACE_TTY_DEFAULT_FG_COLOR;
+ FRAME_BACKGROUND_PIXEL (f) = FACE_TTY_DEFAULT_BG_COLOR;
+
+ FRAME_CAN_HAVE_SCROLL_BARS (f) = 0;
+ FRAME_VERTICAL_SCROLL_BAR_TYPE (f) = vertical_scroll_bar_none;
+
+ return f;
+}
+
+
+struct frame *
+make_terminal_frame (struct terminal *terminal)
+{
+ register struct frame *f;
+ Lisp_Object frame;
+ char name[20];
+
+ if (!terminal->name)
+ error ("Terminal is not live, can't create new frames on it");
+
f = make_frame (1);
XSETFRAME (frame, f);
Vframe_list = Fcons (frame, Vframe_list);
- terminal_frame_count++;
- sprintf (name, "F%d", terminal_frame_count);
+ tty_frame_count++;
+ sprintf (name, "F%d", tty_frame_count);
f->name = build_string (name);
f->visible = 1; /* FRAME_SET_VISIBLE wd set frame_garbaged. */
@@ -536,30 +603,44 @@ make_terminal_frame ()
for the black color. Other frames all inherit their pixels
from what's already in the_only_x_display. */
if ((!FRAMEP (selected_frame) || !FRAME_LIVE_P (XFRAME (selected_frame)))
- && f->output_data.x->background_pixel == 0
- && f->output_data.x->foreground_pixel == 0)
+ && FRAME_BACKGROUND_PIXEL (f) == 0
+ && FRAME_FOREGROUND_PIXEL (f) == 0)
{
- f->output_data.x->background_pixel = FACE_TTY_DEFAULT_BG_COLOR;
- f->output_data.x->foreground_pixel = FACE_TTY_DEFAULT_FG_COLOR;
+ FRAME_BACKGROUND_PIXEL (f) = FACE_TTY_DEFAULT_BG_COLOR;
+ FRAME_FOREGROUND_PIXEL (f) = FACE_TTY_DEFAULT_FG_COLOR;
}
}
else
f->output_method = output_termcap;
#else
-#ifdef WINDOWSNT
- f->output_method = output_termcap;
- f->output_data.x = &tty_display;
-#else
#ifdef MAC_OS8
make_mac_terminal_frame (f);
#else
- f->output_data.x = &tty_display;
+ {
+ f->output_method = output_termcap;
+ f->terminal = terminal;
+ f->terminal->reference_count++;
+ create_tty_output (f);
+
+ FRAME_FOREGROUND_PIXEL (f) = FACE_TTY_DEFAULT_FG_COLOR;
+ FRAME_BACKGROUND_PIXEL (f) = FACE_TTY_DEFAULT_BG_COLOR;
+
+ FRAME_CAN_HAVE_SCROLL_BARS (f) = 0;
+ FRAME_VERTICAL_SCROLL_BAR_TYPE (f) = vertical_scroll_bar_none;
+
+ /* Set the top frame to the newly created frame. */
+ if (FRAMEP (FRAME_TTY (f)->top_frame)
+ && FRAME_LIVE_P (XFRAME (FRAME_TTY (f)->top_frame)))
+ XFRAME (FRAME_TTY (f)->top_frame)->async_visible = 2; /* obscured */
+
+ FRAME_TTY (f)->top_frame = frame;
+ }
+
#ifdef CANNOT_DUMP
FRAME_FOREGROUND_PIXEL(f) = FACE_TTY_DEFAULT_FG_COLOR;
FRAME_BACKGROUND_PIXEL(f) = FACE_TTY_DEFAULT_BG_COLOR;
#endif
#endif /* MAC_OS8 */
-#endif /* WINDOWSNT */
#endif /* MSDOS */
if (!noninteractive)
@@ -568,18 +649,55 @@ make_terminal_frame ()
return f;
}
+/* Get a suitable value for frame parameter PARAMETER for a newly
+ created frame, based on (1) the user-supplied frame parameter
+ alist SUPPLIED_PARMS, (2) CURRENT_VALUE, and finally, if all else
+ fails, (3) Vdefault_frame_alist. */
+
+static Lisp_Object
+get_future_frame_param (Lisp_Object parameter,
+ Lisp_Object supplied_parms,
+ char *current_value)
+{
+ Lisp_Object result;
+
+ result = Fassq (parameter, supplied_parms);
+ if (NILP (result))
+ result = Fassq (parameter, XFRAME (selected_frame)->param_alist);
+ if (NILP (result) && current_value != NULL)
+ result = build_string (current_value);
+ if (NILP (result))
+ result = Fassq (parameter, Vdefault_frame_alist);
+ if (!NILP (result) && !STRINGP (result))
+ result = XCDR (result);
+ if (NILP (result) || !STRINGP (result))
+ result = Qnil;
+
+ return result;
+}
+
DEFUN ("make-terminal-frame", Fmake_terminal_frame, Smake_terminal_frame,
1, 1, 0,
- doc: /* Create an additional terminal frame.
-You can create multiple frames on a text-only terminal in this way.
-Only the selected terminal frame is actually displayed.
+ doc: /* Create an additional terminal frame, possibly on another terminal.
This function takes one argument, an alist specifying frame parameters.
-In practice, generally you don't need to specify any parameters.
-Note that changing the size of one terminal frame automatically affects all. */)
+
+You can create multiple frames on a single text-only terminal, but
+only one of them (the selected terminal frame) is actually displayed.
+
+In practice, generally you don't need to specify any parameters,
+except when you want to create a new frame on another terminal.
+In that case, the `tty' parameter specifies the device file to open,
+and the `tty-type' parameter specifies the terminal type. Example:
+
+ (make-terminal-frame '((tty . "/dev/pts/5") (tty-type . "xterm")))
+
+Note that changing the size of one terminal frame automatically
+affects all frames on the same terminal device. */)
(parms)
Lisp_Object parms;
{
struct frame *f;
+ struct terminal *t = NULL;
Lisp_Object frame, tem;
struct frame *sf = SELECTED_FRAME ();
@@ -589,25 +707,84 @@ Note that changing the size of one terminal frame automatically affects all. */
abort ();
#else /* not MSDOS */
-#ifdef MAC_OS
+#if 0 /* #ifdef MAC_OS */
+ /* This can happen for multi-tty when using both terminal frames and
+ Carbon frames. */
if (sf->output_method != output_mac)
error ("Not running on a Macintosh screen; cannot make a new Macintosh frame");
#else
+#if 0 /* This should work now! */
if (sf->output_method != output_termcap)
error ("Not using an ASCII terminal now; cannot make a new ASCII frame");
#endif
+#endif
#endif /* not MSDOS */
+
+ {
+ Lisp_Object terminal;
+
+ terminal = Fassq (Qterminal, parms);
+ if (!NILP (terminal))
+ {
+ terminal = XCDR (terminal);
+ t = get_terminal (terminal, 1);
+ }
+ }
+
+ if (!t)
+ {
+ char *name = 0, *type = 0;
+ Lisp_Object tty, tty_type;
+
+ tty = get_future_frame_param
+ (Qtty, parms, (FRAME_TERMCAP_P (XFRAME (selected_frame))
+ ? FRAME_TTY (XFRAME (selected_frame))->name
+ : NULL));
+ if (!NILP (tty))
+ {
+ name = (char *) alloca (SBYTES (tty) + 1);
+ strncpy (name, SDATA (tty), SBYTES (tty));
+ name[SBYTES (tty)] = 0;
+ }
+
+ tty_type = get_future_frame_param
+ (Qtty_type, parms, (FRAME_TERMCAP_P (XFRAME (selected_frame))
+ ? FRAME_TTY (XFRAME (selected_frame))->type
+ : NULL));
+ if (!NILP (tty_type))
+ {
+ type = (char *) alloca (SBYTES (tty_type) + 1);
+ strncpy (type, SDATA (tty_type), SBYTES (tty_type));
+ type[SBYTES (tty_type)] = 0;
+ }
+
+ t = init_tty (name, type, 0); /* Errors are not fatal. */
+ }
- f = make_terminal_frame ();
+ f = make_terminal_frame (t);
- change_frame_size (f, FRAME_LINES (sf),
- FRAME_COLS (sf), 0, 0, 0);
+ {
+ int width, height;
+ get_tty_size (fileno (FRAME_TTY (f)->input), &width, &height);
+ change_frame_size (f, height, width, 0, 0, 0);
+ }
+
adjust_glyphs (f);
calculate_costs (f);
XSETFRAME (frame, f);
Fmodify_frame_parameters (frame, Vdefault_frame_alist);
Fmodify_frame_parameters (frame, parms);
-
+ Fmodify_frame_parameters (frame, Fcons (Fcons (Qwindow_system, Qnil), Qnil));
+ Fmodify_frame_parameters (frame, Fcons (Fcons (Qtty_type,
+ build_string (t->display_info.tty->type)),
+ Qnil));
+ if (t->display_info.tty->name != NULL)
+ Fmodify_frame_parameters (frame, Fcons (Fcons (Qtty,
+ build_string (t->display_info.tty->name)),
+ Qnil));
+ else
+ Fmodify_frame_parameters (frame, Fcons (Fcons (Qtty, Qnil), Qnil));
+
/* Make the frame face alist be frame-specific, so that each
frame could change its face definitions independently. */
f->face_alist = Fcopy_alist (sf->face_alist);
@@ -630,7 +807,7 @@ Note that changing the size of one terminal frame automatically affects all. */
frame's focus to FRAME instead.
FOR_DELETION non-zero means that the selected frame is being
- deleted, which includes the possibility that the frame's display
+ deleted, which includes the possibility that the frame's terminal
is dead. */
Lisp_Object
@@ -705,6 +882,15 @@ do_switch_frame (frame, track, for_deletion)
if (!for_deletion && FRAME_HAS_MINIBUF_P (sf))
resize_mini_window (XWINDOW (FRAME_MINIBUF_WINDOW (sf)), 1);
+ if (FRAME_TERMCAP_P (XFRAME (selected_frame))
+ && FRAME_TERMCAP_P (XFRAME (frame))
+ && FRAME_TTY (XFRAME (selected_frame)) == FRAME_TTY (XFRAME (frame)))
+ {
+ XFRAME (selected_frame)->async_visible = 2; /* obscured */
+ XFRAME (frame)->async_visible = 1;
+ FRAME_TTY (XFRAME (frame))->top_frame = frame;
+ }
+
selected_frame = frame;
if (! FRAME_MINIBUF_ONLY_P (XFRAME (selected_frame)))
last_nonminibuf_frame = XFRAME (selected_frame);
@@ -888,6 +1074,7 @@ If FRAME is the selected frame, this makes WINDOW the selected window. */)
return XFRAME (frame)->selected_window = window;
}
+
DEFUN ("frame-list", Fframe_list, Sframe_list,
0, 0, 0,
@@ -935,7 +1122,10 @@ next_frame (frame, minibuf)
f = XCAR (tail);
if (passed
- && FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame)))
+ && ((!FRAME_TERMCAP_P (XFRAME (f)) && !FRAME_TERMCAP_P (XFRAME (frame))
+ && FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame)))
+ || (FRAME_TERMCAP_P (XFRAME (f)) && FRAME_TERMCAP_P (XFRAME (frame))
+ && FRAME_TTY (XFRAME (f)) == FRAME_TTY (XFRAME (frame)))))
{
/* Decide whether this frame is eligible to be returned. */
@@ -1012,7 +1202,10 @@ prev_frame (frame, minibuf)
if (EQ (frame, f) && !NILP (prev))
return prev;
- if (FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame)))
+ if ((!FRAME_TERMCAP_P (XFRAME (f)) && !FRAME_TERMCAP_P (XFRAME (frame))
+ && FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame)))
+ || (FRAME_TERMCAP_P (XFRAME (f)) && FRAME_TERMCAP_P (XFRAME (frame))
+ && FRAME_TTY (XFRAME (f)) == FRAME_TTY (XFRAME (frame))))
{
/* Decide whether this frame is eligible to be returned,
according to minibuf. */
@@ -1146,6 +1339,14 @@ other_visible_frames (f)
return 1;
}
+/* Error handler for `delete-frame-functions'. */
+static Lisp_Object
+delete_frame_handler (Lisp_Object arg)
+{
+ add_to_log ("Error during `delete-frame': %s", arg, Qnil);
+ return Qnil;
+}
+
DEFUN ("delete-frame", Fdelete_frame, Sdelete_frame, 0, 2, "",
doc: /* Delete FRAME, permanently eliminating it from use.
If omitted, FRAME defaults to the selected frame.
@@ -1161,6 +1362,8 @@ The functions are run with one arg, the frame to be deleted. */)
{
struct frame *f;
struct frame *sf = SELECTED_FRAME ();
+ struct kboard *kb;
+
int minibuffer_selected;
if (EQ (frame, Qnil))
@@ -1219,11 +1422,22 @@ The functions are run with one arg, the frame to be deleted. */)
&& NILP (Fframe_parameter (frame, intern ("tooltip"))))
{
Lisp_Object args[2];
+ struct gcpro gcpro1, gcpro2;
+
+ /* Don't let a rogue function in `delete-frame-functions'
+ prevent the frame deletion. */
+ GCPRO2 (args[0], args[1]);
args[0] = intern ("delete-frame-functions");
args[1] = frame;
- Frun_hook_with_args (2, args);
+ internal_condition_case_2 (Frun_hook_with_args, 2, args,
+ Qt, delete_frame_handler);
+ UNGCPRO;
}
+ /* The hook may sometimes (indirectly) cause the frame to be deleted. */
+ if (! FRAME_LIVE_P (f))
+ return Qnil;
+
minibuffer_selected = EQ (minibuf_window, selected_window);
/* Don't let the frame remain selected. */
@@ -1239,7 +1453,7 @@ The functions are run with one arg, the frame to be deleted. */)
{
FOR_EACH_FRAME (tail, frame1)
{
- if (! EQ (frame, frame1))
+ if (! EQ (frame, frame1) && FRAME_LIVE_P (XFRAME (frame1)))
break;
}
}
@@ -1265,6 +1479,24 @@ The functions are run with one arg, the frame to be deleted. */)
if (EQ (f->minibuffer_window, echo_area_window))
echo_area_window = sf->minibuffer_window;
+ /* Don't allow other frames to refer to a deleted frame in their
+ 'environment parameter. */
+ {
+ Lisp_Object tail, frame1;
+ Lisp_Object env = get_frame_param (XFRAME (frame), Qenvironment);
+ FOR_EACH_FRAME (tail, frame1)
+ {
+ if (EQ (frame, frame1) || !FRAME_LIVE_P (XFRAME (frame1)))
+ continue;
+ if (EQ (frame, get_frame_param (XFRAME (frame1), Qenvironment)))
+ {
+ store_frame_param (XFRAME (frame1), Qenvironment, env);
+ if (!FRAMEP (env))
+ env = frame1;
+ }
+ }
+ }
+
/* Clear any X selections for this frame. */
#ifdef HAVE_X_WINDOWS
if (FRAME_X_P (f))
@@ -1305,18 +1537,36 @@ The functions are run with one arg, the frame to be deleted. */)
xfree (FRAME_MESSAGE_BUF (f));
/* Since some events are handled at the interrupt level, we may get
- an event for f at any time; if we zero out the frame's display
+ an event for f at any time; if we zero out the frame's terminal
now, then we may trip up the event-handling code. Instead, we'll
- promise that the display of the frame must be valid until we have
- called the window-system-dependent frame destruction routine. */
+ promise that the terminal of the frame must be valid until we
+ have called the window-system-dependent frame destruction
+ routine. */
- /* I think this should be done with a hook. */
-#ifdef HAVE_WINDOW_SYSTEM
- if (FRAME_WINDOW_P (f))
- x_destroy_window (f);
-#endif
+ if (FRAME_TERMINAL (f)->delete_frame_hook)
+ (*FRAME_TERMINAL (f)->delete_frame_hook) (f);
- f->output_data.nothing = 0;
+ {
+ struct terminal *terminal = FRAME_TERMINAL (f);
+ f->output_data.nothing = 0;
+ f->terminal = 0; /* Now the frame is dead. */
+
+ /* If needed, delete the terminal that this frame was on.
+ (This must be done after the frame is killed.) */
+ terminal->reference_count--;
+ if (terminal->reference_count == 0)
+ {
+ kb = NULL;
+ if (terminal->delete_terminal_hook)
+ (*terminal->delete_terminal_hook) (terminal);
+ else
+ delete_terminal (terminal);
+ }
+#ifdef MULTI_KBOARD
+ else
+ kb = terminal->kboard;
+#endif
+ }
/* If we've deleted the last_nonminibuf_frame, then try to find
another one. */
@@ -1341,38 +1591,39 @@ The functions are run with one arg, the frame to be deleted. */)
/* If there's no other frame on the same kboard, get out of
single-kboard state if we're in it for this kboard. */
- {
- Lisp_Object frames;
- /* Some frame we found on the same kboard, or nil if there are none. */
- Lisp_Object frame_on_same_kboard;
+ if (kb != NULL)
+ {
+ Lisp_Object frames;
+ /* Some frame we found on the same kboard, or nil if there are none. */
+ Lisp_Object frame_on_same_kboard;
- frame_on_same_kboard = Qnil;
+ frame_on_same_kboard = Qnil;
- for (frames = Vframe_list;
- CONSP (frames);
- frames = XCDR (frames))
- {
- Lisp_Object this;
- struct frame *f1;
+ for (frames = Vframe_list;
+ CONSP (frames);
+ frames = XCDR (frames))
+ {
+ Lisp_Object this;
+ struct frame *f1;
- this = XCAR (frames);
- if (!FRAMEP (this))
- abort ();
- f1 = XFRAME (this);
+ this = XCAR (frames);
+ if (!FRAMEP (this))
+ abort ();
+ f1 = XFRAME (this);
- if (FRAME_KBOARD (f) == FRAME_KBOARD (f1))
- frame_on_same_kboard = this;
- }
+ if (kb == FRAME_KBOARD (f1))
+ frame_on_same_kboard = this;
+ }
- if (NILP (frame_on_same_kboard))
- not_single_kboard_state (FRAME_KBOARD (f));
- }
+ if (NILP (frame_on_same_kboard))
+ not_single_kboard_state (kb);
+ }
/* If we've deleted this keyboard's default_minibuffer_frame, try to
find another one. Prefer minibuffer-only frames, but also notice
frames with other windows. */
- if (EQ (frame, FRAME_KBOARD (f)->Vdefault_minibuffer_frame))
+ if (kb != NULL && EQ (frame, kb->Vdefault_minibuffer_frame))
{
Lisp_Object frames;
@@ -1398,7 +1649,7 @@ The functions are run with one arg, the frame to be deleted. */)
/* Consider only frames on the same kboard
and only those with minibuffers. */
- if (FRAME_KBOARD (f) == FRAME_KBOARD (f1)
+ if (kb == FRAME_KBOARD (f1)
&& FRAME_HAS_MINIBUF_P (f1))
{
frame_with_minibuf = this;
@@ -1406,7 +1657,7 @@ The functions are run with one arg, the frame to be deleted. */)
break;
}
- if (FRAME_KBOARD (f) == FRAME_KBOARD (f1))
+ if (kb == FRAME_KBOARD (f1))
frame_on_same_kboard = this;
}
@@ -1421,11 +1672,11 @@ The functions are run with one arg, the frame to be deleted. */)
if (NILP (frame_with_minibuf))
abort ();
- FRAME_KBOARD (f)->Vdefault_minibuffer_frame = frame_with_minibuf;
+ kb->Vdefault_minibuffer_frame = frame_with_minibuf;
}
else
/* No frames left on this kboard--say no minibuffer either. */
- FRAME_KBOARD (f)->Vdefault_minibuffer_frame = Qnil;
+ kb->Vdefault_minibuffer_frame = Qnil;
}
/* Cause frame titles to update--necessary if we now have just one frame. */
@@ -1462,11 +1713,11 @@ and returns whatever that function returns. */)
#if defined (HAVE_MOUSE) || defined (HAVE_GPM)
/* It's okay for the hook to refrain from storing anything. */
- if (mouse_position_hook)
- (*mouse_position_hook) (&f, -1,
- &lispy_dummy, &party_dummy,
- &x, &y,
- &long_dummy);
+ if (FRAME_TERMINAL (f)->mouse_position_hook)
+ (*FRAME_TERMINAL (f)->mouse_position_hook) (&f, -1,
+ &lispy_dummy, &party_dummy,
+ &x, &y,
+ &long_dummy);
if (! NILP (x))
{
col = XINT (x);
@@ -1506,11 +1757,11 @@ and nil for X and Y. */)
#if defined (HAVE_MOUSE) || defined (HAVE_GPM)
/* It's okay for the hook to refrain from storing anything. */
- if (mouse_position_hook)
- (*mouse_position_hook) (&f, -1,
- &lispy_dummy, &party_dummy,
- &x, &y,
- &long_dummy);
+ if (FRAME_TERMINAL (f)->mouse_position_hook)
+ (*FRAME_TERMINAL (f)->mouse_position_hook) (&f, -1,
+ &lispy_dummy, &party_dummy,
+ &x, &y,
+ &long_dummy);
#endif
XSETFRAME (lispy_dummy, f);
return Fcons (lispy_dummy, Fcons (x, y));
@@ -1797,16 +2048,19 @@ doesn't support multiple overlapping frames, this function does nothing. */)
(frame)
Lisp_Object frame;
{
+ struct frame *f;
if (NILP (frame))
frame = selected_frame;
CHECK_LIVE_FRAME (frame);
+ f = XFRAME (frame);
+
/* Do like the documentation says. */
Fmake_frame_visible (frame);
- if (frame_raise_lower_hook)
- (*frame_raise_lower_hook) (XFRAME (frame), 1);
+ if (FRAME_TERMINAL (f)->frame_raise_lower_hook)
+ (*FRAME_TERMINAL (f)->frame_raise_lower_hook) (f, 1);
return Qnil;
}
@@ -1820,13 +2074,17 @@ doesn't support multiple overlapping frames, this function does nothing. */)
(frame)
Lisp_Object frame;
{
+ struct frame *f;
+
if (NILP (frame))
frame = selected_frame;
CHECK_LIVE_FRAME (frame);
- if (frame_raise_lower_hook)
- (*frame_raise_lower_hook) (XFRAME (frame), 0);
+ f = XFRAME (frame);
+
+ if (FRAME_TERMINAL (f)->frame_raise_lower_hook)
+ (*FRAME_TERMINAL (f)->frame_raise_lower_hook) (f, 0);
return Qnil;
}
@@ -1860,6 +2118,8 @@ The redirection lasts until `redirect-frame-focus' is called to change it. */)
(frame, focus_frame)
Lisp_Object frame, focus_frame;
{
+ struct frame *f;
+
/* Note that we don't check for a live frame here. It's reasonable
to redirect the focus of a frame you're about to delete, if you
know what other frame should receive those keystrokes. */
@@ -1868,10 +2128,12 @@ The redirection lasts until `redirect-frame-focus' is called to change it. */)
if (! NILP (focus_frame))
CHECK_LIVE_FRAME (focus_frame);
- XFRAME (frame)->focus_frame = focus_frame;
+ f = XFRAME (frame);
+
+ f->focus_frame = focus_frame;
- if (frame_rehighlight_hook)
- (*frame_rehighlight_hook) (XFRAME (frame));
+ if (FRAME_TERMINAL (f)->frame_rehighlight_hook)
+ (*FRAME_TERMINAL (f)->frame_rehighlight_hook) (f);
return Qnil;
}
@@ -1933,7 +2195,7 @@ set_frame_buffer_list (frame, list)
XFRAME (frame)->buffer_list = list;
}
-/* Discard BUFFER from the buffer-list of each frame. */
+/* Discard BUFFER from the buffer-list and buried-buffer-list of each frame. */
void
frames_discard_buffer (buffer)
@@ -1945,6 +2207,8 @@ frames_discard_buffer (buffer)
{
XFRAME (frame)->buffer_list
= Fdelq (buffer, XFRAME (frame)->buffer_list);
+ XFRAME (frame)->buried_buffer_list
+ = Fdelq (buffer, XFRAME (frame)->buried_buffer_list);
}
}
@@ -2003,8 +2267,8 @@ set_term_frame_name (f, name)
SBYTES (f->name)))
return;
- terminal_frame_count++;
- sprintf (namebuf, "F%d", terminal_frame_count);
+ tty_frame_count++;
+ sprintf (namebuf, "F%d", tty_frame_count);
name = build_string (namebuf);
}
else
@@ -2032,13 +2296,18 @@ store_frame_param (f, prop, val)
{
register Lisp_Object old_alist_elt;
- /* The buffer-alist parameter is stored in a special place and is
- not in the alist. */
+ /* The buffer-list parameters are stored in a special place and not
+ in the alist. */
if (EQ (prop, Qbuffer_list))
{
f->buffer_list = val;
return;
}
+ if (EQ (prop, Qburied_buffer_list))
+ {
+ f->buried_buffer_list = val;
+ return;
+ }
/* If PROP is a symbol which is supposed to have frame-local values,
and it is set up based on this frame, switch to the global
@@ -2051,6 +2320,7 @@ store_frame_param (f, prop, val)
if ((BUFFER_LOCAL_VALUEP (valcontents)
|| SOME_BUFFER_LOCAL_VALUEP (valcontents))
&& XBUFFER_LOCAL_VALUE (valcontents)->check_frame
+ && XBUFFER_LOCAL_VALUE (valcontents)->found_for_frame
&& XFRAME (XBUFFER_LOCAL_VALUE (valcontents)->frame) == f)
swap_in_global_binding (prop);
}
@@ -2133,7 +2403,7 @@ If FRAME is omitted, return information on the currently selected frame. */)
unspecified and reversed, take the frame's background pixel
for foreground and vice versa. */
elt = Fassq (Qforeground_color, alist);
- if (!NILP (elt) && CONSP (elt) && STRINGP (XCDR (elt)))
+ if (CONSP (elt) && STRINGP (XCDR (elt)))
{
if (strncmp (SDATA (XCDR (elt)),
unspecified_bg,
@@ -2147,7 +2417,7 @@ If FRAME is omitted, return information on the currently selected frame. */)
else
store_in_alist (&alist, Qforeground_color, tty_color_name (f, fg));
elt = Fassq (Qbackground_color, alist);
- if (!NILP (elt) && CONSP (elt) && STRINGP (XCDR (elt)))
+ if (CONSP (elt) && STRINGP (XCDR (elt)))
{
if (strncmp (SDATA (XCDR (elt)),
unspecified_fg,
@@ -2178,6 +2448,7 @@ If FRAME is omitted, return information on the currently selected frame. */)
: FRAME_MINIBUF_WINDOW (f)));
store_in_alist (&alist, Qunsplittable, (FRAME_NO_SPLIT_P (f) ? Qt : Qnil));
store_in_alist (&alist, Qbuffer_list, frame_buffer_list (frame));
+ store_in_alist (&alist, Qburied_buffer_list, XFRAME (frame)->buried_buffer_list);
/* I think this should be done with a hook. */
#ifdef HAVE_WINDOW_SYSTEM
@@ -2345,9 +2616,45 @@ enabled such bindings for that variable with `make-variable-frame-local'. */)
call1 (Qframe_set_background_mode, frame);
}
}
-
return Qnil;
}
+
+DEFUN ("frame-with-environment", Fframe_with_environment, Sframe_with_environment, 0, 1, 0,
+ doc: /* Return the frame that has the environment variable list for FRAME.
+
+The frame-local environment variable list is normally shared between
+frames that were created in the same Emacsclient session. The
+environment list is stored in a single frame's 'environment parameter;
+the other frames' 'environment parameter is set to this frame. This
+function follows the chain of 'environment references to reach the
+frame that stores the actual local environment list, and returns that
+frame. */)
+ (frame)
+ Lisp_Object frame;
+{
+ Lisp_Object hare, tortoise;
+
+ if (NILP (frame))
+ frame = selected_frame;
+ CHECK_FRAME (frame);
+
+ hare = tortoise = get_frame_param (XFRAME (frame), Qenvironment);
+ while (!NILP (hare) && FRAMEP (hare))
+ {
+ frame = hare;
+ hare = get_frame_param (XFRAME (hare), Qenvironment);
+ if (NILP (hare) || !FRAMEP (hare))
+ break;
+ frame = hare;
+ hare = get_frame_param (XFRAME (hare), Qenvironment);
+ tortoise = get_frame_param (XFRAME (tortoise), Qenvironment);
+ if (EQ (hare, tortoise))
+ error ("Cyclic frame-local environment indirection");
+ }
+
+ return frame;
+}
+
DEFUN ("frame-char-height", Fframe_char_height, Sframe_char_height,
0, 1, 0,
@@ -2767,9 +3074,8 @@ x_set_frame_parameters (f, alist)
if (NATNUMP (param_index)
&& (XFASTINT (param_index)
< sizeof (frame_parms)/sizeof (frame_parms[0]))
- && rif->frame_parm_handlers[XINT (param_index)])
- (*(rif->frame_parm_handlers[XINT (param_index)])) (f, val, old_value);
-
+ && FRAME_RIF (f)->frame_parm_handlers[XINT (param_index)])
+ (*(FRAME_RIF (f)->frame_parm_handlers[XINT (param_index)])) (f, val, old_value);
unbind_to (count, Qnil);
}
}
@@ -2783,9 +3089,9 @@ x_set_frame_parameters (f, alist)
prop = parms[i];
val = values[i];
- if (EQ (prop, Qwidth) && NUMBERP (val))
+ if (EQ (prop, Qwidth) && NATNUMP (val))
width = XFASTINT (val);
- else if (EQ (prop, Qheight) && NUMBERP (val))
+ else if (EQ (prop, Qheight) && NATNUMP (val))
height = XFASTINT (val);
else if (EQ (prop, Qtop))
top = val;
@@ -2813,8 +3119,8 @@ x_set_frame_parameters (f, alist)
if (NATNUMP (param_index)
&& (XFASTINT (param_index)
< sizeof (frame_parms)/sizeof (frame_parms[0]))
- && rif->frame_parm_handlers[XINT (param_index)])
- (*(rif->frame_parm_handlers[XINT (param_index)])) (f, val, old_value);
+ && FRAME_RIF (f)->frame_parm_handlers[XINT (param_index)])
+ (*(FRAME_RIF (f)->frame_parm_handlers[XINT (param_index)])) (f, val, old_value);
}
}
@@ -3052,8 +3358,8 @@ x_set_fullscreen (f, new_value, old_value)
else if (EQ (new_value, Qfullheight))
f->want_fullscreen = FULLSCREEN_HEIGHT;
- if (fullscreen_hook != NULL)
- fullscreen_hook (f);
+ if (FRAME_TERMINAL (f)->fullscreen_hook != NULL)
+ FRAME_TERMINAL (f)->fullscreen_hook (f);
}
@@ -3102,9 +3408,9 @@ x_set_screen_gamma (f, new_value, old_value)
if (NATNUMP (index)
&& (XFASTINT (index)
< sizeof (frame_parms)/sizeof (frame_parms[0]))
- && rif->frame_parm_handlers[XFASTINT (index)])
- (*(rif->frame_parm_handlers[XFASTINT (index)]))
- (f, bgcolor, Qnil);
+ && FRAME_RIF (f)->frame_parm_handlers[XFASTINT (index)])
+ (*FRAME_RIF (f)->frame_parm_handlers[XFASTINT (index)])
+ (f, bgcolor, Qnil);
}
Fclear_face_cache (Qnil);
@@ -4135,12 +4441,22 @@ syms_of_frame ()
staticpro (&Qbuffer_predicate);
Qbuffer_list = intern ("buffer-list");
staticpro (&Qbuffer_list);
+ Qburied_buffer_list = intern ("buried-buffer-list");
+ staticpro (&Qburied_buffer_list);
Qdisplay_type = intern ("display-type");
staticpro (&Qdisplay_type);
Qbackground_mode = intern ("background-mode");
staticpro (&Qbackground_mode);
Qtty_color_mode = intern ("tty-color-mode");
staticpro (&Qtty_color_mode);
+ Qtty = intern ("tty");
+ staticpro (&Qtty);
+ Qtty_type = intern ("tty-type");
+ staticpro (&Qtty_type);
+ Qwindow_system = intern ("window-system");
+ staticpro (&Qwindow_system);
+ Qenvironment = intern ("environment");
+ staticpro (&Qenvironment);
Qface_set_after_frame_default = intern ("face-set-after-frame-default");
staticpro (&Qface_set_after_frame_default);
@@ -4161,6 +4477,11 @@ syms_of_frame ()
Qx_frame_parameter = intern ("x-frame-parameter");
staticpro (&Qx_frame_parameter);
+ Qterminal = intern ("terminal");
+ staticpro (&Qterminal);
+ Qterminal_live_p = intern ("terminal-live-p");
+ staticpro (&Qterminal_live_p);
+
{
int i;
@@ -4209,6 +4530,7 @@ These may be set in your init file, like this:
These override values given in window system configuration data,
including X Windows' defaults database.
For values specific to the first Emacs frame, see `initial-frame-alist'.
+For window-system specific values, see `window-system-default-frame-alist'.
For values specific to the separate minibuffer frame, see
`minibuffer-frame-alist'.
The `menu-bar-lines' element of the list controls whether new frames
@@ -4230,7 +4552,7 @@ Setting this variable does not affect existing frames, only new ones. */);
#endif
DEFVAR_LISP ("terminal-frame", &Vterminal_frame,
- doc: /* The initial frame-object, which represents Emacs's stdout. */);
+ doc: /* The initial frame-object, which represents Emacs's stdout. */);
DEFVAR_LISP ("emacs-iconified", &Vemacs_iconified,
doc: /* Non-nil if all of Emacs is iconified and frame updates are not needed. */);
@@ -4255,7 +4577,14 @@ when the mouse is over clickable text. */);
DEFVAR_LISP ("delete-frame-functions", &Vdelete_frame_functions,
doc: /* Functions to be run before deleting a frame.
The functions are run with one arg, the frame to be deleted.
-See `delete-frame'. */);
+See `delete-frame'.
+
+Note that functions in this list may be called twice on the same
+frame. In the second invocation, the frame is already deleted, and
+the function should do nothing. (You can use `frame-live-p' to check
+for this.) This wrinkle happens when an earlier function in
+`delete-frame-functions' (indirectly) calls delete-frame
+recursively. */);
Vdelete_frame_functions = Qnil;
DEFVAR_KBOARD ("default-minibuffer-frame", Vdefault_minibuffer_frame,
@@ -4273,11 +4602,27 @@ displayed.
This variable is local to the current terminal and cannot be buffer-local. */);
+ DEFVAR_BOOL ("focus-follows-mouse", &focus_follows_mouse,
+ doc: /* Non-nil if window system changes focus when you move the mouse.
+You should set this variable to tell Emacs how your window manager
+handles focus, since there is no way in general for Emacs to find out
+automatically. */);
+#ifdef HAVE_WINDOW_SYSTEM
+#if defined(HAVE_NTGUI) || defined(MAC_OS)
+ focus_follows_mouse = 0;
+#else
+ focus_follows_mouse = 1;
+#endif
+#else
+ focus_follows_mouse = 0;
+#endif
+
staticpro (&Vframe_list);
defsubr (&Sactive_minibuffer_window);
defsubr (&Sframep);
defsubr (&Sframe_live_p);
+ defsubr (&Swindow_system);
defsubr (&Smake_terminal_frame);
defsubr (&Shandle_switch_frame);
defsubr (&Sselect_frame);
@@ -4311,6 +4656,7 @@ This variable is local to the current terminal and cannot be buffer-local. */);
defsubr (&Sframe_parameters);
defsubr (&Sframe_parameter);
defsubr (&Smodify_frame_parameters);
+ defsubr (&Sframe_with_environment);
defsubr (&Sframe_char_height);
defsubr (&Sframe_char_width);
defsubr (&Sframe_pixel_height);
diff --git a/src/frame.h b/src/frame.h
index 245b4aa3eb..e48dd646da 100644
--- a/src/frame.h
+++ b/src/frame.h
@@ -29,9 +29,7 @@ Boston, MA 02110-1301, USA. */
/* Miscellanea. */
-/* Nonzero means don't assume anything about current contents of
- actual terminal frame */
-
+/* Nonzero means there is at least one garbaged frame. */
extern int frame_garbaged;
/* Nonzero means FRAME_MESSAGE_BUF (selected_frame) is being used by
@@ -39,11 +37,17 @@ extern int frame_garbaged;
extern int message_buf_print;
+/* Nonzero means window system changes focus when moving the
+ mouse. */
+
+extern int focus_follows_mouse;
+
/* The structure representing a frame. */
enum output_method
{
+ output_initial,
output_termcap,
output_x_window,
output_msdos_raw,
@@ -68,30 +72,10 @@ enum text_cursor_kinds
HBAR_CURSOR
};
-#if !defined(MSDOS) && !defined(WINDOWSNT) && !defined(MAC_OS)
-
-#if !defined(HAVE_X_WINDOWS)
-
-#define PIX_TYPE unsigned long
-
-/* A (mostly empty) x_output structure definition for building Emacs
- on Unix and GNU/Linux without X support. */
-struct x_output
-{
- PIX_TYPE background_pixel;
- PIX_TYPE foreground_pixel;
-};
-
-#endif /* ! HAVE_X_WINDOWS */
-
-
-#define FRAME_FOREGROUND_PIXEL(f) ((f)->output_data.x->foreground_pixel)
-#define FRAME_BACKGROUND_PIXEL(f) ((f)->output_data.x->background_pixel)
-
-/* A structure describing a termcap frame display. */
-extern struct x_output tty_display;
+#define FRAME_FOREGROUND_PIXEL(f) ((f)->foreground_pixel)
+#define FRAME_BACKGROUND_PIXEL(f) ((f)->background_pixel)
-#endif /* ! MSDOS && ! WINDOWSNT && ! MAC_OS */
+struct terminal;
#ifdef USE_FONT_BACKEND
struct font_driver_list;
@@ -99,11 +83,10 @@ struct font_driver_list;
struct frame
{
- EMACS_INT size;
+ EMACS_UINT size;
struct Lisp_Vector *next;
/* All Lisp_Object components must come first.
- Only EMACS_INT values can be intermixed with them.
That ensures they are all aligned normally. */
/* Name of this frame: a Lisp string. It is used for looking up resources,
@@ -157,7 +140,7 @@ struct frame
Actually, we don't specify exactly what is stored here at all; the
scroll bar implementation code can use it to store anything it likes.
This field is marked by the garbage collector. It is here
- instead of in the `display' structure so that the garbage
+ instead of in the `device' structure so that the garbage
collector doesn't need to look inside the window-system-dependent
structure. */
Lisp_Object scroll_bars;
@@ -177,8 +160,6 @@ struct frame
For the format of the data, see extensive comments in xmenu.c.
Only the X toolkit version uses this. */
Lisp_Object menu_bar_vector;
- /* Number of elements in the vector that have meaningful data. */
- EMACS_INT menu_bar_items_used;
/* Predicate for selecting buffers for other-buffer. */
Lisp_Object buffer_predicate;
@@ -186,6 +167,10 @@ struct frame
/* List of buffers viewed in this frame, for other-buffer. */
Lisp_Object buffer_list;
+ /* List of buffers that were viewed, then buried in this frame. The
+ most recently buried buffer is first. For last-buffer. */
+ Lisp_Object buried_buffer_list;
+
/* A dummy window used to display menu bars under X when no X
toolkit support is available. */
Lisp_Object menu_bar_window;
@@ -199,11 +184,14 @@ struct frame
/* Desired and current contents displayed in tool_bar_window. */
Lisp_Object desired_tool_bar_string, current_tool_bar_string;
- /* beyond here, there should be no more Lisp_Object components. */
+ /* Beyond here, there should be no more Lisp_Object components. */
/* Cache of realized faces. */
struct face_cache *face_cache;
+ /* Number of elements in `menu_bar_vector' that have meaningful data. */
+ EMACS_INT menu_bar_items_used;
+
/* A buffer to hold the frame's name. We can't use the Lisp
string's pointer (`name', above) because it might get relocated. */
char *namebuf;
@@ -290,20 +278,24 @@ struct frame
/* Canonical Y unit. Height of a line, in pixels. */
int line_height;
- /* The output method says how the contents of this frame
- are displayed. It could be using termcap, or using an X window. */
+ /* The output method says how the contents of this frame are
+ displayed. It could be using termcap, or using an X window.
+ This must be the same as the terminal->type. */
enum output_method output_method;
- /* A structure of auxiliary data used for displaying the contents.
- struct x_output is used for X window frames;
- it is defined in xterm.h.
- struct w32_output is used for W32 window frames;
- it is defined in w32term.h. */
+ /* The terminal device that this frame uses. If this is NULL, then
+ the frame has been deleted. */
+ struct terminal *terminal;
+
+ /* Device-dependent, frame-local auxiliary data used for displaying
+ the contents. When the frame is deleted, this data is deleted as
+ well. */
union output_data
{
- struct x_output *x;
- struct w32_output *w32;
- struct mac_output *mac;
+ struct tty_output *tty; /* termchar.h */
+ struct x_output *x; /* xterm.h */
+ struct w32_output *w32; /* w32term.h */
+ struct mac_output *mac; /* macterm.h */
EMACS_INT nothing;
}
output_data;
@@ -323,13 +315,6 @@ struct frame
/* The extra width (in pixels) currently allotted for fringes. */
int left_fringe_width, right_fringe_width;
-#ifdef MULTI_KBOARD
- /* A pointer to the kboard structure associated with this frame.
- For termcap frames, this points to initial_kboard. For X frames,
- it will be the same as display.x->display_info->kboard. */
- struct kboard *kboard;
-#endif
-
/* See FULLSCREEN_ enum below */
int want_fullscreen;
@@ -353,13 +338,13 @@ struct frame
frame becomes visible again, it must be marked as garbaged. The
FRAME_SAMPLE_VISIBILITY macro takes care of this.
- On Windows NT/9X, to avoid wasting effort updating visible frames
- that are actually completely obscured by other windows on the
- display, we bend the meaning of visible slightly: if greater than
- 1, then the frame is obscured - we still consider it to be
- "visible" as seen from lisp, but we don't bother updating it. We
- must take care to garbage the frame when it ceaces to be obscured
- though. Note that these semantics are only used on NT/9X.
+ On ttys and on Windows NT/9X, to avoid wasting effort updating
+ visible frames that are actually completely obscured by other
+ windows on the display, we bend the meaning of visible slightly:
+ if greater than 1, then the frame is obscured - we still consider
+ it to be "visible" as seen from lisp, but we don't bother
+ updating it. We must take care to garbage the frame when it
+ ceaces to be obscured though.
iconified is nonzero if the frame is currently iconified.
@@ -453,7 +438,7 @@ struct frame
/* The baud rate that was used to calculate costs for this frame. */
int cost_calculation_baud_rate;
- /* Nonzero if the mouse has moved on this display
+ /* Nonzero if the mouse has moved on this display device
since the last time we checked. */
char mouse_moved;
@@ -473,6 +458,10 @@ struct frame
update_frame, usually after resizing the frame. */
unsigned force_flush_display_p : 1;
+ /* All display backends seem to need these two pixel values. */
+ unsigned long background_pixel;
+ unsigned long foreground_pixel;
+
/* Set to non-zero if the default face for the frame has been
realized. Reset to zero whenever the default face changes.
Used to see the difference between a font change and face change. */
@@ -491,7 +480,7 @@ struct frame
};
#ifdef MULTI_KBOARD
-#define FRAME_KBOARD(f) ((f)->kboard)
+#define FRAME_KBOARD(f) ((f)->terminal->kboard)
#else
#define FRAME_KBOARD(f) (&the_only_kboard)
#endif
@@ -505,6 +494,7 @@ typedef struct frame *FRAME_PTR;
#define WINDOW_FRAME(w) (w)->frame
/* Test a frame for particular kinds of display methods. */
+#define FRAME_INITIAL_P(f) ((f)->output_method == output_initial)
#define FRAME_TERMCAP_P(f) ((f)->output_method == output_termcap)
#define FRAME_X_P(f) ((f)->output_method == output_x_window)
#define FRAME_W32_P(f) ((f)->output_method == output_w32)
@@ -528,7 +518,7 @@ typedef struct frame *FRAME_PTR;
#endif
/* Nonzero if frame F is still alive (not deleted). */
-#define FRAME_LIVE_P(f) ((f)->output_data.nothing != 0)
+#define FRAME_LIVE_P(f) ((f)->terminal != 0)
/* Nonzero if frame F is a minibuffer-only frame. */
#define FRAME_MINIBUF_ONLY_P(f) \
@@ -768,7 +758,10 @@ typedef struct frame *FRAME_PTR;
Also, if a frame used to be invisible, but has just become visible,
it must be marked as garbaged, since redisplay hasn't been keeping
- up its contents. */
+ up its contents.
+
+ Note that a tty frame is visible if and only if it is the topmost
+ frame. */
#define FRAME_SAMPLE_VISIBILITY(f) \
(((f)->async_visible && (f)->visible != (f)->async_visible) ? \
@@ -801,10 +794,14 @@ typedef struct frame *FRAME_PTR;
extern Lisp_Object Qframep, Qframe_live_p;
+extern Lisp_Object Qtty, Qtty_type;
+extern Lisp_Object Qterminal, Qterminal_live_p;
+extern Lisp_Object Qenvironment;
extern struct frame *last_nonminibuf_frame;
-extern struct frame *make_terminal_frame P_ ((void));
+extern struct frame *make_initial_frame P_ ((void));
+extern struct frame *make_terminal_frame P_ ((struct terminal *));
extern struct frame *make_frame P_ ((int));
#ifdef HAVE_WINDOW_SYSTEM
extern struct frame *make_minibuffer_frame P_ ((void));
@@ -1004,7 +1001,7 @@ extern Lisp_Object selected_frame;
extern Lisp_Object Qauto_raise, Qauto_lower;
extern Lisp_Object Qborder_color, Qborder_width;
-extern Lisp_Object Qbuffer_predicate, Qbuffer_list;
+extern Lisp_Object Qbuffer_predicate, Qbuffer_list, Qburied_buffer_list;
extern Lisp_Object Qcursor_color, Qcursor_type;
extern Lisp_Object Qfont;
extern Lisp_Object Qbackground_color, Qforeground_color;
@@ -1037,6 +1034,8 @@ extern Lisp_Object Qx_resource_name;
extern Lisp_Object Qleft, Qright, Qtop, Qbox;
extern Lisp_Object Qdisplay;
+extern Lisp_Object Qwindow_system;
+
#ifdef HAVE_WINDOW_SYSTEM
/* The class of this X application. */
@@ -1049,7 +1048,7 @@ enum
FULLSCREEN_WIDTH = 1,
FULLSCREEN_HEIGHT = 2,
FULLSCREEN_BOTH = 3,
- FULLSCREEN_WAIT = 4,
+ FULLSCREEN_WAIT = 4
};
diff --git a/src/fringe.c b/src/fringe.c
index 9f1089f71c..f24ab34f42 100644
--- a/src/fringe.c
+++ b/src/fringe.c
@@ -29,6 +29,7 @@ Boston, MA 02110-1301, USA. */
#include "dispextern.h"
#include "buffer.h"
#include "blockinput.h"
+#include "termhooks.h"
#ifdef HAVE_WINDOW_SYSTEM
@@ -686,7 +687,7 @@ draw_fringe_bitmap_1 (w, row, left_p, overlay, which)
break;
}
- rif->draw_fringe_bitmap (w, row, &p);
+ FRAME_RIF (f)->draw_fringe_bitmap (w, row, &p);
}
static int
@@ -1278,6 +1279,8 @@ destroy_fringe_bitmap (n)
fbp = &fringe_bitmaps[n];
if (*fbp && (*fbp)->dynamic)
{
+ /* XXX Is SELECTED_FRAME OK here? */
+ struct redisplay_interface *rif = FRAME_RIF (SELECTED_FRAME ());
if (rif && rif->destroy_fringe_bitmap)
rif->destroy_fringe_bitmap (n);
xfree (*fbp);
@@ -1327,6 +1330,14 @@ If BITMAP overrides a standard fringe bitmap, the original bitmap is restored.
On W32 and MAC (little endian), there's no need to do this.
*/
+#if defined (HAVE_X_WINDOWS)
+static unsigned char swap_nibble[16] = {
+ 0x0, 0x8, 0x4, 0xc, /* 0000 1000 0100 1100 */
+ 0x2, 0xa, 0x6, 0xe, /* 0010 1010 0110 1110 */
+ 0x1, 0x9, 0x5, 0xd, /* 0001 1001 0101 1101 */
+ 0x3, 0xb, 0x7, 0xf}; /* 0011 1011 0111 1111 */
+#endif /* HAVE_X_WINDOWS */
+
void
init_fringe_bitmap (which, fb, once_p)
int which;
@@ -1336,11 +1347,6 @@ init_fringe_bitmap (which, fb, once_p)
if (once_p || fb->dynamic)
{
#if defined (HAVE_X_WINDOWS)
- static unsigned char swap_nibble[16]
- = { 0x0, 0x8, 0x4, 0xc, /* 0000 1000 0100 1100 */
- 0x2, 0xa, 0x6, 0xe, /* 0010 1010 0110 1110 */
- 0x1, 0x9, 0x5, 0xd, /* 0001 1001 0101 1101 */
- 0x3, 0xb, 0x7, 0xf }; /* 0011 1011 0111 1111 */
unsigned short *bits = fb->bits;
int j;
@@ -1383,6 +1389,9 @@ init_fringe_bitmap (which, fb, once_p)
if (!once_p)
{
+ /* XXX Is SELECTED_FRAME OK here? */
+ struct redisplay_interface *rif = FRAME_RIF (SELECTED_FRAME ());
+
destroy_fringe_bitmap (which);
if (rif && rif->define_fringe_bitmap)
@@ -1693,10 +1702,11 @@ init_fringe ()
void
#ifdef HAVE_NTGUI
-w32_init_fringe ()
+w32_init_fringe (rif)
#else /* MAC_OS */
-mac_init_fringe ()
+mac_init_fringe (rif)
#endif
+ struct redisplay_interface *rif;
{
int bt;
@@ -1717,6 +1727,7 @@ w32_reset_fringes ()
{
/* Destroy row bitmaps. */
int bt;
+ struct redisplay_interface *rif = FRAME_RIF (SELECTED_FRAME ());
if (!rif)
return;
diff --git a/src/gtkutil.c b/src/gtkutil.c
index 9fb011de91..81ef09b7ec 100644
--- a/src/gtkutil.c
+++ b/src/gtkutil.c
@@ -51,6 +51,13 @@ Boston, MA 02110-1301, USA. */
#ifdef HAVE_GTK_MULTIDISPLAY
+/* Gtk does not work well without any display open. Emacs may close
+ all its displays. In that case, keep a display around just for
+ the purpose of having one. */
+
+static GdkDisplay *gdpy_def;
+
+
/* Return the GdkDisplay that corresponds to the X display DPY. */
static GdkDisplay *
@@ -147,9 +154,15 @@ xg_display_close (Display *dpy)
break;
}
- if (! new_dpy) return; /* Emacs will exit anyway. */
+ if (new_dpy)
+ gdpy_new = gdk_x11_lookup_xdisplay (new_dpy);
+ else
+ {
+ if (!gdpy_def)
+ gdpy_def = gdk_display_open (gdk_display_get_name (gdpy));
+ gdpy_new = gdpy_def;
+ }
- gdpy_new = gdk_x11_lookup_xdisplay (new_dpy);
gdk_display_manager_set_default_display (gdk_display_manager_get (),
gdpy_new);
}
@@ -336,6 +349,8 @@ xg_get_image_for_pixmap (f, img, widget, old_widget)
GdkPixmap *gpix;
GdkPixmap *gmask;
GdkDisplay *gdpy;
+ GdkColormap *cmap;
+ GdkPixbuf *icon_buf;
/* If we have a file, let GTK do all the image handling.
This seems to be the only way to make insensitive and activated icons
@@ -366,32 +381,24 @@ xg_get_image_for_pixmap (f, img, widget, old_widget)
gpix = gdk_pixmap_foreign_new_for_display (gdpy, img->pixmap);
gmask = img->mask ? gdk_pixmap_foreign_new_for_display (gdpy, img->mask) : 0;
- if (x_screen_planes (f) > 8 || x_screen_planes (f) == 1)
- {
- if (! old_widget)
- old_widget = GTK_IMAGE (gtk_image_new_from_pixmap (gpix, gmask));
- else
- gtk_image_set_from_pixmap (old_widget, gpix, gmask);
- }
+ /* This is a workaround to make icons look good on pseudo color
+ displays. Apparently GTK expects the images to have an alpha
+ channel. If they don't, insensitive and activated icons will
+ look bad. This workaround does not work on monochrome displays,
+ and is strictly not needed on true color/static color displays (i.e.
+ 16 bits and higher). But we do it anyway so we get a pixbuf that is
+ not associated with the img->pixmap. The img->pixmap may be removed
+ by clearing the image cache and then the tool bar redraw fails, since
+ Gtk+ assumes the pixmap is always there. */
+ cmap = gtk_widget_get_colormap (widget);
+ icon_buf = xg_get_pixbuf_from_pix_and_mask (gpix, gmask, cmap);
+
+ if (! old_widget)
+ old_widget = GTK_IMAGE (gtk_image_new_from_pixbuf (icon_buf));
else
- {
-
- /* This is a workaround to make icons look good on pseudo color
- displays. Apparently GTK expects the images to have an alpha
- channel. If they don't, insensitive and activated icons will
- look bad. This workaround does not work on monochrome displays,
- and is not needed on true color/static color displays (i.e.
- 16 bits and higher). */
- GdkColormap *cmap = gtk_widget_get_colormap (widget);
- GdkPixbuf *icon_buf = xg_get_pixbuf_from_pix_and_mask (gpix, gmask, cmap);
-
- if (! old_widget)
- old_widget = GTK_IMAGE (gtk_image_new_from_pixbuf (icon_buf));
- else
- gtk_image_set_from_pixbuf (old_widget, icon_buf);
+ gtk_image_set_from_pixbuf (old_widget, icon_buf);
- g_object_unref (G_OBJECT (icon_buf));
- }
+ g_object_unref (G_OBJECT (icon_buf));
g_object_unref (G_OBJECT (gpix));
if (gmask) g_object_unref (G_OBJECT (gmask));
@@ -874,7 +881,7 @@ xg_create_frame_widgets (f)
/* Since GTK clears its window by filling with the background color,
we must keep X and GTK background in sync. */
- xg_pix_to_gcolor (wfixed, f->output_data.x->background_pixel, &bg);
+ xg_pix_to_gcolor (wfixed, FRAME_BACKGROUND_PIXEL (f), &bg);
gtk_widget_modify_bg (wfixed, GTK_STATE_NORMAL, &bg);
/* Also, do not let any background pixmap to be set, this looks very
@@ -1412,8 +1419,8 @@ xg_get_file_with_chooser (f, prompt, default_filename,
{
Lisp_Object file;
struct gcpro gcpro1;
- GCPRO1 (file);
char *utf8_filename;
+ GCPRO1 (file);
file = build_string (default_filename);
@@ -1780,19 +1787,19 @@ menu_destroy_callback (w, client_data)
UNGRAB_P is TRUE if this is an ungrab, FALSE if it is a grab.
CLIENT_DATA is NULL (not used). */
+/* Keep track of total number of grabs. */
+static int menu_grab_callback_cnt;
+
static void
menu_grab_callback (GtkWidget *widget,
gboolean ungrab_p,
gpointer client_data)
{
- /* Keep track of total number of grabs. */
- static int cnt;
-
- if (ungrab_p) cnt--;
- else cnt++;
+ if (ungrab_p) menu_grab_callback_cnt--;
+ else menu_grab_callback_cnt++;
- if (cnt > 0 && ! xg_timer) xg_start_timer ();
- else if (cnt == 0 && xg_timer) xg_stop_timer ();
+ if (menu_grab_callback_cnt > 0 && ! xg_timer) xg_start_timer ();
+ else if (menu_grab_callback_cnt == 0 && xg_timer) xg_stop_timer ();
}
/* Make a GTK widget that contains both UTF8_LABEL and UTF8_KEY (both
@@ -1890,6 +1897,24 @@ make_menu_item (utf8_label, utf8_key, item, group)
/* Return non-zero if LABEL specifies a separator (GTK only has one
separator type) */
+static char* separator_names[] = {
+ "space",
+ "no-line",
+ "single-line",
+ "double-line",
+ "single-dashed-line",
+ "double-dashed-line",
+ "shadow-etched-in",
+ "shadow-etched-out",
+ "shadow-etched-in-dash",
+ "shadow-etched-out-dash",
+ "shadow-double-etched-in",
+ "shadow-double-etched-out",
+ "shadow-double-etched-in-dash",
+ "shadow-double-etched-out-dash",
+ 0,
+};
+
static int
xg_separator_p (char *label)
{
@@ -1898,24 +1923,6 @@ xg_separator_p (char *label)
&& strncmp (label, "--", 2) == 0
&& label[2] != '-')
{
- static char* separator_names[] = {
- "space",
- "no-line",
- "single-line",
- "double-line",
- "single-dashed-line",
- "double-dashed-line",
- "shadow-etched-in",
- "shadow-etched-out",
- "shadow-etched-in-dash",
- "shadow-etched-out-dash",
- "shadow-double-etched-in",
- "shadow-double-etched-out",
- "shadow-double-etched-in-dash",
- "shadow-double-etched-out-dash",
- 0,
- };
-
int i;
label += 2;
@@ -2043,7 +2050,7 @@ xg_create_one_menuitem (item, f, select_cb, highlight_cb, cl_data, group)
return w;
}
-/* Callback called when keyboard traversal (started by menu-bar-open) ends.
+/* Callback called when keyboard traversal (started by x-menu-bar-open) ends.
WMENU is the menu for which traversal has been done. DATA points to the
frame for WMENU. We must release grabs, some bad interaction between GTK
and Emacs makes the menus keep the grabs. */
@@ -3346,6 +3353,10 @@ xg_set_toolkit_scroll_bar_thumb (bar, portion, position, whole)
the GtkImage with a new image. */
#define XG_TOOL_BAR_STOCK_NAME "emacs-tool-bar-stock-name"
+/* As above, but this is used for named theme widgets, as opposed to
+ stock items. */
+#define XG_TOOL_BAR_ICON_NAME "emacs-tool-bar-icon-name"
+
/* Callback function invoked when a tool bar item is pressed.
W is the button widget in the tool bar that got pressed,
CLIENT_DATA is an integer that is the index of the button in the
@@ -3635,25 +3646,6 @@ xg_tool_bar_item_expose_callback (w, event, client_data)
#define PROP(IDX) AREF (f->tool_bar_items, i * TOOL_BAR_ITEM_NSLOTS + (IDX))
-/* This callback is called when a tool bar shall be redrawn.
- We need to update the images in case the image cache
- has deleted the pixmaps used in the tool bar.
- W is the GtkToolbar to be redrawn.
- EVENT is the expose event for W.
- CLIENT_DATA is pointing to the frame for this tool bar.
-
- Returns FALSE to tell GTK to keep processing this event. */
-
-static gboolean
-xg_tool_bar_expose_callback (w, event, client_data)
- GtkWidget *w;
- GdkEventExpose *event;
- gpointer client_data;
-{
- FRAME_PTR f = (FRAME_PTR) client_data;
- SET_FRAME_GARBAGED (f);
- return FALSE;
-}
/* Create a tool bar for frame F. */
@@ -3695,10 +3687,6 @@ xg_create_tool_bar (f)
G_CALLBACK (xg_tool_bar_detach_callback), f);
g_signal_connect (G_OBJECT (x->handlebox_widget), "child-attached",
G_CALLBACK (xg_tool_bar_attach_callback), f);
- g_signal_connect (G_OBJECT (x->toolbar_widget),
- "expose-event",
- G_CALLBACK (xg_tool_bar_expose_callback),
- f);
gtk_widget_show_all (x->handlebox_widget);
@@ -3809,8 +3797,9 @@ update_frame_tool_bar (f)
Lisp_Object stock;
GtkStockItem stock_item;
char *stock_name = NULL;
+ char *icon_name = NULL;
Lisp_Object rtl;
- GtkWidget *wbutton;
+ GtkWidget *wbutton = NULL;
GtkWidget *weventbox;
Lisp_Object func = intern ("x-gtk-map-stock");
@@ -3834,13 +3823,33 @@ update_frame_tool_bar (f)
if (EQ (Qt, Ffboundp (func)))
stock = call1 (func, file_for_image (image));
- if (! NILP (stock) && STRINGP (stock)
- && gtk_stock_lookup (SSDATA (stock), &stock_item))
+ if (! NILP (stock) && STRINGP (stock))
{
stock_name = SSDATA (stock);
- icon_size = gtk_toolbar_get_icon_size (wtoolbar);
+ if (stock_name[0] == 'n' && stock_name[1] == ':')
+ {
+ GdkScreen *screen = gtk_widget_get_screen (GTK_WIDGET (wtoolbar));
+ GtkIconTheme *icon_theme = gtk_icon_theme_get_for_screen (screen);
+
+ icon_name = stock_name + 2;
+ stock_name = NULL;
+ stock = Qnil;
+
+ if (! gtk_icon_theme_has_icon (icon_theme, icon_name))
+ icon_name = NULL;
+ else
+ icon_size = gtk_toolbar_get_icon_size (wtoolbar);
+ }
+ else if (gtk_stock_lookup (SSDATA (stock), &stock_item))
+ icon_size = gtk_toolbar_get_icon_size (wtoolbar);
+ else
+ {
+ stock = Qnil;
+ stock_name = NULL;
+ }
}
- else
+
+ if (stock_name == NULL && icon_name == NULL)
{
/* No stock image, or stock item not known. Try regular image. */
@@ -3905,6 +3914,13 @@ update_frame_tool_bar (f)
(gpointer) xstrdup (stock_name),
(GDestroyNotify) xfree);
}
+ else if (icon_name)
+ {
+ w = gtk_image_new_from_icon_name (icon_name, icon_size);
+ g_object_set_data_full (G_OBJECT (w), XG_TOOL_BAR_ICON_NAME,
+ (gpointer) xstrdup (icon_name),
+ (GDestroyNotify) xfree);
+ }
else
{
w = xg_get_image_for_pixmap (f, img, x->widget, NULL);
@@ -3980,6 +3996,8 @@ update_frame_tool_bar (f)
XG_TOOL_BAR_IMAGE_DATA);
gpointer old_stock_name = g_object_get_data (G_OBJECT (wimage),
XG_TOOL_BAR_STOCK_NAME);
+ gpointer old_icon_name = g_object_get_data (G_OBJECT (wimage),
+ XG_TOOL_BAR_ICON_NAME);
if (stock_name &&
(! old_stock_name || strcmp (old_stock_name, stock_name) != 0))
{
@@ -3990,6 +4008,20 @@ update_frame_tool_bar (f)
(GDestroyNotify) xfree);
g_object_set_data (G_OBJECT (wimage), XG_TOOL_BAR_IMAGE_DATA,
NULL);
+ g_object_set_data (G_OBJECT (wimage), XG_TOOL_BAR_ICON_NAME, NULL);
+ }
+ else if (icon_name &&
+ (! old_icon_name || strcmp (old_icon_name, icon_name) != 0))
+ {
+ gtk_image_set_from_icon_name (GTK_IMAGE (wimage),
+ icon_name, icon_size);
+ g_object_set_data_full (G_OBJECT (wimage), XG_TOOL_BAR_ICON_NAME,
+ (gpointer) xstrdup (icon_name),
+ (GDestroyNotify) xfree);
+ g_object_set_data (G_OBJECT (wimage), XG_TOOL_BAR_IMAGE_DATA,
+ NULL);
+ g_object_set_data (G_OBJECT (wimage), XG_TOOL_BAR_STOCK_NAME,
+ NULL);
}
else if (img && old_img != img->pixmap)
{
@@ -3999,6 +4031,7 @@ update_frame_tool_bar (f)
g_object_set_data (G_OBJECT (wimage), XG_TOOL_BAR_STOCK_NAME,
NULL);
+ g_object_set_data (G_OBJECT (wimage), XG_TOOL_BAR_ICON_NAME, NULL);
}
gtk_misc_set_padding (GTK_MISC (wimage), hmargin, vmargin);
@@ -4071,6 +4104,8 @@ xg_initialize ()
we keep it permanently linked in. */
XftInit (0);
#endif
+
+ gdpy_def = NULL;
xg_ignore_gtk_scrollbar = 0;
xg_detached_menus = 0;
xg_menu_cb_list.prev = xg_menu_cb_list.next =
diff --git a/src/image.c b/src/image.c
index 54c01cf36b..16826c425f 100644
--- a/src/image.c
+++ b/src/image.c
@@ -532,7 +532,7 @@ x_create_bitmap_from_file (f, file)
/* Free bitmap B. */
static void
-Free_Bitmap_Record (dpyinfo, bm)
+free_bitmap_record (dpyinfo, bm)
Display_Info *dpyinfo;
Bitmap_Record *bm;
{
@@ -574,7 +574,7 @@ x_destroy_bitmap (f, id)
if (--bm->refcount == 0)
{
BLOCK_INPUT;
- Free_Bitmap_Record (dpyinfo, bm);
+ free_bitmap_record (dpyinfo, bm);
UNBLOCK_INPUT;
}
}
@@ -591,7 +591,7 @@ x_destroy_all_bitmaps (dpyinfo)
for (i = 0; i < dpyinfo->bitmaps_last; i++, bm++)
if (bm->refcount > 0)
- Free_Bitmap_Record (dpyinfo, bm);
+ free_bitmap_record (dpyinfo, bm);
dpyinfo->bitmaps_last = 0;
}
@@ -1710,9 +1710,9 @@ free_image_cache (f)
/* Clear image cache of frame F. FORCE_P non-zero means free all
images. FORCE_P zero means clear only images that haven't been
displayed for some time. Should be called from time to time to
- reduce the number of loaded images. If image-eviction-seconds is
- non-nil, this frees images in the cache which weren't displayed for
- at least that many seconds. */
+ reduce the number of loaded images. If image-cache-eviction-delay
+ is non-nil, this frees images in the cache which weren't displayed
+ for at least that many seconds. */
void
clear_image_cache (f, force_p)
@@ -1905,6 +1905,7 @@ lookup_image (f, spec)
struct frame *f;
Lisp_Object spec;
{
+ struct image_cache *c;
struct image *img;
unsigned hash;
struct gcpro gcpro1;
@@ -1915,6 +1916,8 @@ lookup_image (f, spec)
xassert (FRAME_WINDOW_P (f));
xassert (valid_image_p (spec));
+ c = FRAME_X_IMAGE_CACHE (f);
+
GCPRO1 (spec);
/* Look up SPEC in the hash table of the image cache. */
@@ -2374,7 +2377,7 @@ x_find_image_file (file)
Vx_bitmap_file_path);
GCPRO2 (file_found, search_path);
- /* Try to find FILE in data-directory, then x-bitmap-file-path. */
+ /* Try to find FILE in data-directory/images, then x-bitmap-file-path. */
fd = openp (search_path, file, Qnil, &file_found, Qnil);
if (fd == -1)
@@ -2883,7 +2886,7 @@ enum xbm_token
3. a vector of strings or bool-vectors, one for each line of the
bitmap.
- 4. A string containing an in-memory XBM file. WIDTH and HEIGHT
+ 4. a string containing an in-memory XBM file. WIDTH and HEIGHT
may not be specified in this case because they are defined in the
XBM file.
@@ -4280,7 +4283,7 @@ xpm_scan (s, end, beg, len)
return XPM_TK_EOF;
}
-/* Functions for color table lookup in XPM data. A Key is a string
+/* Functions for color table lookup in XPM data. A key is a string
specifying the color of each pixel in XPM data. A value is either
an integer that specifies a pixel color, Qt that specifies
transparency, or Qnil for the unspecified color. If the length of
@@ -6343,7 +6346,7 @@ png_load (f, img)
simple transparency, we prefer a clipping mask. */
if (!transparent_p)
{
- png_color_16 *image_bg;
+ /* png_color_16 *image_bg; */
Lisp_Object specified_bg
= image_spec_value (img->spec, QCbackground, NULL);
@@ -6774,18 +6777,19 @@ our_common_term_source (cinfo)
whenever more data is needed. We read the whole image in one step,
so this only adds a fake end of input marker at the end. */
+static JOCTET our_memory_buffer[2];
+
static boolean
our_memory_fill_input_buffer (cinfo)
j_decompress_ptr cinfo;
{
/* Insert a fake EOI marker. */
struct jpeg_source_mgr *src = cinfo->src;
- static JOCTET buffer[2];
- buffer[0] = (JOCTET) 0xFF;
- buffer[1] = (JOCTET) JPEG_EOI;
+ our_memory_buffer[0] = (JOCTET) 0xFF;
+ our_memory_buffer[1] = (JOCTET) JPEG_EOI;
- src->next_input_byte = buffer;
+ src->next_input_byte = our_memory_buffer;
src->bytes_in_buffer = 2;
return 1;
}
@@ -7755,6 +7759,9 @@ gif_read_from_memory (file, buf, len)
/* Load GIF image IMG for use on frame F. Value is non-zero if
successful. */
+static int interlace_start[] = {0, 4, 2, 1};
+static int interlace_increment[] = {8, 8, 4, 2};
+
static int
gif_load (f, img)
struct frame *f;
@@ -7883,13 +7890,14 @@ gif_load (f, img)
init_color_table ();
bzero (pixel_colors, sizeof pixel_colors);
- for (i = 0; i < gif_color_map->ColorCount; ++i)
- {
- int r = gif_color_map->Colors[i].Red << 8;
- int g = gif_color_map->Colors[i].Green << 8;
- int b = gif_color_map->Colors[i].Blue << 8;
- pixel_colors[i] = lookup_rgb_color (f, r, g, b);
- }
+ if (gif_color_map)
+ for (i = 0; i < gif_color_map->ColorCount; ++i)
+ {
+ int r = gif_color_map->Colors[i].Red << 8;
+ int g = gif_color_map->Colors[i].Green << 8;
+ int b = gif_color_map->Colors[i].Blue << 8;
+ pixel_colors[i] = lookup_rgb_color (f, r, g, b);
+ }
#ifdef COLOR_TABLE_SUPPORT
img->colors = colors_in_color_table (&img->ncolors);
@@ -7924,8 +7932,6 @@ gif_load (f, img)
if (gif->SavedImages[ino].ImageDesc.Interlace)
{
- static int interlace_start[] = {0, 4, 2, 1};
- static int interlace_increment[] = {8, 8, 4, 2};
int pass;
int row = interlace_start[0];
@@ -8436,16 +8442,16 @@ svg_load (f, img)
return success_p;
}
-/* svg_load_image is a helper function for svg_load, which does the actual
- loading given contents and size, apart from frame and image
- structures, passed from svg_load.
+/* svg_load_image is a helper function for svg_load, which does the
+ actual loading given contents and size, apart from frame and image
+ structures, passed from svg_load.
- Uses librsvg to do most of the image processing.
+ Uses librsvg to do most of the image processing.
- Returns non-zero when sucessful. */
+ Returns non-zero when successful. */
static int
svg_load_image (f, img, contents, size)
- /* Pointer to emacs frame sturcture. */
+ /* Pointer to emacs frame structure. */
struct frame *f;
/* Pointer to emacs image structure. */
struct image *img;
@@ -8555,8 +8561,8 @@ svg_load_image (f, img, contents, size)
/* This loop handles opacity values, since Emacs assumes
non-transparent images. Each pixel must be "flattened" by
- calculating he resulting color, given the transparency of the
- pixel, and the image background color. */
+ calculating the resulting color, given the transparency of the
+ pixel, and the image background color. */
for (y = 0; y < height; ++y)
{
for (x = 0; x < width; ++x)
@@ -9039,7 +9045,7 @@ syms_of_image ()
defining the supported image types. */
DEFVAR_LISP ("image-types", &Vimage_types,
doc: /* List of potentially supported image types.
-Each element of the list is a symbol for a image type, like 'jpeg or 'png.
+Each element of the list is a symbol for an image type, like 'jpeg or 'png.
To check whether it is really supported, use `image-type-available-p'. */);
Vimage_types = Qnil;
diff --git a/src/indent.c b/src/indent.c
index 95afa03148..2a4fe1e5e7 100644
--- a/src/indent.c
+++ b/src/indent.c
@@ -20,6 +20,8 @@ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
#include <config.h>
+#include <stdio.h>
+
#include "lisp.h"
#include "buffer.h"
#include "character.h"
@@ -51,7 +53,7 @@ double last_known_column;
/* Value of point when current_column was called. */
-int last_known_column_point;
+EMACS_INT last_known_column_point;
/* Value of MODIFF when current_column was called. */
@@ -63,7 +65,7 @@ static double position_indentation P_ ((int));
/* Cache of beginning of line found by the last call of
current_column. */
-int current_column_bol_cache;
+static EMACS_INT current_column_bol_cache;
/* Get the display table to use for the current buffer. */
@@ -212,16 +214,17 @@ width_run_cache_on_off ()
characters immediately following, then *NEXT_BOUNDARY_P
will equal the return value. */
-int
+EMACS_INT
skip_invisible (pos, next_boundary_p, to, window)
- int pos;
- int *next_boundary_p;
- int to;
+ EMACS_INT pos;
+ EMACS_INT *next_boundary_p;
+ EMACS_INT to;
Lisp_Object window;
{
Lisp_Object prop, position, overlay_limit, proplimit;
Lisp_Object buffer, tmp;
- int end, inv_p;
+ EMACS_INT end;
+ int inv_p;
XSETFASTINT (position, pos);
XSETBUFFER (buffer, current_buffer);
@@ -508,16 +511,16 @@ current_column ()
static double
current_column_1 ()
{
- register int tab_width = XINT (current_buffer->tab_width);
+ register EMACS_INT tab_width = XINT (current_buffer->tab_width);
register int ctl_arrow = !NILP (current_buffer->ctl_arrow);
register struct Lisp_Char_Table *dp = buffer_display_table ();
int multibyte = !NILP (current_buffer->enable_multibyte_characters);
/* Start the scan at the beginning of this line with column number 0. */
- register int col = 0;
- int scan, scan_byte;
- int next_boundary;
- int opoint = PT, opoint_byte = PT_BYTE;
+ register EMACS_INT col = 0;
+ EMACS_INT scan, scan_byte;
+ EMACS_INT next_boundary;
+ EMACS_INT opoint = PT, opoint_byte = PT_BYTE;
scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, -1, 1);
current_column_bol_cache = PT;
@@ -806,13 +809,13 @@ static double
position_indentation (pos_byte)
register int pos_byte;
{
- register int column = 0;
- register int tab_width = XINT (current_buffer->tab_width);
+ register EMACS_INT column = 0;
+ register EMACS_INT tab_width = XINT (current_buffer->tab_width);
register unsigned char *p;
register unsigned char *stop;
unsigned char *start;
- int next_boundary_byte = pos_byte;
- int ceiling = next_boundary_byte;
+ EMACS_INT next_boundary_byte = pos_byte;
+ EMACS_INT ceiling = next_boundary_byte;
if (tab_width <= 0 || tab_width > 1000) tab_width = 8;
@@ -827,7 +830,7 @@ position_indentation (pos_byte)
{
while (p == stop)
{
- int stop_pos_byte;
+ EMACS_INT stop_pos_byte;
/* If we have updated P, set POS_BYTE to match.
The first time we enter the loop, POS_BYTE is already right. */
@@ -838,8 +841,8 @@ position_indentation (pos_byte)
return column;
if (pos_byte == next_boundary_byte)
{
- int next_boundary;
- int pos = BYTE_TO_CHAR (pos_byte);
+ EMACS_INT next_boundary;
+ EMACS_INT pos = BYTE_TO_CHAR (pos_byte);
pos = skip_invisible (pos, &next_boundary, ZV, Qnil);
pos_byte = CHAR_TO_BYTE (pos);
next_boundary_byte = CHAR_TO_BYTE (next_boundary);
@@ -930,19 +933,19 @@ The return value is the current column. */)
(column, force)
Lisp_Object column, force;
{
- register int pos;
- register int col = current_column ();
- register int goal;
- register int end;
+ register EMACS_INT pos;
+ register EMACS_INT col = current_column ();
+ register EMACS_INT goal;
+ register EMACS_INT end;
register int tab_width = XINT (current_buffer->tab_width);
register int ctl_arrow = !NILP (current_buffer->ctl_arrow);
register struct Lisp_Char_Table *dp = buffer_display_table ();
register int multibyte = !NILP (current_buffer->enable_multibyte_characters);
Lisp_Object val;
- int prev_col = 0;
+ EMACS_INT prev_col = 0;
int c = 0;
- int next_boundary, pos_byte;
+ EMACS_INT next_boundary, pos_byte;
if (tab_width <= 0 || tab_width > 1000) tab_width = 8;
CHECK_NATNUM (column);
@@ -968,7 +971,7 @@ The return value is the current column. */)
{
while (pos == next_boundary)
{
- int prev = pos;
+ EMACS_INT prev = pos;
pos = skip_invisible (pos, &next_boundary, end, Qnil);
if (pos != prev)
pos_byte = CHAR_TO_BYTE (pos);
@@ -1088,7 +1091,7 @@ The return value is the current column. */)
and scan through it again. */
if (!NILP (force) && col > goal && c == '\t' && prev_col < goal)
{
- int goal_pt, goal_pt_byte;
+ EMACS_INT goal_pt, goal_pt_byte;
/* Insert spaces in front of the tab to reach GOAL. Do this
first so that a marker at the end of the tab gets
@@ -1188,19 +1191,19 @@ struct position val_compute_motion;
struct position *
compute_motion (from, fromvpos, fromhpos, did_motion, to, tovpos, tohpos, width, hscroll, tab_offset, win)
- int from, fromvpos, fromhpos, to, tovpos, tohpos;
+ EMACS_INT from, fromvpos, fromhpos, to, tovpos, tohpos;
int did_motion;
- register int width;
- int hscroll, tab_offset;
+ EMACS_INT width;
+ EMACS_INT hscroll, tab_offset;
struct window *win;
{
- register int hpos = fromhpos;
- register int vpos = fromvpos;
+ register EMACS_INT hpos = fromhpos;
+ register EMACS_INT vpos = fromvpos;
- register int pos;
- int pos_byte;
+ register EMACS_INT pos;
+ EMACS_INT pos_byte;
register int c = 0;
- register int tab_width = XFASTINT (current_buffer->tab_width);
+ register EMACS_INT tab_width = XFASTINT (current_buffer->tab_width);
register int ctl_arrow = !NILP (current_buffer->ctl_arrow);
register struct Lisp_Char_Table *dp = window_display_table (win);
int selective
@@ -1212,33 +1215,33 @@ compute_motion (from, fromvpos, fromhpos, did_motion, to, tovpos, tohpos, width,
? XVECTOR (DISP_INVIS_VECTOR (dp))->size : 0);
/* The next location where the `invisible' property changes, or an
overlay starts or ends. */
- int next_boundary = from;
+ EMACS_INT next_boundary = from;
/* For computing runs of characters with similar widths.
Invariant: width_run_width is zero, or all the characters
from width_run_start to width_run_end have a fixed width of
width_run_width. */
- int width_run_start = from;
- int width_run_end = from;
- int width_run_width = 0;
+ EMACS_INT width_run_start = from;
+ EMACS_INT width_run_end = from;
+ EMACS_INT width_run_width = 0;
Lisp_Object *width_table;
Lisp_Object buffer;
/* The next buffer pos where we should consult the width run cache. */
- int next_width_run = from;
+ EMACS_INT next_width_run = from;
Lisp_Object window;
int multibyte = !NILP (current_buffer->enable_multibyte_characters);
/* If previous char scanned was a wide character,
this is the column where it ended. Otherwise, this is 0. */
- int wide_column_end_hpos = 0;
- int prev_pos; /* Previous buffer position. */
- int prev_pos_byte; /* Previous buffer position. */
- int prev_hpos = 0;
- int prev_vpos = 0;
- int contin_hpos; /* HPOS of last column of continued line. */
- int prev_tab_offset; /* Previous tab offset. */
- int continuation_glyph_width;
+ EMACS_INT wide_column_end_hpos = 0;
+ EMACS_INT prev_pos; /* Previous buffer position. */
+ EMACS_INT prev_pos_byte; /* Previous buffer position. */
+ EMACS_INT prev_hpos = 0;
+ EMACS_INT prev_vpos = 0;
+ EMACS_INT contin_hpos; /* HPOS of last column of continued line. */
+ EMACS_INT prev_tab_offset; /* Previous tab offset. */
+ EMACS_INT continuation_glyph_width;
XSETBUFFER (buffer, current_buffer);
XSETWINDOW (window, win);
@@ -1284,8 +1287,8 @@ compute_motion (from, fromvpos, fromhpos, did_motion, to, tovpos, tohpos, width,
{
while (pos == next_boundary)
{
- int pos_here = pos;
- int newpos;
+ EMACS_INT pos_here = pos;
+ EMACS_INT newpos;
/* Don't skip invisible if we are already at the margin. */
if (vpos > tovpos || (vpos == tovpos && hpos >= tohpos))
@@ -1883,23 +1886,23 @@ struct position val_vmotion;
struct position *
vmotion (from, vtarget, w)
- register int from, vtarget;
+ register EMACS_INT from, vtarget;
struct window *w;
{
- int hscroll = XINT (w->hscroll);
+ EMACS_INT hscroll = XINT (w->hscroll);
struct position pos;
/* vpos is cumulative vertical position, changed as from is changed */
register int vpos = 0;
- int prevline;
- register int first;
- int from_byte;
- int lmargin = hscroll > 0 ? 1 - hscroll : 0;
+ EMACS_INT prevline;
+ register EMACS_INT first;
+ EMACS_INT from_byte;
+ EMACS_INT lmargin = hscroll > 0 ? 1 - hscroll : 0;
int selective
= (INTEGERP (current_buffer->selective_display)
? XINT (current_buffer->selective_display)
: !NILP (current_buffer->selective_display) ? -1 : 0);
Lisp_Object window;
- int start_hpos = 0;
+ EMACS_INT start_hpos = 0;
int did_motion;
/* This is the object we use for fetching character properties. */
Lisp_Object text_prop_object;
diff --git a/src/indent.h b/src/indent.h
index 2e87376960..95cf23aaef 100644
--- a/src/indent.h
+++ b/src/indent.h
@@ -39,25 +39,31 @@ Boston, MA 02110-1301, USA. */
struct position
{
- int bufpos;
- int bytepos;
- int hpos;
- int vpos;
- int prevhpos;
- int contin;
+ EMACS_INT bufpos;
+ EMACS_INT bytepos;
+ EMACS_INT hpos;
+ EMACS_INT vpos;
+ EMACS_INT prevhpos;
+ EMACS_INT contin;
/* Number of characters we have already handled
from the before and after strings at this position. */
- int ovstring_chars_done;
- int tab_offset;
+ EMACS_INT ovstring_chars_done;
+ EMACS_INT tab_offset;
};
-struct position *compute_motion P_ ((int, int, int, int, int, int, int,
- int, int, int, struct window *));
-struct position *vmotion P_ ((int, int, struct window *));
-int skip_invisible P_ ((int, int *, int, Lisp_Object));
+struct position *compute_motion P_ ((EMACS_INT from, EMACS_INT fromvpos,
+ EMACS_INT fromhpos, int did_motion,
+ EMACS_INT to, EMACS_INT tovpos,
+ EMACS_INT tohpos,
+ EMACS_INT width, EMACS_INT hscroll,
+ EMACS_INT tab_offset, struct window *));
+struct position *vmotion P_ ((EMACS_INT from, EMACS_INT vtarget,
+ struct window *));
+EMACS_INT skip_invisible P_ ((EMACS_INT pos, EMACS_INT *next_boundary_p,
+ EMACS_INT to, Lisp_Object window));
/* Value of point when current_column was called */
-extern int last_known_column_point;
+extern EMACS_INT last_known_column_point;
/* Functions for dealing with the column cache. */
diff --git a/src/insdel.c b/src/insdel.c
index 059a3c47d1..0b10534db2 100644
--- a/src/insdel.c
+++ b/src/insdel.c
@@ -415,13 +415,8 @@ adjust_markers_for_insert (from, from_byte, to, to_byte, before_markers)
for (m = BUF_MARKERS (current_buffer); m; m = m->next)
{
- /* In a single-byte buffer, a marker's two positions must be
- equal. */
- if (Z == Z_BYTE)
- {
- if (m->charpos != m->bytepos)
- abort ();
- }
+ eassert (m->bytepos >= m->charpos
+ && m->bytepos - m->charpos <= Z_BYTE - Z);
if (m->bytepos == from_byte)
{
@@ -468,9 +463,7 @@ adjust_point (nchars, nbytes)
BUF_PT_BYTE (current_buffer) += nbytes;
/* In a single-byte buffer, the two positions must be equal. */
- if (ZV == ZV_BYTE
- && PT != PT_BYTE)
- abort ();
+ eassert (PT_BYTE >= PT && PT_BYTE - PT <= ZV_BYTE - ZV);
}
/* Adjust markers for a replacement of a text at FROM (FROM_BYTE) of
diff --git a/src/keyboard.c b/src/keyboard.c
index d202fc4fc9..d64091db50 100644
--- a/src/keyboard.c
+++ b/src/keyboard.c
@@ -23,13 +23,13 @@ Boston, MA 02110-1301, USA. */
#include <config.h>
#include <signal.h>
#include <stdio.h>
+#include "lisp.h"
#include "termchar.h"
#include "termopts.h"
-#include "lisp.h"
+#include "frame.h"
#include "termhooks.h"
#include "macros.h"
#include "keyboard.h"
-#include "frame.h"
#include "window.h"
#include "commands.h"
#include "buffer.h"
@@ -59,7 +59,6 @@ Boston, MA 02110-1301, USA. */
#endif /* not MSDOS */
#include "syssignal.h"
-#include "systty.h"
#include <sys/types.h>
#ifdef HAVE_UNISTD_H
@@ -97,9 +96,6 @@ volatile int interrupt_input_blocked;
int interrupt_input_pending;
-/* File descriptor to use for input. */
-extern int input_fd;
-
#ifdef HAVE_WINDOW_SYSTEM
/* Make all keyboard buffers much bigger when using X windows. */
#ifdef MAC_OS8
@@ -112,8 +108,6 @@ extern int input_fd;
#define KBD_BUFFER_SIZE 4096
#endif /* No X-windows */
-#define abs(x) ((x) >= 0 ? (x) : -(x))
-
/* Following definition copied from eval.c */
struct backtrace
@@ -425,16 +419,6 @@ Lisp_Object Vecho_keystrokes;
/* Form to evaluate (if non-nil) when Emacs is started. */
Lisp_Object Vtop_level;
-/* User-supplied table to translate input characters. */
-Lisp_Object Vkeyboard_translate_table;
-
-/* Keymap mapping ASCII function key sequences onto their preferred forms. */
-extern Lisp_Object Vfunction_key_map;
-
-/* Another keymap that maps key sequences into key sequences.
- This one takes precedence over ordinary definitions. */
-extern Lisp_Object Vkey_translation_map;
-
/* If non-nil, this implements the current input method. */
Lisp_Object Vinput_method_function;
Lisp_Object Qinput_method_function;
@@ -458,6 +442,12 @@ Lisp_Object Qpre_command_hook, Vpre_command_hook;
Lisp_Object Qpost_command_hook, Vpost_command_hook;
Lisp_Object Qcommand_hook_internal, Vcommand_hook_internal;
+/* Parent keymap of terminal-local function-key-map instances. */
+Lisp_Object Vfunction_key_map;
+
+/* Keymap of key translations that can override keymaps. */
+Lisp_Object Vkey_translation_map;
+
/* List of deferred actions to be performed at a later time.
The precise format isn't relevant here; we just check whether it is nil. */
Lisp_Object Vdeferred_action_list;
@@ -475,11 +465,6 @@ FILE *dribble;
/* Nonzero if input is available. */
int input_pending;
-/* 1 if should obey 0200 bit in input chars as "Meta", 2 if should
- keep 0200 bit in input chars. 0 to ignore the 0200 bit. */
-
-int meta_key;
-
extern char *pending_malloc_warning;
/* Circular buffer for pre-read keyboard input. */
@@ -609,9 +594,6 @@ int interrupt_input;
/* Nonzero while interrupts are temporarily deferred during redisplay. */
int interrupts_deferred;
-/* Nonzero means use ^S/^Q for flow control. */
-int flow_control;
-
/* Allow m- file to inhibit use of FIONREAD. */
#ifdef BROKEN_FIONREAD
#undef FIONREAD
@@ -694,8 +676,11 @@ static void save_getcjmp ();
static void restore_getcjmp P_ ((jmp_buf));
static Lisp_Object apply_modifiers P_ ((int, Lisp_Object));
static void clear_event P_ ((struct input_event *));
-static void any_kboard_state P_ ((void));
+#ifdef MULTI_KBOARD
+static Lisp_Object restore_kboard_configuration P_ ((Lisp_Object));
+#endif
static SIGTYPE interrupt_signal P_ ((int signalnum));
+static void handle_interrupt P_ ((void));
static void timer_start_idle P_ ((void));
static void timer_stop_idle P_ ((void));
static void timer_resume_idle P_ ((void));
@@ -1061,24 +1046,20 @@ This function is called by the editor initialization to begin editing. */)
like it is done in the splash screen display, we have to
make sure that we restore single_kboard as command_loop_1
would have done if it were left normally. */
- record_unwind_protect (recursive_edit_unwind,
- Fcons (buffer, single_kboard ? Qt : Qnil));
+ if (command_loop_level > 0)
+ temporarily_switch_to_single_kboard (SELECTED_FRAME ());
+ record_unwind_protect (recursive_edit_unwind, buffer);
recursive_edit_1 ();
return unbind_to (count, Qnil);
}
Lisp_Object
-recursive_edit_unwind (info)
- Lisp_Object info;
+recursive_edit_unwind (buffer)
+ Lisp_Object buffer;
{
- if (BUFFERP (XCAR (info)))
- Fset_buffer (XCAR (info));
-
- if (NILP (XCDR (info)))
- any_kboard_state ();
- else
- single_kboard_state ();
+ if (BUFFERP (buffer))
+ Fset_buffer (buffer);
command_loop_level--;
update_mode_lines = 1;
@@ -1086,6 +1067,8 @@ recursive_edit_unwind (info)
}
+#if 0 /* These two functions are now replaced with
+ temporarily_switch_to_single_kboard. */
static void
any_kboard_state ()
{
@@ -1116,6 +1099,7 @@ single_kboard_state ()
single_kboard = 1;
#endif
}
+#endif
/* If we're in single_kboard state for kboard KBOARD,
get out of it. */
@@ -1143,8 +1127,8 @@ struct kboard_stack
static struct kboard_stack *kboard_stack;
void
-push_frame_kboard (f)
- FRAME_PTR f;
+push_kboard (k)
+ struct kboard *k;
{
#ifdef MULTI_KBOARD
struct kboard_stack *p
@@ -1154,20 +1138,110 @@ push_frame_kboard (f)
p->kboard = current_kboard;
kboard_stack = p;
- current_kboard = FRAME_KBOARD (f);
+ current_kboard = k;
#endif
}
void
-pop_frame_kboard ()
+pop_kboard ()
{
#ifdef MULTI_KBOARD
+ struct terminal *t;
struct kboard_stack *p = kboard_stack;
- current_kboard = p->kboard;
+ int found = 0;
+ for (t = terminal_list; t; t = t->next_terminal)
+ {
+ if (t->kboard == p->kboard)
+ {
+ current_kboard = p->kboard;
+ found = 1;
+ break;
+ }
+ }
+ if (!found)
+ {
+ /* The terminal we remembered has been deleted. */
+ current_kboard = FRAME_KBOARD (SELECTED_FRAME ());
+ single_kboard = 0;
+ }
kboard_stack = p->next;
xfree (p);
#endif
}
+
+/* Switch to single_kboard mode, making current_kboard the only KBOARD
+ from which further input is accepted. If F is non-nil, set its
+ KBOARD as the current keyboard.
+
+ This function uses record_unwind_protect to return to the previous
+ state later.
+
+ If Emacs is already in single_kboard mode, and F's keyboard is
+ locked, then this function will throw an errow. */
+
+void
+temporarily_switch_to_single_kboard (f)
+ struct frame *f;
+{
+#ifdef MULTI_KBOARD
+ int was_locked = single_kboard;
+ if (was_locked)
+ {
+ if (f != NULL && FRAME_KBOARD (f) != current_kboard)
+ /* We can not switch keyboards while in single_kboard mode.
+ In rare cases, Lisp code may call `recursive-edit' (or
+ `read-minibuffer' or `y-or-n-p') after it switched to a
+ locked frame. For example, this is likely to happen
+ when server.el connects to a new terminal while Emacs is in
+ single_kboard mode. It is best to throw an error instead
+ of presenting the user with a frozen screen. */
+ error ("Terminal %d is locked, cannot read from it",
+ FRAME_TERMINAL (f)->id);
+ else
+ /* This call is unnecessary, but helps
+ `restore_kboard_configuration' discover if somebody changed
+ `current_kboard' behind our back. */
+ push_kboard (current_kboard);
+ }
+ else if (f != NULL)
+ current_kboard = FRAME_KBOARD (f);
+ single_kboard = 1;
+ record_unwind_protect (restore_kboard_configuration,
+ (was_locked ? Qt : Qnil));
+#endif
+}
+
+#if 0 /* This function is not needed anymore. */
+void
+record_single_kboard_state ()
+{
+ if (single_kboard)
+ push_kboard (current_kboard);
+ record_unwind_protect (restore_kboard_configuration,
+ (single_kboard ? Qt : Qnil));
+}
+#endif
+
+#ifdef MULTI_KBOARD
+static Lisp_Object
+restore_kboard_configuration (was_locked)
+ Lisp_Object was_locked;
+{
+ if (NILP (was_locked))
+ single_kboard = 0;
+ else
+ {
+ struct kboard *prev = current_kboard;
+ single_kboard = 1;
+ pop_kboard ();
+ /* The pop should not change the kboard. */
+ if (single_kboard && current_kboard != prev)
+ abort ();
+ }
+ return Qnil;
+}
+#endif
+
/* Handle errors that are not handled at inner levels
by printing an error message and returning to the editor command loop. */
@@ -1215,10 +1289,12 @@ cmd_error (data)
Vquit_flag = Qnil;
Vinhibit_quit = Qnil;
+#if 0 /* This shouldn't be necessary anymore. --lorentey */
#ifdef MULTI_KBOARD
if (command_loop_level == 0 && minibuf_level == 0)
any_kboard_state ();
#endif
+#endif
return make_number (0);
}
@@ -1254,11 +1330,7 @@ cmd_error_internal (data, context)
/* If the window system or terminal frame hasn't been initialized
yet, or we're not interactive, write the message to stderr and exit. */
else if (!sf->glyphs_initialized_p
- /* This is the case of the frame dumped with Emacs, when we're
- running under a window system. */
- || (!NILP (Vwindow_system)
- && !inhibit_window_system
- && FRAME_TERMCAP_P (sf))
+ || FRAME_INITIAL_P (sf)
|| noninteractive)
{
print_error_message (data, Qexternal_debugging_output,
@@ -1301,10 +1373,12 @@ command_loop ()
while (1)
{
internal_catch (Qtop_level, top_level_1, Qnil);
- /* Reset single_kboard in case top-level set it while
- evaluating an -f option, or we are stuck there for some
- other reason. */
- any_kboard_state ();
+#if 0 /* This shouldn't be necessary anymore. --lorentey */
+ /* Reset single_kboard in case top-level set it while
+ evaluating an -f option, or we are stuck there for some
+ other reason. */
+ any_kboard_state ();
+#endif
internal_catch (Qtop_level, command_loop_2, Qnil);
executing_kbd_macro = Qnil;
@@ -1499,10 +1573,12 @@ command_loop_1 ()
int no_direct;
int prev_modiff = 0;
struct buffer *prev_buffer = NULL;
+#if 0 /* This shouldn't be necessary anymore. --lorentey */
#ifdef MULTI_KBOARD
int was_locked = single_kboard;
#endif
- int already_adjusted;
+#endif
+ int already_adjusted = 0;
current_kboard->Vprefix_arg = Qnil;
current_kboard->Vlast_prefix_arg = Qnil;
@@ -1536,6 +1612,8 @@ command_loop_1 ()
/* Do this after running Vpost_command_hook, for consistency. */
current_kboard->Vlast_command = Vthis_command;
current_kboard->Vreal_last_command = real_this_command;
+ if (!CONSP (last_command_char))
+ current_kboard->Vlast_repeatable_command = real_this_command;
while (1)
{
@@ -1587,11 +1665,6 @@ command_loop_1 ()
}
}
-#ifdef C_ALLOCA
- alloca (0); /* Cause a garbage collection now */
- /* Since we can free the most stuff here. */
-#endif /* C_ALLOCA */
-
#if 0
/* Select the frame that the last event came from. Usually,
switch-frame events will take care of this, but if some lisp
@@ -1916,6 +1989,8 @@ command_loop_1 ()
{
current_kboard->Vlast_command = Vthis_command;
current_kboard->Vreal_last_command = real_this_command;
+ if (!CONSP (last_command_char))
+ current_kboard->Vlast_repeatable_command = real_this_command;
cancel_echoing ();
this_command_key_count = 0;
this_command_key_count_reset = 0;
@@ -1961,10 +2036,11 @@ command_loop_1 ()
if (!NILP (current_kboard->defining_kbd_macro)
&& NILP (current_kboard->Vprefix_arg))
finalize_kbd_macro_chars ();
-
+#if 0 /* This shouldn't be necessary anymore. --lorentey */
#ifdef MULTI_KBOARD
if (!was_locked)
- any_kboard_state ();
+ any_kboard_state ();
+#endif
#endif
}
}
@@ -2203,7 +2279,10 @@ void
start_polling ()
{
#ifdef POLL_FOR_INPUT
- if (read_socket_hook && !interrupt_input)
+ /* XXX This condition was (read_socket_hook && !interrupt_input),
+ but read_socket_hook is not global anymore. Let's pretend that
+ it's always set. */
+ if (!interrupt_input)
{
/* Turn alarm handling on unconditionally. It might have
been turned off in process.c. */
@@ -2237,7 +2316,10 @@ int
input_polling_used ()
{
#ifdef POLL_FOR_INPUT
- return read_socket_hook && !interrupt_input;
+ /* XXX This condition was (read_socket_hook && !interrupt_input),
+ but read_socket_hook is not global anymore. Let's pretend that
+ it's always set. */
+ return !interrupt_input;
#else
return 0;
#endif
@@ -2249,7 +2331,10 @@ void
stop_polling ()
{
#ifdef POLL_FOR_INPUT
- if (read_socket_hook && !interrupt_input)
+ /* XXX This condition was (read_socket_hook && !interrupt_input),
+ but read_socket_hook is not global anymore. Let's pretend that
+ it's always set. */
+ if (!interrupt_input)
++poll_suppress_count;
#endif
}
@@ -2461,10 +2546,6 @@ read_char_help_form_unwind (arg)
return Qnil;
}
-#ifdef MULTI_KBOARD
-static jmp_buf wrong_kboard_jmpbuf;
-#endif
-
#define STOP_POLLING \
do { if (! polling_stopped_here) stop_polling (); \
polling_stopped_here = 1; } while (0)
@@ -2491,6 +2572,9 @@ do { if (polling_stopped_here) start_polling (); \
if we used a mouse menu to read the input, or zero otherwise. If
USED_MOUSE_MENU is null, we don't dereference it.
+ Value is -2 when we find input on another keyboard. A second call
+ to read_char will read it.
+
If END_TIME is non-null, it is a pointer to an EMACS_TIME
specifying the maximum time to wait until. If no input arrives by
that time, stop waiting and return nil.
@@ -2517,6 +2601,7 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
volatile int reread;
struct gcpro gcpro1, gcpro2;
int polling_stopped_here = 0;
+ struct kboard *orig_kboard = current_kboard;
also_record = Qnil;
@@ -2731,6 +2816,10 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
&& !detect_input_pending_run_timers (0))
{
c = read_char_minibuf_menu_prompt (commandflag, nmaps, maps);
+
+ if (INTEGERP (c) && XINT (c) == -2)
+ return c; /* wrong_kboard_jmpbuf */
+
if (! NILP (c))
{
key_already_recorded = 1;
@@ -2747,6 +2836,7 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
jmpcount = SPECPDL_INDEX ();
if (_setjmp (local_getcjmp))
{
+ /* Handle quits while reading the keyboard. */
/* We must have saved the outer value of getcjmp here,
so restore it now. */
restore_getcjmp (save_jump);
@@ -2784,7 +2874,7 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
/* This is going to exit from read_char
so we had better get rid of this frame's stuff. */
UNGCPRO;
- longjmp (wrong_kboard_jmpbuf, 1);
+ return make_number (-2); /* wrong_kboard_jmpbuf */
}
}
#endif
@@ -2921,6 +3011,19 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
}
}
+ /* Notify the caller if an autosave hook, or a timer, sentinel or
+ filter in the sit_for calls above have changed the current
+ kboard. This could happen if they use the minibuffer or start a
+ recursive edit, like the fancy splash screen in server.el's
+ filter. If this longjmp wasn't here, read_key_sequence would
+ interpret the next key sequence using the wrong translation
+ tables and function keymaps. */
+ if (NILP (c) && current_kboard != orig_kboard)
+ {
+ UNGCPRO;
+ return make_number (-2); /* wrong_kboard_jmpbuf */
+ }
+
/* If this has become non-nil here, it has been set by a timer
or sentinel or filter. */
if (CONSP (Vunread_command_events))
@@ -2969,7 +3072,7 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
/* This is going to exit from read_char
so we had better get rid of this frame's stuff. */
UNGCPRO;
- longjmp (wrong_kboard_jmpbuf, 1);
+ return make_number (-2); /* wrong_kboard_jmpbuf */
}
}
#endif
@@ -3025,7 +3128,7 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
/* This is going to exit from read_char
so we had better get rid of this frame's stuff. */
UNGCPRO;
- longjmp (wrong_kboard_jmpbuf, 1);
+ return make_number (-2);
}
#endif
}
@@ -3080,8 +3183,12 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
if (!NILP (tem))
{
+#if 0 /* This shouldn't be necessary anymore. --lorentey */
int was_locked = single_kboard;
-
+ int count = SPECPDL_INDEX ();
+ record_single_kboard_state ();
+#endif
+
last_input_char = c;
Fcommand_execute (tem, Qnil, Fvector (1, &last_input_char), Qt);
@@ -3092,9 +3199,12 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
example banishing the mouse under mouse-avoidance-mode. */
timer_resume_idle ();
+#if 0 /* This shouldn't be necessary anymore. --lorentey */
/* Resume allowing input from any kboard, if that was true before. */
if (!was_locked)
any_kboard_state ();
+ unbind_to (count, Qnil);
+#endif
goto retry;
}
@@ -3106,15 +3216,15 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu, end_time)
if (XINT (c) == -1)
goto exit;
- if ((STRINGP (Vkeyboard_translate_table)
- && SCHARS (Vkeyboard_translate_table) > (unsigned) XFASTINT (c))
- || (VECTORP (Vkeyboard_translate_table)
- && XVECTOR (Vkeyboard_translate_table)->size > (unsigned) XFASTINT (c))
- || (CHAR_TABLE_P (Vkeyboard_translate_table)
+ if ((STRINGP (current_kboard->Vkeyboard_translate_table)
+ && SCHARS (current_kboard->Vkeyboard_translate_table) > (unsigned) XFASTINT (c))
+ || (VECTORP (current_kboard->Vkeyboard_translate_table)
+ && XVECTOR (current_kboard->Vkeyboard_translate_table)->size > (unsigned) XFASTINT (c))
+ || (CHAR_TABLE_P (current_kboard->Vkeyboard_translate_table)
&& CHARACTERP (c)))
{
Lisp_Object d;
- d = Faref (Vkeyboard_translate_table, c);
+ d = Faref (current_kboard->Vkeyboard_translate_table, c);
/* nil in keyboard-translate-table means no translation. */
if (!NILP (d))
c = d;
@@ -3734,12 +3844,10 @@ kbd_buffer_store_event_hold (event, hold_quit)
if (c == quit_char)
{
#ifdef MULTI_KBOARD
- KBOARD *kb;
+ KBOARD *kb = FRAME_KBOARD (XFRAME (event->frame_or_window));
struct input_event *sp;
- if (single_kboard
- && (kb = FRAME_KBOARD (XFRAME (event->frame_or_window)),
- kb != current_kboard))
+ if (single_kboard && kb != current_kboard)
{
kb->kbd_queue
= Fcons (make_lispy_switch_frame (event->frame_or_window),
@@ -3782,7 +3890,7 @@ kbd_buffer_store_event_hold (event, hold_quit)
}
last_event_timestamp = event->timestamp;
- interrupt_signal (0 /* dummy */);
+ handle_interrupt ();
return;
}
@@ -3915,6 +4023,7 @@ discard_mouse_events ()
if (sp->kind == MOUSE_CLICK_EVENT
|| sp->kind == WHEEL_EVENT
+ || sp->kind == HORIZ_WHEEL_EVENT
#ifdef WINDOWSNT
|| sp->kind == W32_SCROLL_BAR_CLICK_EVENT
#endif
@@ -3993,6 +4102,12 @@ kbd_buffer_get_event (kbp, used_mouse_menu, end_time)
/* Wait until there is input available. */
for (;;)
{
+ /* Break loop if there's an unread command event. Needed in
+ moused window autoselection which uses a timer to insert such
+ events. */
+ if (CONSP (Vunread_command_events))
+ break;
+
if (kbd_fetch_ptr != kbd_store_ptr)
break;
#if defined (HAVE_MOUSE) || defined (HAVE_GPM)
@@ -4264,11 +4379,15 @@ kbd_buffer_get_event (kbp, used_mouse_menu, end_time)
unsigned long time;
*kbp = current_kboard;
- /* Note that this uses F to determine which display to look at.
+ /* Note that this uses F to determine which terminal to look at.
If there is no valid info, it does not store anything
so x remains nil. */
x = Qnil;
- (*mouse_position_hook) (&f, 0, &bar_window, &part, &x, &y, &time);
+
+ /* XXX Can f or mouse_position_hook be NULL here? */
+ if (f && FRAME_TERMINAL (f)->mouse_position_hook)
+ (*FRAME_TERMINAL (f)->mouse_position_hook) (&f, 0, &bar_window,
+ &part, &x, &y, &time);
obj = Qnil;
@@ -4565,10 +4684,14 @@ timer_check (do_it_now)
{
if (NILP (vector[0]))
{
- int was_locked = single_kboard;
int count = SPECPDL_INDEX ();
Lisp_Object old_deactivate_mark = Vdeactivate_mark;
+#if 0 /* This shouldn't be necessary anymore. --lorentey */
+ /* On unbind_to, resume allowing input from any kboard, if that
+ was true before. */
+ record_single_kboard_state ();
+#endif
/* Mark the timer as triggered to prevent problems if the lisp
code fails to reschedule it right. */
vector[0] = Qt;
@@ -4580,10 +4703,6 @@ timer_check (do_it_now)
timers_run++;
unbind_to (count, Qnil);
- /* Resume allowing input from any kboard, if that was true before. */
- if (!was_locked)
- any_kboard_state ();
-
/* Since we have handled the event,
we don't need to tell the caller to wake up and do it. */
}
@@ -5089,7 +5208,7 @@ Lisp_Object Vlispy_mouse_stem;
static char *lispy_wheel_names[] =
{
- "wheel-up", "wheel-down"
+ "wheel-up", "wheel-down", "wheel-left", "wheel-right"
};
/* drag-n-drop events are generated when a set of selected files are
@@ -5726,6 +5845,7 @@ make_lispy_event (event)
}
case WHEEL_EVENT:
+ case HORIZ_WHEEL_EVENT:
{
Lisp_Object position;
Lisp_Object head;
@@ -5810,6 +5930,9 @@ make_lispy_event (event)
the up_modifier set. */
abort ();
+ if (event->kind == HORIZ_WHEEL_EVENT)
+ symbol_num += 2;
+
/* Get the symbol we should use for the wheel event. */
head = modify_event_symbol (symbol_num,
event->modifiers,
@@ -6544,8 +6667,8 @@ modify_event_symbol (symbol_num, modifiers, symbol_kind, name_alist_or_stem,
{
int len = SBYTES (name_alist_or_stem);
char *buf = (char *) alloca (len + 50);
- sprintf (buf, "%s-%ld", SDATA (name_alist_or_stem),
- (long) XINT (symbol_int) + 1);
+ sprintf (buf, "%s-%ld", SDATA (name_alist_or_stem),
+ (long) XINT (symbol_int) + 1);
value = intern (buf);
}
else if (name_table != 0 && name_table[symbol_num])
@@ -6810,7 +6933,10 @@ gobble_input (expected)
}
else
#ifdef POLL_FOR_INPUT
- if (read_socket_hook && !interrupt_input && poll_suppress_count == 0)
+ /* XXX This condition was (read_socket_hook && !interrupt_input),
+ but read_socket_hook is not global anymore. Let's pretend that
+ it's always set. */
+ if (!interrupt_input && poll_suppress_count == 0)
{
SIGMASKTYPE mask;
mask = sigblock (sigmask (SIGALRM));
@@ -6887,170 +7013,241 @@ static int
read_avail_input (expected)
int expected;
{
- register int i;
int nread = 0;
+ int err = 0;
+ struct terminal *t;
/* Store pending user signal events, if any. */
if (store_user_signal_events ())
expected = 0;
- if (read_socket_hook)
+ /* Loop through the available terminals, and call their input hooks. */
+ t = terminal_list;
+ while (t)
{
- int nr;
- struct input_event hold_quit;
+ struct terminal *next = t->next_terminal;
- EVENT_INIT (hold_quit);
- hold_quit.kind = NO_EVENT;
+ if (t->read_socket_hook)
+ {
+ int nr;
+ struct input_event hold_quit;
+
+ EVENT_INIT (hold_quit);
+ hold_quit.kind = NO_EVENT;
+
+ /* No need for FIONREAD or fcntl; just say don't wait. */
+ while (nr = (*t->read_socket_hook) (t, expected, &hold_quit), nr > 0)
+ {
+ nread += nr;
+ expected = 0;
+ }
+
+ if (nr == -1) /* Not OK to read input now. */
+ {
+ err = 1;
+ }
+ else if (nr == -2) /* Non-transient error. */
+ {
+ /* The terminal device terminated; it should be closed. */
+
+ /* Kill Emacs if this was our last terminal. */
+ if (!terminal_list->next_terminal)
+ /* Formerly simply reported no input, but that
+ sometimes led to a failure of Emacs to terminate.
+ SIGHUP seems appropriate if we can't reach the
+ terminal. */
+ /* ??? Is it really right to send the signal just to
+ this process rather than to the whole process
+ group? Perhaps on systems with FIONREAD Emacs is
+ alone in its group. */
+ kill (getpid (), SIGHUP);
+
+ /* XXX Is calling delete_terminal safe here? It calls Fdelete_frame. */
+ if (t->delete_terminal_hook)
+ (*t->delete_terminal_hook) (t);
+ else
+ delete_terminal (t);
+ }
+
+ if (hold_quit.kind != NO_EVENT)
+ kbd_buffer_store_event (&hold_quit);
+ }
- /* No need for FIONREAD or fcntl; just say don't wait. */
- while (nr = (*read_socket_hook) (input_fd, expected, &hold_quit), nr > 0)
- {
- nread += nr;
- expected = 0;
- }
- if (hold_quit.kind != NO_EVENT)
- kbd_buffer_store_event (&hold_quit);
+ t = next;
}
- else
- {
- /* Using KBD_BUFFER_SIZE - 1 here avoids reading more than
- the kbd_buffer can really hold. That may prevent loss
- of characters on some systems when input is stuffed at us. */
- unsigned char cbuf[KBD_BUFFER_SIZE - 1];
- int n_to_read;
- /* Determine how many characters we should *try* to read. */
+ if (err && !nread)
+ nread = -1;
+
+ return nread;
+}
+
+/* This is the tty way of reading available input.
+
+ Note that each terminal device has its own `struct terminal' object,
+ and so this function is called once for each individual termcap
+ terminal. The first parameter indicates which terminal to read from. */
+
+int
+tty_read_avail_input (struct terminal *terminal,
+ int expected,
+ struct input_event *hold_quit)
+{
+ /* Using KBD_BUFFER_SIZE - 1 here avoids reading more than
+ the kbd_buffer can really hold. That may prevent loss
+ of characters on some systems when input is stuffed at us. */
+ unsigned char cbuf[KBD_BUFFER_SIZE - 1];
+ int n_to_read, i;
+ struct tty_display_info *tty = terminal->display_info.tty;
+ int nread = 0;
+
+ if (!terminal->name) /* Don't read from a dead terminal. */
+ return;
+
+ if (terminal->type != output_termcap)
+ abort ();
+
+ /* XXX I think the following code should be moved to separate hook
+ functions in system-dependent files. */
#ifdef WINDOWSNT
- return 0;
+ return 0;
#else /* not WINDOWSNT */
#ifdef MSDOS
- n_to_read = dos_keysns ();
- if (n_to_read == 0)
- return 0;
+ n_to_read = dos_keysns ();
+ if (n_to_read == 0)
+ return 0;
+
+ cbuf[0] = dos_keyread ();
+ nread = 1;
+
#else /* not MSDOS */
+
+ if (! tty->term_initted) /* In case we get called during bootstrap. */
+ return 0;
+
+ if (! tty->input)
+ return 0; /* The terminal is suspended. */
+
#ifdef HAVE_GPM
- if (term_gpm)
- {
- Gpm_Event event;
- struct input_event hold_quit;
- int gpm;
+ if (gpm_tty == tty)
+ {
+ Gpm_Event event;
+ struct input_event hold_quit;
+ int gpm;
- EVENT_INIT (hold_quit);
- hold_quit.kind = NO_EVENT;
+ EVENT_INIT (hold_quit);
+ hold_quit.kind = NO_EVENT;
- while (gpm = Gpm_GetEvent (&event), gpm == 1) {
- nread += handle_one_term_event (&event, &hold_quit);
- }
- if (hold_quit.kind != NO_EVENT)
- kbd_buffer_store_event (&hold_quit);
- if (nread)
- return nread;
- }
+ while (gpm = Gpm_GetEvent (&event), gpm == 1) {
+ nread += handle_one_term_event (tty, &event, &hold_quit);
+ }
+ if (hold_quit.kind != NO_EVENT)
+ kbd_buffer_store_event (&hold_quit);
+ if (nread)
+ return nread;
+ }
#endif /* HAVE_GPM */
-#ifdef FIONREAD
- /* Find out how much input is available. */
- if (ioctl (input_fd, FIONREAD, &n_to_read) < 0)
- /* Formerly simply reported no input, but that sometimes led to
- a failure of Emacs to terminate.
- SIGHUP seems appropriate if we can't reach the terminal. */
- /* ??? Is it really right to send the signal just to this process
- rather than to the whole process group?
- Perhaps on systems with FIONREAD Emacs is alone in its group. */
- {
- if (! noninteractive)
- kill (getpid (), SIGHUP);
- else
- n_to_read = 0;
- }
- if (n_to_read == 0)
- return 0;
- if (n_to_read > sizeof cbuf)
- n_to_read = sizeof cbuf;
+/* Determine how many characters we should *try* to read. */
+#ifdef FIONREAD
+ /* Find out how much input is available. */
+ if (ioctl (fileno (tty->input), FIONREAD, &n_to_read) < 0)
+ {
+ if (! noninteractive)
+ return -2; /* Close this terminal. */
+ else
+ n_to_read = 0;
+ }
+ if (n_to_read == 0)
+ return 0;
+ if (n_to_read > sizeof cbuf)
+ n_to_read = sizeof cbuf;
#else /* no FIONREAD */
#if defined (USG) || defined (DGUX) || defined(CYGWIN)
- /* Read some input if available, but don't wait. */
- n_to_read = sizeof cbuf;
- fcntl (input_fd, F_SETFL, O_NDELAY);
+ /* Read some input if available, but don't wait. */
+ n_to_read = sizeof cbuf;
+ fcntl (fileno (tty->input), F_SETFL, O_NDELAY);
#else
- you lose;
+ you lose;
#endif
#endif
-#endif /* not MSDOS */
-#endif /* not WINDOWSNT */
- /* Now read; for one reason or another, this will not block.
- NREAD is set to the number of chars read. */
- do
- {
-#ifdef MSDOS
- cbuf[0] = dos_keyread ();
- nread = 1;
-#else
- nread = emacs_read (input_fd, cbuf, n_to_read);
-#endif
- /* POSIX infers that processes which are not in the session leader's
- process group won't get SIGHUP's at logout time. BSDI adheres to
- this part standard and returns -1 from read (0) with errno==EIO
- when the control tty is taken away.
- Jeffrey Honig <[email protected]> says this is generally safe. */
- if (nread == -1 && errno == EIO)
- kill (0, SIGHUP);
+ /* Now read; for one reason or another, this will not block.
+ NREAD is set to the number of chars read. */
+ do
+ {
+ nread = emacs_read (fileno (tty->input), cbuf, n_to_read);
+ /* POSIX infers that processes which are not in the session leader's
+ process group won't get SIGHUP's at logout time. BSDI adheres to
+ this part standard and returns -1 from read (0) with errno==EIO
+ when the control tty is taken away.
+ Jeffrey Honig <[email protected]> says this is generally safe. */
+ if (nread == -1 && errno == EIO)
+ return -2; /* Close this terminal. */
#if defined (AIX) && (! defined (aix386) && defined (_BSD))
- /* The kernel sometimes fails to deliver SIGHUP for ptys.
- This looks incorrect, but it isn't, because _BSD causes
- O_NDELAY to be defined in fcntl.h as O_NONBLOCK,
- and that causes a value other than 0 when there is no input. */
- if (nread == 0)
- kill (0, SIGHUP);
-#endif
- }
- while (
- /* We used to retry the read if it was interrupted.
- But this does the wrong thing when O_NDELAY causes
- an EAGAIN error. Does anybody know of a situation
- where a retry is actually needed? */
+ /* The kernel sometimes fails to deliver SIGHUP for ptys.
+ This looks incorrect, but it isn't, because _BSD causes
+ O_NDELAY to be defined in fcntl.h as O_NONBLOCK,
+ and that causes a value other than 0 when there is no input. */
+ if (nread == 0)
+ return -2; /* Close this terminal. */
+#endif
+ }
+ while (
+ /* We used to retry the read if it was interrupted.
+ But this does the wrong thing when O_NDELAY causes
+ an EAGAIN error. Does anybody know of a situation
+ where a retry is actually needed? */
#if 0
- nread < 0 && (errno == EAGAIN
+ nread < 0 && (errno == EAGAIN
#ifdef EFAULT
- || errno == EFAULT
+ || errno == EFAULT
#endif
#ifdef EBADSLT
- || errno == EBADSLT
+ || errno == EBADSLT
#endif
- )
+ )
#else
- 0
+ 0
#endif
- );
+ );
#ifndef FIONREAD
#if defined (USG) || defined (DGUX) || defined (CYGWIN)
- fcntl (input_fd, F_SETFL, 0);
+ fcntl (fileno (tty->input), F_SETFL, 0);
#endif /* USG or DGUX or CYGWIN */
#endif /* no FIONREAD */
- for (i = 0; i < nread; i++)
- {
- struct input_event buf;
- EVENT_INIT (buf);
- buf.kind = ASCII_KEYSTROKE_EVENT;
- buf.modifiers = 0;
- if (meta_key == 1 && (cbuf[i] & 0x80))
- buf.modifiers = meta_modifier;
- if (meta_key != 2)
- cbuf[i] &= ~0x80;
-
- buf.code = cbuf[i];
- buf.frame_or_window = selected_frame;
- buf.arg = Qnil;
-
- kbd_buffer_store_event (&buf);
- /* Don't look at input that follows a C-g too closely.
- This reduces lossage due to autorepeat on C-g. */
- if (buf.kind == ASCII_KEYSTROKE_EVENT
- && buf.code == quit_char)
- break;
- }
+
+ if (nread <= 0)
+ return nread;
+
+#endif /* not MSDOS */
+#endif /* not WINDOWSNT */
+
+ for (i = 0; i < nread; i++)
+ {
+ struct input_event buf;
+ EVENT_INIT (buf);
+ buf.kind = ASCII_KEYSTROKE_EVENT;
+ buf.modifiers = 0;
+ if (tty->meta_key == 1 && (cbuf[i] & 0x80))
+ buf.modifiers = meta_modifier;
+ if (tty->meta_key != 2)
+ cbuf[i] &= ~0x80;
+
+ buf.code = cbuf[i];
+ /* Set the frame corresponding to the active tty. Note that the
+ value of selected_frame is not reliable here, redisplay tends
+ to temporarily change it. */
+ buf.frame_or_window = tty->top_frame;
+ buf.arg = Qnil;
+
+ kbd_buffer_store_event (&buf);
+ /* Don't look at input that follows a C-g too closely.
+ This reduces lossage due to autorepeat on C-g. */
+ if (buf.kind == ASCII_KEYSTROKE_EVENT
+ && buf.code == quit_char)
+ break;
}
return nread;
@@ -8632,6 +8829,8 @@ read_char_minibuf_menu_prompt (commandflag, nmaps, maps)
if (!INTEGERP (obj))
return obj;
+ else if (XINT (obj) == -2)
+ return obj;
else
ch = XINT (obj);
@@ -8942,8 +9141,8 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
key's again in Vfunction_key_map. */
volatile keyremap fkey;
- /* Likewise, for key_translation_map. */
- volatile keyremap keytran;
+ /* Likewise, for key_translation_map and input-decode-map. */
+ volatile keyremap keytran, indec;
/* If we receive a `switch-frame' or `select-window' event in the middle of
a key sequence, we put it off for later.
@@ -8978,11 +9177,7 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
last_nonmenu_event = Qnil;
delayed_switch_frame = Qnil;
- fkey.map = fkey.parent = Vfunction_key_map;
- keytran.map = keytran.parent = Vkey_translation_map;
- fkey.start = fkey.end = 0;
- keytran.start = keytran.end = 0;
-
+
if (INTERACTIVE)
{
if (!NILP (prompt))
@@ -9022,6 +9217,15 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
keybuf[0..mock_input] holds the sequence we should reread. */
replay_sequence:
+ /* We may switch keyboards between rescans, so we need to
+ reinitialize fkey and keytran before each replay. */
+ indec.map = indec.parent = current_kboard->Vinput_decode_map;
+ fkey.map = fkey.parent = current_kboard->Vlocal_function_key_map;
+ keytran.map = keytran.parent = Vkey_translation_map;
+ indec.start = indec.end = 0;
+ fkey.start = fkey.end = 0;
+ keytran.start = keytran.end = 0;
+
starting_buffer = current_buffer;
first_unbound = bufsize + 1;
@@ -9107,7 +9311,7 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
Thus, if ESC O a has a function-key-map translation
and ESC o has a binding, don't return after ESC O,
so that we can translate ESC O plus the next character. */
- : (fkey.start < t || keytran.start < t))
+ : (/* indec.start < t || fkey.start < t || */ keytran.start < t))
{
Lisp_Object key;
int used_mouse_menu = 0;
@@ -9125,13 +9329,17 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
just one key. */
volatile int echo_local_start, keys_local_start, local_first_binding;
- eassert (fkey.end == t || (fkey.end > t && fkey.end <= mock_input));
+ eassert (indec.end == t || (indec.end > t && indec.end <= mock_input));
+ eassert (indec.start <= indec.end);
eassert (fkey.start <= fkey.end);
eassert (keytran.start <= keytran.end);
- /* key-translation-map is applied *after* function-key-map. */
+ /* key-translation-map is applied *after* function-key-map
+ which is itself applied *after* input-decode-map. */
+ eassert (fkey.end <= indec.start);
eassert (keytran.end <= fkey.start);
- if (first_unbound < fkey.start && first_unbound < keytran.start)
+ if (/* first_unbound < indec.start && first_unbound < fkey.start && */
+ first_unbound < keytran.start)
{ /* The prefix upto first_unbound has no binding and has
no translation left to do either, so we know it's unbound.
If we don't stop now, we risk staying here indefinitely
@@ -9141,6 +9349,8 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
for (i = first_unbound + 1; i < t; i++)
keybuf[i - first_unbound - 1] = keybuf[i];
mock_input = t - first_unbound - 1;
+ indec.end = indec.start -= first_unbound + 1;
+ indec.map = indec.parent;
fkey.end = fkey.start -= first_unbound + 1;
fkey.map = fkey.parent;
keytran.end = keytran.start -= first_unbound + 1;
@@ -9186,8 +9396,28 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
#ifdef MULTI_KBOARD
KBOARD *interrupted_kboard = current_kboard;
struct frame *interrupted_frame = SELECTED_FRAME ();
- if (setjmp (wrong_kboard_jmpbuf))
+#endif
+ key = read_char (NILP (prompt), nmaps,
+ (Lisp_Object *) submaps, last_nonmenu_event,
+ &used_mouse_menu, NULL);
+#ifdef MULTI_KBOARD
+ if (INTEGERP (key) && XINT (key) == -2) /* wrong_kboard_jmpbuf */
{
+ int found = 0;
+ struct kboard *k;
+
+ for (k = all_kboards; k; k = k->next_kboard)
+ if (k == interrupted_kboard)
+ found = 1;
+
+ if (!found)
+ {
+ /* Don't touch interrupted_kboard when it's been
+ deleted. */
+ delayed_switch_frame = Qnil;
+ goto replay_sequence;
+ }
+
if (!NILP (delayed_switch_frame))
{
interrupted_kboard->kbd_queue
@@ -9195,6 +9425,7 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
interrupted_kboard->kbd_queue);
delayed_switch_frame = Qnil;
}
+
while (t > 0)
interrupted_kboard->kbd_queue
= Fcons (keybuf[--t], interrupted_kboard->kbd_queue);
@@ -9219,9 +9450,6 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
goto replay_sequence;
}
#endif
- key = read_char (NILP (prompt), nmaps,
- (Lisp_Object *) submaps, last_nonmenu_event,
- &used_mouse_menu, NULL);
}
/* read_char returns t when it shows a menu and the user rejects it.
@@ -9548,15 +9776,15 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
/* This is needed for the following scenario:
event 0: a down-event that gets dropped by calling replay_key.
event 1: some normal prefix like C-h.
- After event 0, first_unbound is 0, after event 1 fkey.start
- and keytran.start are both 1, so when we see that C-h is bound,
- we need to update first_unbound. */
+ After event 0, first_unbound is 0, after event 1 indec.start,
+ fkey.start, and keytran.start are all 1, so when we see that
+ C-h is bound, we need to update first_unbound. */
first_unbound = max (t + 1, first_unbound);
else
{
Lisp_Object head;
- /* Remember the position to put an upper bound on fkey.start. */
+ /* Remember the position to put an upper bound on indec.start. */
first_unbound = min (t, first_unbound);
head = EVENT_HEAD (key);
@@ -9641,21 +9869,27 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
/* If mock_input > t + 1, the above simplification
will actually end up dropping keys on the floor.
This is probably OK for now, but even
- if mock_input <= t + 1, we need to adjust fkey
- and keytran.
+ if mock_input <= t + 1, we need to adjust indec,
+ fkey, and keytran.
Typical case [header-line down-mouse-N]:
mock_input = 2, t = 1, fkey.end = 1,
last_real_key_start = 0. */
- if (fkey.end > last_real_key_start)
+ if (indec.end > last_real_key_start)
{
- fkey.end = fkey.start
- = min (last_real_key_start, fkey.start);
- fkey.map = fkey.parent;
- if (keytran.end > last_real_key_start)
+ indec.end = indec.start
+ = min (last_real_key_start, indec.start);
+ indec.map = indec.parent;
+ if (fkey.end > last_real_key_start)
{
- keytran.end = keytran.start
- = min (last_real_key_start, keytran.start);
- keytran.map = keytran.parent;
+ fkey.end = fkey.start
+ = min (last_real_key_start, fkey.start);
+ fkey.map = fkey.parent;
+ if (keytran.end > last_real_key_start)
+ {
+ keytran.end = keytran.start
+ = min (last_real_key_start, keytran.start);
+ keytran.map = keytran.parent;
+ }
}
}
if (t == last_real_key_start)
@@ -9709,8 +9943,28 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
/* Record what part of this_command_keys is the current key sequence. */
this_single_command_key_start = this_command_key_count - t;
- if (first_binding < nmaps && NILP (submaps[first_binding]))
+ /* Look for this sequence in input-decode-map.
+ Scan from indec.end until we find a bound suffix. */
+ while (indec.end < t)
+ {
+ struct gcpro gcpro1, gcpro2, gcpro3, gcpro4;
+ int done, diff;
+
+ GCPRO4 (indec.map, fkey.map, keytran.map, delayed_switch_frame);
+ done = keyremap_step (keybuf, bufsize, &indec, max (t, mock_input),
+ 1, &diff, prompt);
+ UNGCPRO;
+ if (done)
+ {
+ mock_input = diff + max (t, mock_input);
+ goto replay_sequence;
+ }
+ }
+
+ if (first_binding < nmaps && NILP (submaps[first_binding])
+ && indec.start >= t)
/* There is a binding and it's not a prefix.
+ (and it doesn't have any input-decode-map translation pending).
There is thus no function-key in this sequence.
Moving fkey.start is important in this case to allow keytran.start
to go over the sequence before we return (since we keep the
@@ -9723,12 +9977,12 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
/* If the sequence is unbound, see if we can hang a function key
off the end of it. */
/* Continue scan from fkey.end until we find a bound suffix. */
- while (fkey.end < t)
+ while (fkey.end < indec.start)
{
- struct gcpro gcpro1, gcpro2, gcpro3;
+ struct gcpro gcpro1, gcpro2, gcpro3, gcpro4;
int done, diff;
- GCPRO3 (fkey.map, keytran.map, delayed_switch_frame);
+ GCPRO4 (indec.map, fkey.map, keytran.map, delayed_switch_frame);
done = keyremap_step (keybuf, bufsize, &fkey,
max (t, mock_input),
/* If there's a binding (i.e.
@@ -9740,6 +9994,10 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
if (done)
{
mock_input = diff + max (t, mock_input);
+ /* Adjust the input-decode-map counters. */
+ indec.end += diff;
+ indec.start += diff;
+
goto replay_sequence;
}
}
@@ -9748,17 +10006,19 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
Scan from keytran.end until we find a bound suffix. */
while (keytran.end < fkey.start)
{
- struct gcpro gcpro1, gcpro2, gcpro3;
+ struct gcpro gcpro1, gcpro2, gcpro3, gcpro4;
int done, diff;
- GCPRO3 (fkey.map, keytran.map, delayed_switch_frame);
+ GCPRO4 (indec.map, fkey.map, keytran.map, delayed_switch_frame);
done = keyremap_step (keybuf, bufsize, &keytran, max (t, mock_input),
1, &diff, prompt);
UNGCPRO;
if (done)
{
mock_input = diff + max (t, mock_input);
- /* Adjust the function-key-map counters. */
+ /* Adjust the function-key-map and input-decode-map counters. */
+ indec.end += diff;
+ indec.start += diff;
fkey.end += diff;
fkey.start += diff;
@@ -9771,7 +10031,7 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
and is an upper case letter
use the corresponding lower-case letter instead. */
if (first_binding >= nmaps
- && fkey.start >= t && keytran.start >= t
+ && /* indec.start >= t && fkey.start >= t && */ keytran.start >= t
&& INTEGERP (key)
&& ((CHARACTERP (make_number (XINT (key) & ~CHAR_MODIFIER_MASK))
&& UPPERCASEP (XINT (key) & ~CHAR_MODIFIER_MASK))
@@ -9801,7 +10061,7 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
and is a shifted function key,
use the corresponding unshifted function key instead. */
if (first_binding >= nmaps
- && fkey.start >= t && keytran.start >= t
+ && /* indec.start >= t && fkey.start >= t && */ keytran.start >= t
&& SYMBOLP (key))
{
Lisp_Object breakdown;
@@ -9822,9 +10082,6 @@ read_key_sequence (keybuf, bufsize, prompt, dont_downcase_last,
keybuf[t - 1] = new_key;
mock_input = max (t, mock_input);
- fkey.start = fkey.end = 0;
- keytran.start = keytran.end = 0;
-
goto replay_sequence;
}
}
@@ -10332,8 +10589,12 @@ detect_input_pending_run_timers (do_display)
from an idle timer function. The symptom of the bug is that
the cursor sometimes doesn't become visible until the next X
event is processed. --gerd. */
- if (rif)
- rif->flush_display (NULL);
+ {
+ Lisp_Object tail, frame;
+ FOR_EACH_FRAME (tail, frame)
+ if (FRAME_RIF (XFRAME (frame)))
+ FRAME_RIF (XFRAME (frame))->flush_display (XFRAME (frame));
+ }
}
return input_pending;
@@ -10585,6 +10846,9 @@ On such systems, Emacs starts a subshell instead of suspending. */)
int width, height;
struct gcpro gcpro1;
+ if (tty_list && tty_list->next)
+ error ("There are other tty frames open; close them before suspending Emacs");
+
if (!NILP (stuffstring))
CHECK_STRING (stuffstring);
@@ -10593,11 +10857,11 @@ On such systems, Emacs starts a subshell instead of suspending. */)
call1 (Vrun_hooks, intern ("suspend-hook"));
GCPRO1 (stuffstring);
- get_frame_size (&old_width, &old_height);
- reset_sys_modes ();
+ get_tty_size (fileno (CURTTY ()->input), &old_width, &old_height);
+ reset_all_sys_modes ();
/* sys_suspend can get an error if it tries to fork a subshell
and the system resources aren't available for that. */
- record_unwind_protect ((Lisp_Object (*) P_ ((Lisp_Object))) init_sys_modes,
+ record_unwind_protect ((Lisp_Object (*) P_ ((Lisp_Object))) init_all_sys_modes,
Qnil);
stuff_buffered_input (stuffstring);
if (cannot_suspend)
@@ -10609,7 +10873,7 @@ On such systems, Emacs starts a subshell instead of suspending. */)
/* Check if terminal/window size has changed.
Note that this is not useful when we are running directly
with a window system; but suspend should be disabled in that case. */
- get_frame_size (&width, &height);
+ get_tty_size (fileno (CURTTY ()->input), &width, &height);
if (width != old_width || height != old_height)
change_frame_size (SELECTED_FRAME (), height, width, 0, 0, 0);
@@ -10669,10 +10933,10 @@ set_waiting_for_input (time_to_clear)
{
input_available_clear_time = time_to_clear;
- /* Tell interrupt_signal to throw back to read_char, */
+ /* Tell handle_interrupt to throw back to read_char, */
waiting_for_input = 1;
- /* If interrupt_signal was called before and buffered a C-g,
+ /* If handle_interrupt was called before and buffered a C-g,
make it run again now, to avoid timing error. */
if (!NILP (Vquit_flag))
quit_throw_to_read_char ();
@@ -10681,48 +10945,82 @@ set_waiting_for_input (time_to_clear)
void
clear_waiting_for_input ()
{
- /* Tell interrupt_signal not to throw back to read_char, */
+ /* Tell handle_interrupt not to throw back to read_char, */
waiting_for_input = 0;
input_available_clear_time = 0;
}
-/* This routine is called at interrupt level in response to C-g.
-
- If interrupt_input, this is the handler for SIGINT. Otherwise, it
- is called from kbd_buffer_store_event, in handling SIGIO or
- SIGTINT.
+/* The SIGINT handler.
- If `waiting_for_input' is non zero, then unless `echoing' is
- nonzero, immediately throw back to read_char.
-
- Otherwise it sets the Lisp variable quit-flag not-nil. This causes
- eval to throw, when it gets a chance. If quit-flag is already
- non-nil, it stops the job right away. */
+ If we have a frame on the controlling tty, we assume that the
+ SIGINT was generated by C-g, so we call handle_interrupt.
+ Otherwise, the handler kills Emacs. */
static SIGTYPE
interrupt_signal (signalnum) /* If we don't have an argument, */
int signalnum; /* some compilers complain in signal calls. */
{
- char c;
/* Must preserve main program's value of errno. */
int old_errno = errno;
- struct frame *sf = SELECTED_FRAME ();
+ struct terminal *terminal;
#if defined (USG) && !defined (POSIX_SIGNALS)
- if (!read_socket_hook && NILP (Vwindow_system))
- {
- /* USG systems forget handlers when they are used;
- must reestablish each time */
- signal (SIGINT, interrupt_signal);
- signal (SIGQUIT, interrupt_signal);
- }
+ /* USG systems forget handlers when they are used;
+ must reestablish each time */
+ signal (SIGINT, interrupt_signal);
+ signal (SIGQUIT, interrupt_signal);
#endif /* USG */
SIGNAL_THREAD_CHECK (signalnum);
+
+ /* See if we have an active terminal on our controlling tty. */
+ terminal = get_named_tty ("/dev/tty");
+ if (!terminal)
+ {
+ /* If there are no frames there, let's pretend that we are a
+ well-behaving UN*X program and quit. */
+ Fkill_emacs (Qnil);
+ }
+ else
+ {
+ /* Otherwise, the SIGINT was probably generated by C-g. */
+
+ /* Set internal_last_event_frame to the top frame of the
+ controlling tty, if we have a frame there. We disable the
+ interrupt key on secondary ttys, so the SIGINT must have come
+ from the controlling tty. */
+ internal_last_event_frame = terminal->display_info.tty->top_frame;
+
+ handle_interrupt ();
+ }
+
+ errno = old_errno;
+}
+
+/* This routine is called at interrupt level in response to C-g.
+
+ It is called from the SIGINT handler or kbd_buffer_store_event.
+
+ If `waiting_for_input' is non zero, then unless `echoing' is
+ nonzero, immediately throw back to read_char.
+
+ Otherwise it sets the Lisp variable quit-flag not-nil. This causes
+ eval to throw, when it gets a chance. If quit-flag is already
+ non-nil, it stops the job right away. */
+
+static void
+handle_interrupt ()
+{
+ char c;
+
cancel_echoing ();
+ /* XXX This code needs to be revised for multi-tty support. */
if (!NILP (Vquit_flag)
- && (FRAME_TERMCAP_P (sf) || FRAME_MSDOS_P (sf)))
+#ifndef MSDOS
+ && get_named_tty ("/dev/tty")
+#endif
+ )
{
/* If SIGINT isn't blocked, don't let us be interrupted by
another SIGINT, it might be harmful due to non-reentrancy
@@ -10730,7 +11028,7 @@ interrupt_signal (signalnum) /* If we don't have an argument, */
sigblock (sigmask (SIGINT));
fflush (stdout);
- reset_sys_modes ();
+ reset_all_sys_modes ();
#ifdef SIGTSTP /* Support possible in later USG versions */
/*
@@ -10809,7 +11107,7 @@ interrupt_signal (signalnum) /* If we don't have an argument, */
printf ("Continuing...\n");
#endif /* not MSDOS */
fflush (stdout);
- init_sys_modes ();
+ init_all_sys_modes ();
sigfree ();
}
else
@@ -10837,9 +11135,7 @@ interrupt_signal (signalnum) /* If we don't have an argument, */
}
if (waiting_for_input && !echoing)
- quit_throw_to_read_char ();
-
- errno = old_errno;
+ quit_throw_to_read_char ();
}
/* Handle a C-g by making read_char return C-g. */
@@ -10872,75 +11168,203 @@ quit_throw_to_read_char ()
_longjmp (getcjmp, 1);
}
-DEFUN ("set-input-mode", Fset_input_mode, Sset_input_mode, 3, 4, 0,
- doc: /* Set mode of reading keyboard input.
-First arg INTERRUPT non-nil means use input interrupts;
- nil means use CBREAK mode.
-Second arg FLOW non-nil means use ^S/^Q flow control for output to terminal
- (no effect except in CBREAK mode).
-Third arg META t means accept 8-bit input (for a Meta key).
- META nil means ignore the top bit, on the assumption it is parity.
- Otherwise, accept 8-bit input and don't use the top bit for Meta.
-Optional fourth arg QUIT if non-nil specifies character to use for quitting.
+DEFUN ("set-input-interrupt-mode", Fset_input_interrupt_mode, Sset_input_interrupt_mode, 1, 1, 0,
+ doc: /* Set interrupt mode of reading keyboard input.
+If INTERRUPT is non-nil, Emacs will use input interrupts;
+otherwise Emacs uses CBREAK mode.
+
See also `current-input-mode'. */)
- (interrupt, flow, meta, quit)
- Lisp_Object interrupt, flow, meta, quit;
+ (interrupt)
+ Lisp_Object interrupt;
{
- if (!NILP (quit)
- && (!INTEGERP (quit) || XINT (quit) < 0 || XINT (quit) > 0400))
- error ("set-input-mode: QUIT must be an ASCII character");
-
-#ifdef POLL_FOR_INPUT
- stop_polling ();
-#endif
-
-#ifndef DOS_NT
- /* this causes startup screen to be restored and messes with the mouse */
- reset_sys_modes ();
-#endif
-
+ int new_interrupt_input;
#ifdef SIGIO
/* Note SIGIO has been undef'd if FIONREAD is missing. */
- if (read_socket_hook)
+#ifdef HAVE_X_WINDOWS
+ if (x_display_list != NULL)
{
/* When using X, don't give the user a real choice,
because we haven't implemented the mechanisms to support it. */
#ifdef NO_SOCK_SIGIO
- interrupt_input = 0;
+ new_interrupt_input = 0;
#else /* not NO_SOCK_SIGIO */
- interrupt_input = 1;
+ new_interrupt_input = 1;
#endif /* NO_SOCK_SIGIO */
}
else
- interrupt_input = !NILP (interrupt);
+#endif
+ new_interrupt_input = !NILP (interrupt);
#else /* not SIGIO */
- interrupt_input = 0;
+ new_interrupt_input = 0;
#endif /* not SIGIO */
/* Our VMS input only works by interrupts, as of now. */
#ifdef VMS
- interrupt_input = 1;
+ new_interrupt_input = 1;
#endif
- flow_control = !NILP (flow);
+ if (new_interrupt_input != interrupt_input)
+ {
+#ifdef POLL_FOR_INPUT
+ stop_polling ();
+#endif
+#ifndef DOS_NT
+ /* this causes startup screen to be restored and messes with the mouse */
+ reset_all_sys_modes ();
+#endif
+ interrupt_input = new_interrupt_input;
+#ifndef DOS_NT
+ init_all_sys_modes ();
+#endif
+
+#ifdef POLL_FOR_INPUT
+ poll_suppress_count = 1;
+ start_polling ();
+#endif
+ }
+ return Qnil;
+}
+
+DEFUN ("set-output-flow-control", Fset_output_flow_control, Sset_output_flow_control, 1, 2, 0,
+ doc: /* Enable or disable ^S/^Q flow control for output to TERMINAL.
+If FLOW is non-nil, flow control is enabled and you cannot use C-s or
+C-q in key sequences.
+
+This setting only has an effect on tty terminals and only when
+Emacs reads input in CBREAK mode; see `set-input-interrupt-mode'.
+
+See also `current-input-mode'. */)
+ (flow, terminal)
+ Lisp_Object flow, terminal;
+{
+ struct terminal *t = get_terminal (terminal, 1);
+ struct tty_display_info *tty;
+ if (t == NULL || t->type != output_termcap)
+ return Qnil;
+ tty = t->display_info.tty;
+
+ if (tty->flow_control != !NILP (flow))
+ {
+#ifndef DOS_NT
+ /* this causes startup screen to be restored and messes with the mouse */
+ reset_sys_modes (tty);
+#endif
+
+ tty->flow_control = !NILP (flow);
+
+#ifndef DOS_NT
+ init_sys_modes (tty);
+#endif
+ }
+ return Qnil;
+}
+
+DEFUN ("set-input-meta-mode", Fset_input_meta_mode, Sset_input_meta_mode, 1, 2, 0,
+ doc: /* Enable or disable 8-bit input on TERMINAL.
+If META is t, Emacs will accept 8-bit input, and interpret the 8th
+bit as the Meta modifier.
+
+If META is nil, Emacs will ignore the top bit, on the assumption it is
+parity.
+
+Otherwise, Emacs will accept and pass through 8-bit input without
+specially interpreting the top bit.
+
+This setting only has an effect on tty terminal devices.
+
+Optional parameter TERMINAL specifies the tty terminal device to use.
+It may be a terminal id, a frame, or nil for the terminal used by the
+currently selected frame.
+
+See also `current-input-mode'. */)
+ (meta, terminal)
+ Lisp_Object meta, terminal;
+{
+ struct terminal *t = get_terminal (terminal, 1);
+ struct tty_display_info *tty;
+ int new_meta;
+
+ if (t == NULL || t->type != output_termcap)
+ return Qnil;
+ tty = t->display_info.tty;
+
if (NILP (meta))
- meta_key = 0;
+ new_meta = 0;
else if (EQ (meta, Qt))
- meta_key = 1;
+ new_meta = 1;
else
- meta_key = 2;
- if (!NILP (quit))
- /* Don't let this value be out of range. */
- quit_char = XINT (quit) & (meta_key ? 0377 : 0177);
+ new_meta = 2;
+ if (tty->meta_key != new_meta)
+ {
#ifndef DOS_NT
- init_sys_modes ();
+ /* this causes startup screen to be restored and messes with the mouse */
+ reset_sys_modes (tty);
#endif
-#ifdef POLL_FOR_INPUT
- poll_suppress_count = 1;
- start_polling ();
+ tty->meta_key = new_meta;
+
+#ifndef DOS_NT
+ init_sys_modes (tty);
#endif
+ }
+ return Qnil;
+}
+
+DEFUN ("set-quit-char", Fset_quit_char, Sset_quit_char, 1, 1, 0,
+ doc: /* Specify character used for quitting.
+QUIT must be an ASCII character.
+
+This function only has an effect on the controlling tty of the Emacs
+process.
+
+See also `current-input-mode'. */)
+ (quit)
+ Lisp_Object quit;
+{
+ struct terminal *t = get_named_tty ("/dev/tty");
+ struct tty_display_info *tty;
+ if (t == NULL || t->type != output_termcap)
+ return Qnil;
+ tty = t->display_info.tty;
+
+ if (NILP (quit) || !INTEGERP (quit) || XINT (quit) < 0 || XINT (quit) > 0400)
+ error ("QUIT must be an ASCII character");
+
+#ifndef DOS_NT
+ /* this causes startup screen to be restored and messes with the mouse */
+ reset_sys_modes (tty);
+#endif
+
+ /* Don't let this value be out of range. */
+ quit_char = XINT (quit) & (tty->meta_key == 0 ? 0177 : 0377);
+
+#ifndef DOS_NT
+ init_sys_modes (tty);
+#endif
+
+ return Qnil;
+}
+
+DEFUN ("set-input-mode", Fset_input_mode, Sset_input_mode, 3, 4, 0,
+ doc: /* Set mode of reading keyboard input.
+First arg INTERRUPT non-nil means use input interrupts;
+ nil means use CBREAK mode.
+Second arg FLOW non-nil means use ^S/^Q flow control for output to terminal
+ (no effect except in CBREAK mode).
+Third arg META t means accept 8-bit input (for a Meta key).
+ META nil means ignore the top bit, on the assumption it is parity.
+ Otherwise, accept 8-bit input and don't use the top bit for Meta.
+Optional fourth arg QUIT if non-nil specifies character to use for quitting.
+See also `current-input-mode'. */)
+ (interrupt, flow, meta, quit)
+ Lisp_Object interrupt, flow, meta, quit;
+{
+ Fset_input_interrupt_mode (interrupt);
+ Fset_output_flow_control (flow, Qnil);
+ Fset_input_meta_mode (meta, Qnil);
+ if (!NILP (quit))
+ Fset_quit_char (quit);
return Qnil;
}
@@ -10961,10 +11385,21 @@ The elements of this list correspond to the arguments of
()
{
Lisp_Object val[4];
+ struct frame *sf = XFRAME (selected_frame);
val[0] = interrupt_input ? Qt : Qnil;
- val[1] = flow_control ? Qt : Qnil;
- val[2] = meta_key == 2 ? make_number (0) : meta_key == 1 ? Qt : Qnil;
+ if (FRAME_TERMCAP_P (sf))
+ {
+ val[1] = FRAME_TTY (sf)->flow_control ? Qt : Qnil;
+ val[2] = (FRAME_TTY (sf)->meta_key == 2
+ ? make_number (0)
+ : (CURTTY ()->meta_key == 1 ? Qt : Qnil));
+ }
+ else
+ {
+ val[1] = Qnil;
+ val[2] = Qt;
+ }
XSETFASTINT (val[3], quit_char);
return Flist (sizeof (val) / sizeof (val[0]), val);
@@ -11056,6 +11491,8 @@ init_kboard (kb)
kb->Voverriding_terminal_local_map = Qnil;
kb->Vlast_command = Qnil;
kb->Vreal_last_command = Qnil;
+ kb->Vkeyboard_translate_table = Qnil;
+ kb->Vlast_repeatable_command = Qnil;
kb->Vprefix_arg = Qnil;
kb->Vlast_prefix_arg = Qnil;
kb->kbd_queue = Qnil;
@@ -11070,6 +11507,9 @@ init_kboard (kb)
kb->reference_count = 0;
kb->Vsystem_key_alist = Qnil;
kb->system_key_syms = Qnil;
+ kb->Vinput_decode_map = Fmake_sparse_keymap (Qnil);
+ kb->Vlocal_function_key_map = Fmake_sparse_keymap (Qnil);
+ Fset_keymap_parent (kb->Vlocal_function_key_map, Vfunction_key_map);
kb->Vdefault_minibuffer_frame = Qnil;
}
@@ -11106,7 +11546,8 @@ delete_kboard (kb)
&& FRAMEP (selected_frame)
&& FRAME_LIVE_P (XFRAME (selected_frame)))
{
- current_kboard = XFRAME (selected_frame)->kboard;
+ current_kboard = FRAME_KBOARD (XFRAME (selected_frame));
+ single_kboard = 0;
if (current_kboard == kb)
abort ();
}
@@ -11149,8 +11590,14 @@ init_keyboard ()
wipe_kboard (current_kboard);
init_kboard (current_kboard);
- if (!noninteractive && !read_socket_hook && NILP (Vwindow_system))
+ if (!noninteractive)
{
+ /* Before multi-tty support, these handlers used to be installed
+ only if the current session was a tty session. Now an Emacs
+ session may have multiple display types, so we always handle
+ SIGINT. There is special code in interrupt_signal to exit
+ Emacs on SIGINT when there are no termcap frames on the
+ controlling terminal. */
signal (SIGINT, interrupt_signal);
#if defined (HAVE_TERMIO) || defined (HAVE_TERMIOS)
/* For systems with SysV TERMIO, C-g is set up for both SIGINT and
@@ -11397,7 +11844,7 @@ syms_of_keyboard ()
staticpro (&button_down_location);
mouse_syms = Fmake_vector (make_number (1), Qnil);
staticpro (&mouse_syms);
- wheel_syms = Fmake_vector (make_number (2), Qnil);
+ wheel_syms = Fmake_vector (make_number (4), Qnil);
staticpro (&wheel_syms);
{
@@ -11475,6 +11922,10 @@ syms_of_keyboard ()
defsubr (&Stop_level);
defsubr (&Sdiscard_input);
defsubr (&Sopen_dribble_file);
+ defsubr (&Sset_input_interrupt_mode);
+ defsubr (&Sset_output_flow_control);
+ defsubr (&Sset_input_meta_mode);
+ defsubr (&Sset_quit_char);
defsubr (&Sset_input_mode);
defsubr (&Scurrent_input_mode);
defsubr (&Sexecute_extended_command);
@@ -11541,11 +11992,19 @@ In other words, the present command is the event that made the previous
command exit.
The value `kill-region' is special; it means that the previous command
-was a kill command. */);
+was a kill command.
+
+`last-command' has a separate binding for each terminal device.
+See Info node `(elisp)Multiple displays'. */);
DEFVAR_KBOARD ("real-last-command", Vreal_last_command,
doc: /* Same as `last-command', but never altered by Lisp code. */);
+ DEFVAR_KBOARD ("last-repeatable-command", Vlast_repeatable_command,
+ doc: /* Last command that may be repeated.
+The last command executed that was not bound to an input event.
+This is the command `repeat' will try to repeat. */);
+
DEFVAR_LISP ("this-command", &Vthis_command,
doc: /* The command now being executed.
The command can set this variable; whatever is put here
@@ -11653,8 +12112,8 @@ for that character after that prefix key. */);
Useful to set before you dump a modified Emacs. */);
Vtop_level = Qnil;
- DEFVAR_LISP ("keyboard-translate-table", &Vkeyboard_translate_table,
- doc: /* Translate table for keyboard input, or nil.
+ DEFVAR_KBOARD ("keyboard-translate-table", Vkeyboard_translate_table,
+ doc: /* Translate table for local keyboard input, or nil.
If non-nil, the value should be a char-table. Each character read
from the keyboard is looked up in this char-table. If the value found
there is non-nil, then it is used instead of the actual input character.
@@ -11664,8 +12123,10 @@ If it is a string or vector of length N, character codes N and up are left
untranslated. In a vector, an element which is nil means "no translation".
This is applied to the characters supplied to input methods, not their
-output. See also `translation-table-for-input'. */);
- Vkeyboard_translate_table = Qnil;
+output. See also `translation-table-for-input'.
+
+This variable has a separate binding for each terminal. See Info node
+`(elisp)Multiple displays'. */);
DEFVAR_BOOL ("cannot-suspend", &cannot_suspend,
doc: /* Non-nil means to always spawn a subshell instead of suspending.
@@ -11750,7 +12211,11 @@ buffer's local map, and the minor mode keymaps and text property keymaps.
It also replaces `overriding-local-map'.
This variable is intended to let commands such as `universal-argument'
-set up a different keymap for reading the next command. */);
+set up a different keymap for reading the next command.
+
+`overriding-terminal-local-map' has a separate binding for each
+terminal device.
+See Info node `(elisp)Multiple displays'. */);
DEFVAR_LISP ("overriding-local-map", &Voverriding_local_map,
doc: /* Keymap that overrides all other local keymaps.
@@ -11775,7 +12240,73 @@ and the minor mode maps regardless of `overriding-local-map'. */);
doc: /* Alist of system-specific X windows key symbols.
Each element should have the form (N . SYMBOL) where N is the
numeric keysym code (sans the \"system-specific\" bit 1<<28)
-and SYMBOL is its name. */);
+and SYMBOL is its name.
+
+`system-key-alist' has a separate binding for each terminal device.
+See Info node `(elisp)Multiple displays'. */);
+
+ DEFVAR_KBOARD ("local-function-key-map", Vlocal_function_key_map,
+ doc: /* Keymap that translates key sequences to key sequences during input.
+This is used mainly for mapping key sequences into some preferred
+key events (symbols).
+
+The `read-key-sequence' function replaces any subsequence bound by
+`local-function-key-map' with its binding. More precisely, when the
+active keymaps have no binding for the current key sequence but
+`local-function-key-map' binds a suffix of the sequence to a vector or
+string, `read-key-sequence' replaces the matching suffix with its
+binding, and continues with the new sequence.
+
+If the binding is a function, it is called with one argument (the prompt)
+and its return value (a key sequence) is used.
+
+The events that come from bindings in `local-function-key-map' are not
+themselves looked up in `local-function-key-map'.
+
+For example, suppose `local-function-key-map' binds `ESC O P' to [f1].
+Typing `ESC O P' to `read-key-sequence' would return [f1]. Typing
+`C-x ESC O P' would return [?\\C-x f1]. If [f1] were a prefix key,
+typing `ESC O P x' would return [f1 x].
+
+`local-function-key-map' has a separate binding for each terminal
+device. See Info node `(elisp)Multiple displays'. If you need to
+define a binding on all terminals, change `function-key-map'
+instead. Initially, `local-function-key-map' is an empty keymap that
+has `function-key-map' as its parent on all terminal devices. */);
+
+ DEFVAR_KBOARD ("input-decode-map", Vinput_decode_map,
+ doc: /* Keymap that decodes input escape sequences.
+This is used mainly for mapping ASCII function key sequences into
+real Emacs function key events (symbols).
+
+The `read-key-sequence' function replaces any subsequence bound by
+`local-function-key-map' with its binding. Contrary to `function-key-map',
+this map applies its rebinding regardless of the presence of an ordinary
+binding. So it is more like `key-translation-map' except that it applies
+before `function-key-map' rather than after.
+
+If the binding is a function, it is called with one argument (the prompt)
+and its return value (a key sequence) is used.
+
+The events that come from bindings in `input-decode-map' are not
+themselves looked up in `input-decode-map'.
+
+This variable is keyboard-local. */);
+
+ DEFVAR_LISP ("function-key-map", &Vfunction_key_map,
+ doc: /* The parent keymap of all `local-function-key-map' instances.
+Function key definitions that apply to all terminal devices should go
+here. If a mapping is defined in both the current
+`local-function-key-map' binding and this variable, then the local
+definition will take precendence. */);
+ Vfunction_key_map = Fmake_sparse_keymap (Qnil);
+
+ DEFVAR_LISP ("key-translation-map", &Vkey_translation_map,
+ doc: /* Keymap of key translations that can override keymaps.
+This keymap works like `function-key-map', but comes after that,
+and its non-prefix bindings override ordinary bindings.
+Another difference is that it is global rather than keyboard-local. */);
+ Vkey_translation_map = Fmake_sparse_keymap (Qnil);
DEFVAR_LISP ("deferred-action-list", &Vdeferred_action_list,
doc: /* List of deferred actions to be performed at a later time.
@@ -11944,6 +12475,8 @@ mark_kboards ()
mark_object (kb->Voverriding_terminal_local_map);
mark_object (kb->Vlast_command);
mark_object (kb->Vreal_last_command);
+ mark_object (kb->Vkeyboard_translate_table);
+ mark_object (kb->Vlast_repeatable_command);
mark_object (kb->Vprefix_arg);
mark_object (kb->Vlast_prefix_arg);
mark_object (kb->kbd_queue);
@@ -11951,6 +12484,8 @@ mark_kboards ()
mark_object (kb->Vlast_kbd_macro);
mark_object (kb->Vsystem_key_alist);
mark_object (kb->system_key_syms);
+ mark_object (kb->Vinput_decode_map);
+ mark_object (kb->Vlocal_function_key_map);
mark_object (kb->Vdefault_minibuffer_frame);
mark_object (kb->echo_string);
}
diff --git a/src/keyboard.h b/src/keyboard.h
index 15e55ad4e6..ae135b30b7 100644
--- a/src/keyboard.h
+++ b/src/keyboard.h
@@ -23,8 +23,9 @@ Boston, MA 02110-1301, USA. */
/* Length of echobuf field in each KBOARD. */
-/* Each KBOARD represents one logical input stream from which Emacs gets input.
- If we are using an ordinary terminal, it has one KBOARD object.
+/* Each KBOARD represents one logical input stream from which Emacs
+ gets input. If we are using ordinary terminals, it has one KBOARD
+ object for each terminal device.
Usually each X display screen has its own KBOARD,
but when two of them are on the same X server,
we assume they share a keyboard and give them one KBOARD in common.
@@ -83,6 +84,12 @@ struct kboard
other commands. */
Lisp_Object Vreal_last_command;
+ /* User-supplied table to translate input characters through. */
+ Lisp_Object Vkeyboard_translate_table;
+
+ /* Last command that may be repeated by `repeat'. */
+ Lisp_Object Vlast_repeatable_command;
+
/* The prefix argument for the next command, in raw form. */
Lisp_Object Vprefix_arg;
@@ -123,6 +130,15 @@ struct kboard
/* Cache for modify_event_symbol. */
Lisp_Object system_key_syms;
+ /* Keymap mapping keys to alternative preferred forms.
+ See the DEFVAR for more documentation. */
+ Lisp_Object Vlocal_function_key_map;
+
+ /* Keymap mapping ASCII function key sequences onto their preferred
+ forms. Initialized by the terminal-specific lisp files. See the
+ DEFVAR for more documentation. */
+ Lisp_Object Vinput_decode_map;
+
/* Minibufferless frames on this display use this frame's minibuffer. */
Lisp_Object Vdefault_minibuffer_frame;
@@ -155,7 +171,7 @@ struct kboard
};
#ifdef MULTI_KBOARD
-/* Temporarily used before a frame has been opened, and for termcap frames */
+/* Temporarily used before a frame has been opened. */
extern KBOARD *initial_kboard;
/* In the single-kboard state, this is the kboard
@@ -190,10 +206,6 @@ extern EMACS_INT num_nonmacro_input_events;
/* Nonzero means polling for input is temporarily suppressed. */
extern int poll_suppress_count;
-/* Keymap mapping ASCII function key sequences onto their preferred forms.
- Initialized by the terminal-specific lisp files. */
-extern Lisp_Object Vfunction_key_map;
-
/* Vector holding the key sequence that invoked the current command.
It is reused for each command, and it may be longer than the current
sequence; this_command_key_count indicates how many elements
@@ -301,18 +313,24 @@ extern Lisp_Object parse_modifiers P_ ((Lisp_Object));
extern Lisp_Object reorder_modifiers P_ ((Lisp_Object));
extern Lisp_Object read_char P_ ((int, int, Lisp_Object *, Lisp_Object,
int *, EMACS_TIME *));
-/* User-supplied string to translate input characters through. */
-extern Lisp_Object Vkeyboard_translate_table;
+
+
+/* Parent keymap of terminal-local function-key-map instances. */
+extern Lisp_Object Vfunction_key_map;
+
+/* Keymap of key translations that can override keymaps. */
+extern Lisp_Object Vkey_translation_map;
extern int parse_menu_item P_ ((Lisp_Object, int, int));
extern void echo_now P_ ((void));
extern void init_kboard P_ ((KBOARD *));
extern void delete_kboard P_ ((KBOARD *));
-extern void single_kboard_state P_ ((void));
extern void not_single_kboard_state P_ ((KBOARD *));
+extern void push_kboard P_ ((struct kboard *));
extern void push_frame_kboard P_ ((struct frame *));
-extern void pop_frame_kboard P_ ((void));
+extern void pop_kboard P_ ((void));
+extern void temporarily_switch_to_single_kboard P_ ((struct frame *));
extern void record_asynch_buffer_change P_ ((void));
extern SIGTYPE input_poll_signal P_ ((int));
extern void start_polling P_ ((void));
@@ -346,5 +364,8 @@ extern Lisp_Object menu_item_eval_property P_ ((Lisp_Object));
extern int kbd_buffer_events_waiting P_ ((int));
extern void add_user_signals P_ ((int, const char *));
+extern int tty_read_avail_input P_ ((struct terminal *, int,
+ struct input_event *));
+
/* arch-tag: 769cbade-1ba9-4950-b886-db265b061aa3
(do not change this comment) */
diff --git a/src/keymap.c b/src/keymap.c
index 7f329cc9a1..b6243594be 100644
--- a/src/keymap.c
+++ b/src/keymap.c
@@ -32,6 +32,7 @@ Boston, MA 02110-1301, USA. */
#include "character.h"
#include "charset.h"
#include "keyboard.h"
+#include "frame.h"
#include "termhooks.h"
#include "blockinput.h"
#include "puresize.h"
@@ -91,14 +92,6 @@ Lisp_Object Vminor_mode_overriding_map_alist;
/* List of emulation mode keymap alists. */
Lisp_Object Vemulation_mode_map_alists;
-/* Keymap mapping ASCII function key sequences onto their preferred forms.
- Initialized by the terminal-specific lisp files. See DEFVAR for more
- documentation. */
-Lisp_Object Vfunction_key_map;
-
-/* Keymap mapping ASCII function key sequences onto their preferred forms. */
-Lisp_Object Vkey_translation_map;
-
/* A list of all commands given new bindings since a certain time
when nil was stored here.
This is used to speed up recomputation of menu key equivalents
@@ -2977,11 +2970,11 @@ You type Translation\n\
outbuf = Fcurrent_buffer ();
/* Report on alternates for keys. */
- if (STRINGP (Vkeyboard_translate_table) && !NILP (prefix))
+ if (STRINGP (current_kboard->Vkeyboard_translate_table) && !NILP (prefix))
{
int c;
- const unsigned char *translate = SDATA (Vkeyboard_translate_table);
- int translate_len = SCHARS (Vkeyboard_translate_table);
+ const unsigned char *translate = SDATA (current_kboard->Vkeyboard_translate_table);
+ int translate_len = SCHARS (current_kboard->Vkeyboard_translate_table);
for (c = 0; c < translate_len; c++)
if (translate[c] != c)
@@ -3004,7 +2997,7 @@ You type Translation\n\
insert ("\n", 1);
/* Insert calls signal_after_change which may GC. */
- translate = SDATA (Vkeyboard_translate_table);
+ translate = SDATA (current_kboard->Vkeyboard_translate_table);
}
insert ("\n", 1);
@@ -3100,10 +3093,15 @@ You type Translation\n\
"\f\nGlobal Bindings", nomenu, 0, 1, 0);
/* Print the function-key-map translations under this prefix. */
- if (!NILP (Vfunction_key_map))
- describe_map_tree (Vfunction_key_map, 0, Qnil, prefix,
+ if (!NILP (current_kboard->Vlocal_function_key_map))
+ describe_map_tree (current_kboard->Vlocal_function_key_map, 0, Qnil, prefix,
"\f\nFunction key map translations", nomenu, 1, 0, 0);
+ /* Print the input-decode-map translations under this prefix. */
+ if (!NILP (current_kboard->Vinput_decode_map))
+ describe_map_tree (current_kboard->Vinput_decode_map, 0, Qnil, prefix,
+ "\f\nInput decoding map translations", nomenu, 1, 0, 0);
+
UNGCPRO;
return Qnil;
}
@@ -3923,37 +3921,6 @@ the same way. The "active" keymaps in each alist are used before
`minor-mode-map-alist' and `minor-mode-overriding-map-alist'. */);
Vemulation_mode_map_alists = Qnil;
-
- DEFVAR_LISP ("function-key-map", &Vfunction_key_map,
- doc: /* Keymap that translates key sequences to key sequences during input.
-This is used mainly for mapping ASCII function key sequences into
-real Emacs function key events (symbols).
-
-The `read-key-sequence' function replaces any subsequence bound by
-`function-key-map' with its binding. More precisely, when the active
-keymaps have no binding for the current key sequence but
-`function-key-map' binds a suffix of the sequence to a vector or string,
-`read-key-sequence' replaces the matching suffix with its binding, and
-continues with the new sequence.
-
-If the binding is a function, it is called with one argument (the prompt)
-and its return value (a key sequence) is used.
-
-The events that come from bindings in `function-key-map' are not
-themselves looked up in `function-key-map'.
-
-For example, suppose `function-key-map' binds `ESC O P' to [f1].
-Typing `ESC O P' to `read-key-sequence' would return [f1]. Typing
-`C-x ESC O P' would return [?\\C-x f1]. If [f1] were a prefix
-key, typing `ESC O P x' would return [f1 x]. */);
- Vfunction_key_map = Fmake_sparse_keymap (Qnil);
-
- DEFVAR_LISP ("key-translation-map", &Vkey_translation_map,
- doc: /* Keymap of key translations that can override keymaps.
-This keymap works like `function-key-map', but comes after that,
-and its non-prefix bindings override ordinary bindings. */);
- Vkey_translation_map = Qnil;
-
staticpro (&Vmouse_events);
Vmouse_events = Fcons (intern ("menu-bar"),
Fcons (intern ("tool-bar"),
diff --git a/src/keymap.h b/src/keymap.h
index 1a51de705b..3268967089 100644
--- a/src/keymap.h
+++ b/src/keymap.h
@@ -38,6 +38,7 @@ EXFUN (Fcurrent_active_maps, 2);
extern Lisp_Object access_keymap P_ ((Lisp_Object, Lisp_Object, int, int, int));
extern Lisp_Object get_keyelt P_ ((Lisp_Object, int));
extern Lisp_Object get_keymap P_ ((Lisp_Object, int, int));
+EXFUN (Fset_keymap_parent, 2);
extern void describe_map_tree P_ ((Lisp_Object, int, Lisp_Object, Lisp_Object,
char *, int, int, int, int));
extern int current_minor_maps P_ ((Lisp_Object **, Lisp_Object **));
diff --git a/src/lisp.h b/src/lisp.h
index c047355b21..578cc3a641 100644
--- a/src/lisp.h
+++ b/src/lisp.h
@@ -113,6 +113,57 @@ extern void die P_((const char *, const char *, int)) NO_RETURN;
#define eassert(cond) CHECK(cond,"assertion failed")
#endif
#endif /* ENABLE_CHECKING */
+
+/***** Select the tagging scheme. *****/
+/* There are basically two options that control the tagging scheme:
+ - NO_UNION_TYPE says that Lisp_Object should be an integer instead
+ of a union.
+ - USE_LSB_TAG means that we can assume the least 3 bits of pointers are
+ always 0, and we can thus use them to hold tag bits, without
+ restricting our addressing space.
+
+ If USE_LSB_TAG is not set, then we use the top 3 bits for tagging, thus
+ restricting our possible address range. Currently USE_LSB_TAG is not
+ allowed together with a union. This is not due to any fundamental
+ technical (or political ;-) problem: nobody wrote the code to do it yet.
+
+ USE_LSB_TAG not only requires the least 3 bits of pointers returned by
+ malloc to be 0 but also needs to be able to impose a mult-of-8 alignment
+ on the few static Lisp_Objects used: all the defsubr as well
+ as the two special buffers buffer_defaults and buffer_local_symbols. */
+
+/* First, try and define DECL_ALIGN(type,var) which declares a static
+ variable VAR of type TYPE with the added requirement that it be
+ TYPEBITS-aligned. */
+#ifndef NO_DECL_ALIGN
+# ifndef DECL_ALIGN
+/* What compiler directive should we use for non-gcc compilers? -stef */
+# if defined (__GNUC__)
+# define DECL_ALIGN(type, var) \
+ type __attribute__ ((__aligned__ (1 << GCTYPEBITS))) var
+# endif
+# endif
+#endif
+
+/* Let's USE_LSB_TAG on systems where we know malloc returns mult-of-8. */
+#if defined GNU_MALLOC || defined DOUG_LEA_MALLOC || defined __GLIBC__ || defined MAC_OSX
+/* We also need to be able to specify mult-of-8 alignment on static vars. */
+# if defined DECL_ALIGN
+/* We currently do not support USE_LSB_TAG with a union Lisp_Object. */
+# if defined NO_UNION_TYPE
+# define USE_LSB_TAG
+# endif
+# endif
+#endif
+
+/* If we cannot use 8-byte alignment, make DECL_ALIGN a no-op. */
+#ifndef DECL_ALIGN
+# ifdef USE_LSB_TAG
+# error "USE_LSB_TAG used without defining DECL_ALIGN"
+# endif
+# define DECL_ALIGN(type, var) type var
+#endif
+
/* Define the fundamental Lisp data structures. */
@@ -194,7 +245,7 @@ union Lisp_Object
{
/* Used for comparing two Lisp_Objects;
also, positive integers can be accessed fast this way. */
- EMACS_INT i;
+ EMACS_UINT i;
struct
{
@@ -216,7 +267,7 @@ union Lisp_Object
{
/* Used for comparing two Lisp_Objects;
also, positive integers can be accessed fast this way. */
- EMACS_INT i;
+ EMACS_UINT i;
struct
{
@@ -247,34 +298,29 @@ LISP_MAKE_RVALUE (Lisp_Object o)
#define LISP_MAKE_RVALUE(o) (o)
#endif
-#endif /* NO_UNION_TYPE */
-
+#else /* NO_UNION_TYPE */
/* If union type is not wanted, define Lisp_Object as just a number. */
-#ifdef NO_UNION_TYPE
typedef EMACS_INT Lisp_Object;
#define LISP_MAKE_RVALUE(o) (0+(o))
#endif /* NO_UNION_TYPE */
-/* Two flags that are set during GC. On some machines, these flags
- are defined differently by the m- file. */
-
/* In the size word of a vector, this bit means the vector has been marked. */
-#ifndef ARRAY_MARK_FLAG
-#define ARRAY_MARK_FLAG ((EMACS_INT) ((EMACS_UINT) 1 << (VALBITS + GCTYPEBITS - 1)))
-#endif /* no ARRAY_MARK_FLAG */
+#define ARRAY_MARK_FLAG ((EMACS_UINT) 1 << (BITS_PER_EMACS_INT - 1))
/* In the size word of a struct Lisp_Vector, this bit means it's really
some other vector-like object. */
-#ifndef PSEUDOVECTOR_FLAG
-#define PSEUDOVECTOR_FLAG ((ARRAY_MARK_FLAG >> 1) & ~ARRAY_MARK_FLAG)
-#endif
+#define PSEUDOVECTOR_FLAG ((ARRAY_MARK_FLAG >> 1))
/* In a pseudovector, the size field actually contains a word with one
PSEUDOVECTOR_FLAG bit set, and exactly one of the following bits to
- indicate the actual type. */
+ indicate the actual type.
+ We use a bitset, even tho only one of the bits can be set at any
+ particular time just so as to be able to use micro-optimizations such as
+ testing membership of a particular subset of pseudovectors in Fequal.
+ It is not crucial, but there are plenty of bits here, so why not do it? */
enum pvec_type
{
PVEC_NORMAL_VECTOR = 0,
@@ -288,8 +334,9 @@ enum pvec_type
PVEC_BOOL_VECTOR = 0x10000,
PVEC_BUFFER = 0x20000,
PVEC_HASH_TABLE = 0x40000,
- PVEC_SUB_CHAR_TABLE = 0x80000,
- PVEC_TYPE_MASK = 0x0ffe00
+ PVEC_TERMINAL = 0x80000,
+ PVEC_SUB_CHAR_TABLE = 0x100000,
+ PVEC_TYPE_MASK = 0x1ffe00
#if 0 /* This is used to make the value of PSEUDOVECTOR_FLAG available to
GDB. It doesn't work on OS Alpha. Moved to a variable in
@@ -309,63 +356,15 @@ enum pvec_type
of bool vectors. This should not vary across implementations. */
#define BOOL_VECTOR_BITS_PER_CHAR 8
-/***** Select the tagging scheme. *****/
-/* There are basically two options that control the tagging scheme:
- - NO_UNION_TYPE says that Lisp_Object should be an integer instead
- of a union.
- - USE_LSB_TAG means that we can assume the least 3 bits of pointers are
- always 0, and we can thus use them to hold tag bits, without
- restricting our addressing space.
-
- If USE_LSB_TAG is not set, then we use the top 3 bits for tagging, thus
- restricting our possible address range. Currently USE_LSB_TAG is not
- allowed together with a union. This is not due to any fundamental
- technical (or political ;-) problem: nobody wrote the code to do it yet.
-
- USE_LSB_TAG not only requires the least 3 bits of pointers returned by
- malloc to be 0 but also needs to be able to impose a mult-of-8 alignment
- on the few static Lisp_Objects used: all the defsubr as well
- as the two special buffers buffer_defaults and buffer_local_symbols. */
-
-/* First, try and define DECL_ALIGN(type,var) which declares a static
- variable VAR of type TYPE with the added requirement that it be
- TYPEBITS-aligned. */
-#ifndef NO_DECL_ALIGN
-# ifndef DECL_ALIGN
-/* What compiler directive should we use for non-gcc compilers? -stef */
-# if defined (__GNUC__)
-# define DECL_ALIGN(type, var) \
- type __attribute__ ((__aligned__ (1 << GCTYPEBITS))) var
-# endif
-# endif
-#endif
-
-/* Let's USE_LSB_TAG on systems where we know malloc returns mult-of-8. */
-#if defined GNU_MALLOC || defined DOUG_LEA_MALLOC || defined __GLIBC__ || defined MAC_OSX
-/* We also need to be able to specify mult-of-8 alignment on static vars. */
-# if defined DECL_ALIGN
-/* We currently do not support USE_LSB_TAG with a union Lisp_Object. */
-# if defined NO_UNION_TYPE
-# define USE_LSB_TAG
-# endif
-# endif
-#endif
-
-/* If we cannot use 8-byte alignment, make DECL_ALIGN a no-op. */
-#ifndef DECL_ALIGN
-# ifdef USE_LSB_TAG
-# error "USE_LSB_TAG used without defining DECL_ALIGN"
-# endif
-# define DECL_ALIGN(type, var) type var
-#endif
-
-
/* These macros extract various sorts of values from a Lisp_Object.
For example, if tem is a Lisp_Object whose type is Lisp_Cons,
XCONS (tem) is the struct Lisp_Cons * pointing to the memory for that cons. */
#ifdef NO_UNION_TYPE
+/* Return a perfect hash of the Lisp_Object representation. */
+#define XHASH(a) (a)
+
#ifdef USE_LSB_TAG
#define TYPEMASK ((((EMACS_INT) 1) << GCTYPEBITS) - 1)
@@ -427,10 +426,10 @@ enum pvec_type
#endif /* not USE_LSB_TAG */
-#define EQ(x, y) ((x) == (y))
-
#else /* not NO_UNION_TYPE */
+#define XHASH(a) ((a).i)
+
#define XTYPE(a) ((enum Lisp_Type) (a).u.type)
/* For integers known to be positive, XFASTINT provides fast retrieval
@@ -459,10 +458,10 @@ enum pvec_type
extern Lisp_Object make_number P_ ((EMACS_INT));
#endif
-#define EQ(x, y) ((x).i == (y).i)
-
#endif /* NO_UNION_TYPE */
+#define EQ(x, y) (XHASH (x) == XHASH (y))
+
#ifndef XPNTR
#ifdef HAVE_SHM
/* In this representation, data is found in two widely separated segments. */
@@ -528,11 +527,12 @@ extern size_t pure_size;
#define XPROCESS(a) (eassert (PROCESSP(a)),(struct Lisp_Process *) XPNTR(a))
#define XWINDOW(a) (eassert (WINDOWP(a)),(struct window *) XPNTR(a))
+#define XTERMINAL(a) (eassert (TERMINALP(a)),(struct terminal *) XPNTR(a))
#define XSUBR(a) (eassert (SUBRP(a)),(struct Lisp_Subr *) XPNTR(a))
#define XBUFFER(a) (eassert (BUFFERP(a)),(struct buffer *) XPNTR(a))
-#define XCHAR_TABLE(a) ((struct Lisp_Char_Table *) XPNTR(a))
-#define XSUB_CHAR_TABLE(a) ((struct Lisp_Sub_Char_Table *) XPNTR(a))
-#define XBOOL_VECTOR(a) ((struct Lisp_Bool_Vector *) XPNTR(a))
+#define XCHAR_TABLE(a) (eassert (CHAR_TABLE_P (a)), (struct Lisp_Char_Table *) XPNTR(a))
+#define XSUB_CHAR_TABLE(a) (eassert (SUB_CHAR_TABLE_P (a)), (struct Lisp_Sub_Char_Table *) XPNTR(a))
+#define XBOOL_VECTOR(a) (eassert (BOOL_VECTOR_P (a)), (struct Lisp_Bool_Vector *) XPNTR(a))
/* Construct a Lisp_Object from a value or address. */
@@ -550,12 +550,16 @@ extern size_t pure_size;
/* Pseudovector types. */
+#define XSETPVECTYPE(v,code) ((v)->size |= PSEUDOVECTOR_FLAG | (code))
#define XSETPSEUDOVECTOR(a, b, code) \
- (XSETVECTOR (a, b), XVECTOR (a)->size |= PSEUDOVECTOR_FLAG | (code))
+ (XSETVECTOR (a, b), \
+ eassert ((XVECTOR (a)->size & (PSEUDOVECTOR_FLAG | PVEC_TYPE_MASK)) \
+ == (PSEUDOVECTOR_FLAG | (code))))
#define XSETWINDOW_CONFIGURATION(a, b) \
(XSETPSEUDOVECTOR (a, b, PVEC_WINDOW_CONFIGURATION))
#define XSETPROCESS(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_PROCESS))
#define XSETWINDOW(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_WINDOW))
+#define XSETTERMINAL(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_TERMINAL))
#define XSETSUBR(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_SUBR))
#define XSETCOMPILED(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_COMPILED))
#define XSETBUFFER(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_BUFFER))
@@ -571,9 +575,9 @@ extern size_t pure_size;
/* Convenience macros for dealing with Lisp strings. */
-#define SREF(string, index) (XSTRING (string)->data[index] + 0)
-#define SSET(string, index, new) (XSTRING (string)->data[index] = (new))
#define SDATA(string) (XSTRING (string)->data + 0)
+#define SREF(string, index) (SDATA (string)[index] + 0)
+#define SSET(string, index, new) (SDATA (string)[index] = (new))
#define SCHARS(string) (XSTRING (string)->size + 0)
#define SBYTES(string) (STRING_BYTES (XSTRING (string)) + 0)
@@ -581,7 +585,7 @@ extern size_t pure_size;
(XSTRING (string)->size = (newsize))
#define STRING_COPYIN(string, index, new, count) \
- bcopy (new, XSTRING (string)->data + index, count)
+ bcopy (new, SDATA (string) + index, count)
/* Type checking. */
@@ -723,7 +727,7 @@ struct Lisp_String
struct Lisp_Vector
{
- EMACS_INT size;
+ EMACS_UINT size;
struct Lisp_Vector *next;
Lisp_Object contents[1];
};
@@ -799,10 +803,10 @@ struct Lisp_Sub_Char_Table;
struct Lisp_Char_Table
{
/* This is the vector's size field, which also holds the
- pseudovector type information. It holds the size, too. The size
- counts the defalt, parent, purpose, ascii, contents, and extras
- slots. */
- EMACS_INT size;
+ pseudovector type information. It holds the size, too.
+ The size counts the defalt, parent, purpose, ascii,
+ contents, and extras slots. */
+ EMACS_UINT size;
struct Lisp_Vector *next;
/* This holds a default value,
@@ -854,10 +858,10 @@ struct Lisp_Bool_Vector
{
/* This is the vector's size field. It doesn't have the real size,
just the subtype information. */
- EMACS_INT vector_size;
+ EMACS_UINT vector_size;
struct Lisp_Vector *next;
/* This is the size in bits. */
- EMACS_INT size;
+ EMACS_UINT size;
/* This contains the actual bits, packed into bytes. */
unsigned char data[1];
};
@@ -872,11 +876,11 @@ struct Lisp_Bool_Vector
struct Lisp_Subr
{
- EMACS_INT size;
+ EMACS_UINT size;
Lisp_Object (*function) ();
short min_args, max_args;
char *symbol_name;
- char *prompt;
+ char *intspec;
char *doc;
};
@@ -983,7 +987,7 @@ struct Lisp_Symbol
struct Lisp_Hash_Table
{
/* Vector fields. The hash table code doesn't refer to these. */
- EMACS_INT size;
+ EMACS_UINT size;
struct Lisp_Vector *vec_next;
/* Function used to compare keys. */
@@ -1002,13 +1006,6 @@ struct Lisp_Hash_Table
ratio, a float. */
Lisp_Object rehash_threshold;
- /* Number of key/value entries in the table. */
- Lisp_Object count;
-
- /* Vector of keys and values. The key of item I is found at index
- 2 * I, the value is found at index 2 * I + 1. */
- Lisp_Object key_and_value;
-
/* Vector of hash codes.. If hash[I] is nil, this means that that
entry I is unused. */
Lisp_Object hash;
@@ -1032,6 +1029,18 @@ struct Lisp_Hash_Table
/* User-supplied key comparison function, or nil. */
Lisp_Object user_cmp_function;
+ /* Only the fields above are traced normally by the GC. The ones below
+ `count'. are special and are either ignored by the GC or traced in
+ a special way (e.g. because of weakness). */
+
+ /* Number of key/value entries in the table. */
+ unsigned int count;
+
+ /* Vector of keys and values. The key of item I is found at index
+ 2 * I, the value is found at index 2 * I + 1.
+ This is gc_marked specially if the table is weak. */
+ Lisp_Object key_and_value;
+
/* Next weak hash table if this is a weak hash table. The head
of the list is in weak_hash_tables. */
struct Lisp_Hash_Table *next_weak;
@@ -1107,8 +1116,16 @@ struct Lisp_Marker
/* 1 means normal insertion at the marker's position
leaves the marker after the inserted text. */
unsigned int insertion_type : 1;
- /* This is the buffer that the marker points into,
- or 0 if it points nowhere. */
+ /* This is the buffer that the marker points into, or 0 if it points nowhere.
+ Note: a chain of markers can contain markers pointing into different
+ buffers (the chain is per buffer_text rather than per buffer, so it's
+ shared between indirect buffers). */
+ /* This is used for (other than NULL-checking):
+ - Fmarker_buffer
+ - Fset_marker: check eq(oldbuf, newbuf) to avoid unchain+rechain.
+ - unchain_marker: to find the list from which to unchain.
+ - Fkill_buffer: to unchain the markers of current indirect buffer.
+ */
struct buffer *buffer;
/* The remaining fields are meaningless in a marker that
@@ -1116,6 +1133,8 @@ struct Lisp_Marker
/* For markers that point somewhere,
this is used to chain of all the markers in a given buffer. */
+ /* We could remove it and use an array in buffer_text instead.
+ That would also allow to preserve it ordered. */
struct Lisp_Marker *next;
/* This is the char position where the marker points. */
EMACS_INT charpos;
@@ -1213,6 +1232,10 @@ struct Lisp_Buffer_Local_Value
unsigned int found_for_frame : 1;
Lisp_Object realvalue;
/* The buffer and frame for which the loaded binding was found. */
+ /* Having both is only needed if we want to allow variables that are
+ both buffer local and frame local (in which case, we currently give
+ precedence to the buffer-local binding). I don't think such
+ a combination is desirable. --Stef */
Lisp_Object buffer, frame;
/* A cons cell, (LOADED-BINDING . DEFAULT-VALUE).
@@ -1364,34 +1387,6 @@ typedef unsigned char UCHAR;
We need one more byte for string terminator `\0'. */
#define KEY_DESCRIPTION_SIZE ((2 * 6) + 1 + (CHARACTERBITS / 3) + 1 + 1)
-#ifdef USE_X_TOOLKIT
-#ifdef NO_UNION_TYPE
-/* Use this for turning a (void *) into a Lisp_Object, as when the
- Lisp_Object is passed into a toolkit callback function. */
-#define VOID_TO_LISP(larg,varg) \
- do { ((larg) = ((Lisp_Object) (varg))); } while (0)
-#define CVOID_TO_LISP VOID_TO_LISP
-
-/* Use this for turning a Lisp_Object into a (void *), as when the
- Lisp_Object is passed into a toolkit callback function. */
-#define LISP_TO_VOID(larg) ((void *) (larg))
-#define LISP_TO_CVOID(varg) ((const void *) (larg))
-
-#else /* not NO_UNION_TYPE */
-/* Use this for turning a (void *) into a Lisp_Object, as when the
- Lisp_Object is passed into a toolkit callback function. */
-#define VOID_TO_LISP(larg,varg) \
- do { ((larg).v = (void *) (varg)); } while (0)
-#define CVOID_TO_LISP(larg,varg) \
- do { ((larg).cv = (const void *) (varg)); } while (0)
-
-/* Use this for turning a Lisp_Object into a (void *), as when the
- Lisp_Object is passed into a toolkit callback function. */
-#define LISP_TO_VOID(larg) ((larg).v)
-#define LISP_TO_CVOID(larg) ((larg).cv)
-#endif /* not NO_UNION_TYPE */
-#endif /* USE_X_TOOLKIT */
-
/* The glyph datatype, used to represent characters on the display. */
@@ -1471,6 +1466,7 @@ typedef unsigned char UCHAR;
#define WINDOW_CONFIGURATIONP(x) PSEUDOVECTORP (x, PVEC_WINDOW_CONFIGURATION)
#define PROCESSP(x) PSEUDOVECTORP (x, PVEC_PROCESS)
#define WINDOWP(x) PSEUDOVECTORP (x, PVEC_WINDOW)
+#define TERMINALP(x) PSEUDOVECTORP (x, PVEC_TERMINAL)
#define SUBRP(x) PSEUDOVECTORP (x, PVEC_SUBR)
#define COMPILEDP(x) PSEUDOVECTORP (x, PVEC_COMPILED)
#define BUFFERP(x) PSEUDOVECTORP (x, PVEC_BUFFER)
@@ -1628,30 +1624,33 @@ typedef unsigned char UCHAR;
followed by the address of a vector of Lisp_Objects
which contains the argument values.
UNEVALLED means pass the list of unevaluated arguments
- `prompt' says how to read arguments for an interactive call.
- See the doc string for `interactive'.
+ `intspec' says how interactive arguments are to be fetched.
+ If the string starts with a `(', `intspec' is evaluated and the resulting
+ list is the list of arguments.
+ If it's a string that doesn't start with `(', the value should follow
+ the one of the doc string for `interactive'.
A null string means call interactively with no arguments.
`doc' is documentation for the user. */
#if (!defined (__STDC__) && !defined (PROTOTYPES)) \
|| defined (USE_NONANSI_DEFUN)
-#define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \
+#define DEFUN(lname, fnname, sname, minargs, maxargs, intspec, doc) \
Lisp_Object fnname (); \
DECL_ALIGN (struct Lisp_Subr, sname) = \
{ PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \
- fnname, minargs, maxargs, lname, prompt, 0}; \
+ fnname, minargs, maxargs, lname, intspec, 0}; \
Lisp_Object fnname
#else
/* This version of DEFUN declares a function prototype with the right
arguments, so we can catch errors with maxargs at compile-time. */
-#define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \
+#define DEFUN(lname, fnname, sname, minargs, maxargs, intspec, doc) \
Lisp_Object fnname DEFUN_ARGS_ ## maxargs ; \
DECL_ALIGN (struct Lisp_Subr, sname) = \
{ PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \
- fnname, minargs, maxargs, lname, prompt, 0}; \
+ fnname, minargs, maxargs, lname, intspec, 0}; \
Lisp_Object fnname
/* Note that the weird token-substitution semantics of ANSI C makes
@@ -1692,7 +1691,6 @@ extern void defvar_lisp P_ ((char *, Lisp_Object *));
extern void defvar_lisp_nopro P_ ((char *, Lisp_Object *));
extern void defvar_bool P_ ((char *, int *));
extern void defvar_int P_ ((char *, EMACS_INT *));
-extern void defvar_per_buffer P_ ((char *, Lisp_Object *, Lisp_Object, char *));
extern void defvar_kboard P_ ((char *, int));
/* Macros we use to define forwarded Lisp variables.
@@ -1703,15 +1701,6 @@ extern void defvar_kboard P_ ((char *, int));
#define DEFVAR_BOOL(lname, vname, doc) defvar_bool (lname, vname)
#define DEFVAR_INT(lname, vname, doc) defvar_int (lname, vname)
-/* TYPE is nil for a general Lisp variable.
- An integer specifies a type; then only LIsp values
- with that type code are allowed (except that nil is allowed too).
- LNAME is the LIsp-level variable name.
- VNAME is the name of the buffer slot.
- DOC is a dummy where you write the doc string as a comment. */
-#define DEFVAR_PER_BUFFER(lname, vname, type, doc) \
- defvar_per_buffer (lname, vname, type, 0)
-
#define DEFVAR_KBOARD(lname, vname, doc) \
defvar_kboard (lname, \
(int)((char *)(&current_kboard->vname) \
@@ -2558,6 +2547,7 @@ extern struct Lisp_Hash_Table *allocate_hash_table P_ ((void));
extern struct window *allocate_window P_ ((void));
extern struct frame *allocate_frame P_ ((void));
extern struct Lisp_Process *allocate_process P_ ((void));
+extern struct terminal *allocate_terminal P_ ((void));
extern int gc_in_progress;
extern int abort_on_gc;
extern Lisp_Object make_float P_ ((double));
@@ -2979,6 +2969,10 @@ extern Lisp_Object Qvertical_scroll_bar;
extern void discard_mouse_events P_ ((void));
EXFUN (Fevent_convert_list, 1);
EXFUN (Fread_key_sequence, 5);
+EXFUN (Fset_input_interrupt_mode, 1);
+EXFUN (Fset_output_flow_control, 2);
+EXFUN (Fset_input_meta_mode, 2);
+EXFUN (Fset_quit_char, 1);
EXFUN (Fset_input_mode, 4);
extern int detect_input_pending P_ ((void));
extern int detect_input_pending_ignore_squeezables P_ ((void));
@@ -2992,6 +2986,7 @@ extern void init_keyboard P_ ((void));
extern void syms_of_keyboard P_ ((void));
extern void keys_of_keyboard P_ ((void));
extern char *push_key_description P_ ((unsigned int, char *, int));
+extern void add_user_signal P_ ((int sig, const char *name));
/* defined in indent.c */
@@ -3034,6 +3029,7 @@ EXFUN (Fvisible_frame_list, 0);
EXFUN (Fframe_parameter, 2);
EXFUN (Fframe_parameters, 1);
EXFUN (Fmodify_frame_parameters, 2);
+EXFUN (Fframe_with_environment, 1);
EXFUN (Fset_frame_height, 3);
EXFUN (Fset_frame_width, 3);
EXFUN (Fset_frame_size, 3);
@@ -3102,7 +3098,7 @@ EXFUN (Fcall_process, MANY);
extern int child_setup P_ ((int, int, int, char **, int, Lisp_Object));
extern void init_callproc_1 P_ ((void));
extern void init_callproc P_ ((void));
-extern void set_process_environment P_ ((void));
+extern void set_initial_environment P_ ((void));
extern void syms_of_callproc P_ ((void));
/* defined in doc.c */
@@ -3165,28 +3161,31 @@ EXFUN (Fx_popup_menu, 2);
EXFUN (Fx_popup_dialog, 3);
extern void syms_of_xmenu P_ ((void));
+/* defined in termchar.h */
+struct tty_display_info;
+
+/* defined in termhooks.h */
+struct terminal;
+
/* defined in sysdep.c */
#ifndef HAVE_GET_CURRENT_DIR_NAME
extern char *get_current_dir_name P_ ((void));
#endif
extern void stuff_char P_ ((char c));
extern void init_sigio P_ ((int));
-extern void request_sigio P_ ((void));
-extern void unrequest_sigio P_ ((void));
-extern void reset_sys_modes P_ ((void));
extern void sys_subshell P_ ((void));
extern void sys_suspend P_ ((void));
extern void discard_tty_input P_ ((void));
-extern void init_sys_modes P_ ((void));
-extern void get_frame_size P_ ((int *, int *));
+extern void init_sys_modes P_ ((struct tty_display_info *));
+extern void reset_sys_modes P_ ((struct tty_display_info *));
+extern void init_all_sys_modes P_ ((void));
+extern void reset_all_sys_modes P_ ((void));
extern void wait_for_termination P_ ((int));
extern void flush_pending_output P_ ((int));
extern void child_setup_tty P_ ((int));
extern void setup_pty P_ ((int));
extern int set_window_size P_ ((int, int, int));
extern void create_process P_ ((Lisp_Object, char **, Lisp_Object));
-extern int tabs_safe_p P_ ((void));
-extern void init_baud_rate P_ ((void));
extern int emacs_open P_ ((const char *, int, int));
extern int emacs_close P_ ((int));
extern int emacs_read P_ ((int, char *, unsigned int));
@@ -3222,6 +3221,9 @@ extern void syms_of_dired P_ ((void));
extern void syms_of_term P_ ((void));
extern void fatal () NO_RETURN;
+/* Defined in terminal.c */
+extern void syms_of_terminal P_ ((void));
+
#ifdef HAVE_WINDOW_SYSTEM
/* Defined in fontset.c */
extern void syms_of_fontset P_ ((void));
@@ -3367,6 +3369,11 @@ extern Lisp_Object Vdirectory_sep_char;
#define min(a, b) ((a) < (b) ? (a) : (b))
#define max(a, b) ((a) > (b) ? (a) : (b))
+/* Make sure we have abs defined */
+#if !defined(abs)
+#define abs(x) ((x) < 0 ? -(x) : (x))
+#endif
+
/* Return a fixnum or float, depending on whether VAL fits in a Lisp
fixnum. */
diff --git a/src/lread.c b/src/lread.c
index 6bec084c5c..bccdf28b05 100644
--- a/src/lread.c
+++ b/src/lread.c
@@ -27,6 +27,7 @@ Boston, MA 02110-1301, USA. */
#include <sys/stat.h>
#include <sys/file.h>
#include <errno.h>
+#include <setjmp.h>
#include "lisp.h"
#include "intervals.h"
#include "buffer.h"
@@ -36,6 +37,7 @@ Boston, MA 02110-1301, USA. */
#include <epaths.h>
#include "commands.h"
#include "keyboard.h"
+#include "frame.h"
#include "termhooks.h"
#include "coding.h"
#include "blockinput.h"
@@ -627,8 +629,6 @@ static void substitute_in_interval P_ ((INTERVAL, Lisp_Object));
/* Get a character from the tty. */
-extern Lisp_Object read_char ();
-
/* Read input events until we get one that's acceptable for our purposes.
If NO_SWITCH_FRAME is non-zero, switch-frame events are stashed
@@ -680,10 +680,12 @@ read_filtered_event (no_switch_frame, ascii_required, error_nonascii,
EMACS_ADD_TIME (end_time, end_time, wait_time);
}
- /* Read until we get an acceptable event. */
+/* Read until we get an acceptable event. */
retry:
- val = read_char (0, 0, 0, (input_method ? Qnil : Qt), 0,
- NUMBERP (seconds) ? &end_time : NULL);
+ do
+ val = read_char (0, 0, 0, (input_method ? Qnil : Qt), 0,
+ NUMBERP (seconds) ? &end_time : NULL);
+ while (INTEGERP (val) && XINT (val) == -2); /* wrong_kboard_jmpbuf */
if (BUFFERP (val))
goto retry;
@@ -824,7 +826,7 @@ DEFUN ("get-file-char", Fget_file_char, Sget_file_char, 0, 0, 0,
/* Value is a version number of byte compiled code if the file
- asswociated with file descriptor FD is a compiled Lisp file that's
+ associated with file descriptor FD is a compiled Lisp file that's
safe to load. Only files compiled with Emacs are safe to load.
Files compiled with XEmacs can lead to a crash in Fbyte_code
because of an incompatible change in the byte compiler. */
@@ -890,7 +892,7 @@ load_warn_old_style_backquotes (file)
if (!NILP (Vold_style_backquotes))
{
Lisp_Object args[2];
- args[0] = build_string ("!! File %s uses old-style backquotes !!");
+ args[0] = build_string ("Loading `%s': old-style backquotes detected!");
args[1] = file;
Fmessage (2, args);
}
@@ -923,7 +925,7 @@ DEFUN ("load", Fload, Sload, 1, 5, 0,
doc: /* Execute a file of Lisp code named FILE.
First try FILE with `.elc' appended, then try with `.el',
then try FILE unmodified (the exact suffixes in the exact order are
-determined by `load-suffixes'). Environment variable references in
+determined by `load-suffixes'). Environment variable references in
FILE are replaced with their values by calling `substitute-in-file-name'.
This function searches the directories in `load-path'.
@@ -1098,7 +1100,7 @@ Return t if the file exists and loads successfully. */)
version = -1;
- /* Check fore the presence of old-style quotes and warn about them. */
+ /* Check for the presence of old-style quotes and warn about them. */
specbind (Qold_style_backquotes, Qnil);
record_unwind_protect (load_warn_old_style_backquotes, file);
@@ -2832,7 +2834,7 @@ read1 (readcharfun, pch, first_in_list)
}
default:
default_label:
- if (c <= 040) goto retry;
+ if (c <= 040) goto retry;
if (c == 0x8a0) /* NBSP */
goto retry;
{
@@ -3802,6 +3804,7 @@ defsubr (sname)
{
Lisp_Object sym;
sym = intern (sname->symbol_name);
+ XSETPVECTYPE (sname, PVEC_SUBR);
XSETSUBR (XSYMBOL (sym)->function, sname);
}
@@ -3876,37 +3879,6 @@ defvar_lisp (namestring, address)
staticpro (address);
}
-/* Similar but define a variable whose value is the Lisp Object stored in
- the current buffer. address is the address of the slot in the buffer
- that is current now. */
-
-void
-defvar_per_buffer (namestring, address, type, doc)
- char *namestring;
- Lisp_Object *address;
- Lisp_Object type;
- char *doc;
-{
- Lisp_Object sym, val;
- int offset;
-
- sym = intern (namestring);
- val = allocate_misc ();
- offset = (char *)address - (char *)current_buffer;
-
- XMISCTYPE (val) = Lisp_Misc_Buffer_Objfwd;
- XBUFFER_OBJFWD (val)->offset = offset;
- SET_SYMBOL_VALUE (sym, val);
- PER_BUFFER_SYMBOL (offset) = sym;
- PER_BUFFER_TYPE (offset) = type;
-
- if (PER_BUFFER_IDX (offset) == 0)
- /* Did a DEFVAR_PER_BUFFER without initializing the corresponding
- slot of buffer_local_flags */
- abort ();
-}
-
-
/* Similar but define a variable whose value is the Lisp Object stored
at a particular offset in the current kboard object. */
@@ -4003,7 +3975,7 @@ init_lread ()
Vload_path = Fcons (tem, Vload_path);
}
- /* Add site-list under the installation dir, if it exists. */
+ /* Add site-lisp under the installation dir, if it exists. */
tem = Fexpand_file_name (build_string ("site-lisp"),
Vinstallation_directory);
tem1 = Ffile_exists_p (tem);
@@ -4063,7 +4035,7 @@ init_lread ()
/* NORMAL refers to the lisp dir in the source directory. */
/* We used to add ../lisp at the front here, but
that caused trouble because it was copied from dump_path
- into Vload_path, aboe, when Vinstallation_directory was non-nil.
+ into Vload_path, above, when Vinstallation_directory was non-nil.
It should be unnecessary. */
Vload_path = decode_env_path (0, normal);
dump_path = Vload_path;
@@ -4122,7 +4094,7 @@ init_lread ()
}
/* Print a warning, using format string FORMAT, that directory DIRNAME
- does not exist. Print it on stderr and put it in *Message*. */
+ does not exist. Print it on stderr and put it in *Messages*. */
void
dir_warning (format, dirname)
diff --git a/src/m/ibms390x.h b/src/m/ibms390x.h
index 64ede365d0..0dafe59000 100644
--- a/src/m/ibms390x.h
+++ b/src/m/ibms390x.h
@@ -22,7 +22,7 @@ Boston, MA 02110-1301, USA. */
into ibms390.h. */
-/* The following line tells the configuration script what sort of
+/* The following line tells the configuration script what sort of
operating system this machine is likely to run.
USUAL-OPSYS="<name of system .h file here, without the s- or .h>"
@@ -97,14 +97,10 @@ NOTE-END */
#define VIRT_ADDR_VARIES
-/* Define C_ALLOCA if this machine does not support a true alloca
- and the one written in C should be used instead.
- Define HAVE_ALLOCA to say that the system provides a properly
- working alloca function and it should be used.
- Define neither one if an assembler-language alloca
- in the file alloca.s should be used. */
+/* Define HAVE_ALLOCA to say that the system provides a properly
+ working alloca function and it should be used. Undefine it if an
+ assembler-language alloca in the file alloca.s should be used. */
-#undef C_ALLOCA
#define HAVE_ALLOCA
/* Define NO_REMAP if memory segmentation makes it not work well
@@ -144,11 +140,6 @@ NOTE-END */
#define VALBITS 60
-/* This definition of MARKBIT is necessary because of the comparison of
- ARRAY_MARK_FLAG and MARKBIT in an #if in lisp.h, which cpp doesn't like. */
-
-#define MARKBIT 0x8000000000000000L
-
#define LINKER $(CC) -nostdlib
/* Define XINT and XUINT so that they can take arguments of type int */
diff --git a/src/m/sh3el.h b/src/m/sh3el.h
index eefcccea6d..77f6dc12c2 100644
--- a/src/m/sh3el.h
+++ b/src/m/sh3el.h
@@ -19,7 +19,7 @@ the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
-/* The following line tells the configuration script what sort of
+/* The following line tells the configuration script what sort of
operating system this machine is likely to run.
USUAL-OPSYS="<name of system .h file here, without the s- or .h>" */
@@ -79,14 +79,11 @@ Boston, MA 02111-1307, USA. */
#define VIRT_ADDR_VARIES
-/* Define C_ALLOCA if this machine does not support a true alloca
- and the one written in C should be used instead.
- Define HAVE_ALLOCA to say that the system provides a properly
+/* Define HAVE_ALLOCA to say that the system provides a properly
working alloca function and it should be used.
- Define neither one if an assembler-language alloca
+ Undefine it if an assembler-language alloca
in the file alloca.s should be used. */
-/* #define C_ALLOCA */
#define HAVE_ALLOCA
/* Define NO_REMAP if memory segmentation makes it not work well
diff --git a/src/macfns.c b/src/macfns.c
index 2cfdc9f17c..71eae699f9 100644
--- a/src/macfns.c
+++ b/src/macfns.c
@@ -107,7 +107,6 @@ extern Lisp_Object Vwindow_system_version;
int image_cache_refcount, dpyinfo_refcount;
#endif
-
#if 0 /* Use xstricmp instead. */
/* compare two strings ignoring case */
@@ -1367,11 +1366,11 @@ x_set_mouse_color (f, arg, oldval)
Cursor cursor, nontext_cursor, mode_cursor, hand_cursor;
Cursor hourglass_cursor, horizontal_drag_cursor;
unsigned long pixel = x_decode_color (f, arg, BLACK_PIX_DEFAULT (f));
- unsigned long mask_color = x->background_pixel;
+ unsigned long mask_color = FRAME_BACKGROUND_PIXEL (f);
/* Don't let pointers be invisible. */
if (mask_color == pixel)
- pixel = x->foreground_pixel;
+ pixel = FRAME_FOREGROUND_PIXEL (f);
f->output_data.mac->mouse_pixel = pixel;
@@ -1444,7 +1443,7 @@ x_set_mouse_color (f, arg, oldval)
BLOCK_INPUT;
if (FRAME_MAC_WINDOW (f) != 0)
- rif->define_frame_cursor (f, cursor);
+ FRAME_TERMINAL (f)->rif->define_frame_cursor (f, cursor);
f->output_data.mac->text_cursor = cursor;
f->output_data.mac->nontext_cursor = nontext_cursor;
@@ -1724,10 +1723,8 @@ x_set_tool_bar_lines (f, value, oldval)
below the menu bar. */
if (FRAME_MAC_WINDOW (f) && FRAME_TOOL_BAR_LINES (f) == 0)
{
- updating_frame = f;
- clear_frame ();
+ clear_frame (f);
clear_current_matrices (f);
- updating_frame = NULL;
}
/* If the tool bar gets smaller, the internal border below it
@@ -2253,8 +2250,10 @@ XParseGeometry (string, x, y, width, height)
/* Create and set up the Mac window for frame F. */
static void
-mac_window (f)
+mac_window (f, window_prompting, minibuffer_only)
struct frame *f;
+ long window_prompting;
+ int minibuffer_only;
{
Rect r;
@@ -2427,8 +2426,8 @@ x_make_gc (f)
= (XCreatePixmapFromBitmapData
(FRAME_X_DISPLAY (f), FRAME_X_DISPLAY_INFO (f)->root_window,
gray_bits, gray_width, gray_height,
- f->output_data.x->foreground_pixel,
- f->output_data.x->background_pixel,
+ FRAME_FOREGROUND_PIXEL (f),
+ FRAME_BACKGROUND_PIXEL (f),
DefaultDepth (FRAME_X_DISPLAY (f), FRAME_X_SCREEN_NUMBER (f))));
#endif
@@ -2523,15 +2522,15 @@ DEFUN ("x-create-frame", Fx_create_frame, Sx_create_frame,
1, 1, 0,
doc: /* Make a new window, which is called a "frame" in Emacs terms.
Returns an Emacs frame object.
-ALIST is an alist of frame parameters.
+PARAMETERS is an alist of frame parameters.
If the parameters specify that the frame should not have a minibuffer,
and do not specify a specific minibuffer window to use,
then `default-minibuffer-frame' must be a frame whose minibuffer can
be shared by the new frame.
This function is an internal primitive--use `make-frame' instead. */)
- (parms)
- Lisp_Object parms;
+ (parameters)
+ Lisp_Object parameters;
{
struct frame *f;
Lisp_Object frame, tem;
@@ -2548,23 +2547,21 @@ This function is an internal primitive--use `make-frame' instead. */)
check_mac ();
- parms = Fcopy_alist (parms);
-
/* Use this general default value to start with
until we know if this frame has a specified name. */
Vx_resource_name = Vinvocation_name;
- display = mac_get_arg (parms, Qdisplay, 0, 0, RES_TYPE_STRING);
+ display = mac_get_arg (parameters, Qdisplay, 0, 0, RES_TYPE_STRING);
if (EQ (display, Qunbound))
display = Qnil;
dpyinfo = check_x_display_info (display);
#ifdef MULTI_KBOARD
- kb = dpyinfo->kboard;
+ kb = dpyinfo->terminal->kboard;
#else
kb = &the_only_kboard;
#endif
- name = mac_get_arg (parms, Qname, "name", "Name", RES_TYPE_STRING);
+ name = mac_get_arg (parameters, Qname, "name", "Name", RES_TYPE_STRING);
if (!STRINGP (name)
&& ! EQ (name, Qunbound)
&& ! NILP (name))
@@ -2574,7 +2571,7 @@ This function is an internal primitive--use `make-frame' instead. */)
Vx_resource_name = name;
/* See if parent window is specified. */
- parent = mac_get_arg (parms, Qparent_id, NULL, NULL, RES_TYPE_NUMBER);
+ parent = mac_get_arg (parameters, Qparent_id, NULL, NULL, RES_TYPE_NUMBER);
if (EQ (parent, Qunbound))
parent = Qnil;
if (! NILP (parent))
@@ -2584,8 +2581,8 @@ This function is an internal primitive--use `make-frame' instead. */)
/* No need to protect DISPLAY because that's not used after passing
it to make_frame_without_minibuffer. */
frame = Qnil;
- GCPRO4 (parms, parent, name, frame);
- tem = mac_get_arg (parms, Qminibuffer, "minibuffer", "Minibuffer",
+ GCPRO4 (parameters, parent, name, frame);
+ tem = mac_get_arg (parameters, Qminibuffer, "minibuffer", "Minibuffer",
RES_TYPE_SYMBOL);
if (EQ (tem, Qnone) || NILP (tem))
f = make_frame_without_minibuffer (Qnil, kb, display);
@@ -2604,20 +2601,24 @@ This function is an internal primitive--use `make-frame' instead. */)
/* Note that X Windows does support scroll bars. */
FRAME_CAN_HAVE_SCROLL_BARS (f) = 1;
+ f->terminal = dpyinfo->terminal;
+ f->terminal->reference_count++;
+
f->output_method = output_mac;
f->output_data.mac = (struct mac_output *) xmalloc (sizeof (struct mac_output));
bzero (f->output_data.mac, sizeof (struct mac_output));
FRAME_FONTSET (f) = -1;
+ record_unwind_protect (unwind_create_frame, frame);
f->icon_name
- = mac_get_arg (parms, Qicon_name, "iconName", "Title", RES_TYPE_STRING);
+ = mac_get_arg (parameters, Qicon_name, "iconName", "Title", RES_TYPE_STRING);
if (! STRINGP (f->icon_name))
f->icon_name = Qnil;
-/* FRAME_MAC_DISPLAY_INFO (f) = dpyinfo; */
+ /* XXX Is this needed? */
+ /*FRAME_MAC_DISPLAY_INFO (f) = dpyinfo;*/
/* With FRAME_MAC_DISPLAY_INFO set up, this unwind-protect is safe. */
- record_unwind_protect (unwind_create_frame, frame);
#if GLYPH_DEBUG
image_cache_refcount = FRAME_X_IMAGE_CACHE (f)->refcount;
dpyinfo_refcount = dpyinfo->reference_count;
@@ -2659,7 +2660,7 @@ This function is an internal primitive--use `make-frame' instead. */)
{
Lisp_Object font;
- font = mac_get_arg (parms, Qfont, "font", "Font", RES_TYPE_STRING);
+ font = mac_get_arg (parameters, Qfont, "font", "Font", RES_TYPE_STRING);
BLOCK_INPUT;
/* First, try whatever font the caller has specified. */
@@ -2671,7 +2672,6 @@ This function is an internal primitive--use `make-frame' instead. */)
else
font = x_new_font (f, SDATA (font));
}
-
/* Try out a font which we hope has bold and italic variations. */
#if USE_ATSUI
if (! STRINGP (font))
@@ -2690,48 +2690,50 @@ This function is an internal primitive--use `make-frame' instead. */)
error ("Cannot find any usable font");
UNBLOCK_INPUT;
- x_set_frame_parameters (f, Fcons (Fcons (Qfont, font), Qnil));
+ x_default_parameter (f, parameters, Qfont, font,
+ "font", "Font", RES_TYPE_STRING);
}
- x_default_parameter (f, parms, Qborder_width, make_number (0),
+ /* XXX Shouldn't this be borderWidth, not borderwidth ?*/
+ x_default_parameter (f, parameters, Qborder_width, make_number (0),
"borderwidth", "BorderWidth", RES_TYPE_NUMBER);
/* This defaults to 2 in order to match xterm. We recognize either
internalBorderWidth or internalBorder (which is what xterm calls
it). */
- if (NILP (Fassq (Qinternal_border_width, parms)))
+ if (NILP (Fassq (Qinternal_border_width, parameters)))
{
Lisp_Object value;
- value = mac_get_arg (parms, Qinternal_border_width,
+ value = mac_get_arg (parameters, Qinternal_border_width,
"internalBorder", "InternalBorder", RES_TYPE_NUMBER);
if (! EQ (value, Qunbound))
- parms = Fcons (Fcons (Qinternal_border_width, value),
- parms);
+ parameters = Fcons (Fcons (Qinternal_border_width, value),
+ parameters);
}
/* Default internalBorderWidth to 0 on Windows to match other programs. */
- x_default_parameter (f, parms, Qinternal_border_width, make_number (0),
+ x_default_parameter (f, parameters, Qinternal_border_width, make_number (0),
"internalBorderWidth", "InternalBorder", RES_TYPE_NUMBER);
- x_default_parameter (f, parms, Qvertical_scroll_bars, Qright,
+ x_default_parameter (f, parameters, Qvertical_scroll_bars, Qright,
"verticalScrollBars", "ScrollBars", RES_TYPE_SYMBOL);
/* Also do the stuff which must be set before the window exists. */
- x_default_parameter (f, parms, Qforeground_color, build_string ("black"),
+ x_default_parameter (f, parameters, Qforeground_color, build_string ("black"),
"foreground", "Foreground", RES_TYPE_STRING);
- x_default_parameter (f, parms, Qbackground_color, build_string ("white"),
+ x_default_parameter (f, parameters, Qbackground_color, build_string ("white"),
"background", "Background", RES_TYPE_STRING);
- x_default_parameter (f, parms, Qmouse_color, build_string ("black"),
+ x_default_parameter (f, parameters, Qmouse_color, build_string ("black"),
"pointerColor", "Foreground", RES_TYPE_STRING);
- x_default_parameter (f, parms, Qcursor_color, build_string ("black"),
+ x_default_parameter (f, parameters, Qcursor_color, build_string ("black"),
"cursorColor", "Foreground", RES_TYPE_STRING);
- x_default_parameter (f, parms, Qborder_color, build_string ("black"),
+ x_default_parameter (f, parameters, Qborder_color, build_string ("black"),
"borderColor", "BorderColor", RES_TYPE_STRING);
- x_default_parameter (f, parms, Qscreen_gamma, Qnil,
+ x_default_parameter (f, parameters, Qscreen_gamma, Qnil,
"screenGamma", "ScreenGamma", RES_TYPE_FLOAT);
- x_default_parameter (f, parms, Qline_spacing, Qnil,
+ x_default_parameter (f, parameters, Qline_spacing, Qnil,
"lineSpacing", "LineSpacing", RES_TYPE_NUMBER);
- x_default_parameter (f, parms, Qleft_fringe, Qnil,
+ x_default_parameter (f, parameters, Qleft_fringe, Qnil,
"leftFringe", "LeftFringe", RES_TYPE_NUMBER);
- x_default_parameter (f, parms, Qright_fringe, Qnil,
+ x_default_parameter (f, parameters, Qright_fringe, Qnil,
"rightFringe", "RightFringe", RES_TYPE_NUMBER);
@@ -2743,29 +2745,29 @@ This function is an internal primitive--use `make-frame' instead. */)
happen. */
init_frame_faces (f);
- x_default_parameter (f, parms, Qmenu_bar_lines, make_number (1),
+ x_default_parameter (f, parameters, Qmenu_bar_lines, make_number (1),
"menuBar", "MenuBar", RES_TYPE_NUMBER);
- x_default_parameter (f, parms, Qtool_bar_lines, make_number (1),
- "toolBar", "ToolBar", RES_TYPE_NUMBER);
- x_default_parameter (f, parms, Qbuffer_predicate, Qnil,
- "bufferPredicate", "BufferPredicate",
- RES_TYPE_SYMBOL);
- x_default_parameter (f, parms, Qtitle, Qnil,
+ x_default_parameter (f, parameters, Qtool_bar_lines, make_number (1),
+ "toolBar", "ToolBar", RES_TYPE_NUMBER);
+
+ x_default_parameter (f, parameters, Qbuffer_predicate, Qnil,
+ "bufferPredicate", "BufferPredicate", RES_TYPE_SYMBOL);
+ x_default_parameter (f, parameters, Qtitle, Qnil,
"title", "Title", RES_TYPE_STRING);
- x_default_parameter (f, parms, Qfullscreen, Qnil,
+ x_default_parameter (f, parameters, Qfullscreen, Qnil,
"fullscreen", "Fullscreen", RES_TYPE_SYMBOL);
f->output_data.mac->parent_desc = FRAME_MAC_DISPLAY_INFO (f)->root_window;
/* Compute the size of the window. */
- window_prompting = x_figure_window_size (f, parms, 1);
+ window_prompting = x_figure_window_size (f, parameters, 1);
- tem = mac_get_arg (parms, Qunsplittable, 0, 0, RES_TYPE_BOOLEAN);
+ tem = mac_get_arg (parameters, Qunsplittable, 0, 0, RES_TYPE_BOOLEAN);
f->no_split = minibuffer_only || EQ (tem, Qt);
- mac_window (f);
+ mac_window (f, window_prompting, minibuffer_only);
+ x_icon (f, parameters);
- x_icon (f, parms);
x_make_gc (f);
/* Now consider the frame official. */
@@ -2774,18 +2776,17 @@ This function is an internal primitive--use `make-frame' instead. */)
/* We need to do this after creating the window, so that the
icon-creation functions can say whose icon they're describing. */
- x_default_parameter (f, parms, Qicon_type, Qnil,
+ x_default_parameter (f, parameters, Qicon_type, Qnil,
"bitmapIcon", "BitmapIcon", RES_TYPE_SYMBOL);
- x_default_parameter (f, parms, Qauto_raise, Qnil,
+ x_default_parameter (f, parameters, Qauto_raise, Qnil,
"autoRaise", "AutoRaiseLower", RES_TYPE_BOOLEAN);
- x_default_parameter (f, parms, Qauto_lower, Qnil,
+ x_default_parameter (f, parameters, Qauto_lower, Qnil,
"autoLower", "AutoRaiseLower", RES_TYPE_BOOLEAN);
- x_default_parameter (f, parms, Qcursor_type, Qbox,
+ x_default_parameter (f, parameters, Qcursor_type, Qbox,
"cursorType", "CursorType", RES_TYPE_SYMBOL);
- x_default_parameter (f, parms, Qscroll_bar_width, Qnil,
- "scrollBarWidth", "ScrollBarWidth",
- RES_TYPE_NUMBER);
+ x_default_parameter (f, parameters, Qscroll_bar_width, Qnil,
+ "scrollBarWidth", "ScrollBarWidth", RES_TYPE_NUMBER);
/* Dimensions, especially FRAME_LINES (f), must be done via change_frame_size.
Change will not be effected unless different from the current
@@ -2793,8 +2794,8 @@ This function is an internal primitive--use `make-frame' instead. */)
width = FRAME_COLS (f);
height = FRAME_LINES (f);
- SET_FRAME_COLS (f, 0);
FRAME_LINES (f) = 0;
+ SET_FRAME_COLS (f, 0);
change_frame_size (f, height, width, 1, 0, 0);
/* Tell the server what size and position, etc, we want, and how
@@ -2811,7 +2812,7 @@ This function is an internal primitive--use `make-frame' instead. */)
{
Lisp_Object visibility;
- visibility = mac_get_arg (parms, Qvisibility, 0, 0, RES_TYPE_SYMBOL);
+ visibility = mac_get_arg (parameters, Qvisibility, 0, 0, RES_TYPE_SYMBOL);
if (EQ (visibility, Qunbound))
visibility = Qt;
@@ -2833,10 +2834,12 @@ This function is an internal primitive--use `make-frame' instead. */)
/* All remaining specified parameters, which have not been "used"
by x_get_arg and friends, now go in the misc. alist of the frame. */
- for (tem = parms; !NILP (tem); tem = XCDR (tem))
+ for (tem = parameters; !NILP (tem); tem = XCDR (tem))
if (CONSP (XCAR (tem)) && !NILP (XCAR (XCAR (tem))))
f->param_alist = Fcons (XCAR (tem), f->param_alist);
+ store_frame_param (f, Qwindow_system, Qmac);
+
UNGCPRO;
/* Make sure windows on this frame appear in calls to next-window
@@ -3299,9 +3302,6 @@ x_display_info_for_name (name)
CHECK_STRING (name);
- if (! EQ (Vwindow_system, intern ("mac")))
- error ("Not using Mac native windows");
-
for (dpyinfo = &one_mac_display_info, names = x_display_name_list;
dpyinfo;
dpyinfo = dpyinfo->next, names = XCDR (names))
@@ -3346,9 +3346,6 @@ terminate Emacs if we can't open the connection. */)
if (! NILP (xrm_string))
CHECK_STRING (xrm_string);
- if (! EQ (Vwindow_system, intern ("mac")))
- error ("Not using Mac native windows");
-
if (! NILP (xrm_string))
xrm_option = (unsigned char *) SDATA (xrm_string);
else
@@ -3611,10 +3608,6 @@ start_hourglass ()
EMACS_TIME delay;
int secs, usecs = 0;
- /* Don't bother for ttys. */
- if (NILP (Vwindow_system))
- return;
-
cancel_hourglass ();
if (INTEGERP (Vhourglass_delay)
@@ -3827,7 +3820,7 @@ x_create_tip_frame (dpyinfo, parms, text)
parms = Fcopy_alist (parms);
#ifdef MULTI_KBOARD
- kb = dpyinfo->kboard;
+ kb = dpyinfo->terminal->kboard;
#else
kb = &the_only_kboard;
#endif
diff --git a/src/macmenu.c b/src/macmenu.c
index 883a8463c2..8305c89ee6 100644
--- a/src/macmenu.c
+++ b/src/macmenu.c
@@ -26,10 +26,10 @@ Boston, MA 02110-1301, USA. */
#include <stdio.h>
#include "lisp.h"
+#include "frame.h"
#include "termhooks.h"
#include "keyboard.h"
#include "keymap.h"
-#include "frame.h"
#include "window.h"
#include "blockinput.h"
#include "buffer.h"
@@ -720,8 +720,8 @@ no quit occurs and `x-popup-menu' returns nil. */)
enum scroll_bar_part part;
unsigned long time;
- if (mouse_position_hook)
- (*mouse_position_hook) (&new_f, 1, &bar_window,
+ if (FRAME_TERMINAL (new_f)->mouse_position_hook)
+ (*FRAME_TERMINAL (new_f)->mouse_position_hook) (&new_f, 1, &bar_window,
&part, &x, &y, &time);
if (new_f != 0)
XSETFRAME (window, new_f);
diff --git a/src/macterm.c b/src/macterm.c
index 734bf52e18..ed7411615f 100644
--- a/src/macterm.c
+++ b/src/macterm.c
@@ -228,14 +228,14 @@ void x_raise_frame P_ ((struct frame *));
void x_set_window_size P_ ((struct frame *, int, int, int));
void x_wm_set_window_state P_ ((struct frame *, int));
void x_wm_set_icon_pixmap P_ ((struct frame *, int));
-void mac_initialize P_ ((void));
+static void mac_initialize P_ ((void));
static void x_font_min_bounds P_ ((XFontStruct *, int *, int *));
static int x_compute_min_glyph_bounds P_ ((struct frame *));
static void x_update_end P_ ((struct frame *));
static void XTframe_up_to_date P_ ((struct frame *));
-static void XTset_terminal_modes P_ ((void));
-static void XTreset_terminal_modes P_ ((void));
-static void x_clear_frame P_ ((void));
+static void XTset_terminal_modes P_ ((struct terminal *));
+static void XTreset_terminal_modes P_ ((struct terminal *));
+static void x_clear_frame P_ ((struct frame *));
static void frame_highlight P_ ((struct frame *));
static void frame_unhighlight P_ ((struct frame *));
static void x_new_focus_frame P_ ((struct x_display_info *, struct frame *));
@@ -263,6 +263,8 @@ static void x_scroll_bar_report_motion P_ ((struct frame **, Lisp_Object *,
static int is_emacs_window P_ ((WindowRef));
static XCharStruct *mac_per_char_metric P_ ((XFontStruct *, XChar2b *, int));
static void XSetFont P_ ((Display *, GC, XFontStruct *));
+static struct terminal *mac_create_terminal P_ ((struct mac_display_info *dpyinfo));
+
#define GC_FORE_COLOR(gc) (&(gc)->fore_color)
#define GC_BACK_COLOR(gc) (&(gc)->back_color)
@@ -2360,6 +2362,9 @@ mac_define_fringe_bitmap (which, bits, h, wd)
for (i = 0; i < h; i++)
bits[i] = ~bits[i];
+
+ BLOCK_INPUT;
+
provider = CGDataProviderCreateWithData (NULL, bits,
sizeof (unsigned short) * h, NULL);
if (provider)
@@ -2369,6 +2374,8 @@ mac_define_fringe_bitmap (which, bits, h, wd)
provider, NULL, 0);
CGDataProviderRelease (provider);
}
+
+ UNBLOCK_INPUT;
}
static void
@@ -2379,7 +2386,11 @@ mac_destroy_fringe_bitmap (which)
return;
if (fringe_bmp[which])
- CGImageRelease (fringe_bmp[which]);
+ {
+ BLOCK_INPUT;
+ CGImageRelease (fringe_bmp[which]);
+ UNBLOCK_INPUT;
+ }
fringe_bmp[which] = 0;
}
#endif
@@ -2391,7 +2402,7 @@ mac_destroy_fringe_bitmap (which)
rarely happens). */
static void
-XTset_terminal_modes ()
+XTset_terminal_modes (struct terminal *t)
{
}
@@ -2399,7 +2410,7 @@ XTset_terminal_modes ()
the windows go away, and suspending requires no action. */
static void
-XTreset_terminal_modes ()
+XTreset_terminal_modes (struct terminal *t)
{
}
@@ -4049,15 +4060,8 @@ x_delete_glyphs (n)
frame. Otherwise clear the selected frame. */
static void
-x_clear_frame ()
+x_clear_frame (struct frame *f)
{
- struct frame *f;
-
- if (updating_frame)
- f = updating_frame;
- else
- f = SELECTED_FRAME ();
-
/* Clearing the frame will erase any cursor, so mark them all as no
longer visible. */
mark_window_cursors_off (XWINDOW (FRAME_ROOT_WINDOW (f)));
@@ -4575,7 +4579,7 @@ note_mouse_movement (frame, pos)
clear_mouse_face (dpyinfo);
dpyinfo->mouse_face_mouse_frame = 0;
if (!dpyinfo->grabbed)
- rif->define_frame_cursor (frame,
+ FRAME_RIF (frame)->define_frame_cursor (frame,
frame->output_data.mac->nontext_cursor);
}
@@ -8781,7 +8785,7 @@ mac_load_query_font (f, fontname)
font_id = atsu_find_font_from_family_name (family);
if (font_id == kATSUInvalidFontID)
- return;
+ return NULL;
size_fixed = Long2Fix (size);
bold_p = (fontface & bold) != 0;
italic_p = (fontface & italic) != 0;
@@ -12174,7 +12178,13 @@ XTread_socket (sd, expected, hold_quit)
will be selected only when it is active. */
if (WINDOWP (window)
&& !EQ (window, last_window)
- && !EQ (window, selected_window))
+ && !EQ (window, selected_window)
+ /* For click-to-focus window managers
+ create event iff we don't leave the
+ selected frame. */
+ && (focus_follows_mouse
+ || (EQ (XWINDOW (window)->frame,
+ XWINDOW (selected_window)->frame))))
{
inev.kind = SELECT_WINDOW_EVENT;
inev.frame_or_window = window;
@@ -12552,6 +12562,7 @@ mac_term_init (display_name, xrm_option, resource_name)
char *resource_name;
{
struct mac_display_info *dpyinfo;
+ struct terminal *terminal;
BLOCK_INPUT;
@@ -12567,6 +12578,13 @@ mac_term_init (display_name, xrm_option, resource_name)
dpyinfo = &one_mac_display_info;
bzero (dpyinfo, sizeof (*dpyinfo));
+ terminal = mac_create_terminal (dpyinfo);
+
+ /* Set the name of the terminal. */
+ terminal->name = (char *) xmalloc (SBYTES (display_name) + 1);
+ strncpy (terminal->name, SDATA (display_name), SBYTES (display_name));
+ terminal->name[SBYTES (display_name)] = 0;
+
#ifdef MAC_OSX
dpyinfo->mac_id_name
= (char *) xmalloc (SCHARS (Vinvocation_name)
@@ -12608,6 +12626,10 @@ mac_term_init (display_name, xrm_option, resource_name)
x_display_name_list);
dpyinfo->name_list_element = XCAR (x_display_name_list);
+#if USE_CG_DRAWING
+ mac_init_fringe (terminal->rif);
+#endif
+
UNBLOCK_INPUT;
return dpyinfo;
@@ -12768,44 +12790,72 @@ static struct redisplay_interface x_redisplay_interface =
mac_shift_glyphs_for_insert
};
-void
+static struct terminal *
+mac_create_terminal (struct mac_display_info *dpyinfo)
+{
+ struct terminal *terminal;
+
+ terminal = create_terminal ();
+
+ terminal->type = output_mac;
+ terminal->display_info.mac = dpyinfo;
+ dpyinfo->terminal = terminal;
+
+ terminal->clear_frame_hook = x_clear_frame;
+ terminal->ins_del_lines_hook = x_ins_del_lines;
+ terminal->delete_glyphs_hook = x_delete_glyphs;
+ terminal->ring_bell_hook = XTring_bell;
+ terminal->reset_terminal_modes_hook = XTreset_terminal_modes;
+ terminal->set_terminal_modes_hook = XTset_terminal_modes;
+ terminal->update_begin_hook = x_update_begin;
+ terminal->update_end_hook = x_update_end;
+ terminal->set_terminal_window_hook = XTset_terminal_window;
+ terminal->read_socket_hook = XTread_socket;
+ terminal->frame_up_to_date_hook = XTframe_up_to_date;
+ terminal->mouse_position_hook = XTmouse_position;
+ terminal->frame_rehighlight_hook = XTframe_rehighlight;
+ terminal->frame_raise_lower_hook = XTframe_raise_lower;
+ /* terminal->fullscreen_hook = XTfullscreen_hook; */
+ terminal->set_vertical_scroll_bar_hook = XTset_vertical_scroll_bar;
+ terminal->condemn_scroll_bars_hook = XTcondemn_scroll_bars;
+ terminal->redeem_scroll_bar_hook = XTredeem_scroll_bar;
+ terminal->judge_scroll_bars_hook = XTjudge_scroll_bars;
+ terminal->delete_frame_hook = x_destroy_window;
+ /* terminal->delete_terminal_hook = x_delete_terminal; */
+
+ terminal->rif = &x_redisplay_interface;
+#if 0
+ TTY_SCROLL_REGION_OK (CURTTY ()) = 1; /* we'll scroll partial frames */
+ TTY_CHAR_INS_DEL_OK (CURTTY ()) = 1;
+ TTY_LINE_INS_DEL_OK (CURTTY ()) = 1; /* we'll just blt 'em */
+ TTY_FAST_CLEAR_END_OF_LINE (CURTTY ()) = 1; /* X does this well */
+ TTY_MEMORY_BELOW_FRAME (CURTTY ()) = 0; /* we don't remember what
+ scrolls off the
+ bottom */
+#else
+ terminal->scroll_region_ok = 1; /* We'll scroll partial frames. */
+ terminal->char_ins_del_ok = 1;
+ terminal->line_ins_del_ok = 1; /* We'll just blt 'em. */
+ terminal->fast_clear_end_of_line = 1; /* X does this well. */
+ terminal->memory_below_frame = 0; /* We don't remember what scrolls
+ off the bottom. */
+
+#endif
+
+ return terminal;
+}
+
+static void
mac_initialize ()
{
- rif = &x_redisplay_interface;
-
- clear_frame_hook = x_clear_frame;
- ins_del_lines_hook = x_ins_del_lines;
- delete_glyphs_hook = x_delete_glyphs;
- ring_bell_hook = XTring_bell;
- reset_terminal_modes_hook = XTreset_terminal_modes;
- set_terminal_modes_hook = XTset_terminal_modes;
- update_begin_hook = x_update_begin;
- update_end_hook = x_update_end;
- set_terminal_window_hook = XTset_terminal_window;
- read_socket_hook = XTread_socket;
- frame_up_to_date_hook = XTframe_up_to_date;
- mouse_position_hook = XTmouse_position;
- frame_rehighlight_hook = XTframe_rehighlight;
- frame_raise_lower_hook = XTframe_raise_lower;
-
- set_vertical_scroll_bar_hook = XTset_vertical_scroll_bar;
- condemn_scroll_bars_hook = XTcondemn_scroll_bars;
- redeem_scroll_bar_hook = XTredeem_scroll_bar;
- judge_scroll_bars_hook = XTjudge_scroll_bars;
-
- scroll_region_ok = 1; /* we'll scroll partial frames */
- char_ins_del_ok = 1;
- line_ins_del_ok = 1; /* we'll just blt 'em */
- fast_clear_end_of_line = 1; /* X does this well */
- memory_below_frame = 0; /* we don't remember what scrolls
- off the bottom */
+
baud_rate = 19200;
last_tool_bar_item = -1;
any_help_event_p = 0;
/* Try to use interrupt input; if we can't, then start polling. */
- Fset_input_mode (Qt, Qnil, Qt, Qnil);
+ Fset_input_interrupt_mode (Qt);
BLOCK_INPUT;
@@ -12837,11 +12887,10 @@ mac_initialize ()
#if USE_CG_DRAWING
init_cg_color ();
-
- mac_init_fringe ();
#endif
UNBLOCK_INPUT;
+
}
diff --git a/src/macterm.h b/src/macterm.h
index 8a85e714ab..f319adeb65 100644
--- a/src/macterm.h
+++ b/src/macterm.h
@@ -64,6 +64,9 @@ struct mac_display_info
/* Chain of all mac_display_info structures. */
struct mac_display_info *next;
+ /* The generic display parameters corresponding to this X display. */
+ struct terminal *terminal;
+
/* This is a cons cell of the form (NAME . FONT-LIST-CACHE).
The same cons cell also appears in x_display_name_list. */
Lisp_Object name_list_element;
@@ -358,9 +361,6 @@ typedef struct mac_output mac_output;
#define FRAME_MAC_WINDOW(f) ((f)->output_data.mac->window_desc)
#define FRAME_X_WINDOW(f) ((f)->output_data.mac->window_desc)
-#define FRAME_FOREGROUND_PIXEL(f) ((f)->output_data.x->foreground_pixel)
-#define FRAME_BACKGROUND_PIXEL(f) ((f)->output_data.x->background_pixel)
-
#define FRAME_FONT(f) ((f)->output_data.mac->font)
#define FRAME_FONTSET(f) ((f)->output_data.mac->fontset)
@@ -636,7 +636,6 @@ extern void x_free_frame_resources P_ ((struct frame *));
extern void x_destroy_window P_ ((struct frame *));
extern void x_wm_set_size_hint P_ ((struct frame *, long, int));
extern void x_delete_display P_ ((struct x_display_info *));
-extern void mac_initialize P_ ((void));
extern Pixmap XCreatePixmap P_ ((Display *, WindowRef, unsigned int,
unsigned int, unsigned int));
extern Pixmap XCreatePixmapFromBitmapData P_ ((Display *, WindowRef, char *,
diff --git a/src/makefile.w32-in b/src/makefile.w32-in
index df42d0a08d..296c10c420 100644
--- a/src/makefile.w32-in
+++ b/src/makefile.w32-in
@@ -125,7 +125,8 @@ OBJ1 = $(BLD)/abbrev.$(O) \
$(BLD)/ccl.$(O) \
$(BLD)/fontset.$(O) \
$(BLD)/fringe.$(O) \
- $(BLD)/image.$(O)
+ $(BLD)/image.$(O) \
+ $(BLD)/terminal.$(O)
WIN32OBJ = $(BLD)/w32term.$(O) \
@@ -156,6 +157,7 @@ LIBS = $(TLIB0) \
$(SHELL32) \
$(WINSPOOL) \
$(OLE32) \
+ $(COMCTL32) \
$(libc)
#
@@ -393,6 +395,8 @@ $(BLD)/callproc.$(O) : \
$(SRC)/process.h \
$(SRC)/syssignal.h \
$(SRC)/systty.h \
+ $(SRC)/frame.h \
+ $(SRC)/termhooks.h \
$(SRC)/w32.h
$(BLD)/casefiddle.$(O) : \
@@ -508,6 +512,8 @@ $(BLD)/coding.$(O) : \
$(SRC)/composite.h \
$(SRC)/dispextern.h \
$(SRC)/intervals.h \
+ $(SRC)/frame.h \
+ $(SRC)/termhooks.h \
$(SRC)/w32bdf.h \
$(SRC)/w32gui.h \
$(SRC)/window.h
@@ -537,7 +543,8 @@ $(BLD)/data.$(O) : \
$(SRC)/frame.h \
$(SRC)/keyboard.h \
$(SRC)/puresize.h \
- $(SRC)/syssignal.h
+ $(SRC)/syssignal.h \
+ $(SRC)/termhooks.h
$(BLD)/dired.$(O) : \
$(SRC)/dired.c \
@@ -748,6 +755,7 @@ $(BLD)/fns.$(O) : \
$(SRC)/keymap.h \
$(SRC)/md5.h \
$(SRC)/systime.h \
+ $(SRC)/termhooks.h \
$(SRC)/w32bdf.h \
$(SRC)/w32gui.h \
$(SRC)/window.h
@@ -779,6 +787,7 @@ $(BLD)/fontset.$(O) : \
$(SRC)/fontset.h \
$(SRC)/frame.h \
$(SRC)/keyboard.h \
+ $(SRC)/termhooks.h \
$(SRC)/w32bdf.h \
$(SRC)/w32gui.h \
$(SRC)/window.h
@@ -799,6 +808,7 @@ $(BLD)/frame.$(O) : \
$(SRC)/frame.h \
$(SRC)/keyboard.h \
$(SRC)/systime.h \
+ $(SRC)/termchar.h \
$(SRC)/termhooks.h \
$(SRC)/w32bdf.h \
$(SRC)/w32gui.h \
@@ -972,6 +982,7 @@ $(BLD)/lread.$(O) : \
$(EMACS_ROOT)/src/config.h \
$(EMACS_ROOT)/nt/inc/sys/file.h \
$(EMACS_ROOT)/src/epaths.h \
+ $(SRC)/blockinput.h \
$(SRC)/buffer.h \
$(SRC)/ccl.h \
$(SRC)/character.h \
@@ -1029,6 +1040,7 @@ $(BLD)/minibuf.$(O) : \
$(SRC)/keyboard.h \
$(SRC)/keymap.h \
$(SRC)/syntax.h \
+ $(SRC)/termhooks.h \
$(SRC)/w32bdf.h \
$(SRC)/w32gui.h \
$(SRC)/window.h
@@ -1195,6 +1207,7 @@ $(BLD)/scroll.$(O) : \
$(SRC)/frame.h \
$(SRC)/keyboard.h \
$(SRC)/termchar.h \
+ $(SRC)/termhooks.h \
$(SRC)/w32bdf.h \
$(SRC)/w32gui.h \
$(SRC)/window.h
@@ -1263,6 +1276,7 @@ $(BLD)/sysdep.$(O) : \
$(EMACS_ROOT)/nt/inc/sys/file.h \
$(SRC)/atimer.h \
$(SRC)/blockinput.h \
+ $(SRC)/cm.h \
$(SRC)/dispextern.h \
$(SRC)/frame.h \
$(SRC)/keyboard.h \
@@ -1309,6 +1323,18 @@ $(BLD)/termcap.$(O) : \
$(EMACS_ROOT)/src/config.h \
$(EMACS_ROOT)/nt/inc/sys/file.h
+$(BLD)/terminal.$(O) : \
+ $(SRC)/terminal.c \
+ $(EMACS_ROOT)/src/s/ms-w32.h \
+ $(EMACS_ROOT)/src/m/intel386.h \
+ $(EMACS_ROOT)/src/config.h \
+ $(SRC)/charset.h \
+ $(SRC)/coding.h \
+ $(SRC)/frame.h \
+ $(SRC)/keyboard.h \
+ $(SRC)/termchar.h \
+ $(SRC)/termhooks.h
+
$(BLD)/textprop.$(O) : \
$(SRC)/textprop.c \
$(EMACS_ROOT)/src/s/ms-w32.h \
@@ -1426,6 +1452,8 @@ $(BLD)/xfaces.$(O): \
$(SRC)/intervals.h \
$(SRC)/keyboard.h \
$(SRC)/systime.h \
+ $(SRC)/termchar.h \
+ $(SRC)/termhooks.h \
$(SRC)/w32bdf.h \
$(SRC)/w32gui.h \
$(SRC)/w32term.h \
diff --git a/src/marker.c b/src/marker.c
index 6a7652c8ce..d054ef91e7 100644
--- a/src/marker.c
+++ b/src/marker.c
@@ -452,9 +452,12 @@ Returns nil if MARKER points into a dead buffer. */)
if (XMARKER (marker)->buffer)
{
XSETBUFFER (buf, XMARKER (marker)->buffer);
- /* Return marker's buffer only if it is not dead. */
- if (!NILP (XBUFFER (buf)->name))
- return buf;
+ /* If the buffer is dead, we're in trouble: the buffer pointer here
+ does not preserve the buffer from being GC'd (it's weak), so
+ markers have to be unlinked from their buffer as soon as the buffer
+ is killed. */
+ eassert (!NILP (XBUFFER (buf)->name));
+ return buf;
}
return Qnil;
}
diff --git a/src/minibuf.c b/src/minibuf.c
index 74220d0c7c..39d2f8e17b 100644
--- a/src/minibuf.c
+++ b/src/minibuf.c
@@ -35,6 +35,7 @@ Boston, MA 02110-1301, USA. */
#include "syntax.h"
#include "intervals.h"
#include "keymap.h"
+#include "termhooks.h"
extern int quit_char;
@@ -491,7 +492,6 @@ read_minibuf (map, initial, prompt, backup_n, expflag,
if (EQ (Vminibuffer_completing_file_name, Qlambda))
Vminibuffer_completing_file_name = Qnil;
- single_kboard_state ();
#ifdef HAVE_X_WINDOWS
if (display_hourglass_p)
cancel_hourglass ();
@@ -575,6 +575,8 @@ read_minibuf (map, initial, prompt, backup_n, expflag,
if (minibuffer_auto_raise)
Fraise_frame (mini_frame);
+ temporarily_switch_to_single_kboard (XFRAME (mini_frame));
+
/* We have to do this after saving the window configuration
since that is what restores the current buffer. */
@@ -758,8 +760,12 @@ read_minibuf (map, initial, prompt, backup_n, expflag,
XWINDOW (minibuf_window)->cursor.x = 0;
XWINDOW (minibuf_window)->must_be_updated_p = 1;
update_frame (XFRAME (selected_frame), 1, 1);
- if (rif && rif->flush_display)
- rif->flush_display (XFRAME (XWINDOW (minibuf_window)->frame));
+ {
+ struct frame *f = XFRAME (XWINDOW (minibuf_window)->frame);
+ struct redisplay_interface *rif = FRAME_RIF (f);
+ if (rif && rif->flush_display)
+ rif->flush_display (f);
+ }
}
/* Make minibuffer contents into a string. */
diff --git a/src/msdos.c b/src/msdos.c
index c01755b279..02bd2748b8 100644
--- a/src/msdos.c
+++ b/src/msdos.c
@@ -508,8 +508,8 @@ ScreenVisualBell (void)
{
/* This creates an xor-mask that will swap the default fore- and
background colors. */
- do_visible_bell (((the_only_x_display.foreground_pixel
- ^ the_only_x_display.background_pixel)
+ do_visible_bell (((FRAME_FOREGROUND_PIXEL (SELECTED_FRAME ())
+ ^ FRAME_BACKGROUND_PIXEL (SELECTED_FRAME ()))
* 0x11) & 0x7f);
}
#endif
@@ -2531,8 +2531,8 @@ internal_terminal_init ()
initial_screen_colors[0] = initial_screen_colors[1] = -1;
bzero (&the_only_x_display, sizeof the_only_x_display);
- the_only_x_display.background_pixel = 7; /* White */
- the_only_x_display.foreground_pixel = 0; /* Black */
+ FRAME_BACKGROUND_PIXEL (SELECTED_FRAME ()) = 7; /* White */
+ FRAME_FOREGROUND_PIXEL (SELECTED_FRAME ()) = 0; /* Black */
bright_bg ();
colors = getenv ("EMACSCOLORS");
if (colors && strlen (colors) >= 2)
@@ -2543,13 +2543,13 @@ internal_terminal_init ()
else if (isxdigit (colors[0]))
colors[0] -= (isupper (colors[0]) ? 'A' : 'a') - 10;
if (colors[0] >= 0 && colors[0] < 16)
- the_only_x_display.foreground_pixel = colors[0];
+ FRAME_FOREGROUND_PIXEL (SELECTED_FRAME ()) = colors[0];
if (isdigit (colors[1]))
colors[1] -= '0';
else if (isxdigit (colors[1]))
colors[1] -= (isupper (colors[1]) ? 'A' : 'a') - 10;
if (colors[1] >= 0 && colors[1] < 16)
- the_only_x_display.background_pixel = colors[1];
+ FRAME_BACKGROUND_PIXEL (SELECTED_FRAME ()) = colors[1];
}
the_only_x_display.font = (XFontStruct *)1; /* must *not* be zero */
the_only_x_display.display_info.mouse_face_mouse_frame = NULL;
@@ -2583,7 +2583,7 @@ internal_terminal_init ()
set_terminal_modes_hook = IT_set_terminal_modes;
reset_terminal_modes_hook = IT_reset_terminal_modes;
set_terminal_window_hook = IT_set_terminal_window;
- char_ins_del_ok = 0;
+ TTY_CHAR_INS_DEL_OK (CURTTY ()) = 0;
#endif
}
@@ -3393,7 +3393,13 @@ dos_rawgetc ()
it is active. */
if (WINDOWP (mouse_window)
&& !EQ (mouse_window, last_mouse_window)
- && !EQ (mouse_window, selected_window))
+ && !EQ (window, selected_window)
+ /* For click-to-focus window managers
+ create event iff we don't leave the
+ selected frame. */
+ && (focus_follows_mouse
+ || (EQ (XWINDOW (window)->frame,
+ XWINDOW (selected_window)->frame))))
{
event.kind = SELECT_WINDOW_EVENT;
event.frame_or_window = mouse_window;
@@ -4880,7 +4886,7 @@ croak (badfunc)
char *badfunc;
{
fprintf (stderr, "%s not yet implemented\r\n", badfunc);
- reset_sys_modes ();
+ reset_all_sys_modes ();
exit (1);
}
diff --git a/src/prefix-args.c b/src/prefix-args.c
index adf2743ba2..16d7b7dba1 100644
--- a/src/prefix-args.c
+++ b/src/prefix-args.c
@@ -53,6 +53,7 @@ Boston, MA 02110-1301, USA. */
#endif
#include <stdio.h>
+#include <stdlib.h>
int
main (argc, argv)
diff --git a/src/print.c b/src/print.c
index 86fd93a5b3..edd22abc03 100644
--- a/src/print.c
+++ b/src/print.c
@@ -35,6 +35,7 @@ Boston, MA 02110-1301, USA. */
#include "termchar.h"
#include "intervals.h"
#include "blockinput.h"
+#include "termhooks.h" /* For struct terminal. */
Lisp_Object Vstandard_output, Qstandard_output;
@@ -1024,11 +1025,7 @@ safe_debug_print (arg)
else
fprintf (stderr, "#<%s_LISP_OBJECT 0x%08lx>\r\n",
!valid ? "INVALID" : "SOME",
-#ifdef NO_UNION_TYPE
- (unsigned long) arg
-#else
- (unsigned long) arg.i
-#endif
+ (unsigned long) XHASH (arg)
);
}
@@ -1388,10 +1385,10 @@ print_preprocess (obj)
for (i = 0; i < print_number_index; i++)
if (EQ (PRINT_NUMBER_OBJECT (Vprint_number_table, i), obj))
{
- /* OBJ appears more than once. Let's remember that. */
+ /* OBJ appears more than once. Let's remember that. */
PRINT_NUMBER_STATUS (Vprint_number_table, i) = Qt;
print_depth--;
- return;
+ return;
}
/* OBJ is not yet recorded. Let's add to the table. */
@@ -2063,6 +2060,19 @@ print_object (obj, printcharfun, escapeflag)
}
PRINTCHAR ('>');
}
+ else if (TERMINALP (obj))
+ {
+ struct terminal *t = XTERMINAL (obj);
+ strout ("#<terminal ", -1, -1, printcharfun, 0);
+ sprintf (buf, "%d", t->id);
+ strout (buf, -1, -1, printcharfun, 0);
+ if (t->name)
+ {
+ strout (" on ", -1, -1, printcharfun, 0);
+ strout (t->name, -1, -1, printcharfun, 0);
+ }
+ PRINTCHAR ('>');
+ }
else if (HASH_TABLE_P (obj))
{
struct Lisp_Hash_Table *h = XHASH_TABLE (obj);
@@ -2075,7 +2085,7 @@ print_object (obj, printcharfun, escapeflag)
PRINTCHAR (' ');
strout (SDATA (SYMBOL_NAME (h->weak)), -1, -1, printcharfun, 0);
PRINTCHAR (' ');
- sprintf (buf, "%ld/%ld", (long) XFASTINT (h->count),
+ sprintf (buf, "%ld/%ld", (long) h->count,
(long) XVECTOR (h->next)->size);
strout (buf, -1, -1, printcharfun, 0);
}
diff --git a/src/process.c b/src/process.c
index 9e9ef6d077..d94e6d1386 100644
--- a/src/process.c
+++ b/src/process.c
@@ -130,11 +130,11 @@ Boston, MA 02110-1301, USA. */
#include "character.h"
#include "coding.h"
#include "process.h"
+#include "frame.h"
#include "termhooks.h"
#include "termopts.h"
#include "commands.h"
#include "keyboard.h"
-#include "frame.h"
#include "blockinput.h"
#include "dispextern.h"
#include "composite.h"
@@ -2720,7 +2720,9 @@ host, and only clients connecting to that address will be accepted.
:service SERVICE -- SERVICE is name of the service desired, or an
integer specifying a port number to connect to. If SERVICE is t,
-a random port number is selected for the server.
+a random port number is selected for the server. (If Emacs was
+compiled with getaddrinfo, a port number can also be specified as a
+string, e.g. "80", as well as an integer. This is not portable.)
:type TYPE -- TYPE is the type of connection. The default (nil) is a
stream type connection, `datagram' creates a datagram type connection.
@@ -3156,6 +3158,10 @@ usage: (make-network-process &rest ARGS) */)
open_socket:
+#ifdef __ultrix__
+ /* Previously this was compiled unconditionally, but that seems
+ unnecessary on modern systems, and `unrequest_sigio' was a noop
+ under X anyway. --lorentey */
/* Kernel bugs (on Ultrix at least) cause lossage (not just EINTR)
when connect is interrupted. So let's not let it get interrupted.
Note we do not turn off polling, because polling is only used
@@ -3172,6 +3178,7 @@ usage: (make-network-process &rest ARGS) */)
record_unwind_protect (unwind_request_sigio, Qnil);
unrequest_sigio ();
}
+#endif
/* Do this in case we never enter the for-loop below. */
count1 = SPECPDL_INDEX ();
@@ -6862,20 +6869,12 @@ DEFUN ("process-filter-multibyte-p", Fprocess_filter_multibyte_p,
-/* The first time this is called, assume keyboard input comes from DESC
- instead of from where we used to expect it.
- Subsequent calls mean assume input keyboard can come from DESC
- in addition to other places. */
-
-static int add_keyboard_wait_descriptor_called_flag;
+/* Add DESC to the set of keyboard input descriptors. */
void
add_keyboard_wait_descriptor (desc)
int desc;
{
- if (! add_keyboard_wait_descriptor_called_flag)
- FD_CLR (0, &input_wait_mask);
- add_keyboard_wait_descriptor_called_flag = 1;
FD_SET (desc, &input_wait_mask);
FD_SET (desc, &non_process_wait_mask);
if (desc > max_keyboard_desc)
@@ -6981,7 +6980,12 @@ init_process ()
process_output_skip = 0;
#endif
+ /* Don't do this, it caused infinite select loops. The display
+ method should call add_keyboard_wait_descriptor on stdin if it
+ needs that. */
+#if 0
FD_SET (0, &input_wait_mask);
+#endif
Vprocess_alist = Qnil;
#ifdef SIGCHLD
diff --git a/src/process.h b/src/process.h
index eaed95fe4b..c1b1bc01e3 100644
--- a/src/process.h
+++ b/src/process.h
@@ -34,7 +34,7 @@ Boston, MA 02110-1301, USA. */
struct Lisp_Process
{
- EMACS_INT size;
+ EMACS_UINT size;
struct Lisp_Vector *v_next;
/* Name of subprocess terminal. */
Lisp_Object tty_name;
diff --git a/src/puresize.h b/src/puresize.h
index 8ce51dbfd8..4b88283d8d 100644
--- a/src/puresize.h
+++ b/src/puresize.h
@@ -43,7 +43,7 @@ Boston, MA 02110-1301, USA. */
#endif
#ifndef BASE_PURESIZE
-#define BASE_PURESIZE (1140000 + SYSTEM_PURESIZE_EXTRA + SITELOAD_PURESIZE_EXTRA)
+#define BASE_PURESIZE (1164000 + SYSTEM_PURESIZE_EXTRA + SITELOAD_PURESIZE_EXTRA)
#endif
/* Increase BASE_PURESIZE by a ratio depending on the machine's word size. */
diff --git a/src/regex.c b/src/regex.c
index 0858378c6e..a0d6b945cf 100644
--- a/src/regex.c
+++ b/src/regex.c
@@ -1398,18 +1398,12 @@ static const char *re_error_msgid[] =
/* Normally, this is fine. */
#define MATCH_MAY_ALLOCATE
-/* When using GNU C, we are not REALLY using the C alloca, no matter
- what config.h may say. So don't take precautions for it. */
-#ifdef __GNUC__
-# undef C_ALLOCA
-#endif
-
/* The match routines may not allocate if (1) they would do it with malloc
and (2) it's not safe for them to use malloc.
Note that if REL_ALLOC is defined, matching would not use malloc for the
failure stack, but we would still use it for the register vectors;
so REL_ALLOC should not affect this. */
-#if (defined C_ALLOCA || defined REGEX_MALLOC) && defined emacs
+#if defined REGEX_MALLOC && defined emacs
# undef MATCH_MAY_ALLOCATE
#endif
@@ -4635,11 +4629,6 @@ re_search_2 (bufp, str1, size1, str2, size2, startpos, range, regs, stop)
val = re_match_2_internal (bufp, string1, size1, string2, size2,
startpos, regs, stop);
-#ifndef REGEX_MALLOC
-# ifdef C_ALLOCA
- alloca (0);
-# endif
-#endif
if (val >= 0)
return startpos;
@@ -5076,9 +5065,6 @@ re_match (bufp, string, size, pos, regs)
{
int result = re_match_2_internal (bufp, NULL, 0, (re_char*) string, size,
pos, regs, size);
-# if defined C_ALLOCA && !defined REGEX_MALLOC
- alloca (0);
-# endif
return result;
}
WEAK_ALIAS (__re_match, re_match)
@@ -5124,9 +5110,6 @@ re_match_2 (bufp, string1, size1, string2, size2, pos, regs, stop)
result = re_match_2_internal (bufp, (re_char*) string1, size1,
(re_char*) string2, size2,
pos, regs, stop);
-#if defined C_ALLOCA && !defined REGEX_MALLOC
- alloca (0);
-#endif
return result;
}
WEAK_ALIAS (__re_match_2, re_match_2)
diff --git a/src/s/cygwin.h b/src/s/cygwin.h
index 3c0d9c410a..1785c7c6c7 100644
--- a/src/s/cygwin.h
+++ b/src/s/cygwin.h
@@ -140,6 +140,12 @@ Boston, MA 02110-1301, USA. */
change their controlling terminal */
#define vfork fork
+/* This should work (at least when compiling with gcc). But I have no way
+ or intention to verify or even test it. If you encounter a problem with
+ it, feel free to change this setting, but please add a comment here about
+ why it needed to be changed. */
+#define GC_MARK_STACK GC_MAKE_GCPROS_NOOPS
+
/* the end */
/* arch-tag: 5ae7ba00-83b0-4ab3-806a-3e845779191b
diff --git a/src/s/darwin.h b/src/s/darwin.h
index 183aecaf5d..6bfa0e9510 100644
--- a/src/s/darwin.h
+++ b/src/s/darwin.h
@@ -50,6 +50,12 @@ Boston, MA 02110-1301, USA. */
#ifdef MAC_OSX
#ifdef HAVE_CARBON
#define MAC_OS
+/* We need a little extra space, see ../../lisp/loadup.el. */
+#define SYSTEM_PURESIZE_EXTRA 30000
+
+/* XXX The MULTI_KBOARD support does not work yet on this platform. */
+#undef MULTI_KBOARD
+
#endif
#endif
diff --git a/src/s/hpux.h b/src/s/hpux.h
index 5f407a661e..62427ba98a 100644
--- a/src/s/hpux.h
+++ b/src/s/hpux.h
@@ -167,9 +167,15 @@ Boston, MA 02110-1301, USA. */
/* USG systems tend to put everything declared static
into the initialized data area, which becomes pure after dumping Emacs.
- Foil this. Emacs carefully avoids static vars inside functions. */
+ Foil this. Emacs carefully avoids static vars inside functions.
+ http://lists.gnu.org/archive/html/emacs-devel/2007-09/msg00368.html
+ As of at least HPUX 11.11 (2000), it seems this workaround is no
+ longer needed. Try uncommenting the following if you have problems
+ on older versions. */
-#define static
+/* This is unnecessary in HPUX versions 10.20, 11.0, 11.11, 11.23. */
+
+/* #define static */
/* Define extra libraries to load.
This should have -lBSD, but that library is said to make
diff --git a/src/s/ms-w32.h b/src/s/ms-w32.h
index a5898410b3..5a297a4ee8 100644
--- a/src/s/ms-w32.h
+++ b/src/s/ms-w32.h
@@ -302,6 +302,8 @@ Boston, MA 02110-1301, USA. */
#define HAVE_MOUSE 1
#define HAVE_H_ERRNO 1
+#define MULTI_KBOARD 1
+
#ifdef HAVE_NTGUI
#define HAVE_WINDOW_SYSTEM 1
#define HAVE_FACES 1
@@ -480,7 +482,7 @@ extern char *get_emacs_configuration_options (void);
/* We need a little extra space, see ../../lisp/loadup.el.
The number below comes from 23923 bytes worth (as of 2006-04)
of w32-specific files loaded by loadup.el, plus 1K spare. */
-#define SYSTEM_PURESIZE_EXTRA 25000
+#define SYSTEM_PURESIZE_EXTRA 50000
/* For unexec to work on Alpha systems, we need to put Emacs'
initialized data into a separate section from the CRT initialized
diff --git a/src/scroll.c b/src/scroll.c
index 48a40fe23d..5a59c69003 100644
--- a/src/scroll.c
+++ b/src/scroll.c
@@ -23,12 +23,13 @@ Boston, MA 02110-1301, USA. */
#include <config.h>
#include <stdio.h>
#include <string.h>
-#include "termchar.h"
#include "lisp.h"
+#include "termchar.h"
#include "dispextern.h"
#include "keyboard.h"
#include "frame.h"
#include "window.h"
+#include "termhooks.h"
/* All costs measured in characters.
So no cost can exceed the area of a frame, measured in characters.
@@ -58,10 +59,12 @@ struct matrix_elt
unsigned char writecount;
};
-static void do_direct_scrolling P_ ((struct glyph_matrix *,
+static void do_direct_scrolling P_ ((struct frame *,
+ struct glyph_matrix *,
struct matrix_elt *,
int, int));
-static void do_scrolling P_ ((struct glyph_matrix *,
+static void do_scrolling P_ ((struct frame *,
+ struct glyph_matrix *,
struct matrix_elt *,
int, int));
@@ -101,7 +104,8 @@ calculate_scrolling (frame, matrix, window_size, lines_below,
register struct matrix_elt *p, *p1;
register int cost, cost1;
- int lines_moved = window_size + (scroll_region_ok ? 0 : lines_below);
+ int lines_moved = window_size
+ + (FRAME_SCROLL_REGION_OK (frame) ? 0 : lines_below);
/* first_insert_cost[I] is the cost of doing the first insert-line
at the i'th line of the lines we are considering,
where I is origin 1 (as it is below). */
@@ -241,7 +245,8 @@ calculate_scrolling (frame, matrix, window_size, lines_below,
of lines. */
static void
-do_scrolling (current_matrix, matrix, window_size, unchanged_at_top)
+do_scrolling (frame, current_matrix, matrix, window_size, unchanged_at_top)
+ struct frame *frame;
struct glyph_matrix *current_matrix;
struct matrix_elt *matrix;
int window_size;
@@ -308,12 +313,12 @@ do_scrolling (current_matrix, matrix, window_size, unchanged_at_top)
/* Set the terminal window, if not done already. */
if (! terminal_window_p)
{
- set_terminal_window (window_size + unchanged_at_top);
+ set_terminal_window (frame, window_size + unchanged_at_top);
terminal_window_p = 1;
}
/* Delete lines on the terminal. */
- ins_del_lines (j + unchanged_at_top, - p->deletecount);
+ ins_del_lines (frame, j + unchanged_at_top, - p->deletecount);
}
else
{
@@ -338,7 +343,7 @@ do_scrolling (current_matrix, matrix, window_size, unchanged_at_top)
/* Set the terminal window if not yet done. */
if (!terminal_window_p)
{
- set_terminal_window (window_size + unchanged_at_top);
+ set_terminal_window (frame, window_size + unchanged_at_top);
terminal_window_p = 1;
}
@@ -347,7 +352,7 @@ do_scrolling (current_matrix, matrix, window_size, unchanged_at_top)
--queue;
/* Do the deletion on the terminal. */
- ins_del_lines (queue->pos, queue->count);
+ ins_del_lines (frame, queue->pos, queue->count);
/* All lines in the range deleted become empty in the glyph
matrix. Assign to them glyph rows that are not retained.
@@ -380,7 +385,7 @@ do_scrolling (current_matrix, matrix, window_size, unchanged_at_top)
CHECK_MATRIX (current_matrix);
if (terminal_window_p)
- set_terminal_window (0);
+ set_terminal_window (frame, 0);
}
@@ -467,7 +472,8 @@ calculate_direct_scrolling (frame, matrix, window_size, lines_below,
/* Overhead of setting the scroll window, plus the extra cost
cost of scrolling by a distance of one. The extra cost is
added once for consistency with the cost vectors */
- scroll_overhead = scroll_region_cost + extra_cost;
+ scroll_overhead
+ = FRAME_SCROLL_REGION_COST (frame) + extra_cost;
/* initialize the top left corner of the matrix */
matrix->writecost = 0;
@@ -650,8 +656,9 @@ calculate_direct_scrolling (frame, matrix, window_size, lines_below,
the cost matrix for this approach is constructed. */
static void
-do_direct_scrolling (current_matrix, cost_matrix, window_size,
- unchanged_at_top)
+do_direct_scrolling (frame, current_matrix, cost_matrix,
+ window_size, unchanged_at_top)
+ struct frame *frame;
struct glyph_matrix *current_matrix;
struct matrix_elt *cost_matrix;
int window_size;
@@ -742,9 +749,9 @@ do_direct_scrolling (current_matrix, cost_matrix, window_size,
if (i > j)
{
/* Immediately insert lines */
- set_terminal_window (i + unchanged_at_top);
+ set_terminal_window (frame, i + unchanged_at_top);
terminal_window_p = 1;
- ins_del_lines (j - n_to_write + unchanged_at_top, i - j);
+ ins_del_lines (frame, j - n_to_write + unchanged_at_top, i - j);
}
else if (i < j)
{
@@ -774,9 +781,9 @@ do_direct_scrolling (current_matrix, cost_matrix, window_size,
--queue;
if (queue->count)
{
- set_terminal_window (queue->window);
+ set_terminal_window (frame, queue->window);
terminal_window_p = 1;
- ins_del_lines (queue->pos, queue->count);
+ ins_del_lines (frame, queue->pos, queue->count);
}
else
{
@@ -799,7 +806,7 @@ do_direct_scrolling (current_matrix, cost_matrix, window_size,
copy_from, retained_p);
if (terminal_window_p)
- set_terminal_window (0);
+ set_terminal_window (frame, 0);
}
@@ -819,13 +826,13 @@ scrolling_1 (frame, window_size, unchanged_at_top, unchanged_at_bottom,
matrix = ((struct matrix_elt *)
alloca ((window_size + 1) * (window_size + 1) * sizeof *matrix));
- if (scroll_region_ok)
+ if (FRAME_SCROLL_REGION_OK (frame))
{
calculate_direct_scrolling (frame, matrix, window_size,
unchanged_at_bottom,
draw_cost, old_draw_cost,
old_hash, new_hash, free_at_end);
- do_direct_scrolling (frame->current_matrix,
+ do_direct_scrolling (frame, frame->current_matrix,
matrix, window_size, unchanged_at_top);
}
else
@@ -833,7 +840,8 @@ scrolling_1 (frame, window_size, unchanged_at_top, unchanged_at_bottom,
calculate_scrolling (frame, matrix, window_size, unchanged_at_bottom,
draw_cost, old_hash, new_hash,
free_at_end);
- do_scrolling (frame->current_matrix, matrix, window_size,
+ do_scrolling (frame,
+ frame->current_matrix, matrix, window_size,
unchanged_at_top);
}
}
@@ -915,7 +923,7 @@ scroll_cost (frame, from, to, amount)
if (amount == 0)
return 0;
- if (! scroll_region_ok)
+ if (! FRAME_SCROLL_REGION_OK (frame))
limit = height;
else if (amount > 0)
limit += amount;
diff --git a/src/search.c b/src/search.c
index edcf315b2c..aff998b154 100644
--- a/src/search.c
+++ b/src/search.c
@@ -1675,12 +1675,8 @@ boyer_moore (n, base_pat, len, len_byte, trt, inverse_trt,
int translate_prev_byte3 = 0;
int translate_prev_byte4 = 0;
-#ifdef C_ALLOCA
- int BM_tab_space[0400];
- BM_tab = &BM_tab_space[0];
-#else
BM_tab = (int *) alloca (0400 * sizeof (int));
-#endif
+
/* The general approach is that we are going to maintain that we know */
/* the first (closest to the present position, in whatever direction */
/* we're searching) character that could possibly be the last */
diff --git a/src/sound.c b/src/sound.c
index 8b1bda8d6e..0873fe8b82 100644
--- a/src/sound.c
+++ b/src/sound.c
@@ -97,7 +97,6 @@ Boston, MA 02110-1301, USA. */
#endif /* WINDOWSNT */
/* BEGIN: Common Definitions */
-#define abs(X) ((X) < 0 ? -(X) : (X))
/* Symbols. */
diff --git a/src/sysdep.c b/src/sysdep.c
index f2170dabed..35a107f34c 100644
--- a/src/sysdep.c
+++ b/src/sysdep.c
@@ -46,6 +46,12 @@ extern void srandom P_ ((unsigned int));
#endif
#endif
+/* The w32 build defines select stuff in w32.h, which is included by
+ sys/select.h (included below). */
+#ifndef WINDOWSNT
+#include "sysselect.h"
+#endif
+
#include "blockinput.h"
#ifdef MAC_OS8
@@ -176,6 +182,7 @@ extern int quit_char;
#include "termopts.h"
#include "dispextern.h"
#include "process.h"
+#include "cm.h" /* for reset_sys_modes */
#ifdef WINDOWSNT
#include <direct.h>
@@ -239,16 +246,11 @@ static int baud_convert[] =
int emacs_ospeed;
-/* The file descriptor for Emacs's input terminal.
- Under Unix, this is normally zero except when using X;
- under VMS, we place the input channel number here. */
-int input_fd;
-
void croak P_ ((char *)) NO_RETURN;
#ifdef AIXHFT
-void hft_init ();
-void hft_reset ();
+void hft_init P_ ((struct tty_display_info *));
+void hft_reset P_ ((struct tty_display_info *));
#endif
/* Temporary used by `sigblock' when defined in terms of signprocmask. */
@@ -331,16 +333,7 @@ get_current_dir_name ()
#endif
-/* Specify a different file descriptor for further input operations. */
-
-void
-change_input_fd (fd)
- int fd;
-{
- input_fd = fd;
-}
-
-/* Discard pending input on descriptor input_fd. */
+/* Discard pending input on all input descriptors. */
void
discard_tty_input ()
@@ -351,54 +344,61 @@ discard_tty_input ()
if (noninteractive)
return;
- /* Discarding input is not safe when the input could contain
- replies from the X server. So don't do it. */
- if (read_socket_hook)
- return;
-
#ifdef VMS
end_kbd_input ();
- SYS$QIOW (0, input_fd, IO$_READVBLK|IO$M_PURGE, input_iosb, 0, 0,
+ SYS$QIOW (0, fileno (CURTTY()->input), IO$_READVBLK|IO$M_PURGE, input_iosb, 0, 0,
&buf.main, 0, 0, terminator_mask, 0, 0);
queue_kbd_input ();
#else /* not VMS */
#ifdef APOLLO
{
- int zero = 0;
- ioctl (input_fd, TIOCFLUSH, &zero);
+ struct tty_display_info *tty;
+ for (tty = tty_list; tty; tty = tty->next)
+ {
+ int zero = 0;
+ if (tty->input)
+ ioctl (fileno (tty->input), TIOCFLUSH, &zero);
+ }
}
#else /* not Apollo */
#ifdef MSDOS /* Demacs 1.1.1 91/10/16 HIRANO Satoshi */
while (dos_keyread () != -1)
;
#else /* not MSDOS */
- EMACS_GET_TTY (input_fd, &buf);
- EMACS_SET_TTY (input_fd, &buf, 0);
+ {
+ struct tty_display_info *tty;
+ for (tty = tty_list; tty; tty = tty->next)
+ {
+ if (tty->input) /* Is the device suspended? */
+ {
+ EMACS_GET_TTY (fileno (tty->input), &buf);
+ EMACS_SET_TTY (fileno (tty->input), &buf, 0);
+ }
+ }
+ }
#endif /* not MSDOS */
#endif /* not Apollo */
#endif /* not VMS */
#endif /* not WINDOWSNT */
}
+
#ifdef SIGTSTP
/* Arrange for character C to be read as the next input from
- the terminal. */
+ the terminal.
+ XXX What if we have multiple ttys?
+*/
void
-#ifdef PROTOTYPES
stuff_char (char c)
-#else
-stuff_char (c)
- char c;
-#endif
{
- if (read_socket_hook)
+ if (! FRAME_TERMCAP_P (SELECTED_FRAME ()))
return;
/* Should perhaps error if in batch mode */
#ifdef TIOCSTI
- ioctl (input_fd, TIOCSTI, &c);
+ ioctl (fileno (CURTTY()->input), TIOCSTI, &c);
#else /* no TIOCSTI */
error ("Cannot stuff terminal input characters in this version of Unix");
#endif /* no TIOCSTI */
@@ -407,7 +407,7 @@ stuff_char (c)
#endif /* SIGTSTP */
void
-init_baud_rate ()
+init_baud_rate (int fd)
{
if (noninteractive)
emacs_ospeed = 0;
@@ -422,7 +422,7 @@ init_baud_rate ()
#ifdef VMS
struct sensemode sg;
- SYS$QIOW (0, input_fd, IO$_SENSEMODE, &sg, 0, 0,
+ SYS$QIOW (0, fd, IO$_SENSEMODE, &sg, 0, 0,
&sg.class, 12, 0, 0, 0, 0 );
emacs_ospeed = sg.xmit_baud;
#else /* not VMS */
@@ -430,7 +430,7 @@ init_baud_rate ()
struct termios sg;
sg.c_cflag = B9600;
- tcgetattr (input_fd, &sg);
+ tcgetattr (fd, &sg);
emacs_ospeed = cfgetospeed (&sg);
#if defined (USE_GETOBAUD) && defined (getobaud)
/* m88k-motorola-sysv3 needs this ([email protected]) 9/1/94. */
@@ -443,16 +443,16 @@ init_baud_rate ()
sg.c_cflag = B9600;
#ifdef HAVE_TCATTR
- tcgetattr (input_fd, &sg);
+ tcgetattr (fd, &sg);
#else
- ioctl (input_fd, TCGETA, &sg);
+ ioctl (fd, TCGETA, &sg);
#endif
emacs_ospeed = sg.c_cflag & CBAUD;
#else /* neither VMS nor TERMIOS nor TERMIO */
struct sgttyb sg;
sg.sg_ospeed = B9600;
- if (ioctl (input_fd, TIOCGETP, &sg) < 0)
+ if (ioctl (fd, TIOCGETP, &sg) < 0)
abort ();
emacs_ospeed = sg.sg_ospeed;
#endif /* not HAVE_TERMIO */
@@ -468,6 +468,7 @@ init_baud_rate ()
baud_rate = 1200;
}
+
/*ARGSUSED*/
void
set_exclusive_use (fd)
@@ -729,7 +730,7 @@ child_setup_tty (out)
#ifdef BSD4_1
if (interrupt_input)
- reset_sigio ();
+ reset_sigio (0);
#endif /* BSD4_1 */
#ifdef RTU
{
@@ -986,53 +987,86 @@ restore_signal_handlers (saved_handlers)
}
}
+#ifndef SIGIO
+/* If SIGIO is broken, don't do anything. */
+void
+init_sigio (int fd)
+{
+}
+
+void
+reset_sigio (int fd)
+{
+}
+
+void
+request_sigio (void)
+{
+}
+
+void
+unrequest_sigio (void)
+{
+}
+
+#else
#ifdef F_SETFL
-int old_fcntl_flags;
+int old_fcntl_flags[MAXDESC];
void
init_sigio (fd)
int fd;
{
#ifdef FASYNC
- old_fcntl_flags = fcntl (fd, F_GETFL, 0) & ~FASYNC;
- fcntl (fd, F_SETFL, old_fcntl_flags | FASYNC);
+ old_fcntl_flags[fd] = fcntl (fd, F_GETFL, 0) & ~FASYNC;
+ fcntl (fd, F_SETFL, old_fcntl_flags[fd] | FASYNC);
#endif
interrupts_deferred = 0;
}
void
-reset_sigio ()
+reset_sigio (fd)
+ int fd;
{
- unrequest_sigio ();
+#ifdef FASYNC
+ fcntl (fd, F_SETFL, old_fcntl_flags[fd]);
+#endif
}
#ifdef FASYNC /* F_SETFL does not imply existence of FASYNC */
+/* XXX Uhm, FASYNC is not used anymore here. */
+/* XXX Yeah, but you need it for SIGIO, don't you? */
void
request_sigio ()
{
- if (noninteractive || read_socket_hook)
+ if (noninteractive)
return;
#ifdef SIGWINCH
sigunblock (sigmask (SIGWINCH));
#endif
- fcntl (input_fd, F_SETFL, old_fcntl_flags | FASYNC);
+ sigunblock (sigmask (SIGIO));
interrupts_deferred = 0;
}
void
-unrequest_sigio ()
-{
- if (noninteractive || read_socket_hook)
+unrequest_sigio (void)
+{
+ if (noninteractive)
return;
+#if 0 /* XXX What's wrong with blocking SIGIO under X? */
+ if (x_display_list)
+ return;
+#endif
+
#ifdef SIGWINCH
sigblock (sigmask (SIGWINCH));
#endif
- fcntl (input_fd, F_SETFL, old_fcntl_flags);
+ sigblock (sigmask (SIGIO));
interrupts_deferred = 1;
}
@@ -1047,7 +1081,8 @@ request_sigio ()
if (noninteractive || read_socket_hook)
return;
- ioctl (input_fd, FIOASYNC, &on);
+ /* XXX CURTTY() is bogus here. */
+ ioctl (fileno (CURTTY ()->input), FIOASYNC, &on);
interrupts_deferred = 0;
}
@@ -1059,7 +1094,8 @@ unrequest_sigio ()
if (noninteractive || read_socket_hook)
return;
- ioctl (input_fd, FIOASYNC, &off);
+ /* XXX CURTTY() is bogus here. */
+ ioctl (fileno (CURTTY ()->input), FIOASYNC, &off);
interrupts_deferred = 1;
}
@@ -1080,7 +1116,7 @@ request_sigio ()
sigemptyset (&st);
sigaddset (&st, SIGIO);
- ioctl (input_fd, FIOASYNC, &on);
+ ioctl (0, FIOASYNC, &on); /* XXX This fails for multiple ttys. */
interrupts_deferred = 0;
sigprocmask (SIG_UNBLOCK, &st, (sigset_t *)0);
}
@@ -1093,7 +1129,7 @@ unrequest_sigio ()
if (noninteractive || read_socket_hook)
return;
- ioctl (input_fd, FIOASYNC, &off);
+ ioctl (0, FIOASYNC, &off); /* XXX This fails for multiple ttys. */
interrupts_deferred = 1;
}
@@ -1123,6 +1159,7 @@ unrequest_sigio ()
#endif /* STRIDE */
#endif /* FASYNC */
#endif /* F_SETFL */
+#endif /* SIGIO */
/* Saving and restoring the process group of Emacs's terminal. */
@@ -1145,30 +1182,39 @@ unrequest_sigio ()
the tty's pgroup just like any other terminal setting. If
inherited_group was not the tty's pgroup, then we'll get a
SIGTTmumble when we try to change the tty's pgroup, and a CONT if
- it goes foreground in the future, which is what should happen. */
+ it goes foreground in the future, which is what should happen.
+
+ This variable is initialized in emacs.c. */
int inherited_pgroup;
-/* Split off the foreground process group to Emacs alone.
- When we are in the foreground, but not started in our own process
- group, redirect the TTY to point to our own process group. We need
- to be in our own process group to receive SIGIO properly. */
-void
-narrow_foreground_group ()
+/* Split off the foreground process group to Emacs alone. When we are
+ in the foreground, but not started in our own process group,
+ redirect the tty device handle FD to point to our own process
+ group. We need to be in our own process group to receive SIGIO
+ properly. */
+static void
+narrow_foreground_group (int fd)
{
int me = getpid ();
setpgrp (0, inherited_pgroup);
+#if 0
+ /* XXX inherited_pgroup should not be zero here, but GTK seems to
+ mess this up. */
+ if (! inherited_pgroup)
+ abort (); /* Should not happen. */
+#endif
if (inherited_pgroup != me)
- EMACS_SET_TTY_PGRP (input_fd, &me);
+ EMACS_SET_TTY_PGRP (fd, &me); /* XXX This only works on the controlling tty. */
setpgrp (0, me);
}
/* Set the tty to our original foreground group. */
-void
-widen_foreground_group ()
+static void
+widen_foreground_group (int fd)
{
if (inherited_pgroup != getpid ())
- EMACS_SET_TTY_PGRP (input_fd, &inherited_pgroup);
+ EMACS_SET_TTY_PGRP (fd, &inherited_pgroup);
setpgrp (0, inherited_pgroup);
}
@@ -1326,14 +1372,6 @@ emacs_set_tty (fd, settings, flushp)
}
-/* The initial tty mode bits */
-struct emacs_tty old_tty;
-
-/* 1 if we have been through init_sys_modes. */
-int term_initted;
-
-/* 1 if outer tty status has been recorded. */
-int old_tty_valid;
#ifdef BSD4_1
/* BSD 4.1 needs to keep track of the lmode bits in order to start
@@ -1343,7 +1381,7 @@ int lmode;
#ifndef F_SETOWN_BUG
#ifdef F_SETOWN
-int old_fcntl_owner;
+int old_fcntl_owner[MAXDESC];
#endif /* F_SETOWN */
#endif /* F_SETOWN_BUG */
@@ -1368,8 +1406,22 @@ static struct ltchars new_ltchars = {-1,-1,-1,-1,-1,-1};
static struct tchars new_tchars = {-1,-1,-1,-1,-1,-1};
#endif
+/* Initialize the terminal mode on all tty devices that are currently
+ open. */
+
void
-init_sys_modes ()
+init_all_sys_modes (void)
+{
+ struct tty_display_info *tty;
+ for (tty = tty_list; tty; tty = tty->next)
+ init_sys_modes (tty);
+}
+
+/* Initialize the terminal mode on the given tty device. */
+
+void
+init_sys_modes (tty_out)
+ struct tty_display_info *tty_out;
{
struct emacs_tty tty;
@@ -1385,6 +1437,9 @@ init_sys_modes ()
if (noninteractive)
return;
+ if (!tty_out->output)
+ return; /* The tty is suspended. */
+
#ifdef VMS
if (!input_ef)
input_ef = get_kbd_event_flag ();
@@ -1415,269 +1470,291 @@ init_sys_modes ()
#ifndef VMS4_4
sys_access_reinit ();
#endif
-#endif /* not VMS */
+#endif /* VMS */
#ifdef BSD_PGRPS
- if (! read_socket_hook && EQ (Vwindow_system, Qnil))
- narrow_foreground_group ();
+#if 0
+ /* read_socket_hook is not global anymore. I think doing this
+ unconditionally will not cause any problems. */
+ if (! read_socket_hook && EQ (Vinitial_window_system, Qnil))
#endif
-
-#ifdef HAVE_WINDOW_SYSTEM
- /* Emacs' window system on MSDOG uses the `internal terminal' and therefore
- needs the initialization code below. */
- if (!read_socket_hook && EQ (Vwindow_system, Qnil))
+ narrow_foreground_group (fileno (tty_out->input));
#endif
- {
- EMACS_GET_TTY (input_fd, &old_tty);
- old_tty_valid = 1;
+ if (! tty_out->old_tty)
+ tty_out->old_tty = (struct emacs_tty *) xmalloc (sizeof (struct emacs_tty));
+
+ EMACS_GET_TTY (fileno (tty_out->input), tty_out->old_tty);
- tty = old_tty;
+ tty = *tty_out->old_tty;
#if defined (HAVE_TERMIO) || defined (HAVE_TERMIOS)
- XSETINT (Vtty_erase_char, old_tty.main.c_cc[VERASE]);
+ XSETINT (Vtty_erase_char, tty.main.c_cc[VERASE]);
#ifdef DGUX
- /* This allows meta to be sent on 8th bit. */
- tty.main.c_iflag &= ~INPCK; /* don't check input for parity */
+ /* This allows meta to be sent on 8th bit. */
+ tty.main.c_iflag &= ~INPCK; /* don't check input for parity */
#endif
- tty.main.c_iflag |= (IGNBRK); /* Ignore break condition */
- tty.main.c_iflag &= ~ICRNL; /* Disable map of CR to NL on input */
+ tty.main.c_iflag |= (IGNBRK); /* Ignore break condition */
+ tty.main.c_iflag &= ~ICRNL; /* Disable map of CR to NL on input */
#ifdef INLCR /* I'm just being cautious,
since I can't check how widespread INLCR is--rms. */
- tty.main.c_iflag &= ~INLCR; /* Disable map of NL to CR on input */
+ tty.main.c_iflag &= ~INLCR; /* Disable map of NL to CR on input */
#endif
#ifdef ISTRIP
- tty.main.c_iflag &= ~ISTRIP; /* don't strip 8th bit on input */
+ tty.main.c_iflag &= ~ISTRIP; /* don't strip 8th bit on input */
#endif
- tty.main.c_lflag &= ~ECHO; /* Disable echo */
- tty.main.c_lflag &= ~ICANON; /* Disable erase/kill processing */
+ tty.main.c_lflag &= ~ECHO; /* Disable echo */
+ tty.main.c_lflag &= ~ICANON; /* Disable erase/kill processing */
#ifdef IEXTEN
- tty.main.c_lflag &= ~IEXTEN; /* Disable other editing characters. */
+ tty.main.c_lflag &= ~IEXTEN; /* Disable other editing characters. */
#endif
- tty.main.c_lflag |= ISIG; /* Enable signals */
- if (flow_control)
- {
- tty.main.c_iflag |= IXON; /* Enable start/stop output control */
+ tty.main.c_lflag |= ISIG; /* Enable signals */
+ if (tty_out->flow_control)
+ {
+ tty.main.c_iflag |= IXON; /* Enable start/stop output control */
#ifdef IXANY
- tty.main.c_iflag &= ~IXANY;
+ tty.main.c_iflag &= ~IXANY;
#endif /* IXANY */
- }
- else
- tty.main.c_iflag &= ~IXON; /* Disable start/stop output control */
- tty.main.c_oflag &= ~ONLCR; /* Disable map of NL to CR-NL
- on output */
- tty.main.c_oflag &= ~TAB3; /* Disable tab expansion */
+ }
+ else
+ tty.main.c_iflag &= ~IXON; /* Disable start/stop output control */
+ tty.main.c_oflag &= ~ONLCR; /* Disable map of NL to CR-NL
+ on output */
+ tty.main.c_oflag &= ~TAB3; /* Disable tab expansion */
#ifdef CS8
- if (meta_key)
- {
- tty.main.c_cflag |= CS8; /* allow 8th bit on input */
- tty.main.c_cflag &= ~PARENB;/* Don't check parity */
- }
+ if (tty_out->meta_key)
+ {
+ tty.main.c_cflag |= CS8; /* allow 8th bit on input */
+ tty.main.c_cflag &= ~PARENB;/* Don't check parity */
+ }
#endif
+ if (tty_out->input == stdin)
+ {
tty.main.c_cc[VINTR] = quit_char; /* C-g (usually) gives SIGINT */
/* Set up C-g for both SIGQUIT and SIGINT.
- We don't know which we will get, but we handle both alike
- so which one it really gives us does not matter. */
+ We don't know which we will get, but we handle both alike
+ so which one it really gives us does not matter. */
tty.main.c_cc[VQUIT] = quit_char;
- tty.main.c_cc[VMIN] = 1; /* Input should wait for at least 1 char */
- tty.main.c_cc[VTIME] = 0; /* no matter how long that takes. */
+ }
+ else
+ {
+ /* We normally don't get interrupt or quit signals from tty
+ devices other than our controlling terminal; therefore,
+ we must handle C-g as normal input. Unfortunately, this
+ means that the interrupt and quit feature must be
+ disabled on secondary ttys, or we would not even see the
+ keypress.
+
+ Note that even though emacsclient could have special code
+ to pass SIGINT to Emacs, we should _not_ enable
+ interrupt/quit keys for emacsclient frames. This means
+ that we can't break out of loops in C code from a
+ secondary tty frame, but we can always decide what
+ display the C-g came from, which is more important from a
+ usability point of view. (Consider the case when two
+ people work together using the same Emacs instance.) */
+ tty.main.c_cc[VINTR] = CDISABLE;
+ tty.main.c_cc[VQUIT] = CDISABLE;
+ }
+ tty.main.c_cc[VMIN] = 1; /* Input should wait for at least 1 char */
+ tty.main.c_cc[VTIME] = 0; /* no matter how long that takes. */
#ifdef VSWTCH
- tty.main.c_cc[VSWTCH] = CDISABLE; /* Turn off shell layering use
+ tty.main.c_cc[VSWTCH] = CDISABLE; /* Turn off shell layering use
of C-z */
#endif /* VSWTCH */
-
+
#if defined (mips) || defined (HAVE_TCATTR)
#ifdef VSUSP
- tty.main.c_cc[VSUSP] = CDISABLE; /* Turn off mips handling of C-z. */
+ tty.main.c_cc[VSUSP] = CDISABLE; /* Turn off mips handling of C-z. */
#endif /* VSUSP */
#ifdef V_DSUSP
- tty.main.c_cc[V_DSUSP] = CDISABLE; /* Turn off mips handling of C-y. */
+ tty.main.c_cc[V_DSUSP] = CDISABLE; /* Turn off mips handling of C-y. */
#endif /* V_DSUSP */
#ifdef VDSUSP /* Some systems have VDSUSP, some have V_DSUSP. */
- tty.main.c_cc[VDSUSP] = CDISABLE;
+ tty.main.c_cc[VDSUSP] = CDISABLE;
#endif /* VDSUSP */
#ifdef VLNEXT
- tty.main.c_cc[VLNEXT] = CDISABLE;
+ tty.main.c_cc[VLNEXT] = CDISABLE;
#endif /* VLNEXT */
#ifdef VREPRINT
- tty.main.c_cc[VREPRINT] = CDISABLE;
+ tty.main.c_cc[VREPRINT] = CDISABLE;
#endif /* VREPRINT */
#ifdef VWERASE
- tty.main.c_cc[VWERASE] = CDISABLE;
+ tty.main.c_cc[VWERASE] = CDISABLE;
#endif /* VWERASE */
#ifdef VDISCARD
- tty.main.c_cc[VDISCARD] = CDISABLE;
+ tty.main.c_cc[VDISCARD] = CDISABLE;
#endif /* VDISCARD */
- if (flow_control)
- {
+ if (tty_out->flow_control)
+ {
#ifdef VSTART
- tty.main.c_cc[VSTART] = '\021';
+ tty.main.c_cc[VSTART] = '\021';
#endif /* VSTART */
#ifdef VSTOP
- tty.main.c_cc[VSTOP] = '\023';
+ tty.main.c_cc[VSTOP] = '\023';
#endif /* VSTOP */
- }
- else
- {
+ }
+ else
+ {
#ifdef VSTART
- tty.main.c_cc[VSTART] = CDISABLE;
+ tty.main.c_cc[VSTART] = CDISABLE;
#endif /* VSTART */
#ifdef VSTOP
- tty.main.c_cc[VSTOP] = CDISABLE;
+ tty.main.c_cc[VSTOP] = CDISABLE;
#endif /* VSTOP */
- }
+ }
#endif /* mips or HAVE_TCATTR */
#ifdef SET_LINE_DISCIPLINE
- /* Need to explicitly request TERMIODISC line discipline or
- Ultrix's termios does not work correctly. */
- tty.main.c_line = SET_LINE_DISCIPLINE;
+ /* Need to explicitly request TERMIODISC line discipline or
+ Ultrix's termios does not work correctly. */
+ tty.main.c_line = SET_LINE_DISCIPLINE;
#endif
#ifdef AIX
#ifndef IBMR2AIX
- /* AIX enhanced edit loses NULs, so disable it. */
- tty.main.c_line = 0;
- tty.main.c_iflag &= ~ASCEDIT;
+ /* AIX enhanced edit loses NULs, so disable it. */
+ tty.main.c_line = 0;
+ tty.main.c_iflag &= ~ASCEDIT;
#else
- tty.main.c_cc[VSTRT] = CDISABLE;
- tty.main.c_cc[VSTOP] = CDISABLE;
- tty.main.c_cc[VSUSP] = CDISABLE;
- tty.main.c_cc[VDSUSP] = CDISABLE;
+ tty.main.c_cc[VSTRT] = CDISABLE;
+ tty.main.c_cc[VSTOP] = CDISABLE;
+ tty.main.c_cc[VSUSP] = CDISABLE;
+ tty.main.c_cc[VDSUSP] = CDISABLE;
#endif /* IBMR2AIX */
- if (flow_control)
- {
+ if (tty_out->flow_control)
+ {
#ifdef VSTART
- tty.main.c_cc[VSTART] = '\021';
+ tty.main.c_cc[VSTART] = '\021';
#endif /* VSTART */
#ifdef VSTOP
- tty.main.c_cc[VSTOP] = '\023';
+ tty.main.c_cc[VSTOP] = '\023';
#endif /* VSTOP */
- }
- /* Also, PTY overloads NUL and BREAK.
- don't ignore break, but don't signal either, so it looks like NUL.
- This really serves a purpose only if running in an XTERM window
- or via TELNET or the like, but does no harm elsewhere. */
- tty.main.c_iflag &= ~IGNBRK;
- tty.main.c_iflag &= ~BRKINT;
+ }
+ /* Also, PTY overloads NUL and BREAK.
+ don't ignore break, but don't signal either, so it looks like NUL.
+ This really serves a purpose only if running in an XTERM window
+ or via TELNET or the like, but does no harm elsewhere. */
+ tty.main.c_iflag &= ~IGNBRK;
+ tty.main.c_iflag &= ~BRKINT;
#endif
#else /* if not HAVE_TERMIO */
#ifdef VMS
- tty.main.tt_char |= TT$M_NOECHO;
- if (meta_key)
- tty.main.tt_char |= TT$M_EIGHTBIT;
- if (flow_control)
- tty.main.tt_char |= TT$M_TTSYNC;
- else
- tty.main.tt_char &= ~TT$M_TTSYNC;
- tty.main.tt2_char |= TT2$M_PASTHRU | TT2$M_XON;
+ tty.main.tt_char |= TT$M_NOECHO;
+ if (meta_key)
+ tty.main.tt_char |= TT$M_EIGHTBIT;
+ if (tty_out->flow_control)
+ tty.main.tt_char |= TT$M_TTSYNC;
+ else
+ tty.main.tt_char &= ~TT$M_TTSYNC;
+ tty.main.tt2_char |= TT2$M_PASTHRU | TT2$M_XON;
#else /* not VMS (BSD, that is) */
#ifndef DOS_NT
- XSETINT (Vtty_erase_char, tty.main.sg_erase);
- tty.main.sg_flags &= ~(ECHO | CRMOD | XTABS);
- if (meta_key)
- tty.main.sg_flags |= ANYP;
- tty.main.sg_flags |= interrupt_input ? RAW : CBREAK;
+ XSETINT (Vtty_erase_char, tty.main.sg_erase);
+ tty.main.sg_flags &= ~(ECHO | CRMOD | XTABS);
+ if (meta_key)
+ tty.main.sg_flags |= ANYP;
+ tty.main.sg_flags |= interrupt_input ? RAW : CBREAK;
#endif /* not DOS_NT */
#endif /* not VMS (BSD, that is) */
#endif /* not HAVE_TERMIO */
- /* If going to use CBREAK mode, we must request C-g to interrupt
- and turn off start and stop chars, etc. If not going to use
- CBREAK mode, do this anyway so as to turn off local flow
- control for user coming over network on 4.2; in this case,
- only t_stopc and t_startc really matter. */
+ /* If going to use CBREAK mode, we must request C-g to interrupt
+ and turn off start and stop chars, etc. If not going to use
+ CBREAK mode, do this anyway so as to turn off local flow
+ control for user coming over network on 4.2; in this case,
+ only t_stopc and t_startc really matter. */
#ifndef HAVE_TERMIO
#ifdef HAVE_TCHARS
- /* Note: if not using CBREAK mode, it makes no difference how we
- set this */
- tty.tchars = new_tchars;
- tty.tchars.t_intrc = quit_char;
- if (flow_control)
- {
- tty.tchars.t_startc = '\021';
- tty.tchars.t_stopc = '\023';
- }
-
- tty.lmode = LDECCTQ | LLITOUT | LPASS8 | LNOFLSH | old_tty.lmode;
+ /* Note: if not using CBREAK mode, it makes no difference how we
+ set this */
+ tty.tchars = new_tchars;
+ tty.tchars.t_intrc = quit_char;
+ if (tty_out->flow_control)
+ {
+ tty.tchars.t_startc = '\021';
+ tty.tchars.t_stopc = '\023';
+ }
+
+ tty.lmode = LDECCTQ | LLITOUT | LPASS8 | LNOFLSH | tty_out->old_tty.lmode;
#ifdef ultrix
- /* Under Ultrix 4.2a, leaving this out doesn't seem to hurt
- anything, and leaving it in breaks the meta key. Go figure. */
- tty.lmode &= ~LLITOUT;
+ /* Under Ultrix 4.2a, leaving this out doesn't seem to hurt
+ anything, and leaving it in breaks the meta key. Go figure. */
+ tty.lmode &= ~LLITOUT;
#endif
-
+
#ifdef BSD4_1
- lmode = tty.lmode;
+ lmode = tty.lmode;
#endif
#endif /* HAVE_TCHARS */
#endif /* not HAVE_TERMIO */
#ifdef HAVE_LTCHARS
- tty.ltchars = new_ltchars;
+ tty.ltchars = new_ltchars;
#endif /* HAVE_LTCHARS */
#ifdef MSDOS /* Demacs 1.1.2 91/10/20 Manabu Higashida, MW Aug 1993 */
- if (!term_initted)
- internal_terminal_init ();
- dos_ttraw ();
+ if (!tty_out->term_initted)
+ internal_terminal_init ();
+ dos_ttraw ();
#endif
- EMACS_SET_TTY (input_fd, &tty, 0);
+ EMACS_SET_TTY (fileno (tty_out->input), &tty, 0);
- /* This code added to insure that, if flow-control is not to be used,
- we have an unlocked terminal at the start. */
+ /* This code added to insure that, if flow-control is not to be used,
+ we have an unlocked terminal at the start. */
#ifdef TCXONC
- if (!flow_control) ioctl (input_fd, TCXONC, 1);
+ if (!tty_out->flow_control) ioctl (fileno (tty_out->input), TCXONC, 1);
#endif
#ifndef APOLLO
#ifdef TIOCSTART
- if (!flow_control) ioctl (input_fd, TIOCSTART, 0);
+ if (!tty_out->flow_control) ioctl (fileno (tty_out->input), TIOCSTART, 0);
#endif
#endif
#if defined (HAVE_TERMIOS) || defined (HPUX9)
#ifdef TCOON
- if (!flow_control) tcflow (input_fd, TCOON);
+ if (!tty_out->flow_control) tcflow (fileno (tty_out->input), TCOON);
#endif
#endif
#ifdef AIXHFT
- hft_init ();
+ hft_init (tty_out);
#ifdef IBMR2AIX
- {
- /* IBM's HFT device usually thinks a ^J should be LF/CR. We need it
- to be only LF. This is the way that is done. */
- struct termio tty;
-
- if (ioctl (1, HFTGETID, &tty) != -1)
- write (1, "\033[20l", 5);
- }
+ {
+ /* IBM's HFT device usually thinks a ^J should be LF/CR. We need it
+ to be only LF. This is the way that is done. */
+ struct termio tty;
+
+ if (ioctl (1, HFTGETID, &tty) != -1)
+ write (1, "\033[20l", 5);
+ }
#endif
#endif /* AIXHFT */
#ifdef VMS
/* Appears to do nothing when in PASTHRU mode.
- SYS$QIOW (0, input_fd, IO$_SETMODE|IO$M_OUTBAND, 0, 0, 0,
+ SYS$QIOW (0, fileno (tty_out->input), IO$_SETMODE|IO$M_OUTBAND, 0, 0, 0,
interrupt_signal, oob_chars, 0, 0, 0, 0);
*/
- queue_kbd_input (0);
+ queue_kbd_input (0);
#endif /* VMS */
- }
#ifdef F_SETFL
#ifndef F_SETOWN_BUG
#ifdef F_GETOWN /* F_SETFL does not imply existence of F_GETOWN */
- if (interrupt_input
- && ! read_socket_hook && EQ (Vwindow_system, Qnil))
+ if (interrupt_input)
{
- old_fcntl_owner = fcntl (input_fd, F_GETOWN, 0);
- fcntl (input_fd, F_SETOWN, getpid ());
- init_sigio (input_fd);
+ old_fcntl_owner[fileno (tty_out->input)] =
+ fcntl (fileno (tty_out->input), F_GETOWN, 0);
+ fcntl (fileno (tty_out->input), F_SETOWN, getpid ());
+ init_sigio (fileno (tty_out->input));
#ifdef HAVE_GPM
- if (term_gpm)
+ if (gpm_tty == tty_out)
{
+ /* Arrange for mouse events to give us SIGIO signals. */
fcntl (gpm_fd, F_SETOWN, getpid ());
fcntl (gpm_fd, F_SETFL, fcntl (gpm_fd, F_GETFL, 0) | O_NONBLOCK);
init_sigio (gpm_fd);
@@ -1690,7 +1767,7 @@ init_sys_modes ()
#ifdef BSD4_1
if (interrupt_input)
- init_sigio (input_fd);
+ init_sigio (fileno (tty_out->input));
#endif
#ifdef VMS /* VMS sometimes has this symbol but lacks setvbuf. */
@@ -1700,53 +1777,57 @@ init_sys_modes ()
/* This symbol is defined on recent USG systems.
Someone says without this call USG won't really buffer the file
even with a call to setbuf. */
- setvbuf (stdout, (char *) _sobuf, _IOFBF, sizeof _sobuf);
+ setvbuf (tty_out->output, (char *) _sobuf, _IOFBF, sizeof _sobuf);
#else
- setbuf (stdout, (char *) _sobuf);
+ setbuf (tty_out->output, (char *) _sobuf);
#endif
-#ifdef HAVE_WINDOW_SYSTEM
- /* Emacs' window system on MSDOG uses the `internal terminal' and therefore
- needs the initialization code below. */
- if (EQ (Vwindow_system, Qnil)
-#ifndef WINDOWSNT
- /* When running in tty mode on NT/Win95, we have a read_socket
- hook, but still need the rest of the initialization code below. */
- && (! read_socket_hook)
-#endif
- )
-#endif
- set_terminal_modes ();
- if (!term_initted
- && FRAMEP (Vterminal_frame)
- && FRAME_TERMCAP_P (XFRAME (Vterminal_frame)))
- init_frame_faces (XFRAME (Vterminal_frame));
+ if (tty_out->terminal->set_terminal_modes_hook)
+ tty_out->terminal->set_terminal_modes_hook (tty_out->terminal);
- if (term_initted && no_redraw_on_reenter)
+ if (!tty_out->term_initted)
{
+ Lisp_Object tail, frame;
+ FOR_EACH_FRAME (tail, frame)
+ {
+ /* XXX This needs to be revised. */
+ if (FRAME_TERMCAP_P (XFRAME (frame))
+ && FRAME_TTY (XFRAME (frame)) == tty_out)
+ init_frame_faces (XFRAME (frame));
+ }
+ }
+
+ if (tty_out->term_initted && no_redraw_on_reenter)
+ {
+ /* XXX This seems wrong on multi-tty. */
if (display_completed)
direct_output_forward_char (0);
}
else
{
+ Lisp_Object tail, frame;
frame_garbaged = 1;
- if (FRAMEP (Vterminal_frame))
- FRAME_GARBAGED_P (XFRAME (Vterminal_frame)) = 1;
+ FOR_EACH_FRAME (tail, frame)
+ {
+ if (FRAME_TERMCAP_P (XFRAME (frame))
+ && FRAME_TTY (XFRAME (frame)) == tty_out)
+ FRAME_GARBAGED_P (XFRAME (frame)) = 1;
+ }
}
- term_initted = 1;
+ tty_out->term_initted = 1;
}
/* Return nonzero if safe to use tabs in output.
At the time this is called, init_sys_modes has not been done yet. */
int
-tabs_safe_p ()
+tabs_safe_p (int fd)
{
- struct emacs_tty tty;
+ struct emacs_tty etty;
- EMACS_GET_TTY (input_fd, &tty);
- return EMACS_TTY_TABS_OK (&tty);
+ EMACS_GET_TTY (fd, &etty);
+ return EMACS_TTY_TABS_OK (&etty);
}
/* Get terminal size from system.
@@ -1754,8 +1835,7 @@ tabs_safe_p ()
We store 0 if there's no valid information. */
void
-get_frame_size (widthp, heightp)
- int *widthp, *heightp;
+get_tty_size (int fd, int *widthp, int *heightp)
{
#ifdef TIOCGWINSZ
@@ -1763,7 +1843,7 @@ get_frame_size (widthp, heightp)
/* BSD-style. */
struct winsize size;
- if (ioctl (input_fd, TIOCGWINSZ, &size) == -1)
+ if (ioctl (fd, TIOCGWINSZ, &size) == -1)
*widthp = *heightp = 0;
else
{
@@ -1777,7 +1857,7 @@ get_frame_size (widthp, heightp)
/* SunOS - style. */
struct ttysize size;
- if (ioctl (input_fd, TIOCGSIZE, &size) == -1)
+ if (ioctl (fd, TIOCGSIZE, &size) == -1)
*widthp = *heightp = 0;
else
{
@@ -1809,7 +1889,6 @@ get_frame_size (widthp, heightp)
*widthp = 0;
*heightp = 0;
#endif
-
#endif /* not VMS */
#endif /* not SunOS-style */
#endif /* not BSD-style */
@@ -1853,37 +1932,58 @@ set_window_size (fd, height, width)
}
-/* Prepare the terminal for exiting Emacs; move the cursor to the
- bottom of the frame, turn off interrupt-driven I/O, etc. */
+
+/* Prepare all terminal devices for exiting Emacs. */
+
void
-reset_sys_modes ()
+reset_all_sys_modes (void)
{
- struct frame *sf;
+ struct tty_display_info *tty;
+ for (tty = tty_list; tty; tty = tty->next)
+ reset_sys_modes (tty);
+}
+
+/* Prepare the terminal for closing it; move the cursor to the
+ bottom of the frame, turn off interrupt-driven I/O, etc. */
+void
+reset_sys_modes (tty_out)
+ struct tty_display_info *tty_out;
+{
if (noninteractive)
{
fflush (stdout);
return;
}
- if (!term_initted)
+ if (!tty_out->term_initted)
return;
-#ifdef HAVE_WINDOW_SYSTEM
- /* Emacs' window system on MSDOG uses the `internal terminal' and therefore
- needs the clean-up code below. */
- if (!EQ (Vwindow_system, Qnil)
-#ifndef WINDOWSNT
- /* When running in tty mode on NT/Win95, we have a read_socket
- hook, but still need the rest of the clean-up code below. */
- || read_socket_hook
-#endif
- )
- return;
-#endif
- sf = SELECTED_FRAME ();
- cursor_to (FRAME_LINES (sf) - 1, 0);
- clear_end_of_line (FRAME_COLS (sf));
- /* clear_end_of_line may move the cursor */
- cursor_to (FRAME_LINES (sf) - 1, 0);
+
+ if (!tty_out->output)
+ return; /* The tty is suspended. */
+
+ /* Go to and clear the last line of the terminal. */
+
+ cmgoto (tty_out, FrameRows (tty_out) - 1, 0);
+
+ /* Code adapted from tty_clear_end_of_line. */
+ if (tty_out->TS_clr_line)
+ {
+ emacs_tputs (tty_out, tty_out->TS_clr_line, 1, cmputc);
+ }
+ else
+ { /* have to do it the hard way */
+ int i;
+ tty_turn_off_insert (tty_out);
+
+ for (i = curX (tty_out); i < FrameCols (tty_out) - 1; i++)
+ {
+ fputc (' ', tty_out->output);
+ }
+ }
+
+ cmgoto (tty_out, FrameRows (tty_out) - 1, 0);
+ fflush (tty_out->output);
+
#if defined (IBMR2AIX) && defined (AIXHFT)
{
/* HFT devices normally use ^J as a LF/CR. We forced it to
@@ -1895,12 +1995,13 @@ reset_sys_modes ()
}
#endif
- reset_terminal_modes ();
- fflush (stdout);
+ if (tty_out->terminal->reset_terminal_modes_hook)
+ tty_out->terminal->reset_terminal_modes_hook (tty_out->terminal);
+
#ifdef BSD_SYSTEM
#ifndef BSD4_1
/* Avoid possible loss of output when changing terminal modes. */
- fsync (fileno (stdout));
+ fsync (fileno (tty_out->output));
#endif
#endif
@@ -1909,22 +2010,25 @@ reset_sys_modes ()
#ifdef F_SETOWN /* F_SETFL does not imply existence of F_SETOWN */
if (interrupt_input)
{
- reset_sigio ();
- fcntl (input_fd, F_SETOWN, old_fcntl_owner);
+ reset_sigio (fileno (tty_out->input));
+ fcntl (fileno (tty_out->input), F_SETOWN,
+ old_fcntl_owner[fileno (tty_out->input)]);
}
#endif /* F_SETOWN */
#endif /* F_SETOWN_BUG */
#ifdef O_NDELAY
- fcntl (input_fd, F_SETFL, fcntl (input_fd, F_GETFL, 0) & ~O_NDELAY);
+ fcntl (fileno (tty_out->input), F_SETFL,
+ fcntl (fileno (tty_out->input), F_GETFL, 0) & ~O_NDELAY);
#endif
#endif /* F_SETFL */
#ifdef BSD4_1
if (interrupt_input)
- reset_sigio ();
+ reset_sigio (fileno (tty_out->input));
#endif /* BSD4_1 */
- if (old_tty_valid)
- while (EMACS_SET_TTY (input_fd, &old_tty, 0) < 0 && errno == EINTR)
+ if (tty_out->old_tty)
+ while (EMACS_SET_TTY (fileno (tty_out->input),
+ tty_out->old_tty, 0) < 0 && errno == EINTR)
;
#ifdef MSDOS /* Demacs 1.1.2 91/10/20 Manabu Higashida */
@@ -1935,7 +2039,7 @@ reset_sys_modes ()
/* Ultrix's termios *ignores* any line discipline except TERMIODISC.
A different old line discipline is therefore not restored, yet.
Restore the old line discipline by hand. */
- ioctl (0, TIOCSETD, &old_tty.main.c_line);
+ ioctl (0, TIOCSETD, &tty_out->old_tty.main.c_line);
#endif
#ifdef AIXHFT
@@ -1943,7 +2047,7 @@ reset_sys_modes ()
#endif
#ifdef BSD_PGRPS
- widen_foreground_group ();
+ widen_foreground_group (fileno (tty_out->input));
#endif
}
@@ -2008,9 +2112,9 @@ init_vms_input ()
{
int status;
- if (input_fd == 0)
+ if (fileno (CURTTY ()->input)) == 0)
{
- status = SYS$ASSIGN (&input_dsc, &input_fd, 0, 0);
+ status = SYS$ASSIGN (&input_dsc, &fileno (CURTTY ()->input)), 0, 0);
if (! (status & 1))
LIB$STOP (status);
}
@@ -2021,7 +2125,7 @@ init_vms_input ()
void
stop_vms_input ()
{
- return SYS$DASSGN (input_fd);
+ return SYS$DASSGN (fileno (CURTTY ()->input)));
}
short input_buffer;
@@ -2037,7 +2141,7 @@ queue_kbd_input ()
waiting_for_ast = 0;
stop_input = 0;
- status = SYS$QIO (0, input_fd, IO$_READVBLK,
+ status = SYS$QIO (0, fileno (CURTTY()->input), IO$_READVBLK,
&input_iosb, kbd_input_ast, 1,
&input_buffer, 1, 0, terminator_mask, 0, 0);
}
@@ -2154,7 +2258,7 @@ end_kbd_input ()
#endif
if (LIB$AST_IN_PROG ()) /* Don't wait if suspending from kbd_buffer_store_event! */
{
- SYS$CANCEL (input_fd);
+ SYS$CANCEL (fileno (CURTTY()->input));
return;
}
@@ -2163,7 +2267,7 @@ end_kbd_input ()
SYS$CLREF (input_ef);
waiting_for_ast = 1;
stop_input = 1;
- SYS$CANCEL (input_fd);
+ SYS$CANCEL (fileno (CURTTY()->input));
SYS$SETAST (1);
SYS$WAITFR (input_ef);
waiting_for_ast = 0;
@@ -2225,7 +2329,8 @@ init_sigio (fd)
request_sigio ();
}
-reset_sigio ()
+reset_sigio (fd)
+ int fd;
{
unrequest_sigio ();
}
@@ -2567,7 +2672,9 @@ sys_select (nfds, rfds, wfds, efds, timeout)
SELECT_TYPE *rfds, *wfds, *efds;
EMACS_TIME *timeout;
{
- int ravail = 0;
+ /* XXX This needs to be updated for multi-tty support. Is there
+ anybody who needs to emulate select these days? */
+ int ravail = 0;
SELECT_TYPE orfds;
int timeoutval;
int *local_timeout;
@@ -2582,7 +2689,7 @@ sys_select (nfds, rfds, wfds, efds, timeout)
#if defined (HAVE_SELECT) && defined (HAVE_X_WINDOWS)
/* If we're using X, then the native select will work; we only need the
emulation for non-X usage. */
- if (!NILP (Vwindow_system))
+ if (!NILP (Vinitial_window_system))
return select (nfds, rfds, wfds, efds, timeout);
#endif
timeoutval = timeout ? EMACS_SECS (*timeout) : 100000;
@@ -2699,6 +2806,8 @@ sys_select (nfds, rfds, wfds, efds, timeout)
void
read_input_waiting ()
{
+ /* XXX This needs to be updated for multi-tty support. Is there
+ anybody who needs to emulate select these days? */
int nread, i;
extern int quit_char;
@@ -2752,6 +2861,10 @@ read_input_waiting ()
}
}
+#if !defined (HAVE_SELECT) || defined (BROKEN_SELECT_NON_X)
+#define select sys_select
+#endif
+
#endif /* not HAVE_SELECT */
#endif /* not VMS */
#endif /* not MSDOS */
@@ -2768,12 +2881,13 @@ init_sigio (fd)
}
void
-reset_sigio ()
+reset_sigio (fd)
+ int fd;
{
if (noninteractive)
return;
lmode = ~LINTRUP & lmode;
- ioctl (0, TIOCLSET, &lmode);
+ ioctl (fd, TIOCLSET, &lmode);
}
void
@@ -3229,7 +3343,7 @@ sys_getenv (name)
#undef abort
sys_abort ()
{
- reset_sys_modes ();
+ reset_all_sys_modes ();
LIB$SIGNAL (SS$_DEBUG);
}
#endif /* abort */
@@ -3556,7 +3670,7 @@ croak (badfunc)
char *badfunc;
{
printf ("%s not yet implemented\r\n", badfunc);
- reset_sys_modes ();
+ reset_all_sys_modes ();
exit (1);
}
@@ -5143,7 +5257,7 @@ croak (badfunc)
char *badfunc;
{
printf ("%s not yet implemented\r\n", badfunc);
- reset_sys_modes ();
+ reset_all_sys_modes ();
exit (1);
}
@@ -5165,7 +5279,7 @@ srandom (seed)
/* Called from init_sys_modes. */
void
-hft_init ()
+hft_init (struct tty_display_info *tty_out)
{
int junk;
@@ -5211,15 +5325,12 @@ hft_init ()
keymap.hfkey[1].hf_char = 127;
hftctl (0, HFSKBD, &buf);
}
- /* The HFT system on AIX doesn't optimize for scrolling, so it's really ugly
- at times. */
- line_ins_del_ok = char_ins_del_ok = 0;
}
/* Reset the rubout key to backspace. */
void
-hft_reset ()
+hft_reset (struct tty_display_info *tty_out)
{
struct hfbuf buf;
struct hfkeymap keymap;
diff --git a/src/syssignal.h b/src/syssignal.h
index b52e2dd4b9..72ac1ed7f6 100644
--- a/src/syssignal.h
+++ b/src/syssignal.h
@@ -33,6 +33,7 @@ extern pthread_t main_thread;
indicate that SIGIO doesn't work by #undef-ing SIGIO. If this file
#includes <signal.h>, then that will re-#define SIGIO and confuse
things. */
+/* XXX This is not correct anymore, there is a BROKEN_SIGIO macro. */
#define SIGMASKTYPE sigset_t
diff --git a/src/term.c b/src/term.c
index 88e120d6d6..b84cea0ee3 100644
--- a/src/term.c
+++ b/src/term.c
@@ -25,10 +25,20 @@ Boston, MA 02110-1301, USA. */
#include <stdio.h>
#include <ctype.h>
#include <string.h>
+#include <errno.h>
+#include <sys/file.h>
+
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
+#if HAVE_TERMIOS_H
+#include <termios.h> /* For TIOCNOTTY. */
+#endif
+
+#include <signal.h>
+
+#include "lisp.h"
#include "termchar.h"
#include "termopts.h"
#include "lisp.h"
@@ -45,6 +55,8 @@ Boston, MA 02110-1301, USA. */
#include "window.h"
#include "keymap.h"
#include "blockinput.h"
+#include "syssignal.h"
+#include "systty.h"
#include "intervals.h"
/* For now, don't try to include termcap.h. On some systems,
@@ -68,220 +80,74 @@ extern int tgetnum P_ ((char *id));
#include "macterm.h"
#endif
-static void turn_on_face P_ ((struct frame *, int face_id));
-static void turn_off_face P_ ((struct frame *, int face_id));
-static void tty_show_cursor P_ ((void));
-static void tty_hide_cursor P_ ((void));
-
-#define OUTPUT(a) \
- tputs (a, (int) (FRAME_LINES (XFRAME (selected_frame)) - curY), cmputc)
-#define OUTPUT1(a) tputs (a, 1, cmputc)
-#define OUTPUTL(a, lines) tputs (a, lines, cmputc)
-
-#define OUTPUT_IF(a) \
- do { \
- if (a) \
- tputs (a, (int) (FRAME_LINES (XFRAME (selected_frame)) \
- - curY), cmputc); \
- } while (0)
-
-#define OUTPUT1_IF(a) do { if (a) tputs (a, 1, cmputc); } while (0)
-
-/* Display space properties */
+#ifndef O_RDWR
+#define O_RDWR 2
+#endif
-extern Lisp_Object Qspace, QCalign_to, QCwidth;
+#ifndef O_NOCTTY
+#define O_NOCTTY 0
+#endif
-/* Function to use to ring the bell. */
+/* The name of the default console device. */
+#ifdef WINDOWSNT
+#define DEV_TTY "CONOUT$"
+#else
+#define DEV_TTY "/dev/tty"
+#endif
-Lisp_Object Vring_bell_function;
+static void tty_set_scroll_region P_ ((struct frame *f, int start, int stop));
+static void turn_on_face P_ ((struct frame *, int face_id));
+static void turn_off_face P_ ((struct frame *, int face_id));
+static void tty_show_cursor P_ ((struct tty_display_info *));
+static void tty_hide_cursor P_ ((struct tty_display_info *));
+static void tty_background_highlight P_ ((struct tty_display_info *tty));
+static void clear_tty_hooks P_ ((struct terminal *terminal));
+static void set_tty_hooks P_ ((struct terminal *terminal));
+static void dissociate_if_controlling_tty P_ ((int fd));
+static void delete_tty P_ ((struct terminal *));
+
+#define OUTPUT(tty, a) \
+ emacs_tputs ((tty), a, \
+ (int) (FRAME_LINES (XFRAME (selected_frame)) \
+ - curY (tty)), \
+ cmputc)
+
+#define OUTPUT1(tty, a) emacs_tputs ((tty), a, 1, cmputc)
+#define OUTPUTL(tty, a, lines) emacs_tputs ((tty), a, lines, cmputc)
+
+#define OUTPUT_IF(tty, a) \
+ do { \
+ if (a) \
+ emacs_tputs ((tty), a, \
+ (int) (FRAME_LINES (XFRAME (selected_frame)) \
+ - curY (tty) ), \
+ cmputc); \
+ } while (0)
+
+#define OUTPUT1_IF(tty, a) do { if (a) emacs_tputs ((tty), a, 1, cmputc); } while (0)
/* If true, use "vs", otherwise use "ve" to make the cursor visible. */
static int visible_cursor;
-/* Terminal characteristics that higher levels want to look at.
- These are all extern'd in termchar.h */
-
-int must_write_spaces; /* Nonzero means spaces in the text
- must actually be output; can't just skip
- over some columns to leave them blank. */
-int min_padding_speed; /* Speed below which no padding necessary */
-
-int line_ins_del_ok; /* Terminal can insert and delete lines */
-int char_ins_del_ok; /* Terminal can insert and delete chars */
-int scroll_region_ok; /* Terminal supports setting the
- scroll window */
-int scroll_region_cost; /* Cost of setting a scroll window,
- measured in characters */
-int memory_below_frame; /* Terminal remembers lines
- scrolled off bottom */
-int fast_clear_end_of_line; /* Terminal has a `ce' string */
-
-/* Nonzero means no need to redraw the entire frame on resuming
- a suspended Emacs. This is useful on terminals with multiple pages,
- where one page is used for Emacs and another for all else. */
-
-int no_redraw_on_reenter;
-
-/* Hook functions that you can set to snap out the functions in this file.
- These are all extern'd in termhooks.h */
-
-void (*cursor_to_hook) P_ ((int, int));
-void (*raw_cursor_to_hook) P_ ((int, int));
-void (*clear_to_end_hook) P_ ((void));
-void (*clear_frame_hook) P_ ((void));
-void (*clear_end_of_line_hook) P_ ((int));
-
-void (*ins_del_lines_hook) P_ ((int, int));
+/* Display space properties */
-void (*delete_glyphs_hook) P_ ((int));
+extern Lisp_Object Qspace, QCalign_to, QCwidth;
-void (*ring_bell_hook) P_ ((void));
+/* Functions to call after suspending a tty. */
+Lisp_Object Vsuspend_tty_functions;
-void (*reset_terminal_modes_hook) P_ ((void));
-void (*set_terminal_modes_hook) P_ ((void));
-void (*update_begin_hook) P_ ((struct frame *));
-void (*update_end_hook) P_ ((struct frame *));
-void (*set_terminal_window_hook) P_ ((int));
-void (*insert_glyphs_hook) P_ ((struct glyph *, int));
-void (*write_glyphs_hook) P_ ((struct glyph *, int));
-void (*delete_glyphs_hook) P_ ((int));
+/* Functions to call after resuming a tty. */
+Lisp_Object Vresume_tty_functions;
-int (*read_socket_hook) P_ ((int, int, struct input_event *));
+/* Chain of all tty device parameters. */
+struct tty_display_info *tty_list;
-void (*frame_up_to_date_hook) P_ ((struct frame *));
-
-void (*mouse_position_hook) P_ ((FRAME_PTR *f, int insist,
- Lisp_Object *bar_window,
- enum scroll_bar_part *part,
- Lisp_Object *x,
- Lisp_Object *y,
- unsigned long *time));
-
-/* When reading from a minibuffer in a different frame, Emacs wants
- to shift the highlight from the selected frame to the mini-buffer's
- frame; under X, this means it lies about where the focus is.
- This hook tells the window system code to re-decide where to put
- the highlight. */
-
-void (*frame_rehighlight_hook) P_ ((FRAME_PTR f));
-
-/* If we're displaying frames using a window system that can stack
- frames on top of each other, this hook allows you to bring a frame
- to the front, or bury it behind all the other windows. If this
- hook is zero, that means the device we're displaying on doesn't
- support overlapping frames, so there's no need to raise or lower
- anything.
-
- If RAISE is non-zero, F is brought to the front, before all other
- windows. If RAISE is zero, F is sent to the back, behind all other
- windows. */
-
-void (*frame_raise_lower_hook) P_ ((FRAME_PTR f, int raise));
-
-/* If the value of the frame parameter changed, whis hook is called.
- For example, if going from fullscreen to not fullscreen this hook
- may do something OS dependent, like extended window manager hints on X11. */
-void (*fullscreen_hook) P_ ((struct frame *f));
-
-/* Set the vertical scroll bar for WINDOW to have its upper left corner
- at (TOP, LEFT), and be LENGTH rows high. Set its handle to
- indicate that we are displaying PORTION characters out of a total
- of WHOLE characters, starting at POSITION. If WINDOW doesn't yet
- have a scroll bar, create one for it. */
-
-void (*set_vertical_scroll_bar_hook)
- P_ ((struct window *window,
- int portion, int whole, int position));
-
-
-/* The following three hooks are used when we're doing a thorough
- redisplay of the frame. We don't explicitly know which scroll bars
- are going to be deleted, because keeping track of when windows go
- away is a real pain - can you say set-window-configuration?
- Instead, we just assert at the beginning of redisplay that *all*
- scroll bars are to be removed, and then save scroll bars from the
- fiery pit when we actually redisplay their window. */
-
-/* Arrange for all scroll bars on FRAME to be removed at the next call
- to `*judge_scroll_bars_hook'. A scroll bar may be spared if
- `*redeem_scroll_bar_hook' is applied to its window before the judgment.
-
- This should be applied to each frame each time its window tree is
- redisplayed, even if it is not displaying scroll bars at the moment;
- if the HAS_SCROLL_BARS flag has just been turned off, only calling
- this and the judge_scroll_bars_hook will get rid of them.
-
- If non-zero, this hook should be safe to apply to any frame,
- whether or not it can support scroll bars, and whether or not it is
- currently displaying them. */
-
-void (*condemn_scroll_bars_hook) P_ ((FRAME_PTR frame));
-
-/* Unmark WINDOW's scroll bar for deletion in this judgement cycle.
- Note that it's okay to redeem a scroll bar that is not condemned. */
-
-void (*redeem_scroll_bar_hook) P_ ((struct window *window));
-
-/* Remove all scroll bars on FRAME that haven't been saved since the
- last call to `*condemn_scroll_bars_hook'.
-
- This should be applied to each frame after each time its window
- tree is redisplayed, even if it is not displaying scroll bars at the
- moment; if the HAS_SCROLL_BARS flag has just been turned off, only
- calling this and condemn_scroll_bars_hook will get rid of them.
-
- If non-zero, this hook should be safe to apply to any frame,
- whether or not it can support scroll bars, and whether or not it is
- currently displaying them. */
-
-void (*judge_scroll_bars_hook) P_ ((FRAME_PTR FRAME));
-
-/* Strings, numbers and flags taken from the termcap entry. */
-
-char *TS_ins_line; /* "al" */
-char *TS_ins_multi_lines; /* "AL" (one parameter, # lines to insert) */
-char *TS_bell; /* "bl" */
-char *TS_clr_to_bottom; /* "cd" */
-char *TS_clr_line; /* "ce", clear to end of line */
-char *TS_clr_frame; /* "cl" */
-char *TS_set_scroll_region; /* "cs" (2 params, first line and last line) */
-char *TS_set_scroll_region_1; /* "cS" (4 params: total lines,
- lines above scroll region, lines below it,
- total lines again) */
-char *TS_del_char; /* "dc" */
-char *TS_del_multi_chars; /* "DC" (one parameter, # chars to delete) */
-char *TS_del_line; /* "dl" */
-char *TS_del_multi_lines; /* "DL" (one parameter, # lines to delete) */
-char *TS_delete_mode; /* "dm", enter character-delete mode */
-char *TS_end_delete_mode; /* "ed", leave character-delete mode */
-char *TS_end_insert_mode; /* "ei", leave character-insert mode */
-char *TS_ins_char; /* "ic" */
-char *TS_ins_multi_chars; /* "IC" (one parameter, # chars to insert) */
-char *TS_insert_mode; /* "im", enter character-insert mode */
-char *TS_pad_inserted_char; /* "ip". Just padding, no commands. */
-char *TS_end_keypad_mode; /* "ke" */
-char *TS_keypad_mode; /* "ks" */
-char *TS_pad_char; /* "pc", char to use as padding */
-char *TS_repeat; /* "rp" (2 params, # times to repeat
- and character to be repeated) */
-char *TS_end_standout_mode; /* "se" */
-char *TS_fwd_scroll; /* "sf" */
-char *TS_standout_mode; /* "so" */
-char *TS_rev_scroll; /* "sr" */
-char *TS_end_termcap_modes; /* "te" */
-char *TS_termcap_modes; /* "ti" */
-char *TS_visible_bell; /* "vb" */
-char *TS_cursor_normal; /* "ve" */
-char *TS_cursor_visible; /* "vs" */
-char *TS_cursor_invisible; /* "vi" */
-char *TS_set_window; /* "wi" (4 params, start and end of window,
- each as vpos and hpos) */
-
-/* Value of the "NC" (no_color_video) capability, or 0 if not
- present. */
-
-static int TN_no_color_video;
+/* Nonzero means no need to redraw the entire frame on resuming a
+ suspended Emacs. This is useful on terminals with multiple
+ pages, where one page is used for Emacs and another for all
+ else. */
+int no_redraw_on_reenter;
/* Meaning of bits in no_color_video. Each bit set means that the
corresponding attribute cannot be combined with colors. */
@@ -299,68 +165,6 @@ enum no_color_bit
NC_ALT_CHARSET = 1 << 8
};
-/* "md" -- turn on bold (extra bright mode). */
-
-char *TS_enter_bold_mode;
-
-/* "mh" -- turn on half-bright mode. */
-
-char *TS_enter_dim_mode;
-
-/* "mb" -- enter blinking mode. */
-
-char *TS_enter_blink_mode;
-
-/* "mr" -- enter reverse video mode. */
-
-char *TS_enter_reverse_mode;
-
-/* "us"/"ue" -- start/end underlining. */
-
-char *TS_exit_underline_mode, *TS_enter_underline_mode;
-
-/* "as"/"ae" -- start/end alternate character set. Not really
- supported, yet. */
-
-char *TS_enter_alt_charset_mode, *TS_exit_alt_charset_mode;
-
-/* "me" -- switch appearances off. */
-
-char *TS_exit_attribute_mode;
-
-/* "Co" -- number of colors. */
-
-int TN_max_colors;
-
-/* "pa" -- max. number of color pairs on screen. Not handled yet.
- Could be a problem if not equal to TN_max_colors * TN_max_colors. */
-
-int TN_max_pairs;
-
-/* "op" -- SVr4 set default pair to its original value. */
-
-char *TS_orig_pair;
-
-/* "AF"/"AB" or "Sf"/"Sb"-- set ANSI or SVr4 foreground/background color.
- 1 param, the color index. */
-
-char *TS_set_foreground, *TS_set_background;
-
-int TF_hazeltine; /* termcap hz flag. */
-int TF_insmode_motion; /* termcap mi flag: can move while in insert mode. */
-int TF_standout_motion; /* termcap mi flag: can move while in standout mode. */
-int TF_underscore; /* termcap ul flag: _ underlines if over-struck on
- non-blank position. Must clear before writing _. */
-int TF_teleray; /* termcap xt flag: many weird consequences.
- For t1061. */
-
-static int RPov; /* # chars to start a TS_repeat */
-
-static int delete_in_insert_mode; /* delete mode == insert mode */
-
-static int se_is_so; /* 1 if same string both enters and leaves
- standout mode */
-
/* internal state */
/* The largest frame width in any call to calculate_costs. */
@@ -371,57 +175,27 @@ int max_frame_cols;
int max_frame_lines;
-static int costs_set; /* Nonzero if costs have been calculated. */
-
-int insert_mode; /* Nonzero when in insert mode. */
-int standout_mode; /* Nonzero when in standout mode. */
-
-/* Size of window specified by higher levels.
- This is the number of lines, from the top of frame downwards,
- which can participate in insert-line/delete-line operations.
-
- Effectively it excludes the bottom frame_lines - specified_window_size
- lines from those operations. */
-
-int specified_window;
-
-/* Frame currently being redisplayed; 0 if not currently redisplaying.
- (Direct output does not count). */
-
-FRAME_PTR updating_frame;
+/* Non-zero if we have dropped our controlling tty and therefore
+ should not open a frame on stdout. */
+static int no_controlling_tty;
/* Provided for lisp packages. */
static int system_uses_terminfo;
-/* Flag used in tty_show/hide_cursor. */
-
-static int tty_cursor_hidden;
-
char *tparam ();
extern char *tgetstr ();
-
-static void term_clear_mouse_face ();
-static void term_mouse_highlight (struct frame *f, int x, int y);
-#ifdef WINDOWSNT
-/* We aren't X windows, but we aren't termcap either. This makes me
- uncertain as to what value to use for frame.output_method. For
- this file, we'll define FRAME_TERMCAP_P to be zero so that our
- output hooks get called instead of the termcap functions. Probably
- the best long-term solution is to define an output_windows_nt... */
-
-#undef FRAME_TERMCAP_P
-#define FRAME_TERMCAP_P(_f_) 0
-#endif /* WINDOWSNT */
-
#ifdef HAVE_GPM
#include <sys/fcntl.h>
-/* Nonzero means mouse is enabled on Linux console. */
-int term_gpm = 0;
+static void term_clear_mouse_face ();
+static void term_mouse_highlight (struct frame *f, int x, int y);
+
+/* The device for which we have enabled gpm support (or NULL). */
+struct tty_display_info *gpm_tty = NULL;
/* These variables describe the range of text currently shown in its
mouse-face, together with the window they apply to. As long as
@@ -431,199 +205,180 @@ int term_gpm = 0;
static int mouse_face_beg_row, mouse_face_beg_col;
static int mouse_face_end_row, mouse_face_end_col;
static int mouse_face_past_end;
-static Lisp_Object Qmouse_face_window;
+static Lisp_Object mouse_face_window;
static int mouse_face_face_id;
static int pos_x, pos_y;
static int last_mouse_x, last_mouse_y;
#endif /* HAVE_GPM */
-void
-ring_bell ()
-{
- if (!NILP (Vring_bell_function))
- {
- Lisp_Object function;
-
- /* Temporarily set the global variable to nil
- so that if we get an error, it stays nil
- and we don't call it over and over.
+/* Ring the bell on a tty. */
- We don't specbind it, because that would carefully
- restore the bad value if there's an error
- and make the loop of errors happen anyway. */
-
- function = Vring_bell_function;
- Vring_bell_function = Qnil;
-
- call0 (function);
+static void
+tty_ring_bell (struct frame *f)
+{
+ struct tty_display_info *tty = FRAME_TTY (f);
- Vring_bell_function = function;
+ if (tty->output)
+ {
+ OUTPUT (tty, (tty->TS_visible_bell && visible_bell
+ ? tty->TS_visible_bell
+ : tty->TS_bell));
+ fflush (tty->output);
}
- else if (!FRAME_TERMCAP_P (XFRAME (selected_frame)))
- (*ring_bell_hook) ();
- else
- OUTPUT (TS_visible_bell && visible_bell ? TS_visible_bell : TS_bell);
}
+/* Set up termcap modes for Emacs. */
+
void
-set_terminal_modes ()
+tty_set_terminal_modes (struct terminal *terminal)
{
- if (FRAME_TERMCAP_P (XFRAME (selected_frame)))
+ struct tty_display_info *tty = terminal->display_info.tty;
+
+ if (tty->output)
{
- if (TS_termcap_modes)
- OUTPUT (TS_termcap_modes);
+ if (tty->TS_termcap_modes)
+ OUTPUT (tty, tty->TS_termcap_modes);
else
- {
- /* Output enough newlines to scroll all the old screen contents
- off the screen, so it won't be overwritten and lost. */
- int i;
- for (i = 0; i < FRAME_LINES (XFRAME (selected_frame)); i++)
- putchar ('\n');
- }
-
- OUTPUT_IF (visible_cursor ? TS_cursor_visible : TS_cursor_normal);
- OUTPUT_IF (TS_keypad_mode);
- losecursor ();
+ {
+ /* Output enough newlines to scroll all the old screen contents
+ off the screen, so it won't be overwritten and lost. */
+ int i;
+ current_tty = tty;
+ for (i = 0; i < FRAME_LINES (XFRAME (selected_frame)); i++)
+ cmputc ('\n');
+ }
+
+ OUTPUT_IF (tty, tty->TS_termcap_modes);
+ OUTPUT_IF (tty, visible_cursor ? tty->TS_cursor_visible : tty->TS_cursor_normal);
+ OUTPUT_IF (tty, tty->TS_keypad_mode);
+ losecursor (tty);
+ fflush (tty->output);
}
- else
- (*set_terminal_modes_hook) ();
}
+/* Reset termcap modes before exiting Emacs. */
+
void
-reset_terminal_modes ()
+tty_reset_terminal_modes (struct terminal *terminal)
{
- if (FRAME_TERMCAP_P (XFRAME (selected_frame)))
+ struct tty_display_info *tty = terminal->display_info.tty;
+
+ if (tty->output)
{
- turn_off_highlight ();
- turn_off_insert ();
- OUTPUT_IF (TS_end_keypad_mode);
- OUTPUT_IF (TS_cursor_normal);
- OUTPUT_IF (TS_end_termcap_modes);
- OUTPUT_IF (TS_orig_pair);
+ tty_turn_off_highlight (tty);
+ tty_turn_off_insert (tty);
+ OUTPUT_IF (tty, tty->TS_end_keypad_mode);
+ OUTPUT_IF (tty, tty->TS_cursor_normal);
+ OUTPUT_IF (tty, tty->TS_end_termcap_modes);
+ OUTPUT_IF (tty, tty->TS_orig_pair);
/* Output raw CR so kernel can track the cursor hpos. */
+ current_tty = tty;
cmputc ('\r');
+ fflush (tty->output);
}
- else if (reset_terminal_modes_hook)
- (*reset_terminal_modes_hook) ();
}
-void
-update_begin (f)
- struct frame *f;
-{
- updating_frame = f;
- if (!FRAME_TERMCAP_P (f))
- update_begin_hook (f);
-}
+/* Flag the end of a display update on a termcap terminal. */
-void
-update_end (f)
- struct frame *f;
+static void
+tty_update_end (struct frame *f)
{
- if (FRAME_TERMCAP_P (f))
- {
- if (!XWINDOW (selected_window)->cursor_off_p)
- tty_show_cursor ();
- turn_off_insert ();
- background_highlight ();
- }
- else
- update_end_hook (f);
+ struct tty_display_info *tty = FRAME_TTY (f);
- updating_frame = NULL;
+ if (!XWINDOW (selected_window)->cursor_off_p)
+ tty_show_cursor (tty);
+ tty_turn_off_insert (tty);
+ tty_background_highlight (tty);
}
-void
-set_terminal_window (size)
- int size;
+/* The implementation of set_terminal_window for termcap frames. */
+
+static void
+tty_set_terminal_window (struct frame *f, int size)
{
- if (FRAME_TERMCAP_P (updating_frame))
- {
- specified_window = size ? size : FRAME_LINES (updating_frame);
- if (scroll_region_ok)
- set_scroll_region (0, specified_window);
- }
- else
- set_terminal_window_hook (size);
+ struct tty_display_info *tty = FRAME_TTY (f);
+
+ tty->specified_window = size ? size : FRAME_LINES (f);
+ if (FRAME_SCROLL_REGION_OK (f))
+ tty_set_scroll_region (f, 0, tty->specified_window);
}
-void
-set_scroll_region (start, stop)
- int start, stop;
+static void
+tty_set_scroll_region (struct frame *f, int start, int stop)
{
char *buf;
- struct frame *sf = XFRAME (selected_frame);
-
- if (TS_set_scroll_region)
- buf = tparam (TS_set_scroll_region, 0, 0, start, stop - 1);
- else if (TS_set_scroll_region_1)
- buf = tparam (TS_set_scroll_region_1, 0, 0,
- FRAME_LINES (sf), start,
- FRAME_LINES (sf) - stop,
- FRAME_LINES (sf));
+ struct tty_display_info *tty = FRAME_TTY (f);
+
+ if (tty->TS_set_scroll_region)
+ buf = tparam (tty->TS_set_scroll_region, 0, 0, start, stop - 1);
+ else if (tty->TS_set_scroll_region_1)
+ buf = tparam (tty->TS_set_scroll_region_1, 0, 0,
+ FRAME_LINES (f), start,
+ FRAME_LINES (f) - stop,
+ FRAME_LINES (f));
else
- buf = tparam (TS_set_window, 0, 0, start, 0, stop, FRAME_COLS (sf));
+ buf = tparam (tty->TS_set_window, 0, 0, start, 0, stop, FRAME_COLS (f));
- OUTPUT (buf);
+ OUTPUT (tty, buf);
xfree (buf);
- losecursor ();
+ losecursor (tty);
}
static void
-turn_on_insert ()
+tty_turn_on_insert (struct tty_display_info *tty)
{
- if (!insert_mode)
- OUTPUT (TS_insert_mode);
- insert_mode = 1;
+ if (!tty->insert_mode)
+ OUTPUT (tty, tty->TS_insert_mode);
+ tty->insert_mode = 1;
}
void
-turn_off_insert ()
+tty_turn_off_insert (struct tty_display_info *tty)
{
- if (insert_mode)
- OUTPUT (TS_end_insert_mode);
- insert_mode = 0;
+ if (tty->insert_mode)
+ OUTPUT (tty, tty->TS_end_insert_mode);
+ tty->insert_mode = 0;
}
/* Handle highlighting. */
void
-turn_off_highlight ()
+tty_turn_off_highlight (struct tty_display_info *tty)
{
- if (standout_mode)
- OUTPUT_IF (TS_end_standout_mode);
- standout_mode = 0;
+ if (tty->standout_mode)
+ OUTPUT_IF (tty, tty->TS_end_standout_mode);
+ tty->standout_mode = 0;
}
static void
-turn_on_highlight ()
+tty_turn_on_highlight (struct tty_display_info *tty)
{
- if (!standout_mode)
- OUTPUT_IF (TS_standout_mode);
- standout_mode = 1;
+ if (!tty->standout_mode)
+ OUTPUT_IF (tty, tty->TS_standout_mode);
+ tty->standout_mode = 1;
}
static void
-toggle_highlight ()
+tty_toggle_highlight (struct tty_display_info *tty)
{
- if (standout_mode)
- turn_off_highlight ();
+ if (tty->standout_mode)
+ tty_turn_off_highlight (tty);
else
- turn_on_highlight ();
+ tty_turn_on_highlight (tty);
}
/* Make cursor invisible. */
static void
-tty_hide_cursor ()
+tty_hide_cursor (struct tty_display_info *tty)
{
- if (tty_cursor_hidden == 0)
+ if (tty->cursor_hidden == 0)
{
- tty_cursor_hidden = 1;
- OUTPUT_IF (TS_cursor_invisible);
+ tty->cursor_hidden = 1;
+ OUTPUT_IF (tty, tty->TS_cursor_invisible);
}
}
@@ -631,14 +386,14 @@ tty_hide_cursor ()
/* Ensure that cursor is visible. */
static void
-tty_show_cursor ()
+tty_show_cursor (struct tty_display_info *tty)
{
- if (tty_cursor_hidden)
+ if (tty->cursor_hidden)
{
- tty_cursor_hidden = 0;
- OUTPUT_IF (TS_cursor_normal);
+ tty->cursor_hidden = 0;
+ OUTPUT_IF (tty, tty->TS_cursor_normal);
if (visible_cursor)
- OUTPUT_IF (TS_cursor_visible);
+ OUTPUT_IF (tty, tty->TS_cursor_visible);
}
}
@@ -647,180 +402,151 @@ tty_show_cursor ()
empty space inside windows. What this is,
depends on the user option inverse-video. */
-void
-background_highlight ()
+static void
+tty_background_highlight (struct tty_display_info *tty)
{
if (inverse_video)
- turn_on_highlight ();
+ tty_turn_on_highlight (tty);
else
- turn_off_highlight ();
+ tty_turn_off_highlight (tty);
}
/* Set standout mode to the mode specified for the text to be output. */
static void
-highlight_if_desired ()
+tty_highlight_if_desired (struct tty_display_info *tty)
{
if (inverse_video)
- turn_on_highlight ();
+ tty_turn_on_highlight (tty);
else
- turn_off_highlight ();
+ tty_turn_off_highlight (tty);
}
/* Move cursor to row/column position VPOS/HPOS. HPOS/VPOS are
frame-relative coordinates. */
-void
-cursor_to (vpos, hpos)
- int vpos, hpos;
+static void
+tty_cursor_to (struct frame *f, int vpos, int hpos)
{
- struct frame *f = updating_frame ? updating_frame : XFRAME (selected_frame);
-
- if (! FRAME_TERMCAP_P (f) && cursor_to_hook)
- {
- (*cursor_to_hook) (vpos, hpos);
- return;
- }
+ struct tty_display_info *tty = FRAME_TTY (f);
/* Detect the case where we are called from reset_sys_modes
and the costs have never been calculated. Do nothing. */
- if (! costs_set)
+ if (! tty->costs_set)
return;
- if (curY == vpos && curX == hpos)
+ if (curY (tty) == vpos
+ && curX (tty) == hpos)
return;
- if (!TF_standout_motion)
- background_highlight ();
- if (!TF_insmode_motion)
- turn_off_insert ();
- cmgoto (vpos, hpos);
+ if (!tty->TF_standout_motion)
+ tty_background_highlight (tty);
+ if (!tty->TF_insmode_motion)
+ tty_turn_off_insert (tty);
+ cmgoto (tty, vpos, hpos);
}
/* Similar but don't take any account of the wasted characters. */
-void
-raw_cursor_to (row, col)
- int row, col;
+static void
+tty_raw_cursor_to (struct frame *f, int row, int col)
{
- struct frame *f = updating_frame ? updating_frame : XFRAME (selected_frame);
- if (! FRAME_TERMCAP_P (f))
- {
- (*raw_cursor_to_hook) (row, col);
- return;
- }
- if (curY == row && curX == col)
+ struct tty_display_info *tty = FRAME_TTY (f);
+
+ if (curY (tty) == row
+ && curX (tty) == col)
return;
- if (!TF_standout_motion)
- background_highlight ();
- if (!TF_insmode_motion)
- turn_off_insert ();
- cmgoto (row, col);
+ if (!tty->TF_standout_motion)
+ tty_background_highlight (tty);
+ if (!tty->TF_insmode_motion)
+ tty_turn_off_insert (tty);
+ cmgoto (tty, row, col);
}
/* Erase operations */
-/* clear from cursor to end of frame */
-void
-clear_to_end ()
+/* Clear from cursor to end of frame on a termcap device. */
+
+static void
+tty_clear_to_end (struct frame *f)
{
register int i;
+ struct tty_display_info *tty = FRAME_TTY (f);
- if (clear_to_end_hook && ! FRAME_TERMCAP_P (updating_frame))
+ if (tty->TS_clr_to_bottom)
{
- (*clear_to_end_hook) ();
- return;
- }
- if (TS_clr_to_bottom)
- {
- background_highlight ();
- OUTPUT (TS_clr_to_bottom);
+ tty_background_highlight (tty);
+ OUTPUT (tty, tty->TS_clr_to_bottom);
}
else
{
- for (i = curY; i < FRAME_LINES (XFRAME (selected_frame)); i++)
+ for (i = curY (tty); i < FRAME_LINES (f); i++)
{
- cursor_to (i, 0);
- clear_end_of_line (FRAME_COLS (XFRAME (selected_frame)));
+ cursor_to (f, i, 0);
+ clear_end_of_line (f, FRAME_COLS (f));
}
}
}
-/* Clear entire frame */
+/* Clear an entire termcap frame. */
-void
-clear_frame ()
+static void
+tty_clear_frame (struct frame *f)
{
- struct frame *sf = XFRAME (selected_frame);
+ struct tty_display_info *tty = FRAME_TTY (f);
- if (clear_frame_hook
- && ! FRAME_TERMCAP_P ((updating_frame ? updating_frame : sf)))
- {
- (*clear_frame_hook) ();
- return;
- }
- if (TS_clr_frame)
+ if (tty->TS_clr_frame)
{
- background_highlight ();
- OUTPUT (TS_clr_frame);
- cmat (0, 0);
+ tty_background_highlight (tty);
+ OUTPUT (tty, tty->TS_clr_frame);
+ cmat (tty, 0, 0);
}
else
{
- cursor_to (0, 0);
- clear_to_end ();
+ cursor_to (f, 0, 0);
+ clear_to_end (f);
}
}
-/* Clear from cursor to end of line.
- Assume that the line is already clear starting at column first_unused_hpos.
+/* An implementation of clear_end_of_line for termcap frames.
Note that the cursor may be moved, on terminals lacking a `ce' string. */
-void
-clear_end_of_line (first_unused_hpos)
- int first_unused_hpos;
+static void
+tty_clear_end_of_line (struct frame *f, int first_unused_hpos)
{
register int i;
-
- if (clear_end_of_line_hook
- && ! FRAME_TERMCAP_P ((updating_frame
- ? updating_frame
- : XFRAME (selected_frame))))
- {
- (*clear_end_of_line_hook) (first_unused_hpos);
- return;
- }
+ struct tty_display_info *tty = FRAME_TTY (f);
/* Detect the case where we are called from reset_sys_modes
and the costs have never been calculated. Do nothing. */
- if (! costs_set)
+ if (! tty->costs_set)
return;
- if (curX >= first_unused_hpos)
+ if (curX (tty) >= first_unused_hpos)
return;
- background_highlight ();
- if (TS_clr_line)
+ tty_background_highlight (tty);
+ if (tty->TS_clr_line)
{
- OUTPUT1 (TS_clr_line);
+ OUTPUT1 (tty, tty->TS_clr_line);
}
else
{ /* have to do it the hard way */
- struct frame *sf = XFRAME (selected_frame);
- turn_off_insert ();
+ tty_turn_off_insert (tty);
/* Do not write in last row last col with Auto-wrap on. */
- if (AutoWrap && curY == FRAME_LINES (sf) - 1
- && first_unused_hpos == FRAME_COLS (sf))
+ if (AutoWrap (tty)
+ && curY (tty) == FrameRows (tty) - 1
+ && first_unused_hpos == FrameCols (tty))
first_unused_hpos--;
- for (i = curX; i < first_unused_hpos; i++)
+ for (i = curX (tty); i < first_unused_hpos; i++)
{
- if (termscript)
- fputc (' ', termscript);
- putchar (' ');
+ if (tty->termscript)
+ fputc (' ', tty->termscript);
+ fputc (' ', tty->output);
}
- cmplus (first_unused_hpos - curX);
+ cmplus (tty, first_unused_hpos - curX (tty));
}
}
@@ -1005,44 +731,37 @@ encode_terminal_code (src, src_len, coding)
}
-void
-write_glyphs (string, len)
- register struct glyph *string;
- register int len;
+
+/* An implementation of write_glyphs for termcap frames. */
+
+static void
+tty_write_glyphs (struct frame *f, struct glyph *string, int len)
{
- int produced, consumed;
- struct frame *sf = XFRAME (selected_frame);
- struct frame *f = updating_frame ? updating_frame : sf;
unsigned char *conversion_buffer;
struct coding_system *coding;
- if (write_glyphs_hook
- && ! FRAME_TERMCAP_P (f))
- {
- (*write_glyphs_hook) (string, len);
- return;
- }
+ struct tty_display_info *tty = FRAME_TTY (f);
- turn_off_insert ();
- tty_hide_cursor ();
+ tty_turn_off_insert (tty);
+ tty_hide_cursor (tty);
/* Don't dare write in last column of bottom line, if Auto-Wrap,
since that would scroll the whole frame on some terminals. */
- if (AutoWrap
- && curY + 1 == FRAME_LINES (sf)
- && (curX + len) == FRAME_COLS (sf))
+ if (AutoWrap (tty)
+ && curY (tty) + 1 == FRAME_LINES (f)
+ && (curX (tty) + len) == FRAME_COLS (f))
len --;
if (len <= 0)
return;
- cmplus (len);
+ cmplus (tty, len);
/* If terminal_coding does any conversion, use it, otherwise use
safe_terminal_coding. We can't use CODING_REQUIRE_ENCODING here
because it always return 1 if the member src_multibyte is 1. */
- coding = (terminal_coding.common_flags & CODING_REQUIRE_ENCODING_MASK
- ? &terminal_coding : &safe_terminal_coding);
+ coding = (FRAME_TERMINAL_CODING (f)->common_flags & CODING_REQUIRE_ENCODING_MASK
+ ? FRAME_TERMINAL_CODING (f) : &safe_terminal_coding);
/* The mode bit CODING_MODE_LAST_BLOCK should be set to 1 only at
the tail. */
coding->mode &= ~CODING_MODE_LAST_BLOCK;
@@ -1058,7 +777,7 @@ write_glyphs (string, len)
break;
/* Turn appearance modes of the face of the run on. */
- highlight_if_desired ();
+ tty_highlight_if_desired (tty);
turn_on_face (f, face_id);
if (n == len)
@@ -1068,11 +787,11 @@ write_glyphs (string, len)
if (coding->produced > 0)
{
BLOCK_INPUT;
- fwrite (conversion_buffer, 1, coding->produced, stdout);
- if (ferror (stdout))
- clearerr (stdout);
- if (termscript)
- fwrite (conversion_buffer, 1, coding->produced, termscript);
+ fwrite (conversion_buffer, 1, coding->produced, tty->output);
+ if (ferror (tty->output))
+ clearerr (tty->output);
+ if (tty->termscript)
+ fwrite (conversion_buffer, 1, coding->produced, tty->termscript);
UNBLOCK_INPUT;
}
len -= n;
@@ -1080,49 +799,51 @@ write_glyphs (string, len)
/* Turn appearance modes off. */
turn_off_face (f, face_id);
- turn_off_highlight ();
+ tty_turn_off_highlight (tty);
}
- cmcheckmagic ();
+ cmcheckmagic (tty);
}
-void
-write_glyphs_with_face (string, len, face_id)
+#ifdef HAVE_GPM /* Only used by GPM code. */
+
+static void
+tty_write_glyphs_with_face (f, string, len, face_id)
+ register struct frame *f;
register struct glyph *string;
register int len, face_id;
{
- struct frame *sf = XFRAME (selected_frame);
- struct frame *f = updating_frame ? updating_frame : sf;
unsigned char *conversion_buffer;
struct coding_system *coding;
- turn_off_insert ();
- tty_hide_cursor ();
+ struct tty_display_info *tty = FRAME_TTY (f);
+
+ tty_turn_off_insert (tty);
+ tty_hide_cursor (tty);
/* Don't dare write in last column of bottom line, if Auto-Wrap,
since that would scroll the whole frame on some terminals. */
- if (AutoWrap
- && curY + 1 == FRAME_LINES (sf)
- && (curX + len) == FRAME_COLS (sf))
+ if (AutoWrap (tty)
+ && curY (tty) + 1 == FRAME_LINES (f)
+ && (curX (tty) + len) == FRAME_COLS (f))
len --;
if (len <= 0)
return;
- cmplus (len);
+ cmplus (tty, len);
/* If terminal_coding does any conversion, use it, otherwise use
safe_terminal_coding. We can't use CODING_REQUIRE_ENCODING here
because it always return 1 if the member src_multibyte is 1. */
- coding = (terminal_coding.common_flags & CODING_REQUIRE_ENCODING_MASK
- ? &terminal_coding : &safe_terminal_coding);
+ coding = (FRAME_TERMINAL_CODING (f)->common_flags & CODING_REQUIRE_ENCODING_MASK
+ ? FRAME_TERMINAL_CODING (f) : &safe_terminal_coding);
/* The mode bit CODING_MODE_LAST_BLOCK should be set to 1 only at
the tail. */
coding->mode &= ~CODING_MODE_LAST_BLOCK;
-
/* Turn appearance modes of the face. */
- highlight_if_desired ();
+ tty_highlight_if_desired (tty);
turn_on_face (f, face_id);
coding->mode |= CODING_MODE_LAST_BLOCK;
@@ -1130,59 +851,47 @@ write_glyphs_with_face (string, len, face_id)
if (coding->produced > 0)
{
BLOCK_INPUT;
- fwrite (conversion_buffer, 1, coding->produced, stdout);
- if (ferror (stdout))
- clearerr (stdout);
- if (termscript)
- fwrite (conversion_buffer, 1, coding->produced, termscript);
+ fwrite (conversion_buffer, 1, coding->produced, tty->output);
+ if (ferror (tty->output))
+ clearerr (tty->output);
+ if (tty->termscript)
+ fwrite (conversion_buffer, 1, coding->produced, tty->termscript);
UNBLOCK_INPUT;
}
/* Turn appearance modes off. */
turn_off_face (f, face_id);
- turn_off_highlight ();
+ tty_turn_off_highlight (tty);
- cmcheckmagic ();
+ cmcheckmagic (tty);
}
+#endif
-/* If start is zero, insert blanks instead of a string at start */
+/* An implementation of insert_glyphs for termcap frames. */
-void
-insert_glyphs (start, len)
- register struct glyph *start;
- register int len;
+static void
+tty_insert_glyphs (struct frame *f, struct glyph *start, int len)
{
char *buf;
struct glyph *glyph = NULL;
- struct frame *f, *sf;
unsigned char *conversion_buffer;
unsigned char space[1];
struct coding_system *coding;
- if (len <= 0)
- return;
-
- if (insert_glyphs_hook)
- {
- (*insert_glyphs_hook) (start, len);
- return;
- }
+ struct tty_display_info *tty = FRAME_TTY (f);
- sf = XFRAME (selected_frame);
- f = updating_frame ? updating_frame : sf;
-
- if (TS_ins_multi_chars)
+ if (tty->TS_ins_multi_chars)
{
- buf = tparam (TS_ins_multi_chars, 0, 0, len);
- OUTPUT1 (buf);
+ buf = tparam (tty->TS_ins_multi_chars, 0, 0, len);
+ OUTPUT1 (tty, buf);
xfree (buf);
if (start)
- write_glyphs (start, len);
+ write_glyphs (f, start, len);
return;
}
- turn_on_insert ();
- cmplus (len);
+ tty_turn_on_insert (tty);
+ cmplus (tty, len);
if (! start)
space[0] = SPACEGLYPH;
@@ -1190,15 +899,15 @@ insert_glyphs (start, len)
/* If terminal_coding does any conversion, use it, otherwise use
safe_terminal_coding. We can't use CODING_REQUIRE_ENCODING here
because it always return 1 if the member src_multibyte is 1. */
- coding = (terminal_coding.common_flags & CODING_REQUIRE_ENCODING_MASK
- ? &terminal_coding : &safe_terminal_coding);
+ coding = (FRAME_TERMINAL_CODING (f)->common_flags & CODING_REQUIRE_ENCODING_MASK
+ ? FRAME_TERMINAL_CODING (f) : &safe_terminal_coding);
/* The mode bit CODING_MODE_LAST_BLOCK should be set to 1 only at
the tail. */
coding->mode &= ~CODING_MODE_LAST_BLOCK;
while (len-- > 0)
{
- OUTPUT1_IF (TS_ins_char);
+ OUTPUT1_IF (tty, tty->TS_ins_char);
if (!start)
{
conversion_buffer = space;
@@ -1206,7 +915,7 @@ insert_glyphs (start, len)
}
else
{
- highlight_if_desired ();
+ tty_highlight_if_desired (tty);
turn_on_face (f, start->face_id);
glyph = start;
++start;
@@ -1214,7 +923,7 @@ insert_glyphs (start, len)
occupies more than one column. */
while (len && CHAR_GLYPH_PADDING_P (*start))
{
- OUTPUT1_IF (TS_ins_char);
+ OUTPUT1_IF (tty, tty->TS_ins_char);
start++, len--;
}
@@ -1222,89 +931,77 @@ insert_glyphs (start, len)
/* This is the last glyph. */
coding->mode |= CODING_MODE_LAST_BLOCK;
- conversion_buffer = encode_terminal_code (glyph, 1, coding);
+ conversion_buffer = encode_terminal_code (glyph, 1, coding);
}
if (coding->produced > 0)
{
BLOCK_INPUT;
- fwrite (conversion_buffer, 1, coding->produced, stdout);
- if (ferror (stdout))
- clearerr (stdout);
- if (termscript)
- fwrite (conversion_buffer, 1, coding->produced, termscript);
+ fwrite (conversion_buffer, 1, coding->produced, tty->output);
+ if (ferror (tty->output))
+ clearerr (tty->output);
+ if (tty->termscript)
+ fwrite (conversion_buffer, 1, coding->produced, tty->termscript);
UNBLOCK_INPUT;
}
- OUTPUT1_IF (TS_pad_inserted_char);
+ OUTPUT1_IF (tty, tty->TS_pad_inserted_char);
if (start)
{
turn_off_face (f, glyph->face_id);
- turn_off_highlight ();
+ tty_turn_off_highlight (tty);
}
}
- cmcheckmagic ();
+ cmcheckmagic (tty);
}
-void
-delete_glyphs (n)
- register int n;
+/* An implementation of delete_glyphs for termcap frames. */
+
+static void
+tty_delete_glyphs (struct frame *f, int n)
{
char *buf;
register int i;
- if (delete_glyphs_hook && ! FRAME_TERMCAP_P (updating_frame))
- {
- (*delete_glyphs_hook) (n);
- return;
- }
+ struct tty_display_info *tty = FRAME_TTY (f);
- if (delete_in_insert_mode)
+ if (tty->delete_in_insert_mode)
{
- turn_on_insert ();
+ tty_turn_on_insert (tty);
}
else
{
- turn_off_insert ();
- OUTPUT_IF (TS_delete_mode);
+ tty_turn_off_insert (tty);
+ OUTPUT_IF (tty, tty->TS_delete_mode);
}
- if (TS_del_multi_chars)
+ if (tty->TS_del_multi_chars)
{
- buf = tparam (TS_del_multi_chars, 0, 0, n);
- OUTPUT1 (buf);
+ buf = tparam (tty->TS_del_multi_chars, 0, 0, n);
+ OUTPUT1 (tty, buf);
xfree (buf);
}
else
for (i = 0; i < n; i++)
- OUTPUT1 (TS_del_char);
- if (!delete_in_insert_mode)
- OUTPUT_IF (TS_end_delete_mode);
+ OUTPUT1 (tty, tty->TS_del_char);
+ if (!tty->delete_in_insert_mode)
+ OUTPUT_IF (tty, tty->TS_end_delete_mode);
}
-/* Insert N lines at vpos VPOS. If N is negative, delete -N lines. */
+/* An implementation of ins_del_lines for termcap frames. */
-void
-ins_del_lines (vpos, n)
- int vpos, n;
+static void
+tty_ins_del_lines (struct frame *f, int vpos, int n)
{
- char *multi = n > 0 ? TS_ins_multi_lines : TS_del_multi_lines;
- char *single = n > 0 ? TS_ins_line : TS_del_line;
- char *scroll = n > 0 ? TS_rev_scroll : TS_fwd_scroll;
- struct frame *sf;
+ struct tty_display_info *tty = FRAME_TTY (f);
+ char *multi = n > 0 ? tty->TS_ins_multi_lines : tty->TS_del_multi_lines;
+ char *single = n > 0 ? tty->TS_ins_line : tty->TS_del_line;
+ char *scroll = n > 0 ? tty->TS_rev_scroll : tty->TS_fwd_scroll;
register int i = n > 0 ? n : -n;
register char *buf;
- if (ins_del_lines_hook && ! FRAME_TERMCAP_P (updating_frame))
- {
- (*ins_del_lines_hook) (vpos, n);
- return;
- }
-
- sf = XFRAME (selected_frame);
-
/* If the lines below the insertion are being pushed
into the end of the window, this is the same as clearing;
and we know the lines are already clear, since the matching
@@ -1312,45 +1009,49 @@ ins_del_lines (vpos, n)
/* If the lines below the deletion are blank lines coming
out of the end of the window, don't bother,
as there will be a matching inslines later that will flush them. */
- if (scroll_region_ok && vpos + i >= specified_window)
+ if (FRAME_SCROLL_REGION_OK (f)
+ && vpos + i >= tty->specified_window)
return;
- if (!memory_below_frame && vpos + i >= FRAME_LINES (sf))
+ if (!FRAME_MEMORY_BELOW_FRAME (f)
+ && vpos + i >= FRAME_LINES (f))
return;
-
+
if (multi)
{
- raw_cursor_to (vpos, 0);
- background_highlight ();
+ raw_cursor_to (f, vpos, 0);
+ tty_background_highlight (tty);
buf = tparam (multi, 0, 0, i);
- OUTPUT (buf);
+ OUTPUT (tty, buf);
xfree (buf);
}
else if (single)
{
- raw_cursor_to (vpos, 0);
- background_highlight ();
+ raw_cursor_to (f, vpos, 0);
+ tty_background_highlight (tty);
while (--i >= 0)
- OUTPUT (single);
- if (TF_teleray)
- curX = 0;
+ OUTPUT (tty, single);
+ if (tty->TF_teleray)
+ curX (tty) = 0;
}
else
{
- set_scroll_region (vpos, specified_window);
+ tty_set_scroll_region (f, vpos, tty->specified_window);
if (n < 0)
- raw_cursor_to (specified_window - 1, 0);
+ raw_cursor_to (f, tty->specified_window - 1, 0);
else
- raw_cursor_to (vpos, 0);
- background_highlight ();
+ raw_cursor_to (f, vpos, 0);
+ tty_background_highlight (tty);
while (--i >= 0)
- OUTPUTL (scroll, specified_window - vpos);
- set_scroll_region (0, specified_window);
+ OUTPUTL (tty, scroll, tty->specified_window - vpos);
+ tty_set_scroll_region (f, 0, tty->specified_window);
}
-
- if (!scroll_region_ok && memory_below_frame && n < 0)
+
+ if (!FRAME_SCROLL_REGION_OK (f)
+ && FRAME_MEMORY_BELOW_FRAME (f)
+ && n < 0)
{
- cursor_to (FRAME_LINES (sf) + n, 0);
- clear_to_end ();
+ cursor_to (f, FRAME_LINES (f) + n, 0);
+ clear_to_end (f);
}
}
@@ -1358,8 +1059,7 @@ ins_del_lines (vpos, n)
not counting any line-dependent padding. */
int
-string_cost (str)
- char *str;
+string_cost (char *str)
{
cost = 0;
if (str)
@@ -1371,8 +1071,7 @@ string_cost (str)
counting any line-dependent padding at one line. */
static int
-string_cost_one_line (str)
- char *str;
+string_cost_one_line (char *str)
{
cost = 0;
if (str)
@@ -1384,8 +1083,7 @@ string_cost_one_line (str)
in tenths of characters. */
int
-per_line_cost (str)
- register char *str;
+per_line_cost (char *str)
{
cost = 0;
if (str)
@@ -1408,26 +1106,26 @@ int *char_ins_del_vector;
/* ARGSUSED */
static void
-calculate_ins_del_char_costs (frame)
- FRAME_PTR frame;
+calculate_ins_del_char_costs (struct frame *f)
{
+ struct tty_display_info *tty = FRAME_TTY (f);
int ins_startup_cost, del_startup_cost;
int ins_cost_per_char, del_cost_per_char;
register int i;
register int *p;
- if (TS_ins_multi_chars)
+ if (tty->TS_ins_multi_chars)
{
ins_cost_per_char = 0;
- ins_startup_cost = string_cost_one_line (TS_ins_multi_chars);
+ ins_startup_cost = string_cost_one_line (tty->TS_ins_multi_chars);
}
- else if (TS_ins_char || TS_pad_inserted_char
- || (TS_insert_mode && TS_end_insert_mode))
+ else if (tty->TS_ins_char || tty->TS_pad_inserted_char
+ || (tty->TS_insert_mode && tty->TS_end_insert_mode))
{
- ins_startup_cost = (30 * (string_cost (TS_insert_mode)
- + string_cost (TS_end_insert_mode))) / 100;
- ins_cost_per_char = (string_cost_one_line (TS_ins_char)
- + string_cost_one_line (TS_pad_inserted_char));
+ ins_startup_cost = (30 * (string_cost (tty->TS_insert_mode)
+ + string_cost (tty->TS_end_insert_mode))) / 100;
+ ins_cost_per_char = (string_cost_one_line (tty->TS_ins_char)
+ + string_cost_one_line (tty->TS_pad_inserted_char));
}
else
{
@@ -1435,18 +1133,18 @@ calculate_ins_del_char_costs (frame)
ins_cost_per_char = 0;
}
- if (TS_del_multi_chars)
+ if (tty->TS_del_multi_chars)
{
del_cost_per_char = 0;
- del_startup_cost = string_cost_one_line (TS_del_multi_chars);
+ del_startup_cost = string_cost_one_line (tty->TS_del_multi_chars);
}
- else if (TS_del_char)
+ else if (tty->TS_del_char)
{
- del_startup_cost = (string_cost (TS_delete_mode)
- + string_cost (TS_end_delete_mode));
- if (delete_in_insert_mode)
+ del_startup_cost = (string_cost (tty->TS_delete_mode)
+ + string_cost (tty->TS_end_delete_mode));
+ if (tty->delete_in_insert_mode)
del_startup_cost /= 2;
- del_cost_per_char = string_cost_one_line (TS_del_char);
+ del_cost_per_char = string_cost_one_line (tty->TS_del_char);
}
else
{
@@ -1455,75 +1153,80 @@ calculate_ins_del_char_costs (frame)
}
/* Delete costs are at negative offsets */
- p = &char_ins_del_cost (frame)[0];
- for (i = FRAME_COLS (frame); --i >= 0;)
+ p = &char_ins_del_cost (f)[0];
+ for (i = FRAME_COLS (f); --i >= 0;)
*--p = (del_startup_cost += del_cost_per_char);
/* Doing nothing is free */
- p = &char_ins_del_cost (frame)[0];
+ p = &char_ins_del_cost (f)[0];
*p++ = 0;
/* Insert costs are at positive offsets */
- for (i = FRAME_COLS (frame); --i >= 0;)
+ for (i = FRAME_COLS (f); --i >= 0;)
*p++ = (ins_startup_cost += ins_cost_per_char);
}
void
-calculate_costs (frame)
- FRAME_PTR frame;
+calculate_costs (struct frame *frame)
{
- register char *f = (TS_set_scroll_region
- ? TS_set_scroll_region
- : TS_set_scroll_region_1);
-
FRAME_COST_BAUD_RATE (frame) = baud_rate;
- scroll_region_cost = string_cost (f);
+ if (FRAME_TERMCAP_P (frame))
+ {
+ struct tty_display_info *tty = FRAME_TTY (frame);
+ register char *f = (tty->TS_set_scroll_region
+ ? tty->TS_set_scroll_region
+ : tty->TS_set_scroll_region_1);
- /* These variables are only used for terminal stuff. They are allocated
- once for the terminal frame of X-windows emacs, but not used afterwards.
+ FRAME_SCROLL_REGION_COST (frame) = string_cost (f);
- char_ins_del_vector (i.e., char_ins_del_cost) isn't used because
- X turns off char_ins_del_ok. */
+ tty->costs_set = 1;
- max_frame_lines = max (max_frame_lines, FRAME_LINES (frame));
- max_frame_cols = max (max_frame_cols, FRAME_COLS (frame));
+ /* These variables are only used for terminal stuff. They are
+ allocated once for the terminal frame of X-windows emacs, but not
+ used afterwards.
- costs_set = 1;
+ char_ins_del_vector (i.e., char_ins_del_cost) isn't used because
+ X turns off char_ins_del_ok. */
- if (char_ins_del_vector != 0)
- char_ins_del_vector
- = (int *) xrealloc (char_ins_del_vector,
- (sizeof (int)
- + 2 * max_frame_cols * sizeof (int)));
- else
- char_ins_del_vector
- = (int *) xmalloc (sizeof (int)
- + 2 * max_frame_cols * sizeof (int));
-
- bzero (char_ins_del_vector, (sizeof (int)
- + 2 * max_frame_cols * sizeof (int)));
-
- if (f && (!TS_ins_line && !TS_del_line))
- do_line_insertion_deletion_costs (frame,
- TS_rev_scroll, TS_ins_multi_lines,
- TS_fwd_scroll, TS_del_multi_lines,
- f, f, 1);
- else
- do_line_insertion_deletion_costs (frame,
- TS_ins_line, TS_ins_multi_lines,
- TS_del_line, TS_del_multi_lines,
- 0, 0, 1);
+ max_frame_lines = max (max_frame_lines, FRAME_LINES (frame));
+ max_frame_cols = max (max_frame_cols, FRAME_COLS (frame));
- calculate_ins_del_char_costs (frame);
+ if (char_ins_del_vector != 0)
+ char_ins_del_vector
+ = (int *) xrealloc (char_ins_del_vector,
+ (sizeof (int)
+ + 2 * max_frame_cols * sizeof (int)));
+ else
+ char_ins_del_vector
+ = (int *) xmalloc (sizeof (int)
+ + 2 * max_frame_cols * sizeof (int));
- /* Don't use TS_repeat if its padding is worse than sending the chars */
- if (TS_repeat && per_line_cost (TS_repeat) * baud_rate < 9000)
- RPov = string_cost (TS_repeat);
- else
- RPov = FRAME_COLS (frame) * 2;
+ bzero (char_ins_del_vector, (sizeof (int)
+ + 2 * max_frame_cols * sizeof (int)));
- cmcostinit (); /* set up cursor motion costs */
+
+ if (f && (!tty->TS_ins_line && !tty->TS_del_line))
+ do_line_insertion_deletion_costs (frame,
+ tty->TS_rev_scroll, tty->TS_ins_multi_lines,
+ tty->TS_fwd_scroll, tty->TS_del_multi_lines,
+ f, f, 1);
+ else
+ do_line_insertion_deletion_costs (frame,
+ tty->TS_ins_line, tty->TS_ins_multi_lines,
+ tty->TS_del_line, tty->TS_del_multi_lines,
+ 0, 0, 1);
+
+ calculate_ins_del_char_costs (frame);
+
+ /* Don't use TS_repeat if its padding is worse than sending the chars */
+ if (tty->TS_repeat && per_line_cost (tty->TS_repeat) * baud_rate < 9000)
+ tty->RPov = string_cost (tty->TS_repeat);
+ else
+ tty->RPov = FRAME_COLS (frame) * 2;
+
+ cmcostinit (FRAME_TTY (frame)); /* set up cursor motion costs */
+ }
}
struct fkey_table {
@@ -1633,16 +1336,18 @@ static struct fkey_table keys[] =
{"!3", "S-undo"} /*shifted undo key*/
};
-static char **term_get_fkeys_arg;
+static char **term_get_fkeys_address;
+static KBOARD *term_get_fkeys_kboard;
static Lisp_Object term_get_fkeys_1 ();
-/* Find the escape codes sent by the function keys for Vfunction_key_map.
+/* Find the escape codes sent by the function keys for Vinput_decode_map.
This function scans the termcap function key sequence entries, and
- adds entries to Vfunction_key_map for each function key it finds. */
+ adds entries to Vinput_decode_map for each function key it finds. */
-void
-term_get_fkeys (address)
+static void
+term_get_fkeys (address, kboard)
char **address;
+ KBOARD *kboard;
{
/* We run the body of the function (term_get_fkeys_1) and ignore all Lisp
errors during the call. The only errors should be from Fdefine_key
@@ -1653,7 +1358,8 @@ term_get_fkeys (address)
refusing to run at all on such a terminal. */
extern Lisp_Object Fidentity ();
- term_get_fkeys_arg = address;
+ term_get_fkeys_address = address;
+ term_get_fkeys_kboard = kboard;
internal_condition_case (term_get_fkeys_1, Qerror, Fidentity);
}
@@ -1662,17 +1368,18 @@ term_get_fkeys_1 ()
{
int i;
- char **address = term_get_fkeys_arg;
-
+ char **address = term_get_fkeys_address;
+ KBOARD *kboard = term_get_fkeys_kboard;
+
/* This can happen if CANNOT_DUMP or with strange options. */
- if (!initialized)
- Vfunction_key_map = Fmake_sparse_keymap (Qnil);
+ if (!KEYMAPP (kboard->Vinput_decode_map))
+ kboard->Vinput_decode_map = Fmake_sparse_keymap (Qnil);
for (i = 0; i < (sizeof (keys)/sizeof (keys[0])); i++)
{
char *sequence = tgetstr (keys[i].cap, address);
if (sequence)
- Fdefine_key (Vfunction_key_map, build_string (sequence),
+ Fdefine_key (kboard->Vinput_decode_map, build_string (sequence),
Fmake_vector (make_number (1),
intern (keys[i].name)));
}
@@ -1692,13 +1399,13 @@ term_get_fkeys_1 ()
if (k0)
/* Define f0 first, so that f10 takes precedence in case the
key sequences happens to be the same. */
- Fdefine_key (Vfunction_key_map, build_string (k0),
+ Fdefine_key (kboard->Vinput_decode_map, build_string (k0),
Fmake_vector (make_number (1), intern ("f0")));
- Fdefine_key (Vfunction_key_map, build_string (k_semi),
+ Fdefine_key (kboard->Vinput_decode_map, build_string (k_semi),
Fmake_vector (make_number (1), intern ("f10")));
}
else if (k0)
- Fdefine_key (Vfunction_key_map, build_string (k0),
+ Fdefine_key (kboard->Vinput_decode_map, build_string (k0),
Fmake_vector (make_number (1), intern (k0_name)));
}
@@ -1721,7 +1428,7 @@ term_get_fkeys_1 ()
if (sequence)
{
sprintf (fkey, "f%d", i);
- Fdefine_key (Vfunction_key_map, build_string (sequence),
+ Fdefine_key (kboard->Vinput_decode_map, build_string (sequence),
Fmake_vector (make_number (1),
intern (fkey)));
}
@@ -1737,10 +1444,10 @@ term_get_fkeys_1 ()
if (!tgetstr (cap1, address)) \
{ \
char *sequence = tgetstr (cap2, address); \
- if (sequence) \
- Fdefine_key (Vfunction_key_map, build_string (sequence), \
- Fmake_vector (make_number (1), \
- intern (sym))); \
+ if (sequence) \
+ Fdefine_key (kboard->Vinput_decode_map, build_string (sequence), \
+ Fmake_vector (make_number (1), \
+ intern (sym))); \
}
/* if there's no key_next keycap, map key_npage to `next' keysym */
@@ -2142,10 +1849,10 @@ produce_special_glyphs (it, what)
from them. Some display attributes may not be used together with
color; the termcap capability `NC' specifies which ones. */
-#define MAY_USE_WITH_COLORS_P(ATTR) \
- (TN_max_colors > 0 \
- ? (TN_no_color_video & (ATTR)) == 0 \
- : 1)
+#define MAY_USE_WITH_COLORS_P(tty, ATTR) \
+ (tty->TN_max_colors > 0 \
+ ? (tty->TN_no_color_video & (ATTR)) == 0 \
+ : 1)
/* Turn appearances of face FACE_ID on tty frame F on.
FACE_ID is a realized face ID number, in the face cache. */
@@ -2158,12 +1865,13 @@ turn_on_face (f, face_id)
struct face *face = FACE_FROM_ID (f, face_id);
long fg = face->foreground;
long bg = face->background;
+ struct tty_display_info *tty = FRAME_TTY (f);
/* Do this first because TS_end_standout_mode may be the same
as TS_exit_attribute_mode, which turns all appearances off. */
- if (MAY_USE_WITH_COLORS_P (NC_REVERSE))
+ if (MAY_USE_WITH_COLORS_P (tty, NC_REVERSE))
{
- if (TN_max_colors > 0)
+ if (tty->TN_max_colors > 0)
{
if (fg >= 0 && bg >= 0)
{
@@ -2177,13 +1885,13 @@ turn_on_face (f, face_id)
{
if (fg == FACE_TTY_DEFAULT_FG_COLOR
|| bg == FACE_TTY_DEFAULT_BG_COLOR)
- toggle_highlight ();
+ tty_toggle_highlight (tty);
}
else
{
if (fg == FACE_TTY_DEFAULT_BG_COLOR
|| bg == FACE_TTY_DEFAULT_FG_COLOR)
- toggle_highlight ();
+ tty_toggle_highlight (tty);
}
}
else
@@ -2194,55 +1902,55 @@ turn_on_face (f, face_id)
{
if (fg == FACE_TTY_DEFAULT_FG_COLOR
|| bg == FACE_TTY_DEFAULT_BG_COLOR)
- toggle_highlight ();
+ tty_toggle_highlight (tty);
}
else
{
if (fg == FACE_TTY_DEFAULT_BG_COLOR
|| bg == FACE_TTY_DEFAULT_FG_COLOR)
- toggle_highlight ();
+ tty_toggle_highlight (tty);
}
}
}
if (face->tty_bold_p)
{
- if (MAY_USE_WITH_COLORS_P (NC_BOLD))
- OUTPUT1_IF (TS_enter_bold_mode);
+ if (MAY_USE_WITH_COLORS_P (tty, NC_BOLD))
+ OUTPUT1_IF (tty, tty->TS_enter_bold_mode);
}
else if (face->tty_dim_p)
- if (MAY_USE_WITH_COLORS_P (NC_DIM))
- OUTPUT1_IF (TS_enter_dim_mode);
+ if (MAY_USE_WITH_COLORS_P (tty, NC_DIM))
+ OUTPUT1_IF (tty, tty->TS_enter_dim_mode);
/* Alternate charset and blinking not yet used. */
if (face->tty_alt_charset_p
- && MAY_USE_WITH_COLORS_P (NC_ALT_CHARSET))
- OUTPUT1_IF (TS_enter_alt_charset_mode);
+ && MAY_USE_WITH_COLORS_P (tty, NC_ALT_CHARSET))
+ OUTPUT1_IF (tty, tty->TS_enter_alt_charset_mode);
if (face->tty_blinking_p
- && MAY_USE_WITH_COLORS_P (NC_BLINK))
- OUTPUT1_IF (TS_enter_blink_mode);
+ && MAY_USE_WITH_COLORS_P (tty, NC_BLINK))
+ OUTPUT1_IF (tty, tty->TS_enter_blink_mode);
- if (face->tty_underline_p && MAY_USE_WITH_COLORS_P (NC_UNDERLINE))
- OUTPUT1_IF (TS_enter_underline_mode);
+ if (face->tty_underline_p && MAY_USE_WITH_COLORS_P (tty, NC_UNDERLINE))
+ OUTPUT1_IF (tty, tty->TS_enter_underline_mode);
- if (TN_max_colors > 0)
+ if (tty->TN_max_colors > 0)
{
char *ts, *p;
- ts = standout_mode ? TS_set_background : TS_set_foreground;
+ ts = tty->standout_mode ? tty->TS_set_background : tty->TS_set_foreground;
if (fg >= 0 && ts)
{
- p = tparam (ts, NULL, 0, (int) fg);
- OUTPUT (p);
+ p = tparam (ts, NULL, 0, (int) fg);
+ OUTPUT (tty, p);
xfree (p);
}
- ts = standout_mode ? TS_set_foreground : TS_set_background;
+ ts = tty->standout_mode ? tty->TS_set_foreground : tty->TS_set_background;
if (bg >= 0 && ts)
{
- p = tparam (ts, NULL, 0, (int) bg);
- OUTPUT (p);
+ p = tparam (ts, NULL, 0, (int) bg);
+ OUTPUT (tty, p);
xfree (p);
}
}
@@ -2257,10 +1965,11 @@ turn_off_face (f, face_id)
int face_id;
{
struct face *face = FACE_FROM_ID (f, face_id);
+ struct tty_display_info *tty = FRAME_TTY (f);
xassert (face != NULL);
- if (TS_exit_attribute_mode)
+ if (tty->TS_exit_attribute_mode)
{
/* Capability "me" will turn off appearance modes double-bright,
half-bright, reverse-video, standout, underline. It may or
@@ -2272,32 +1981,32 @@ turn_off_face (f, face_id)
|| face->tty_blinking_p
|| face->tty_underline_p)
{
- OUTPUT1_IF (TS_exit_attribute_mode);
- if (strcmp (TS_exit_attribute_mode, TS_end_standout_mode) == 0)
- standout_mode = 0;
+ OUTPUT1_IF (tty, tty->TS_exit_attribute_mode);
+ if (strcmp (tty->TS_exit_attribute_mode, tty->TS_end_standout_mode) == 0)
+ tty->standout_mode = 0;
}
if (face->tty_alt_charset_p)
- OUTPUT_IF (TS_exit_alt_charset_mode);
+ OUTPUT_IF (tty, tty->TS_exit_alt_charset_mode);
}
else
{
/* If we don't have "me" we can only have those appearances
that have exit sequences defined. */
if (face->tty_alt_charset_p)
- OUTPUT_IF (TS_exit_alt_charset_mode);
+ OUTPUT_IF (tty, tty->TS_exit_alt_charset_mode);
if (face->tty_underline_p)
- OUTPUT_IF (TS_exit_underline_mode);
+ OUTPUT_IF (tty, tty->TS_exit_underline_mode);
}
/* Switch back to default colors. */
- if (TN_max_colors > 0
+ if (tty->TN_max_colors > 0
&& ((face->foreground != FACE_TTY_DEFAULT_COLOR
&& face->foreground != FACE_TTY_DEFAULT_FG_COLOR)
|| (face->background != FACE_TTY_DEFAULT_COLOR
&& face->background != FACE_TTY_DEFAULT_BG_COLOR)))
- OUTPUT1_IF (TS_orig_pair);
+ OUTPUT1_IF (tty, tty->TS_orig_pair);
}
@@ -2306,46 +2015,61 @@ turn_off_face (f, face_id)
colors FG and BG. */
int
-tty_capable_p (f, caps, fg, bg)
- struct frame *f;
+tty_capable_p (tty, caps, fg, bg)
+ struct tty_display_info *tty;
unsigned caps;
unsigned long fg, bg;
{
-#define TTY_CAPABLE_P_TRY(cap, TS, NC_bit) \
- if ((caps & (cap)) && (!(TS) || !MAY_USE_WITH_COLORS_P(NC_bit))) \
+#define TTY_CAPABLE_P_TRY(tty, cap, TS, NC_bit) \
+ if ((caps & (cap)) && (!(TS) || !MAY_USE_WITH_COLORS_P(tty, NC_bit))) \
return 0;
- TTY_CAPABLE_P_TRY (TTY_CAP_INVERSE, TS_standout_mode, NC_REVERSE);
- TTY_CAPABLE_P_TRY (TTY_CAP_UNDERLINE, TS_enter_underline_mode, NC_UNDERLINE);
- TTY_CAPABLE_P_TRY (TTY_CAP_BOLD, TS_enter_bold_mode, NC_BOLD);
- TTY_CAPABLE_P_TRY (TTY_CAP_DIM, TS_enter_dim_mode, NC_DIM);
- TTY_CAPABLE_P_TRY (TTY_CAP_BLINK, TS_enter_blink_mode, NC_BLINK);
- TTY_CAPABLE_P_TRY (TTY_CAP_ALT_CHARSET, TS_enter_alt_charset_mode, NC_ALT_CHARSET);
+ TTY_CAPABLE_P_TRY (tty, TTY_CAP_INVERSE, tty->TS_standout_mode, NC_REVERSE);
+ TTY_CAPABLE_P_TRY (tty, TTY_CAP_UNDERLINE, tty->TS_enter_underline_mode, NC_UNDERLINE);
+ TTY_CAPABLE_P_TRY (tty, TTY_CAP_BOLD, tty->TS_enter_bold_mode, NC_BOLD);
+ TTY_CAPABLE_P_TRY (tty, TTY_CAP_DIM, tty->TS_enter_dim_mode, NC_DIM);
+ TTY_CAPABLE_P_TRY (tty, TTY_CAP_BLINK, tty->TS_enter_blink_mode, NC_BLINK);
+ TTY_CAPABLE_P_TRY (tty, TTY_CAP_ALT_CHARSET, tty->TS_enter_alt_charset_mode, NC_ALT_CHARSET);
/* We can do it! */
return 1;
}
-
/* Return non-zero if the terminal is capable to display colors. */
DEFUN ("tty-display-color-p", Ftty_display_color_p, Stty_display_color_p,
0, 1, 0,
- doc: /* Return non-nil if TTY can display colors on DISPLAY. */)
- (display)
- Lisp_Object display;
+ doc: /* Return non-nil if the tty device TERMINAL can display colors.
+
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). This function always returns nil if TERMINAL
+is not on a tty device. */)
+ (terminal)
+ Lisp_Object terminal;
{
- return TN_max_colors > 0 ? Qt : Qnil;
+ struct terminal *t = get_tty_terminal (terminal, 0);
+ if (!t)
+ return Qnil;
+ else
+ return t->display_info.tty->TN_max_colors > 0 ? Qt : Qnil;
}
/* Return the number of supported colors. */
DEFUN ("tty-display-color-cells", Ftty_display_color_cells,
Stty_display_color_cells, 0, 1, 0,
- doc: /* Return the number of colors supported by TTY on DISPLAY. */)
- (display)
- Lisp_Object display;
+ doc: /* Return the number of colors supported by the tty device TERMINAL.
+
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). This function always returns 0 if TERMINAL
+is not on a tty device. */)
+ (terminal)
+ Lisp_Object terminal;
{
- return make_number (TN_max_colors);
+ struct terminal *t = get_tty_terminal (terminal, 0);
+ if (!t)
+ return make_number (0);
+ else
+ return make_number (t->display_info.tty->TN_max_colors);
}
#ifndef WINDOWSNT
@@ -2363,48 +2087,46 @@ static char *default_set_background;
/* Save or restore the default color-related capabilities of this
terminal. */
static void
-tty_default_color_capabilities (save)
- int save;
+tty_default_color_capabilities (struct tty_display_info *tty, int save)
{
if (save)
{
if (default_orig_pair)
xfree (default_orig_pair);
- default_orig_pair = TS_orig_pair ? xstrdup (TS_orig_pair) : NULL;
+ default_orig_pair = tty->TS_orig_pair ? xstrdup (tty->TS_orig_pair) : NULL;
if (default_set_foreground)
xfree (default_set_foreground);
- default_set_foreground = TS_set_foreground ? xstrdup (TS_set_foreground)
+ default_set_foreground = tty->TS_set_foreground ? xstrdup (tty->TS_set_foreground)
: NULL;
if (default_set_background)
xfree (default_set_background);
- default_set_background = TS_set_background ? xstrdup (TS_set_background)
+ default_set_background = tty->TS_set_background ? xstrdup (tty->TS_set_background)
: NULL;
- default_max_colors = TN_max_colors;
- default_max_pairs = TN_max_pairs;
- default_no_color_video = TN_no_color_video;
+ default_max_colors = tty->TN_max_colors;
+ default_max_pairs = tty->TN_max_pairs;
+ default_no_color_video = tty->TN_no_color_video;
}
else
{
- TS_orig_pair = default_orig_pair;
- TS_set_foreground = default_set_foreground;
- TS_set_background = default_set_background;
- TN_max_colors = default_max_colors;
- TN_max_pairs = default_max_pairs;
- TN_no_color_video = default_no_color_video;
+ tty->TS_orig_pair = default_orig_pair;
+ tty->TS_set_foreground = default_set_foreground;
+ tty->TS_set_background = default_set_background;
+ tty->TN_max_colors = default_max_colors;
+ tty->TN_max_pairs = default_max_pairs;
+ tty->TN_no_color_video = default_no_color_video;
}
}
/* Setup one of the standard tty color schemes according to MODE.
MODE's value is generally the number of colors which we want to
support; zero means set up for the default capabilities, the ones
- we saw at term_init time; -1 means turn off color support. */
-void
-tty_setup_colors (mode)
- int mode;
+ we saw at init_tty time; -1 means turn off color support. */
+static void
+tty_setup_colors (struct tty_display_info *tty, int mode)
{
/* Canonicalize all negative values of MODE. */
if (mode < -1)
@@ -2413,27 +2135,27 @@ tty_setup_colors (mode)
switch (mode)
{
case -1: /* no colors at all */
- TN_max_colors = 0;
- TN_max_pairs = 0;
- TN_no_color_video = 0;
- TS_set_foreground = TS_set_background = TS_orig_pair = NULL;
+ tty->TN_max_colors = 0;
+ tty->TN_max_pairs = 0;
+ tty->TN_no_color_video = 0;
+ tty->TS_set_foreground = tty->TS_set_background = tty->TS_orig_pair = NULL;
break;
case 0: /* default colors, if any */
default:
- tty_default_color_capabilities (0);
+ tty_default_color_capabilities (tty, 0);
break;
case 8: /* 8 standard ANSI colors */
- TS_orig_pair = "\033[0m";
+ tty->TS_orig_pair = "\033[0m";
#ifdef TERMINFO
- TS_set_foreground = "\033[3%p1%dm";
- TS_set_background = "\033[4%p1%dm";
+ tty->TS_set_foreground = "\033[3%p1%dm";
+ tty->TS_set_background = "\033[4%p1%dm";
#else
- TS_set_foreground = "\033[3%dm";
- TS_set_background = "\033[4%dm";
+ tty->TS_set_foreground = "\033[3%dm";
+ tty->TS_set_background = "\033[4%dm";
#endif
- TN_max_colors = 8;
- TN_max_pairs = 64;
- TN_no_color_video = 0;
+ tty->TN_max_colors = 8;
+ tty->TN_max_pairs = 64;
+ tty->TN_no_color_video = 0;
break;
}
}
@@ -2484,7 +2206,7 @@ set_tty_color_mode (f, val)
if (mode != old_mode)
{
- tty_setup_colors (mode);
+ tty_setup_colors (FRAME_TTY (f), mode);
/* This recomputes all the faces given the new color
definitions. */
call0 (intern ("tty-set-up-initial-frame-faces"));
@@ -2495,6 +2217,241 @@ set_tty_color_mode (f, val)
#endif /* !WINDOWSNT */
+
+/* Return the tty display object specified by TERMINAL. */
+
+struct terminal *
+get_tty_terminal (Lisp_Object terminal, int throw)
+{
+ struct terminal *t = get_terminal (terminal, throw);
+
+ if (t && t->type != output_termcap)
+ {
+ if (throw)
+ error ("Device %d is not a termcap terminal device", t->id);
+ else
+ return NULL;
+ }
+
+ return t;
+}
+
+/* Return an active termcap device that uses the tty device with the
+ given name.
+
+ This function ignores suspended devices.
+
+ Returns NULL if the named terminal device is not opened. */
+
+struct terminal *
+get_named_tty (name)
+ char *name;
+{
+ struct terminal *t;
+
+ if (!name)
+ abort ();
+
+ for (t = terminal_list; t; t = t->next_terminal)
+ {
+ if (t->type == output_termcap
+ && !strcmp (t->display_info.tty->name, name)
+ && TERMINAL_ACTIVE_P (t))
+ return t;
+ }
+
+ return 0;
+}
+
+
+DEFUN ("tty-type", Ftty_type, Stty_type, 0, 1, 0,
+ doc: /* Return the type of the tty device that TERMINAL uses.
+Returns nil if TERMINAL is not on a tty device.
+
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). */)
+ (terminal)
+ Lisp_Object terminal;
+{
+ struct terminal *t = get_terminal (terminal, 1);
+
+ if (t->type != output_termcap)
+ return Qnil;
+
+ if (t->display_info.tty->type)
+ return build_string (t->display_info.tty->type);
+ else
+ return Qnil;
+}
+
+DEFUN ("controlling-tty-p", Fcontrolling_tty_p, Scontrolling_tty_p, 0, 1, 0,
+ doc: /* Return non-nil if TERMINAL is on the controlling tty of the Emacs process.
+
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). This function always returns nil if TERMINAL
+is not on a tty device. */)
+ (terminal)
+ Lisp_Object terminal;
+{
+ struct terminal *t = get_terminal (terminal, 1);
+
+ if (t->type != output_termcap || strcmp (t->display_info.tty->name, DEV_TTY))
+ return Qnil;
+ else
+ return Qt;
+}
+
+DEFUN ("tty-no-underline", Ftty_no_underline, Stty_no_underline, 0, 1, 0,
+ doc: /* Declare that the tty used by TERMINAL does not handle underlining.
+This is used to override the terminfo data, for certain terminals that
+do not really do underlining, but say that they do. This function has
+no effect if used on a non-tty terminal.
+
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). This function always returns nil if TERMINAL
+is not on a tty device. */)
+ (terminal)
+ Lisp_Object terminal;
+{
+ struct terminal *t = get_terminal (terminal, 1);
+
+ if (t->type == output_termcap)
+ t->display_info.tty->TS_enter_underline_mode = 0;
+ return Qnil;
+}
+
+
+
+DEFUN ("suspend-tty", Fsuspend_tty, Ssuspend_tty, 0, 1, 0,
+ doc: /* Suspend the terminal device TTY.
+
+The device is restored to its default state, and Emacs ceases all
+access to the tty device. Frames that use the device are not deleted,
+but input is not read from them and if they change, their display is
+not updated.
+
+TTY may be a terminal id, a frame, or nil for the terminal device of
+the currently selected frame.
+
+This function runs `suspend-tty-functions' after suspending the
+device. The functions are run with one arg, the id of the suspended
+terminal device.
+
+`suspend-tty' does nothing if it is called on a device that is already
+suspended.
+
+A suspended tty may be resumed by calling `resume-tty' on it. */)
+ (tty)
+ Lisp_Object tty;
+{
+ struct terminal *t = get_tty_terminal (tty, 1);
+ FILE *f;
+
+ if (!t)
+ error ("Unknown tty device");
+
+ f = t->display_info.tty->input;
+
+ if (f)
+ {
+ /* First run `suspend-tty-functions' and then clean up the tty
+ state because `suspend-tty-functions' might need to change
+ the tty state. */
+ if (!NILP (Vrun_hooks))
+ {
+ Lisp_Object args[2];
+ args[0] = intern ("suspend-tty-functions");
+ XSETTERMINAL (args[1], t);
+ Frun_hook_with_args (2, args);
+ }
+
+ reset_sys_modes (t->display_info.tty);
+
+ delete_keyboard_wait_descriptor (fileno (f));
+
+ fclose (f);
+ if (f != t->display_info.tty->output)
+ fclose (t->display_info.tty->output);
+
+ t->display_info.tty->input = 0;
+ t->display_info.tty->output = 0;
+
+ if (FRAMEP (t->display_info.tty->top_frame))
+ FRAME_SET_VISIBLE (XFRAME (t->display_info.tty->top_frame), 0);
+
+ }
+
+ /* Clear display hooks to prevent further output. */
+ clear_tty_hooks (t);
+
+ return Qnil;
+}
+
+DEFUN ("resume-tty", Fresume_tty, Sresume_tty, 0, 1, 0,
+ doc: /* Resume the previously suspended terminal device TTY.
+The terminal is opened and reinitialized. Frames that are on the
+suspended terminal are revived.
+
+It is an error to resume a terminal while another terminal is active
+on the same device.
+
+This function runs `resume-tty-functions' after resuming the terminal.
+The functions are run with one arg, the id of the resumed terminal
+device.
+
+`resume-tty' does nothing if it is called on a device that is not
+suspended.
+
+TTY may be a terminal id, a frame, or nil for the terminal device of
+the currently selected frame. */)
+ (tty)
+ Lisp_Object tty;
+{
+ struct terminal *t = get_tty_terminal (tty, 1);
+ int fd;
+
+ if (!t)
+ error ("Unknown tty device");
+
+ if (!t->display_info.tty->input)
+ {
+ if (get_named_tty (t->display_info.tty->name))
+ error ("Cannot resume display while another display is active on the same device");
+
+ fd = emacs_open (t->display_info.tty->name, O_RDWR | O_NOCTTY, 0);
+
+ if (fd == -1)
+ error ("Can not reopen tty device %s: %s", t->display_info.tty->name, strerror (errno));
+
+ if (strcmp (t->display_info.tty->name, DEV_TTY))
+ dissociate_if_controlling_tty (fd);
+
+ t->display_info.tty->output = fdopen (fd, "w+");
+ t->display_info.tty->input = t->display_info.tty->output;
+
+ add_keyboard_wait_descriptor (fd);
+
+ if (FRAMEP (t->display_info.tty->top_frame))
+ FRAME_SET_VISIBLE (XFRAME (t->display_info.tty->top_frame), 1);
+
+ init_sys_modes (t->display_info.tty);
+
+ /* Run `resume-tty-functions'. */
+ if (!NILP (Vrun_hooks))
+ {
+ Lisp_Object args[2];
+ args[0] = intern ("resume-tty-functions");
+ XSETTERMINAL (args[1], t);
+ Frun_hook_with_args (2, args);
+ }
+ }
+
+ set_tty_hooks (t);
+
+ return Qnil;
+}
+
+
/***********************************************************************
Mouse
***********************************************************************/
@@ -2517,10 +2474,13 @@ term_mouse_moveto (int x, int y)
static void
term_show_mouse_face (enum draw_glyphs_face draw)
{
- struct window *w = XWINDOW (Qmouse_face_window);
+ struct window *w = XWINDOW (mouse_face_window);
int save_x, save_y;
int i;
+ struct frame *f = XFRAME (w->frame);
+ struct tty_display_info *tty = FRAME_TTY (f);
+
if (/* If window is in the process of being destroyed, don't bother
to do anything. */
w->current_matrix != NULL
@@ -2533,8 +2493,8 @@ term_show_mouse_face (enum draw_glyphs_face draw)
the highlight region. */
/* Save current cursor co-ordinates */
- save_y = curY;
- save_x = curX;
+ save_y = curY (tty);
+ save_x = curX (tty);
/* Note that mouse_face_beg_row etc. are window relative. */
for (i = mouse_face_beg_row; i <= mouse_face_end_row; i++)
@@ -2576,29 +2536,29 @@ term_show_mouse_face (enum draw_glyphs_face draw)
pos_x = row->used[LEFT_MARGIN_AREA] + start_hpos
+ WINDOW_LEFT_EDGE_X (w);
- cursor_to (pos_y, pos_x);
+ cursor_to (f, pos_y, pos_x);
if (draw == DRAW_MOUSE_FACE)
{
- write_glyphs_with_face (row->glyphs[TEXT_AREA] + start_hpos,
+ tty_write_glyphs_with_face (f, row->glyphs[TEXT_AREA] + start_hpos,
nglyphs, mouse_face_face_id);
}
else /* draw == DRAW_NORMAL_TEXT */
- write_glyphs (row->glyphs[TEXT_AREA] + start_hpos, nglyphs);
+ write_glyphs (f, row->glyphs[TEXT_AREA] + start_hpos, nglyphs);
}
- cursor_to (save_y, save_x);
+ cursor_to (f, save_y, save_x);
}
}
static void
term_clear_mouse_face ()
{
- if (!NILP (Qmouse_face_window))
+ if (!NILP (mouse_face_window))
term_show_mouse_face (DRAW_NORMAL_TEXT);
mouse_face_beg_row = mouse_face_beg_col = -1;
mouse_face_end_row = mouse_face_end_col = -1;
- Qmouse_face_window = Qnil;
+ mouse_face_window = Qnil;
}
/* Find the glyph matrix position of buffer position POS in window W.
@@ -2695,7 +2655,7 @@ term_mouse_highlight (struct frame *f, int x, int y)
if (!WINDOWP (window))
return;
- if (!EQ (window, Qmouse_face_window))
+ if (!EQ (window, mouse_face_window))
term_clear_mouse_face ();
w = XWINDOW (window);
@@ -2778,7 +2738,7 @@ term_mouse_highlight (struct frame *f, int x, int y)
noverlays = sort_overlays (overlay_vec, noverlays, w);
/* Check mouse-face highlighting. */
- if (!(EQ (window, Qmouse_face_window)
+ if (!(EQ (window, mouse_face_window)
&& y >= mouse_face_beg_row
&& y <= mouse_face_end_row
&& (y > mouse_face_beg_row
@@ -2828,7 +2788,7 @@ term_mouse_highlight (struct frame *f, int x, int y)
= !fast_find_position (w, XFASTINT (after),
&mouse_face_end_col,
&mouse_face_end_row);
- Qmouse_face_window = window;
+ mouse_face_window = window;
mouse_face_face_id
= face_at_buffer_position (w, pos, 0, 0,
@@ -2863,7 +2823,7 @@ term_mouse_highlight (struct frame *f, int x, int y)
= !fast_find_position (w, XFASTINT (after),
&mouse_face_end_col,
&mouse_face_end_row);
- Qmouse_face_window = window;
+ mouse_face_window = window;
mouse_face_face_id
= face_at_buffer_position (w, pos, 0, 0,
@@ -3036,10 +2996,9 @@ term_mouse_click (struct input_event *result, Gpm_Event *event,
}
int
-handle_one_term_event (Gpm_Event *event, struct input_event* hold_quit)
+handle_one_term_event (struct tty_display_info *tty, Gpm_Event *event, struct input_event* hold_quit)
{
- struct frame *f = SELECTED_FRAME ();
- int fd;
+ struct frame *f = XFRAME (tty->top_frame);
struct input_event ie;
int do_help = 0;
int count = 0;
@@ -3049,24 +3008,10 @@ handle_one_term_event (Gpm_Event *event, struct input_event* hold_quit)
ie.arg = Qnil;
if (event->type & (GPM_MOVE | GPM_DRAG)) {
- unsigned char buf[6 * sizeof (short)];
- unsigned short *arg = (unsigned short *) buf + 1;
- const char *name;
-
previous_help_echo_string = help_echo_string;
help_echo_string = Qnil;
- /* Display mouse pointer */
- buf[sizeof(short) - 1] = 2; /* set selection */
-
- arg[0] = arg[2] = (unsigned short) event->x + gpm_zerobased;
- arg[1] = arg[3] = (unsigned short) event->y + gpm_zerobased;
- arg[4] = (unsigned short) 3;
-
- name = ttyname (0);
- fd = open (name, O_WRONLY);
- ioctl (fd, TIOCLINUX, buf + sizeof (short) - 1);
- close (fd);
+ Gpm_DrawPointer (event->x, event->y, fileno (tty->output));
if (!term_mouse_movement (f, event))
help_echo_string = previous_help_echo_string;
@@ -3109,13 +3054,25 @@ handle_one_term_event (Gpm_Event *event, struct input_event* hold_quit)
return count;
}
-DEFUN ("term-open-connection", Fterm_open_connection, Sterm_open_connection,
+DEFUN ("gpm-mouse-start", Fgpm_mouse_start, Sgpm_mouse_start,
0, 0, 0,
- doc: /* Open a connection to Gpm. */)
+ doc: /* Open a connection to Gpm.
+Gpm-mouse can only be activated for one tty at a time. */)
()
{
+ struct frame *f = SELECTED_FRAME ();
+ struct tty_display_info *tty
+ = ((f)->output_method == output_termcap
+ ? (f)->terminal->display_info.tty : NULL);
Gpm_Connect connection;
+ if (!tty)
+ error ("Gpm-mouse only works in the GNU/Linux console");
+ if (gpm_tty == tty)
+ return Qnil; /* Already activated, nothing to do. */
+ if (gpm_tty)
+ error ("Gpm-mouse can only be activated for one tty at a time");
+
connection.eventMask = ~0;
connection.defaultMask = ~GPM_HARD;
connection.maxMod = ~0;
@@ -3123,26 +3080,38 @@ DEFUN ("term-open-connection", Fterm_open_connection, Sterm_open_connection,
gpm_zerobased = 1;
if (Gpm_Open (&connection, 0) < 0)
- return Qnil;
+ error ("Gpm-mouse failed to connect to the gpm daemon");
else
{
- term_gpm = 1;
- reset_sys_modes ();
- init_sys_modes ();
+ gpm_tty = tty;
+ /* `init_sys_modes' arranges for mouse movements sent through gpm_fd
+ to generate SIGIOs. Apparently we need to call reset_sys_modes
+ before calling init_sys_modes. */
+ reset_sys_modes (tty);
+ init_sys_modes (tty);
add_gpm_wait_descriptor (gpm_fd);
- return Qt;
+ return Qnil;
}
}
-DEFUN ("term-close-connection", Fterm_close_connection, Sterm_close_connection,
+DEFUN ("gpm-mouse-stop", Fgpm_mouse_stop, Sgpm_mouse_stop,
0, 0, 0,
doc: /* Close a connection to Gpm. */)
()
{
- delete_gpm_wait_descriptor (gpm_fd);
- while (Gpm_Close()); /* close all the stack */
- term_gpm = 0;
- return Qnil;
+ struct frame *f = SELECTED_FRAME ();
+ struct tty_display_info *tty
+ = ((f)->output_method == output_termcap
+ ? (f)->terminal->display_info.tty : NULL);
+
+ if (!tty || gpm_tty != tty)
+ return Qnil; /* Not activated on this terminal, nothing to do. */
+
+ if (gpm_fd >= 0)
+ delete_gpm_wait_descriptor (gpm_fd);
+ while (Gpm_Close()); /* close all the stack */
+ gpm_tty = NULL;
+ return Qnil;
}
#endif /* HAVE_GPM */
@@ -3151,87 +3120,359 @@ DEFUN ("term-close-connection", Fterm_close_connection, Sterm_close_connection,
Initialization
***********************************************************************/
+/* Initialize the tty-dependent part of frame F. The frame must
+ already have its device initialized. */
+
void
-term_init (terminal_type)
- char *terminal_type;
+create_tty_output (struct frame *f)
+{
+ struct tty_output *t;
+
+ if (! FRAME_TERMCAP_P (f))
+ abort ();
+
+ t = xmalloc (sizeof (struct tty_output));
+ bzero (t, sizeof (struct tty_output));
+
+ t->display_info = FRAME_TERMINAL (f)->display_info.tty;
+
+ f->output_data.tty = t;
+}
+
+/* Delete the tty-dependent part of frame F. */
+
+static void
+delete_tty_output (struct frame *f)
+{
+ if (! FRAME_TERMCAP_P (f))
+ abort ();
+
+ xfree (f->output_data.tty);
+}
+
+
+/* Reset the hooks in TERMINAL. */
+
+static void
+clear_tty_hooks (struct terminal *terminal)
+{
+ terminal->rif = 0;
+ terminal->cursor_to_hook = 0;
+ terminal->raw_cursor_to_hook = 0;
+ terminal->clear_to_end_hook = 0;
+ terminal->clear_frame_hook = 0;
+ terminal->clear_end_of_line_hook = 0;
+ terminal->ins_del_lines_hook = 0;
+ terminal->insert_glyphs_hook = 0;
+ terminal->write_glyphs_hook = 0;
+ terminal->delete_glyphs_hook = 0;
+ terminal->ring_bell_hook = 0;
+ terminal->reset_terminal_modes_hook = 0;
+ terminal->set_terminal_modes_hook = 0;
+ terminal->update_begin_hook = 0;
+ terminal->update_end_hook = 0;
+ terminal->set_terminal_window_hook = 0;
+ terminal->mouse_position_hook = 0;
+ terminal->frame_rehighlight_hook = 0;
+ terminal->frame_raise_lower_hook = 0;
+ terminal->fullscreen_hook = 0;
+ terminal->set_vertical_scroll_bar_hook = 0;
+ terminal->condemn_scroll_bars_hook = 0;
+ terminal->redeem_scroll_bar_hook = 0;
+ terminal->judge_scroll_bars_hook = 0;
+ terminal->read_socket_hook = 0;
+ terminal->frame_up_to_date_hook = 0;
+
+ /* Leave these two set, or suspended frames are not deleted
+ correctly. */
+ terminal->delete_frame_hook = &delete_tty_output;
+ terminal->delete_terminal_hook = &delete_tty;
+}
+
+/* Initialize hooks in TERMINAL with the values needed for a tty. */
+
+static void
+set_tty_hooks (struct terminal *terminal)
+{
+ terminal->rif = 0; /* ttys don't support window-based redisplay. */
+
+ terminal->cursor_to_hook = &tty_cursor_to;
+ terminal->raw_cursor_to_hook = &tty_raw_cursor_to;
+
+ terminal->clear_to_end_hook = &tty_clear_to_end;
+ terminal->clear_frame_hook = &tty_clear_frame;
+ terminal->clear_end_of_line_hook = &tty_clear_end_of_line;
+
+ terminal->ins_del_lines_hook = &tty_ins_del_lines;
+
+ terminal->insert_glyphs_hook = &tty_insert_glyphs;
+ terminal->write_glyphs_hook = &tty_write_glyphs;
+ terminal->delete_glyphs_hook = &tty_delete_glyphs;
+
+ terminal->ring_bell_hook = &tty_ring_bell;
+
+ terminal->reset_terminal_modes_hook = &tty_reset_terminal_modes;
+ terminal->set_terminal_modes_hook = &tty_set_terminal_modes;
+ terminal->update_begin_hook = 0; /* Not needed. */
+ terminal->update_end_hook = &tty_update_end;
+ terminal->set_terminal_window_hook = &tty_set_terminal_window;
+
+ terminal->mouse_position_hook = 0; /* Not needed. */
+ terminal->frame_rehighlight_hook = 0; /* Not needed. */
+ terminal->frame_raise_lower_hook = 0; /* Not needed. */
+
+ terminal->set_vertical_scroll_bar_hook = 0; /* Not needed. */
+ terminal->condemn_scroll_bars_hook = 0; /* Not needed. */
+ terminal->redeem_scroll_bar_hook = 0; /* Not needed. */
+ terminal->judge_scroll_bars_hook = 0; /* Not needed. */
+
+ terminal->read_socket_hook = &tty_read_avail_input; /* keyboard.c */
+ terminal->frame_up_to_date_hook = 0; /* Not needed. */
+
+ terminal->delete_frame_hook = &delete_tty_output;
+ terminal->delete_terminal_hook = &delete_tty;
+}
+
+/* Drop the controlling terminal if fd is the same device. */
+static void
+dissociate_if_controlling_tty (int fd)
+{
+#ifndef WINDOWSNT
+ int pgid;
+ EMACS_GET_TTY_PGRP (fd, &pgid); /* If tcgetpgrp succeeds, fd is the ctty. */
+ if (pgid != -1)
+ {
+#if defined (USG) && !defined (BSD_PGRPS)
+ setpgrp ();
+ no_controlling_tty = 1;
+#elif defined (CYGWIN)
+ setsid ();
+ no_controlling_tty = 1;
+#else
+#ifdef TIOCNOTTY /* Try BSD ioctls. */
+ sigblock (sigmask (SIGTTOU));
+ fd = emacs_open (DEV_TTY, O_RDWR, 0);
+ if (fd != -1 && ioctl (fd, TIOCNOTTY, 0) != -1)
+ {
+ no_controlling_tty = 1;
+ }
+ if (fd != -1)
+ emacs_close (fd);
+ sigunblock (sigmask (SIGTTOU));
+#else
+ /* Unknown system. */
+ croak ();
+#endif /* ! TIOCNOTTY */
+#endif /* ! USG */
+ }
+#endif /* !WINDOWSNT */
+}
+
+static void maybe_fatal();
+
+/* Create a termcap display on the tty device with the given name and
+ type.
+
+ If NAME is NULL, then use the controlling tty, i.e., "/dev/tty".
+ Otherwise NAME should be a path to the tty device file,
+ e.g. "/dev/pts/7".
+
+ TERMINAL_TYPE is the termcap type of the device, e.g. "vt100".
+
+ If MUST_SUCCEED is true, then all errors are fatal. */
+
+struct terminal *
+init_tty (char *name, char *terminal_type, int must_succeed)
{
- char *area;
+ char *area = NULL;
char **address = &area;
char *buffer = NULL;
int buffer_size = 4096;
- register char *p;
+ register char *p = NULL;
int status;
- struct frame *sf = XFRAME (selected_frame);
+ struct tty_display_info *tty = NULL;
+ struct terminal *terminal = NULL;
+ int ctty = 0; /* 1 if asked to open controlling tty. */
+
+ if (!terminal_type)
+ maybe_fatal (must_succeed, 0, 0,
+ "Unknown terminal type",
+ "Unknown terminal type");
+
+ if (name == NULL)
+ name = DEV_TTY;
+ if (!strcmp (name, DEV_TTY))
+ ctty = 1;
+
+ /* If we already have a terminal on the given device, use that. If
+ all such terminals are suspended, create a new one instead. */
+ /* XXX Perhaps this should be made explicit by having init_tty
+ always create a new terminal and separating terminal and frame
+ creation on Lisp level. */
+ terminal = get_named_tty (name);
+ if (terminal)
+ return terminal;
+
+ terminal = create_terminal ();
+ tty = (struct tty_display_info *) xmalloc (sizeof (struct tty_display_info));
+ bzero (tty, sizeof (struct tty_display_info));
+ tty->next = tty_list;
+ tty_list = tty;
+
+ terminal->type = output_termcap;
+ terminal->display_info.tty = tty;
+ tty->terminal = terminal;
+
+ tty->Wcm = (struct cm *) xmalloc (sizeof (struct cm));
+ Wcm_clear (tty);
+
+#ifndef WINDOWSNT
+ set_tty_hooks (terminal);
+
+ {
+ int fd;
+ FILE *file;
+
+#ifdef O_IGNORE_CTTY
+ if (!ctty)
+ /* Open the terminal device. Don't recognize it as our
+ controlling terminal, and don't make it the controlling tty
+ if we don't have one at the moment. */
+ fd = emacs_open (name, O_RDWR | O_IGNORE_CTTY | O_NOCTTY, 0);
+ else
+#else
+ /* Alas, O_IGNORE_CTTY is a GNU extension that seems to be only
+ defined on Hurd. On other systems, we need to explicitly
+ dissociate ourselves from the controlling tty when we want to
+ open a frame on the same terminal. */
+ fd = emacs_open (name, O_RDWR | O_NOCTTY, 0);
+#endif /* O_IGNORE_CTTY */
+
+ if (fd < 0)
+ maybe_fatal (must_succeed, buffer, terminal,
+ "Could not open file: %s",
+ "Could not open file: %s",
+ name);
+ if (!isatty (fd))
+ {
+ close (fd);
+ maybe_fatal (must_succeed, buffer, terminal,
+ "Not a tty device: %s",
+ "Not a tty device: %s",
+ name);
+ }
+
+#ifndef O_IGNORE_CTTY
+ if (!ctty)
+ dissociate_if_controlling_tty (fd);
+#endif
+
+ file = fdopen (fd, "w+");
+ tty->name = xstrdup (name);
+ terminal->name = xstrdup (name);
+ tty->input = file;
+ tty->output = file;
+ }
+
+ tty->type = xstrdup (terminal_type);
+
+ add_keyboard_wait_descriptor (fileno (tty->input));
+
+#endif
encode_terminal_src_size = 0;
encode_terminal_dst_size = 0;
#ifdef HAVE_GPM
- mouse_position_hook = term_mouse_position;
- Qmouse_face_window = Qnil;
+ terminal->mouse_position_hook = term_mouse_position;
+ mouse_face_window = Qnil;
#endif
#ifdef WINDOWSNT
- initialize_w32_display ();
+ initialize_w32_display (terminal);
+ /* The following two are inaccessible from w32console.c. */
+ terminal->delete_frame_hook = &delete_tty_output;
+ terminal->delete_terminal_hook = &delete_tty;
- Wcm_clear ();
+ tty->name = xstrdup (name);
+ terminal->name = xstrdup (name);
+ tty->type = xstrdup (terminal_type);
- area = (char *) xmalloc (2044);
+ tty->output = stdout;
+ tty->input = stdin;
+ add_keyboard_wait_descriptor (0);
- FrameRows = FRAME_LINES (sf);
- FrameCols = FRAME_COLS (sf);
- specified_window = FRAME_LINES (sf);
+ Wcm_clear (tty);
- delete_in_insert_mode = 1;
+ {
+ struct frame *f = XFRAME (selected_frame);
+
+ FrameRows (tty) = FRAME_LINES (f);
+ FrameCols (tty) = FRAME_COLS (f);
+ tty->specified_window = FRAME_LINES (f);
- UseTabs = 0;
- scroll_region_ok = 0;
+ FRAME_CAN_HAVE_SCROLL_BARS (f) = 0;
+ FRAME_VERTICAL_SCROLL_BAR_TYPE (f) = vertical_scroll_bar_none;
+ }
+ tty->delete_in_insert_mode = 1;
- /* Seems to insert lines when it's not supposed to, messing
- up the display. In doing a trace, it didn't seem to be
- called much, so I don't think we're losing anything by
- turning it off. */
+ UseTabs (tty) = 0;
+ terminal->scroll_region_ok = 0;
- line_ins_del_ok = 0;
- char_ins_del_ok = 1;
+ /* Seems to insert lines when it's not supposed to, messing up the
+ display. In doing a trace, it didn't seem to be called much, so I
+ don't think we're losing anything by turning it off. */
+ terminal->line_ins_del_ok = 0;
+ terminal->char_ins_del_ok = 1;
baud_rate = 19200;
- FRAME_CAN_HAVE_SCROLL_BARS (sf) = 0;
- FRAME_VERTICAL_SCROLL_BAR_TYPE (sf) = vertical_scroll_bar_none;
- TN_max_colors = 16; /* Required to be non-zero for tty-display-color-p */
+ tty->TN_max_colors = 16; /* Required to be non-zero for tty-display-color-p */
- return;
#else /* not WINDOWSNT */
- Wcm_clear ();
+ Wcm_clear (tty);
buffer = (char *) xmalloc (buffer_size);
+
+ /* On some systems, tgetent tries to access the controlling
+ terminal. */
+ sigblock (sigmask (SIGTTOU));
status = tgetent (buffer, terminal_type);
+ sigunblock (sigmask (SIGTTOU));
+
if (status < 0)
{
#ifdef TERMINFO
- fatal ("Cannot open terminfo database file");
+ maybe_fatal (must_succeed, buffer, terminal,
+ "Cannot open terminfo database file",
+ "Cannot open terminfo database file");
#else
- fatal ("Cannot open termcap database file");
+ maybe_fatal (must_succeed, buffer, terminal,
+ "Cannot open termcap database file",
+ "Cannot open termcap database file");
#endif
}
if (status == 0)
{
#ifdef TERMINFO
- fatal ("Terminal type %s is not defined.\n\
+ maybe_fatal (must_succeed, buffer, terminal,
+ "Terminal type %s is not defined",
+ "Terminal type %s is not defined.\n\
If that is not the actual type of terminal you have,\n\
use the Bourne shell command `TERM=... export TERM' (C-shell:\n\
`setenv TERM ...') to specify the correct type. It may be necessary\n\
to do `unset TERMINFO' (C-shell: `unsetenv TERMINFO') as well.",
- terminal_type);
+ terminal_type);
#else
- fatal ("Terminal type %s is not defined.\n\
+ maybe_fatal (must_succeed, buffer, terminal,
+ "Terminal type %s is not defined",
+ "Terminal type %s is not defined.\n\
If that is not the actual type of terminal you have,\n\
use the Bourne shell command `TERM=... export TERM' (C-shell:\n\
`setenv TERM ...') to specify the correct type. It may be necessary\n\
to do `unset TERMCAP' (C-shell: `unsetenv TERMCAP') as well.",
- terminal_type);
+ terminal_type);
#endif
}
@@ -3242,219 +3483,237 @@ to do `unset TERMCAP' (C-shell: `unsetenv TERMCAP') as well.",
#endif
area = (char *) xmalloc (buffer_size);
- TS_ins_line = tgetstr ("al", address);
- TS_ins_multi_lines = tgetstr ("AL", address);
- TS_bell = tgetstr ("bl", address);
- BackTab = tgetstr ("bt", address);
- TS_clr_to_bottom = tgetstr ("cd", address);
- TS_clr_line = tgetstr ("ce", address);
- TS_clr_frame = tgetstr ("cl", address);
- ColPosition = NULL; /* tgetstr ("ch", address); */
- AbsPosition = tgetstr ("cm", address);
- CR = tgetstr ("cr", address);
- TS_set_scroll_region = tgetstr ("cs", address);
- TS_set_scroll_region_1 = tgetstr ("cS", address);
- RowPosition = tgetstr ("cv", address);
- TS_del_char = tgetstr ("dc", address);
- TS_del_multi_chars = tgetstr ("DC", address);
- TS_del_line = tgetstr ("dl", address);
- TS_del_multi_lines = tgetstr ("DL", address);
- TS_delete_mode = tgetstr ("dm", address);
- TS_end_delete_mode = tgetstr ("ed", address);
- TS_end_insert_mode = tgetstr ("ei", address);
- Home = tgetstr ("ho", address);
- TS_ins_char = tgetstr ("ic", address);
- TS_ins_multi_chars = tgetstr ("IC", address);
- TS_insert_mode = tgetstr ("im", address);
- TS_pad_inserted_char = tgetstr ("ip", address);
- TS_end_keypad_mode = tgetstr ("ke", address);
- TS_keypad_mode = tgetstr ("ks", address);
- LastLine = tgetstr ("ll", address);
- Right = tgetstr ("nd", address);
- Down = tgetstr ("do", address);
- if (!Down)
- Down = tgetstr ("nl", address); /* Obsolete name for "do" */
+ tty->TS_ins_line = tgetstr ("al", address);
+ tty->TS_ins_multi_lines = tgetstr ("AL", address);
+ tty->TS_bell = tgetstr ("bl", address);
+ BackTab (tty) = tgetstr ("bt", address);
+ tty->TS_clr_to_bottom = tgetstr ("cd", address);
+ tty->TS_clr_line = tgetstr ("ce", address);
+ tty->TS_clr_frame = tgetstr ("cl", address);
+ ColPosition (tty) = NULL; /* tgetstr ("ch", address); */
+ AbsPosition (tty) = tgetstr ("cm", address);
+ CR (tty) = tgetstr ("cr", address);
+ tty->TS_set_scroll_region = tgetstr ("cs", address);
+ tty->TS_set_scroll_region_1 = tgetstr ("cS", address);
+ RowPosition (tty) = tgetstr ("cv", address);
+ tty->TS_del_char = tgetstr ("dc", address);
+ tty->TS_del_multi_chars = tgetstr ("DC", address);
+ tty->TS_del_line = tgetstr ("dl", address);
+ tty->TS_del_multi_lines = tgetstr ("DL", address);
+ tty->TS_delete_mode = tgetstr ("dm", address);
+ tty->TS_end_delete_mode = tgetstr ("ed", address);
+ tty->TS_end_insert_mode = tgetstr ("ei", address);
+ Home (tty) = tgetstr ("ho", address);
+ tty->TS_ins_char = tgetstr ("ic", address);
+ tty->TS_ins_multi_chars = tgetstr ("IC", address);
+ tty->TS_insert_mode = tgetstr ("im", address);
+ tty->TS_pad_inserted_char = tgetstr ("ip", address);
+ tty->TS_end_keypad_mode = tgetstr ("ke", address);
+ tty->TS_keypad_mode = tgetstr ("ks", address);
+ LastLine (tty) = tgetstr ("ll", address);
+ Right (tty) = tgetstr ("nd", address);
+ Down (tty) = tgetstr ("do", address);
+ if (!Down (tty))
+ Down (tty) = tgetstr ("nl", address); /* Obsolete name for "do" */
#ifdef VMS
/* VMS puts a carriage return before each linefeed,
so it is not safe to use linefeeds. */
- if (Down && Down[0] == '\n' && Down[1] == '\0')
- Down = 0;
+ if (Down (tty) && Down (tty)[0] == '\n' && Down (tty)[1] == '\0')
+ Down (tty) = 0;
#endif /* VMS */
if (tgetflag ("bs"))
- Left = "\b"; /* can't possibly be longer! */
+ Left (tty) = "\b"; /* can't possibly be longer! */
else /* (Actually, "bs" is obsolete...) */
- Left = tgetstr ("le", address);
- if (!Left)
- Left = tgetstr ("bc", address); /* Obsolete name for "le" */
- TS_pad_char = tgetstr ("pc", address);
- TS_repeat = tgetstr ("rp", address);
- TS_end_standout_mode = tgetstr ("se", address);
- TS_fwd_scroll = tgetstr ("sf", address);
- TS_standout_mode = tgetstr ("so", address);
- TS_rev_scroll = tgetstr ("sr", address);
- Wcm.cm_tab = tgetstr ("ta", address);
- TS_end_termcap_modes = tgetstr ("te", address);
- TS_termcap_modes = tgetstr ("ti", address);
- Up = tgetstr ("up", address);
- TS_visible_bell = tgetstr ("vb", address);
- TS_cursor_normal = tgetstr ("ve", address);
- TS_cursor_visible = tgetstr ("vs", address);
- TS_cursor_invisible = tgetstr ("vi", address);
- TS_set_window = tgetstr ("wi", address);
-
- TS_enter_underline_mode = tgetstr ("us", address);
- TS_exit_underline_mode = tgetstr ("ue", address);
- TS_enter_bold_mode = tgetstr ("md", address);
- TS_enter_dim_mode = tgetstr ("mh", address);
- TS_enter_blink_mode = tgetstr ("mb", address);
- TS_enter_reverse_mode = tgetstr ("mr", address);
- TS_enter_alt_charset_mode = tgetstr ("as", address);
- TS_exit_alt_charset_mode = tgetstr ("ae", address);
- TS_exit_attribute_mode = tgetstr ("me", address);
-
- MultiUp = tgetstr ("UP", address);
- MultiDown = tgetstr ("DO", address);
- MultiLeft = tgetstr ("LE", address);
- MultiRight = tgetstr ("RI", address);
+ Left (tty) = tgetstr ("le", address);
+ if (!Left (tty))
+ Left (tty) = tgetstr ("bc", address); /* Obsolete name for "le" */
+ tty->TS_pad_char = tgetstr ("pc", address);
+ tty->TS_repeat = tgetstr ("rp", address);
+ tty->TS_end_standout_mode = tgetstr ("se", address);
+ tty->TS_fwd_scroll = tgetstr ("sf", address);
+ tty->TS_standout_mode = tgetstr ("so", address);
+ tty->TS_rev_scroll = tgetstr ("sr", address);
+ tty->Wcm->cm_tab = tgetstr ("ta", address);
+ tty->TS_end_termcap_modes = tgetstr ("te", address);
+ tty->TS_termcap_modes = tgetstr ("ti", address);
+ Up (tty) = tgetstr ("up", address);
+ tty->TS_visible_bell = tgetstr ("vb", address);
+ tty->TS_cursor_normal = tgetstr ("ve", address);
+ tty->TS_cursor_visible = tgetstr ("vs", address);
+ tty->TS_cursor_invisible = tgetstr ("vi", address);
+ tty->TS_set_window = tgetstr ("wi", address);
+
+ tty->TS_enter_underline_mode = tgetstr ("us", address);
+ tty->TS_exit_underline_mode = tgetstr ("ue", address);
+ tty->TS_enter_bold_mode = tgetstr ("md", address);
+ tty->TS_enter_dim_mode = tgetstr ("mh", address);
+ tty->TS_enter_blink_mode = tgetstr ("mb", address);
+ tty->TS_enter_reverse_mode = tgetstr ("mr", address);
+ tty->TS_enter_alt_charset_mode = tgetstr ("as", address);
+ tty->TS_exit_alt_charset_mode = tgetstr ("ae", address);
+ tty->TS_exit_attribute_mode = tgetstr ("me", address);
+
+ MultiUp (tty) = tgetstr ("UP", address);
+ MultiDown (tty) = tgetstr ("DO", address);
+ MultiLeft (tty) = tgetstr ("LE", address);
+ MultiRight (tty) = tgetstr ("RI", address);
/* SVr4/ANSI color suppert. If "op" isn't available, don't support
color because we can't switch back to the default foreground and
background. */
- TS_orig_pair = tgetstr ("op", address);
- if (TS_orig_pair)
+ tty->TS_orig_pair = tgetstr ("op", address);
+ if (tty->TS_orig_pair)
{
- TS_set_foreground = tgetstr ("AF", address);
- TS_set_background = tgetstr ("AB", address);
- if (!TS_set_foreground)
+ tty->TS_set_foreground = tgetstr ("AF", address);
+ tty->TS_set_background = tgetstr ("AB", address);
+ if (!tty->TS_set_foreground)
{
/* SVr4. */
- TS_set_foreground = tgetstr ("Sf", address);
- TS_set_background = tgetstr ("Sb", address);
+ tty->TS_set_foreground = tgetstr ("Sf", address);
+ tty->TS_set_background = tgetstr ("Sb", address);
}
- TN_max_colors = tgetnum ("Co");
- TN_max_pairs = tgetnum ("pa");
+ tty->TN_max_colors = tgetnum ("Co");
+ tty->TN_max_pairs = tgetnum ("pa");
- TN_no_color_video = tgetnum ("NC");
- if (TN_no_color_video == -1)
- TN_no_color_video = 0;
+ tty->TN_no_color_video = tgetnum ("NC");
+ if (tty->TN_no_color_video == -1)
+ tty->TN_no_color_video = 0;
}
- tty_default_color_capabilities (1);
+ tty_default_color_capabilities (tty, 1);
- MagicWrap = tgetflag ("xn");
+ MagicWrap (tty) = tgetflag ("xn");
/* Since we make MagicWrap terminals look like AutoWrap, we need to have
the former flag imply the latter. */
- AutoWrap = MagicWrap || tgetflag ("am");
- memory_below_frame = tgetflag ("db");
- TF_hazeltine = tgetflag ("hz");
- must_write_spaces = tgetflag ("in");
- meta_key = tgetflag ("km") || tgetflag ("MT");
- TF_insmode_motion = tgetflag ("mi");
- TF_standout_motion = tgetflag ("ms");
- TF_underscore = tgetflag ("ul");
- TF_teleray = tgetflag ("xt");
-
- term_get_fkeys (address);
+ AutoWrap (tty) = MagicWrap (tty) || tgetflag ("am");
+ terminal->memory_below_frame = tgetflag ("db");
+ tty->TF_hazeltine = tgetflag ("hz");
+ terminal->must_write_spaces = tgetflag ("in");
+ tty->meta_key = tgetflag ("km") || tgetflag ("MT");
+ tty->TF_insmode_motion = tgetflag ("mi");
+ tty->TF_standout_motion = tgetflag ("ms");
+ tty->TF_underscore = tgetflag ("ul");
+ tty->TF_teleray = tgetflag ("xt");
+
+#endif /* !WINDOWSNT */
+#ifdef MULTI_KBOARD
+ terminal->kboard = (KBOARD *) xmalloc (sizeof (KBOARD));
+ init_kboard (terminal->kboard);
+ terminal->kboard->next_kboard = all_kboards;
+ all_kboards = terminal->kboard;
+ terminal->kboard->reference_count++;
+ /* Don't let the initial kboard remain current longer than necessary.
+ That would cause problems if a file loaded on startup tries to
+ prompt in the mini-buffer. */
+ if (current_kboard == initial_kboard)
+ current_kboard = terminal->kboard;
+#ifndef WINDOWSNT
+ term_get_fkeys (address, terminal->kboard);
+#endif
+#endif
+#ifndef WINDOWSNT
/* Get frame size from system, or else from termcap. */
{
int height, width;
- get_frame_size (&width, &height);
- FRAME_COLS (sf) = width;
- FRAME_LINES (sf) = height;
+ get_tty_size (fileno (tty->input), &width, &height);
+ FrameCols (tty) = width;
+ FrameRows (tty) = height;
}
- if (FRAME_COLS (sf) <= 0)
- SET_FRAME_COLS (sf, tgetnum ("co"));
- else
- /* Keep width and external_width consistent */
- SET_FRAME_COLS (sf, FRAME_COLS (sf));
- if (FRAME_LINES (sf) <= 0)
- FRAME_LINES (sf) = tgetnum ("li");
+ if (FrameCols (tty) <= 0)
+ FrameCols (tty) = tgetnum ("co");
+ if (FrameRows (tty) <= 0)
+ FrameRows (tty) = tgetnum ("li");
- if (FRAME_LINES (sf) < 3 || FRAME_COLS (sf) < 3)
- fatal ("Screen size %dx%d is too small",
- FRAME_LINES (sf), FRAME_COLS (sf));
+ if (FrameRows (tty) < 3 || FrameCols (tty) < 3)
+ maybe_fatal (must_succeed, NULL, terminal,
+ "Screen size %dx%d is too small"
+ "Screen size %dx%d is too small",
+ FrameCols (tty), FrameRows (tty));
- min_padding_speed = tgetnum ("pb");
- TabWidth = tgetnum ("tw");
+#if 0 /* This is not used anywhere. */
+ tty->terminal->min_padding_speed = tgetnum ("pb");
+#endif
+
+ TabWidth (tty) = tgetnum ("tw");
#ifdef VMS
/* These capabilities commonly use ^J.
I don't know why, but sending them on VMS does not work;
it causes following spaces to be lost, sometimes.
For now, the simplest fix is to avoid using these capabilities ever. */
- if (Down && Down[0] == '\n')
- Down = 0;
+ if (Down (tty) && Down (tty)[0] == '\n')
+ Down (tty) = 0;
#endif /* VMS */
- if (!TS_bell)
- TS_bell = "\07";
+ if (!tty->TS_bell)
+ tty->TS_bell = "\07";
- if (!TS_fwd_scroll)
- TS_fwd_scroll = Down;
+ if (!tty->TS_fwd_scroll)
+ tty->TS_fwd_scroll = Down (tty);
- PC = TS_pad_char ? *TS_pad_char : 0;
+ PC = tty->TS_pad_char ? *tty->TS_pad_char : 0;
- if (TabWidth < 0)
- TabWidth = 8;
+ if (TabWidth (tty) < 0)
+ TabWidth (tty) = 8;
/* Turned off since /etc/termcap seems to have :ta= for most terminals
and newer termcap doc does not seem to say there is a default.
- if (!Wcm.cm_tab)
- Wcm.cm_tab = "\t";
+ if (!tty->Wcm->cm_tab)
+ tty->Wcm->cm_tab = "\t";
*/
/* We don't support standout modes that use `magic cookies', so
turn off any that do. */
- if (TS_standout_mode && tgetnum ("sg") >= 0)
+ if (tty->TS_standout_mode && tgetnum ("sg") >= 0)
{
- TS_standout_mode = 0;
- TS_end_standout_mode = 0;
+ tty->TS_standout_mode = 0;
+ tty->TS_end_standout_mode = 0;
}
- if (TS_enter_underline_mode && tgetnum ("ug") >= 0)
+ if (tty->TS_enter_underline_mode && tgetnum ("ug") >= 0)
{
- TS_enter_underline_mode = 0;
- TS_exit_underline_mode = 0;
+ tty->TS_enter_underline_mode = 0;
+ tty->TS_exit_underline_mode = 0;
}
/* If there's no standout mode, try to use underlining instead. */
- if (TS_standout_mode == 0)
+ if (tty->TS_standout_mode == 0)
{
- TS_standout_mode = TS_enter_underline_mode;
- TS_end_standout_mode = TS_exit_underline_mode;
+ tty->TS_standout_mode = tty->TS_enter_underline_mode;
+ tty->TS_end_standout_mode = tty->TS_exit_underline_mode;
}
/* If no `se' string, try using a `me' string instead.
If that fails, we can't use standout mode at all. */
- if (TS_end_standout_mode == 0)
+ if (tty->TS_end_standout_mode == 0)
{
char *s = tgetstr ("me", address);
if (s != 0)
- TS_end_standout_mode = s;
+ tty->TS_end_standout_mode = s;
else
- TS_standout_mode = 0;
+ tty->TS_standout_mode = 0;
}
- if (TF_teleray)
+ if (tty->TF_teleray)
{
- Wcm.cm_tab = 0;
+ tty->Wcm->cm_tab = 0;
/* We can't support standout mode, because it uses magic cookies. */
- TS_standout_mode = 0;
+ tty->TS_standout_mode = 0;
/* But that means we cannot rely on ^M to go to column zero! */
- CR = 0;
+ CR (tty) = 0;
/* LF can't be trusted either -- can alter hpos */
/* if move at column 0 thru a line with TS_standout_mode */
- Down = 0;
+ Down (tty) = 0;
}
/* Special handling for certain terminal types known to need it */
if (!strcmp (terminal_type, "supdup"))
{
- memory_below_frame = 1;
- Wcm.cm_losewrap = 1;
+ terminal->memory_below_frame = 1;
+ tty->Wcm->cm_losewrap = 1;
}
if (!strncmp (terminal_type, "c10", 3)
|| !strcmp (terminal_type, "perq"))
@@ -3471,102 +3730,140 @@ to do `unset TERMCAP' (C-shell: `unsetenv TERMCAP') as well.",
It would be simpler if the :wi string could go in the termcap
entry, but it can't because it is not fully valid.
If it were in the termcap entry, it would confuse other programs. */
- if (!TS_set_window)
+ if (!tty->TS_set_window)
{
- p = TS_termcap_modes;
+ p = tty->TS_termcap_modes;
while (*p && strcmp (p, "\033v "))
p++;
if (*p)
- TS_set_window = "\033v%C %C %C %C ";
+ tty->TS_set_window = "\033v%C %C %C %C ";
}
/* Termcap entry often fails to have :in: flag */
- must_write_spaces = 1;
+ terminal->must_write_spaces = 1;
/* :ti string typically fails to have \E^G! in it */
/* This limits scope of insert-char to one line. */
- strcpy (area, TS_termcap_modes);
+ strcpy (area, tty->TS_termcap_modes);
strcat (area, "\033\007!");
- TS_termcap_modes = area;
+ tty->TS_termcap_modes = area;
area += strlen (area) + 1;
- p = AbsPosition;
+ p = AbsPosition (tty);
/* Change all %+ parameters to %C, to handle
- values above 96 correctly for the C100. */
+ values above 96 correctly for the C100. */
while (*p)
- {
- if (p[0] == '%' && p[1] == '+')
- p[1] = 'C';
- p++;
- }
+ {
+ if (p[0] == '%' && p[1] == '+')
+ p[1] = 'C';
+ p++;
+ }
}
- FrameRows = FRAME_LINES (sf);
- FrameCols = FRAME_COLS (sf);
- specified_window = FRAME_LINES (sf);
+ tty->specified_window = FrameRows (tty);
- if (Wcm_init () == -1) /* can't do cursor motion */
+ if (Wcm_init (tty) == -1) /* can't do cursor motion */
+ {
+ maybe_fatal (must_succeed, NULL, terminal,
+ "Terminal type \"%s\" is not powerful enough to run Emacs",
#ifdef VMS
- fatal ("Terminal type \"%s\" is not powerful enough to run Emacs.\n\
+ "Terminal type \"%s\" is not powerful enough to run Emacs.\n\
It lacks the ability to position the cursor.\n\
If that is not the actual type of terminal you have, use either the\n\
DCL command `SET TERMINAL/DEVICE= ...' for DEC-compatible terminals,\n\
or `define EMACS_TERM \"terminal type\"' for non-DEC terminals.",
- terminal_type);
#else /* not VMS */
# ifdef TERMINFO
- fatal ("Terminal type \"%s\" is not powerful enough to run Emacs.\n\
+ "Terminal type \"%s\" is not powerful enough to run Emacs.\n\
It lacks the ability to position the cursor.\n\
If that is not the actual type of terminal you have,\n\
use the Bourne shell command `TERM=... export TERM' (C-shell:\n\
`setenv TERM ...') to specify the correct type. It may be necessary\n\
to do `unset TERMINFO' (C-shell: `unsetenv TERMINFO') as well.",
- terminal_type);
# else /* TERMCAP */
- fatal ("Terminal type \"%s\" is not powerful enough to run Emacs.\n\
+ "Terminal type \"%s\" is not powerful enough to run Emacs.\n\
It lacks the ability to position the cursor.\n\
If that is not the actual type of terminal you have,\n\
use the Bourne shell command `TERM=... export TERM' (C-shell:\n\
`setenv TERM ...') to specify the correct type. It may be necessary\n\
to do `unset TERMCAP' (C-shell: `unsetenv TERMCAP') as well.",
- terminal_type);
# endif /* TERMINFO */
#endif /*VMS */
- if (FRAME_LINES (sf) <= 0
- || FRAME_COLS (sf) <= 0)
- fatal ("The frame size has not been specified");
+ terminal_type);
+ }
+
+ if (FrameRows (tty) <= 0 || FrameCols (tty) <= 0)
+ maybe_fatal (must_succeed, NULL, terminal,
+ "Could not determine the frame size",
+ "Could not determine the frame size");
- delete_in_insert_mode
- = TS_delete_mode && TS_insert_mode
- && !strcmp (TS_delete_mode, TS_insert_mode);
+ tty->delete_in_insert_mode
+ = tty->TS_delete_mode && tty->TS_insert_mode
+ && !strcmp (tty->TS_delete_mode, tty->TS_insert_mode);
- se_is_so = (TS_standout_mode
- && TS_end_standout_mode
- && !strcmp (TS_standout_mode, TS_end_standout_mode));
+ tty->se_is_so = (tty->TS_standout_mode
+ && tty->TS_end_standout_mode
+ && !strcmp (tty->TS_standout_mode, tty->TS_end_standout_mode));
- UseTabs = tabs_safe_p () && TabWidth == 8;
+ UseTabs (tty) = tabs_safe_p (fileno (tty->input)) && TabWidth (tty) == 8;
- scroll_region_ok
- = (Wcm.cm_abs
- && (TS_set_window || TS_set_scroll_region || TS_set_scroll_region_1));
+ terminal->scroll_region_ok
+ = (tty->Wcm->cm_abs
+ && (tty->TS_set_window || tty->TS_set_scroll_region || tty->TS_set_scroll_region_1));
- line_ins_del_ok = (((TS_ins_line || TS_ins_multi_lines)
- && (TS_del_line || TS_del_multi_lines))
- || (scroll_region_ok && TS_fwd_scroll && TS_rev_scroll));
+ terminal->line_ins_del_ok
+ = (((tty->TS_ins_line || tty->TS_ins_multi_lines)
+ && (tty->TS_del_line || tty->TS_del_multi_lines))
+ || (terminal->scroll_region_ok
+ && tty->TS_fwd_scroll && tty->TS_rev_scroll));
- char_ins_del_ok = ((TS_ins_char || TS_insert_mode
- || TS_pad_inserted_char || TS_ins_multi_chars)
- && (TS_del_char || TS_del_multi_chars));
+ terminal->char_ins_del_ok
+ = ((tty->TS_ins_char || tty->TS_insert_mode
+ || tty->TS_pad_inserted_char || tty->TS_ins_multi_chars)
+ && (tty->TS_del_char || tty->TS_del_multi_chars));
- fast_clear_end_of_line = TS_clr_line != 0;
+ terminal->fast_clear_end_of_line = tty->TS_clr_line != 0;
- init_baud_rate ();
- if (read_socket_hook) /* Baudrate is somewhat */
- /* meaningless in this case */
- baud_rate = 9600;
+ init_baud_rate (fileno (tty->input));
- FRAME_CAN_HAVE_SCROLL_BARS (sf) = 0;
- FRAME_VERTICAL_SCROLL_BAR_TYPE (sf) = vertical_scroll_bar_none;
-#endif /* WINDOWSNT */
+#ifdef AIXHFT
+ /* The HFT system on AIX doesn't optimize for scrolling, so it's
+ really ugly at times. */
+ terminal->line_ins_del_ok = 0;
+ terminal->char_ins_del_ok = 0;
+#endif
+
+ /* Don't do this. I think termcap may still need the buffer. */
+ /* xfree (buffer); */
+
+#endif /* not WINDOWSNT */
+
+ /* Init system terminal modes (RAW or CBREAK, etc.). */
+ init_sys_modes (tty);
+
+ return terminal;
+}
+
+/* Auxiliary error-handling function for init_tty.
+ Free BUFFER and delete TERMINAL, then call error or fatal
+ with str1 or str2, respectively, according to MUST_SUCCEED. */
- xfree (buffer);
+static void
+maybe_fatal (must_succeed, buffer, terminal, str1, str2, arg1, arg2)
+ int must_succeed;
+ char *buffer;
+ struct terminal *terminal;
+ char *str1, *str2, *arg1, *arg2;
+{
+ if (buffer)
+ xfree (buffer);
+
+ if (terminal)
+ delete_tty (terminal);
+
+ if (must_succeed)
+ fatal (str2, arg1, arg2);
+ else
+ error (str1, arg1, arg2);
+
+ abort ();
}
/* VARARGS 1 */
@@ -3581,16 +3878,105 @@ fatal (str, arg1, arg2)
exit (1);
}
-DEFUN ("tty-no-underline", Ftty_no_underline, Stty_no_underline, 0, 0, 0,
- doc: /* Declare that this terminal does not handle underlining.
-This is used to override the terminfo data, for certain terminals that
-do not really do underlining, but say that they do. */)
- ()
+
+
+/* Delete the given tty terminal, closing all frames on it. */
+
+static void
+delete_tty (struct terminal *terminal)
{
- TS_enter_underline_mode = 0;
- return Qnil;
+ struct tty_display_info *tty;
+ Lisp_Object tail, frame;
+ int last_terminal;
+
+ /* Protect against recursive calls. Fdelete_frame in
+ delete_terminal calls us back when it deletes our last frame. */
+ if (!terminal->name)
+ return;
+
+ if (terminal->type != output_termcap)
+ abort ();
+
+ tty = terminal->display_info.tty;
+
+ last_terminal = 1;
+ FOR_EACH_FRAME (tail, frame)
+ {
+ struct frame *f = XFRAME (frame);
+ if (FRAME_LIVE_P (f) && (!FRAME_TERMCAP_P (f) || FRAME_TTY (f) != tty))
+ {
+ last_terminal = 0;
+ break;
+ }
+ }
+ if (last_terminal)
+ error ("Attempt to delete the sole terminal device with live frames");
+
+ if (tty == tty_list)
+ tty_list = tty->next;
+ else
+ {
+ struct tty_display_info *p;
+ for (p = tty_list; p && p->next != tty; p = p->next)
+ ;
+
+ if (! p)
+ /* This should not happen. */
+ abort ();
+
+ p->next = tty->next;
+ tty->next = 0;
+ }
+
+ /* reset_sys_modes needs a valid device, so this call needs to be
+ before delete_terminal. */
+ reset_sys_modes (tty);
+
+ delete_terminal (terminal);
+
+ if (tty->name)
+ xfree (tty->name);
+
+ if (tty->type)
+ xfree (tty->type);
+
+ if (tty->input)
+ {
+ delete_keyboard_wait_descriptor (fileno (tty->input));
+ if (tty->input != stdin)
+ fclose (tty->input);
+ }
+ if (tty->output && tty->output != stdout && tty->output != tty->input)
+ fclose (tty->output);
+ if (tty->termscript)
+ fclose (tty->termscript);
+
+ if (tty->old_tty)
+ xfree (tty->old_tty);
+
+ if (tty->Wcm)
+ xfree (tty->Wcm);
+
+ bzero (tty, sizeof (struct tty_display_info));
+ xfree (tty);
+}
+
+
+
+/* Mark the pointers in the tty_display_info objects.
+ Called by the Fgarbage_collector. */
+
+void
+mark_ttys (void)
+{
+ struct tty_display_info *tty;
+
+ for (tty = tty_list; tty; tty = tty->next)
+ mark_object (tty->top_frame);
}
+
+
void
syms_of_term ()
{
@@ -3603,10 +3989,18 @@ This variable can be used by terminal emulator packages. */);
system_uses_terminfo = 0;
#endif
- DEFVAR_LISP ("ring-bell-function", &Vring_bell_function,
- doc: /* Non-nil means call this function to ring the bell.
-The function should accept no arguments. */);
- Vring_bell_function = Qnil;
+ DEFVAR_LISP ("suspend-tty-functions", &Vsuspend_tty_functions,
+ doc: /* Functions to be run after suspending a tty.
+The functions are run with one argument, the terminal id to be suspended.
+See `suspend-tty'. */);
+ Vsuspend_tty_functions = Qnil;
+
+
+ DEFVAR_LISP ("resume-tty-functions", &Vresume_tty_functions,
+ doc: /* Functions to be run after resuming a tty.
+The functions are run with one argument, the terminal id that was revived.
+See `resume-tty'. */);
+ Vresume_tty_functions = Qnil;
DEFVAR_BOOL ("visible-cursor", &visible_cursor,
doc: /* Non-nil means to make the cursor very visible.
@@ -3618,15 +4012,19 @@ bigger, or it may make it blink, or it may do nothing at all. */);
defsubr (&Stty_display_color_p);
defsubr (&Stty_display_color_cells);
defsubr (&Stty_no_underline);
+ defsubr (&Stty_type);
+ defsubr (&Scontrolling_tty_p);
+ defsubr (&Ssuspend_tty);
+ defsubr (&Sresume_tty);
#ifdef HAVE_GPM
- defsubr (&Sterm_open_connection);
- defsubr (&Sterm_close_connection);
+ defsubr (&Sgpm_mouse_start);
+ defsubr (&Sgpm_mouse_stop);
- staticpro (&Qmouse_face_window);
+ staticpro (&mouse_face_window);
#endif /* HAVE_GPM */
-
- fullscreen_hook = NULL;
}
+
+
/* arch-tag: 498e7449-6f2e-45e2-91dd-b7d4ca488193
(do not change this comment) */
diff --git a/src/termchar.h b/src/termchar.h
index c4bf2adb0b..381210fd65 100644
--- a/src/termchar.h
+++ b/src/termchar.h
@@ -19,32 +19,185 @@ along with GNU Emacs; see the file COPYING. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
+/* Each termcap frame points to its own struct tty_output object in
+ the output_data.tty field. The tty_output structure contains the
+ information that is specific to termcap frames. */
-/* extern EMACS_INT baud_rate; */ /* Output speed in baud */
-extern int must_write_spaces; /* Nonzero means spaces in the text
- must actually be output; can't just skip
- over some columns to leave them blank. */
-extern int min_padding_speed; /* Speed below which no padding necessary */
-extern int fast_clear_end_of_line; /* Nonzero means terminal has
- command for this */
-
-extern int line_ins_del_ok; /* Terminal can insert and delete lines */
-extern int char_ins_del_ok; /* Terminal can insert and delete chars */
-extern int scroll_region_ok; /* Terminal supports setting the scroll
- window */
-extern int scroll_region_cost; /* Cost of setting the scroll window,
- measured in characters */
-extern int memory_below_frame; /* Terminal remembers lines scrolled
- off bottom */
-extern int fast_clear_end_of_line; /* Terminal has a `ce' string */
-
-extern int dont_calculate_costs; /* Nonzero means don't bother computing
- various cost tables; we won't use them. */
-
-/* Nonzero means no need to redraw the entire frame on resuming
- a suspended Emacs. This is useful on terminals with multiple pages,
- where one page is used for Emacs and another for all else. */
-extern int no_redraw_on_reenter;
+struct tty_output
+{
+ /* The Emacs structure for the tty device this frame is on. */
+ struct tty_display_info *display_info;
+
+ /* There is nothing else here at the moment... */
+};
+
+/* Parameters that are shared between frames on the same tty device. */
+
+struct tty_display_info
+{
+ struct tty_display_info *next; /* Chain of all tty devices. */
+
+ char *name; /* The name of the device file or 0 if
+ stdin/stdout. */
+ char *type; /* The type of the tty. */
+
+ /* Input/output */
+
+ FILE *input; /* The stream to be used for terminal input.
+ NULL if the terminal is suspended. */
+ FILE *output; /* The stream to be used for terminal output.
+ NULL if the terminal is suspended. */
+
+ FILE *termscript; /* If nonzero, send all terminal output
+ characters to this stream also. */
+
+ struct emacs_tty *old_tty; /* The initial tty mode bits */
+
+ int term_initted; /* 1 if we have been through init_sys_modes. */
+
+
+ int reference_count; /* Number of frames that are on this display. */
+
+ struct terminal *terminal; /* Points back to the generic terminal
+ structure. This is sometimes handy. */
+
+ /* Info on cursor positioning. */
+ struct cm *Wcm;
+
+ /* Redisplay. */
+
+ Lisp_Object top_frame; /* The topmost frame on this tty. */
+
+ /* The previous frame we displayed on this tty. */
+ struct frame *previous_frame;
+
+ /* Strings, numbers and flags taken from the termcap entry. */
+
+ char *TS_ins_line; /* "al" */
+ char *TS_ins_multi_lines; /* "AL" (one parameter, # lines to insert) */
+ char *TS_bell; /* "bl" */
+ char *TS_clr_to_bottom; /* "cd" */
+ char *TS_clr_line; /* "ce", clear to end of line */
+ char *TS_clr_frame; /* "cl" */
+ char *TS_set_scroll_region; /* "cs" (2 params, first line and last line) */
+ char *TS_set_scroll_region_1; /* "cS" (4 params: total lines,
+ lines above scroll region, lines below it,
+ total lines again) */
+ char *TS_del_char; /* "dc" */
+ char *TS_del_multi_chars; /* "DC" (one parameter, # chars to delete) */
+ char *TS_del_line; /* "dl" */
+ char *TS_del_multi_lines; /* "DL" (one parameter, # lines to delete) */
+ char *TS_delete_mode; /* "dm", enter character-delete mode */
+ char *TS_end_delete_mode; /* "ed", leave character-delete mode */
+ char *TS_end_insert_mode; /* "ei", leave character-insert mode */
+ char *TS_ins_char; /* "ic" */
+ char *TS_ins_multi_chars; /* "IC" (one parameter, # chars to insert) */
+ char *TS_insert_mode; /* "im", enter character-insert mode */
+ char *TS_pad_inserted_char; /* "ip". Just padding, no commands. */
+ char *TS_end_keypad_mode; /* "ke" */
+ char *TS_keypad_mode; /* "ks" */
+ char *TS_pad_char; /* "pc", char to use as padding */
+ char *TS_repeat; /* "rp" (2 params, # times to repeat
+ and character to be repeated) */
+ char *TS_end_standout_mode; /* "se" */
+ char *TS_fwd_scroll; /* "sf" */
+ char *TS_standout_mode; /* "so" */
+ char *TS_rev_scroll; /* "sr" */
+ char *TS_end_termcap_modes; /* "te" */
+ char *TS_termcap_modes; /* "ti" */
+ char *TS_visible_bell; /* "vb" */
+ char *TS_cursor_normal; /* "ve" */
+ char *TS_cursor_visible; /* "vs" */
+ char *TS_cursor_invisible; /* "vi" */
+ char *TS_set_window; /* "wi" (4 params, start and end of window,
+ each as vpos and hpos) */
+
+ char *TS_enter_bold_mode; /* "md" -- turn on bold (extra bright mode). */
+ char *TS_enter_dim_mode; /* "mh" -- turn on half-bright mode. */
+ char *TS_enter_blink_mode; /* "mb" -- enter blinking mode. */
+ char *TS_enter_reverse_mode; /* "mr" -- enter reverse video mode. */
+ char *TS_exit_underline_mode; /* "us" -- start underlining. */
+ char *TS_enter_underline_mode; /* "ue" -- end underlining. */
+
+ /* "as"/"ae" -- start/end alternate character set. Not really
+ supported, yet. */
+ char *TS_enter_alt_charset_mode;
+ char *TS_exit_alt_charset_mode;
+
+ char *TS_exit_attribute_mode; /* "me" -- switch appearances off. */
+
+ /* Value of the "NC" (no_color_video) capability, or 0 if not present. */
+ int TN_no_color_video;
+
+ int TN_max_colors; /* "Co" -- number of colors. */
+
+ /* "pa" -- max. number of color pairs on screen. Not handled yet.
+ Could be a problem if not equal to TN_max_colors * TN_max_colors. */
+ int TN_max_pairs;
+
+ /* "op" -- SVr4 set default pair to its original value. */
+ char *TS_orig_pair;
+
+ /* "AF"/"AB" or "Sf"/"Sb"-- set ANSI or SVr4 foreground/background color.
+ 1 param, the color index. */
+ char *TS_set_foreground;
+ char *TS_set_background;
+
+ int TF_hazeltine; /* termcap hz flag. */
+ int TF_insmode_motion; /* termcap mi flag: can move while in insert mode. */
+ int TF_standout_motion; /* termcap mi flag: can move while in standout mode. */
+ int TF_underscore; /* termcap ul flag: _ underlines if over-struck on
+ non-blank position. Must clear before writing _. */
+ int TF_teleray; /* termcap xt flag: many weird consequences.
+ For t1061. */
+
+ int RPov; /* # chars to start a TS_repeat */
+
+ int delete_in_insert_mode; /* delete mode == insert mode */
+
+ int se_is_so; /* 1 if same string both enters and leaves
+ standout mode */
+
+ int costs_set; /* Nonzero if costs have been calculated. */
+
+ int insert_mode; /* Nonzero when in insert mode. */
+ int standout_mode; /* Nonzero when in standout mode. */
+
+
+
+ /* 1 if should obey 0200 bit in input chars as "Meta", 2 if should
+ keep 0200 bit in input chars. 0 to ignore the 0200 bit. */
+
+ int meta_key;
+
+ /* Size of window specified by higher levels.
+ This is the number of lines, from the top of frame downwards,
+ which can participate in insert-line/delete-line operations.
+
+ Effectively it excludes the bottom frame_lines - specified_window_size
+ lines from those operations. */
+
+ int specified_window;
+
+ /* Flag used in tty_show/hide_cursor. */
+
+ int cursor_hidden;
+
+ /* Nonzero means use ^S/^Q for flow control. */
+ int flow_control;
+
+};
+
+/* A chain of structures for all tty devices currently in use. */
+extern struct tty_display_info *tty_list;
+
+
+#define FRAME_TTY(f) \
+ ((f)->output_method == output_termcap \
+ ? (f)->terminal->display_info.tty \
+ : (abort(), (struct tty_display_info *) 0))
+
+#define CURTTY() FRAME_TTY (SELECTED_FRAME())
/* arch-tag: bf9f0d49-842b-42fb-9348-ec8759b27193
(do not change this comment) */
diff --git a/src/termhooks.h b/src/termhooks.h
index eb074608e1..4d8fb8a861 100644
--- a/src/termhooks.h
+++ b/src/termhooks.h
@@ -1,7 +1,6 @@
-/* Hooks by which low level terminal operations
- can be made to call other routines.
- Copyright (C) 1985, 1986, 1993, 1994, 2001, 2002, 2003, 2004,
- 2005, 2006, 2007 Free Software Foundation, Inc.
+/* Parameters and display hooks for terminal devices.
+ Copyright (C) 1985, 1986, 1993, 1994, 2002, 2003, 2004,
+ 2005, 2006, 2007 Free Software Foundation, Inc.
This file is part of GNU Emacs.
@@ -26,40 +25,11 @@ Boston, MA 02110-1301, USA. */
struct glyph;
struct frame;
-/* If nonzero, send all terminal output characters to this stream also. */
-extern FILE *termscript;
-
/* Only use prototypes when lisp.h has been included. */
#ifndef P_
#define P_(X) ()
#endif
-/* Text display hooks. */
-
-extern void (*cursor_to_hook) P_ ((int vpos, int hpos));
-extern void (*raw_cursor_to_hook) P_ ((int, int));
-
-extern void (*clear_to_end_hook) P_ ((void));
-extern void (*clear_frame_hook) P_ ((void));
-extern void (*clear_end_of_line_hook) P_ ((int));
-
-extern void (*ins_del_lines_hook) P_ ((int, int));
-
-extern void (*insert_glyphs_hook) P_ ((struct glyph *s, int n));
-extern void (*write_glyphs_hook) P_ ((struct glyph *s, int n));
-extern void (*delete_glyphs_hook) P_ ((int));
-
-extern void (*ring_bell_hook) P_ ((void));
-
-extern void (*reset_terminal_modes_hook) P_ ((void));
-extern void (*set_terminal_modes_hook) P_ ((void));
-extern void (*update_begin_hook) P_ ((struct frame *));
-extern void (*update_end_hook) P_ ((struct frame *));
-extern void (*set_terminal_window_hook) P_ ((int));
-
-
-
-/* Multi-frame and mouse support hooks. */
enum scroll_bar_part {
scroll_bar_above_handle,
@@ -73,131 +43,12 @@ enum scroll_bar_part {
scroll_bar_move_ratio
};
-/* Return the current position of the mouse.
-
- Set *f to the frame the mouse is in, or zero if the mouse is in no
- Emacs frame. If it is set to zero, all the other arguments are
- garbage.
-
- If the motion started in a scroll bar, set *bar_window to the
- scroll bar's window, *part to the part the mouse is currently over,
- *x to the position of the mouse along the scroll bar, and *y to the
- overall length of the scroll bar.
-
- Otherwise, set *bar_window to Qnil, and *x and *y to the column and
- row of the character cell the mouse is over.
-
- Set *time to the time the mouse was at the returned position.
-
- This should clear mouse_moved until the next motion
- event arrives. */
-extern void (*mouse_position_hook) P_ ((struct frame **f, int,
- Lisp_Object *bar_window,
- enum scroll_bar_part *part,
- Lisp_Object *x,
- Lisp_Object *y,
- unsigned long *time));
-
-/* The window system handling code should set this if the mouse has
- moved since the last call to the mouse_position_hook. Calling that
- hook should clear this. */
-extern int mouse_moved;
-
-/* When a frame's focus redirection is changed, this hook tells the
- window system code to re-decide where to put the highlight. Under
- X, this means that Emacs lies about where the focus is. */
-extern void (*frame_rehighlight_hook) P_ ((struct frame *));
-
-/* If we're displaying frames using a window system that can stack
- frames on top of each other, this hook allows you to bring a frame
- to the front, or bury it behind all the other windows. If this
- hook is zero, that means the device we're displaying on doesn't
- support overlapping frames, so there's no need to raise or lower
- anything.
-
- If RAISE is non-zero, F is brought to the front, before all other
- windows. If RAISE is zero, F is sent to the back, behind all other
- windows. */
-extern void (*frame_raise_lower_hook) P_ ((struct frame *f, int raise));
-
/* If the value of the frame parameter changed, whis hook is called.
For example, if going from fullscreen to not fullscreen this hook
may do something OS dependent, like extended window manager hints on X11. */
extern void (*fullscreen_hook) P_ ((struct frame *f));
-/* Scroll bar hooks. */
-
-/* The representation of scroll bars is determined by the code which
- implements them, except for one thing: they must be represented by
- lisp objects. This allows us to place references to them in
- Lisp_Windows without worrying about those references becoming
- dangling references when the scroll bar is destroyed.
-
- The window-system-independent portion of Emacs just refers to
- scroll bars via their windows, and never looks inside the scroll bar
- representation; it always uses hook functions to do all the
- scroll bar manipulation it needs.
-
- The `vertical_scroll_bar' field of a Lisp_Window refers to that
- window's scroll bar, or is nil if the window doesn't have a
- scroll bar.
-
- The `scroll_bars' and `condemned_scroll_bars' fields of a Lisp_Frame
- are free for use by the scroll bar implementation in any way it sees
- fit. They are marked by the garbage collector. */
-
-
-/* Set the vertical scroll bar for WINDOW to have its upper left corner
- at (TOP, LEFT), and be LENGTH rows high. Set its handle to
- indicate that we are displaying PORTION characters out of a total
- of WHOLE characters, starting at POSITION. If WINDOW doesn't yet
- have a scroll bar, create one for it. */
-extern void (*set_vertical_scroll_bar_hook)
- P_ ((struct window *window,
- int portion, int whole, int position));
-
-
-/* The following three hooks are used when we're doing a thorough
- redisplay of the frame. We don't explicitly know which scroll bars
- are going to be deleted, because keeping track of when windows go
- away is a real pain - can you say set-window-configuration?
- Instead, we just assert at the beginning of redisplay that *all*
- scroll bars are to be removed, and then save scroll bars from the
- fiery pit when we actually redisplay their window. */
-
-/* Arrange for all scroll bars on FRAME to be removed at the next call
- to `*judge_scroll_bars_hook'. A scroll bar may be spared if
- `*redeem_scroll_bar_hook' is applied to its window before the judgement.
-
- This should be applied to each frame each time its window tree is
- redisplayed, even if it is not displaying scroll bars at the moment;
- if the HAS_SCROLL_BARS flag has just been turned off, only calling
- this and the judge_scroll_bars_hook will get rid of them.
-
- If non-zero, this hook should be safe to apply to any frame,
- whether or not it can support scroll bars, and whether or not it is
- currently displaying them. */
-extern void (*condemn_scroll_bars_hook) P_ ((struct frame *frame));
-
-/* Unmark WINDOW's scroll bar for deletion in this judgement cycle.
- Note that it's okay to redeem a scroll bar that is not condemned. */
-extern void (*redeem_scroll_bar_hook) P_ ((struct window *window));
-
-/* Remove all scroll bars on FRAME that haven't been saved since the
- last call to `*condemn_scroll_bars_hook'.
-
- This should be applied to each frame after each time its window
- tree is redisplayed, even if it is not displaying scroll bars at the
- moment; if the HAS_SCROLL_BARS flag has just been turned off, only
- calling this and condemn_scroll_bars_hook will get rid of them.
-
- If non-zero, this hook should be safe to apply to any frame,
- whether or not it can support scroll bars, and whether or not it is
- currently displaying them. */
-extern void (*judge_scroll_bars_hook) P_ ((struct frame *FRAME));
-
-
/* Input queue declarations and hooks. */
/* Expedient hack: only provide the below definitions to files that
@@ -258,6 +109,9 @@ enum event_kind
the wheel event occurred in.
.timestamp gives a timestamp (in
milliseconds) for the event. */
+ HORIZ_WHEEL_EVENT, /* A wheel event generated by a second
+ horizontal wheel that is present on some
+ mice. See WHEEL_EVENT. */
#if defined (WINDOWSNT) || defined (MAC_OS)
LANGUAGE_CHANGE_EVENT, /* A LANGUAGE_CHANGE_EVENT is
generated on WINDOWSNT or Mac OS
@@ -331,7 +185,7 @@ enum event_kind
/* Queued from XTread_socket when session manager sends
save yourself before shutdown. */
- SAVE_SESSION_EVENT,
+ SAVE_SESSION_EVENT
#ifdef MAC_OS
/* Generated when an Apple event, a HICommand event, or a Services
@@ -340,11 +194,11 @@ enum event_kind
symbols, respectively. Member `arg' is a Lisp object converted
from the received Apple event. Parameters for non-Apple events
are converted to those in Apple events. */
- MAC_APPLE_EVENT,
+ , MAC_APPLE_EVENT
#endif
#ifdef HAVE_GPM
- GPM_CLICK_EVENT
+ , GPM_CLICK_EVENT
#endif
};
@@ -394,13 +248,6 @@ struct input_event
#define EVENT_INIT(event) bzero (&(event), sizeof (struct input_event))
-/* Called to read input events. */
-extern int (*read_socket_hook) P_ ((int, int, struct input_event *));
-
-/* Called when a frame's display becomes entirely up to date. */
-extern void (*frame_up_to_date_hook) P_ ((struct frame *));
-
-
/* Bits in the modifiers member of the input_event structure.
Note that reorder_modifiers assumes that the bits are in canonical
order.
@@ -452,14 +299,350 @@ enum {
#ifdef HAVE_GPM
#include <gpm.h>
-extern int handle_one_term_event (Gpm_Event *, struct input_event *);
+extern int handle_one_term_event (struct tty_display_info *, Gpm_Event *, struct input_event *);
extern void term_mouse_moveto (int, int);
-/* Nonzero means mouse is enabled on Linux console */
-extern int term_gpm;
+/* The device for which we have enabled gpm support. */
+extern struct tty_display_info *gpm_tty;
+#endif
+
+#endif /* CONSP */
+
+
+struct mac_display_info;
+struct w32_display_info;
+
+/* Terminal-local parameters. */
+struct terminal
+{
+ /* The first two fields are really the header of a vector */
+ /* The terminal code does not refer to them. */
+ EMACS_UINT size;
+ struct Lisp_Vector *vec_next;
+
+ /* Parameter alist of this terminal. */
+ Lisp_Object param_alist;
+
+ /* All fields before `next_terminal' should be Lisp_Object and are traced
+ by the GC. All fields afterwards are ignored by the GC. */
+
+ /* Chain of all terminal devices. */
+ struct terminal *next_terminal;
+
+ /* Unique id for this terminal device. */
+ int id;
+
+ /* The number of frames that are on this terminal. */
+ int reference_count;
+
+ /* The type of the terminal device. */
+ enum output_method type;
+
+ /* The name of the terminal device. Do not use this to uniquely
+ identify a terminal; the same device may be opened multiple
+ times. */
+ char *name;
+
+#ifdef MULTI_KBOARD
+ /* The terminal's keyboard object. */
+ struct kboard *kboard;
+#endif
+
+ /* Device-type dependent data shared amongst all frames on this terminal. */
+ union display_info
+ {
+ struct tty_display_info *tty; /* termchar.h */
+ struct x_display_info *x; /* xterm.h */
+ struct w32_display_info *w32; /* w32term.h */
+ struct mac_display_info *mac; /* macterm.h */
+ } display_info;
+
+
+ /* Coding-system to be used for encoding terminal output. This
+ structure contains information of a coding-system specified by
+ the function `set-terminal-coding-system'. Also see
+ `safe_terminal_coding' in coding.h. */
+ struct coding_system *terminal_coding;
+
+ /* Coding-system of what is sent from terminal keyboard. This
+ structure contains information of a coding-system specified by
+ the function `set-keyboard-coding-system'. */
+ struct coding_system *keyboard_coding;
+
+ /* Terminal characteristics. */
+ /* XXX Are these really used on non-termcap displays? */
+
+ int must_write_spaces; /* Nonzero means spaces in the text must
+ actually be output; can't just skip over
+ some columns to leave them blank. */
+ int fast_clear_end_of_line; /* Nonzero means terminal has a `ce' string */
+
+ int line_ins_del_ok; /* Terminal can insert and delete lines */
+ int char_ins_del_ok; /* Terminal can insert and delete chars */
+ int scroll_region_ok; /* Terminal supports setting the scroll
+ window */
+ int scroll_region_cost; /* Cost of setting the scroll window,
+ measured in characters. */
+ int memory_below_frame; /* Terminal remembers lines scrolled
+ off bottom */
+
+#if 0 /* These are not used anywhere. */
+ /* EMACS_INT baud_rate; */ /* Output speed in baud */
+ int min_padding_speed; /* Speed below which no padding necessary. */
+ int dont_calculate_costs; /* Nonzero means don't bother computing
+ various cost tables; we won't use them. */
#endif
+
+ /* Window-based redisplay interface for this device (0 for tty
+ devices). */
+ struct redisplay_interface *rif;
+
+ /* Frame-based redisplay interface. */
+
+ /* Text display hooks. */
+
+ void (*cursor_to_hook) P_ ((struct frame *f, int vpos, int hpos));
+ void (*raw_cursor_to_hook) P_ ((struct frame *, int, int));
+
+ void (*clear_to_end_hook) P_ ((struct frame *));
+ void (*clear_frame_hook) P_ ((struct frame *));
+ void (*clear_end_of_line_hook) P_ ((struct frame *, int));
+
+ void (*ins_del_lines_hook) P_ ((struct frame *f, int, int));
+
+ void (*insert_glyphs_hook) P_ ((struct frame *f, struct glyph *s, int n));
+ void (*write_glyphs_hook) P_ ((struct frame *f, struct glyph *s, int n));
+ void (*delete_glyphs_hook) P_ ((struct frame *, int));
+
+ void (*ring_bell_hook) P_ ((struct frame *f));
+
+ void (*reset_terminal_modes_hook) P_ ((struct terminal *));
+ void (*set_terminal_modes_hook) P_ ((struct terminal *));
+
+ void (*update_begin_hook) P_ ((struct frame *));
+ void (*update_end_hook) P_ ((struct frame *));
+ void (*set_terminal_window_hook) P_ ((struct frame *, int));
+
+ /* Multi-frame and mouse support hooks. */
+
+ /* Return the current position of the mouse.
+
+ Set *f to the frame the mouse is in, or zero if the mouse is in no
+ Emacs frame. If it is set to zero, all the other arguments are
+ garbage.
+
+ If the motion started in a scroll bar, set *bar_window to the
+ scroll bar's window, *part to the part the mouse is currently over,
+ *x to the position of the mouse along the scroll bar, and *y to the
+ overall length of the scroll bar.
+
+ Otherwise, set *bar_window to Qnil, and *x and *y to the column and
+ row of the character cell the mouse is over.
+
+ Set *time to the time the mouse was at the returned position.
+
+ This should clear mouse_moved until the next motion
+ event arrives. */
+ void (*mouse_position_hook) P_ ((struct frame **f, int,
+ Lisp_Object *bar_window,
+ enum scroll_bar_part *part,
+ Lisp_Object *x,
+ Lisp_Object *y,
+ unsigned long *time));
+
+ /* The window system handling code should set this if the mouse has
+ moved since the last call to the mouse_position_hook. Calling that
+ hook should clear this. */
+ int mouse_moved;
+
+ /* When a frame's focus redirection is changed, this hook tells the
+ window system code to re-decide where to put the highlight. Under
+ X, this means that Emacs lies about where the focus is. */
+ void (*frame_rehighlight_hook) P_ ((struct frame *));
+
+ /* If we're displaying frames using a window system that can stack
+ frames on top of each other, this hook allows you to bring a frame
+ to the front, or bury it behind all the other windows. If this
+ hook is zero, that means the terminal we're displaying on doesn't
+ support overlapping frames, so there's no need to raise or lower
+ anything.
+
+ If RAISE is non-zero, F is brought to the front, before all other
+ windows. If RAISE is zero, F is sent to the back, behind all other
+ windows. */
+ void (*frame_raise_lower_hook) P_ ((struct frame *f, int raise));
+
+ /* If the value of the frame parameter changed, whis hook is called.
+ For example, if going from fullscreen to not fullscreen this hook
+ may do something OS dependent, like extended window manager hints on X11. */
+ void (*fullscreen_hook) P_ ((struct frame *f));
+
+
+ /* Scroll bar hooks. */
+
+ /* The representation of scroll bars is determined by the code which
+ implements them, except for one thing: they must be represented by
+ lisp objects. This allows us to place references to them in
+ Lisp_Windows without worrying about those references becoming
+ dangling references when the scroll bar is destroyed.
+
+ The window-system-independent portion of Emacs just refers to
+ scroll bars via their windows, and never looks inside the scroll bar
+ representation; it always uses hook functions to do all the
+ scroll bar manipulation it needs.
+
+ The `vertical_scroll_bar' field of a Lisp_Window refers to that
+ window's scroll bar, or is nil if the window doesn't have a
+ scroll bar.
+
+ The `scroll_bars' and `condemned_scroll_bars' fields of a Lisp_Frame
+ are free for use by the scroll bar implementation in any way it sees
+ fit. They are marked by the garbage collector. */
+
+
+ /* Set the vertical scroll bar for WINDOW to have its upper left corner
+ at (TOP, LEFT), and be LENGTH rows high. Set its handle to
+ indicate that we are displaying PORTION characters out of a total
+ of WHOLE characters, starting at POSITION. If WINDOW doesn't yet
+ have a scroll bar, create one for it. */
+ void (*set_vertical_scroll_bar_hook) P_ ((struct window *window,
+ int portion, int whole,
+ int position));
+
+
+ /* The following three hooks are used when we're doing a thorough
+ redisplay of the frame. We don't explicitly know which scroll bars
+ are going to be deleted, because keeping track of when windows go
+ away is a real pain - can you say set-window-configuration?
+ Instead, we just assert at the beginning of redisplay that *all*
+ scroll bars are to be removed, and then save scroll bars from the
+ fiery pit when we actually redisplay their window. */
+
+ /* Arrange for all scroll bars on FRAME to be removed at the next call
+ to `*judge_scroll_bars_hook'. A scroll bar may be spared if
+ `*redeem_scroll_bar_hook' is applied to its window before the judgement.
+
+ This should be applied to each frame each time its window tree is
+ redisplayed, even if it is not displaying scroll bars at the moment;
+ if the HAS_SCROLL_BARS flag has just been turned off, only calling
+ this and the judge_scroll_bars_hook will get rid of them.
+
+ If non-zero, this hook should be safe to apply to any frame,
+ whether or not it can support scroll bars, and whether or not it is
+ currently displaying them. */
+ void (*condemn_scroll_bars_hook) P_ ((struct frame *frame));
+
+ /* Unmark WINDOW's scroll bar for deletion in this judgement cycle.
+ Note that it's okay to redeem a scroll bar that is not condemned. */
+ void (*redeem_scroll_bar_hook) P_ ((struct window *window));
+
+ /* Remove all scroll bars on FRAME that haven't been saved since the
+ last call to `*condemn_scroll_bars_hook'.
+
+ This should be applied to each frame after each time its window
+ tree is redisplayed, even if it is not displaying scroll bars at the
+ moment; if the HAS_SCROLL_BARS flag has just been turned off, only
+ calling this and condemn_scroll_bars_hook will get rid of them.
+
+ If non-zero, this hook should be safe to apply to any frame,
+ whether or not it can support scroll bars, and whether or not it is
+ currently displaying them. */
+ void (*judge_scroll_bars_hook) P_ ((struct frame *FRAME));
+
+
+ /* Called to read input events.
+
+ TERMINAL indicates which terminal device to read from. Input
+ events should be read into BUF, the size of which is given in
+ SIZE. EXPECTED is non-zero if the caller suspects that new input
+ is available.
+
+ A positive return value indicates that that many input events
+ where read into BUF.
+ Zero means no events were immediately available.
+ A value of -1 means a transient read error, while -2 indicates
+ that the device was closed (hangup), and it should be deleted.
+
+ XXX Please note that a non-zero value of EXPECTED only means that
+ there is available input on at least one of the currently opened
+ terminal devices -- but not necessarily on this device.
+ Therefore, in most cases EXPECTED should be simply ignored.
+
+ XXX This documentation needs to be updated. */
+ int (*read_socket_hook) P_ ((struct terminal *terminal,
+ int expected,
+ struct input_event *hold_quit));
+
+ /* Called when a frame's display becomes entirely up to date. */
+ void (*frame_up_to_date_hook) P_ ((struct frame *));
+
+
+ /* Called to delete the device-specific portions of a frame that is
+ on this terminal device. */
+ void (*delete_frame_hook) P_ ((struct frame *));
+
+ /* Called after the last frame on this terminal is deleted, or when
+ the display device was closed (hangup).
+
+ If this is NULL, then the generic delete_terminal is called
+ instead. Otherwise the hook must call delete_terminal itself.
+
+ The hook must check for and close any live frames that are still
+ on the terminal. Fdelete_frame ensures that there are no live
+ frames on the terminal when it calls this hook, so infinite
+ recursion is prevented. */
+ void (*delete_terminal_hook) P_ ((struct terminal *));
+};
+
+
+/* Chain of all terminal devices currently in use. */
+extern struct terminal *terminal_list;
+
+#define FRAME_MUST_WRITE_SPACES(f) ((f)->terminal->must_write_spaces)
+#define FRAME_FAST_CLEAR_END_OF_LINE(f) ((f)->terminal->fast_clear_end_of_line)
+#define FRAME_LINE_INS_DEL_OK(f) ((f)->terminal->line_ins_del_ok)
+#define FRAME_CHAR_INS_DEL_OK(f) ((f)->terminal->char_ins_del_ok)
+#define FRAME_SCROLL_REGION_OK(f) ((f)->terminal->scroll_region_ok)
+#define FRAME_SCROLL_REGION_COST(f) ((f)->terminal->scroll_region_cost)
+#define FRAME_MEMORY_BELOW_FRAME(f) ((f)->terminal->memory_below_frame)
+
+#define FRAME_TERMINAL_CODING(f) ((f)->terminal->terminal_coding)
+#define FRAME_KEYBOARD_CODING(f) ((f)->terminal->keyboard_coding)
+
+#define TERMINAL_TERMINAL_CODING(d) ((d)->terminal_coding)
+#define TERMINAL_KEYBOARD_CODING(d) ((d)->keyboard_coding)
+
+#define FRAME_RIF(f) ((f)->terminal->rif)
+
+#define FRAME_TERMINAL(f) ((f)->terminal)
+
+/* FRAME_WINDOW_P tests whether the frame is a window, and is
+ defined to be the predicate for the window system being used. */
+
+#ifdef HAVE_X_WINDOWS
+#define FRAME_WINDOW_P(f) FRAME_X_P (f)
#endif
+#ifdef HAVE_NTGUI
+#define FRAME_WINDOW_P(f) FRAME_W32_P (f)
+#endif
+#ifdef MAC_OS
+#define FRAME_WINDOW_P(f) FRAME_MAC_P (f)
+#endif
+#ifndef FRAME_WINDOW_P
+#define FRAME_WINDOW_P(f) (0)
+#endif
+
+/* Return true if the terminal device is not suspended. */
+#define TERMINAL_ACTIVE_P(d) ((d)->type != output_termcap || (d)->display_info.tty->input)
+
+extern Lisp_Object get_terminal_param P_ ((struct terminal *, Lisp_Object));
+extern struct terminal *get_terminal P_ ((Lisp_Object terminal, int));
+extern struct terminal *create_terminal P_ ((void));
+extern void delete_terminal P_ ((struct terminal *));
+
+/* The initial terminal device, created by initial_term_init. */
+extern struct terminal *initial_terminal;
/* arch-tag: 33a00ecc-52b5-4186-a410-8801ac9f087d
(do not change this comment) */
diff --git a/src/terminal.c b/src/terminal.c
new file mode 100644
index 0000000000..46ffb3c2dc
--- /dev/null
+++ b/src/terminal.c
@@ -0,0 +1,566 @@
+/* Functions related to terminal devices.
+ Copyright (C) 2005, 2006, 2007 Free Software Foundation, Inc.
+
+This file is part of GNU Emacs.
+
+GNU Emacs is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 3, or (at your option)
+any later version.
+
+GNU Emacs is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU Emacs; see the file COPYING. If not, write to
+the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+Boston, MA 02110-1301, USA. */
+
+#include <config.h>
+#include <stdio.h>
+
+#include "lisp.h"
+#include "frame.h"
+#include "termchar.h"
+#include "termhooks.h"
+#include "charset.h"
+#include "coding.h"
+#include "keyboard.h"
+
+/* Chain of all terminals currently in use. */
+struct terminal *terminal_list;
+
+/* The first unallocated terminal id. */
+static int next_terminal_id;
+
+/* The initial terminal device, created by initial_term_init. */
+struct terminal *initial_terminal;
+
+/* Function to use to ring the bell. */
+Lisp_Object Vring_bell_function;
+
+static void delete_initial_terminal P_ ((struct terminal *));
+
+
+
+void
+ring_bell (struct frame *f)
+{
+ if (!NILP (Vring_bell_function))
+ {
+ Lisp_Object function;
+
+ /* Temporarily set the global variable to nil
+ so that if we get an error, it stays nil
+ and we don't call it over and over.
+
+ We don't specbind it, because that would carefully
+ restore the bad value if there's an error
+ and make the loop of errors happen anyway. */
+
+ function = Vring_bell_function;
+ Vring_bell_function = Qnil;
+
+ call0 (function);
+
+ Vring_bell_function = function;
+ }
+ else if (FRAME_TERMINAL (f)->ring_bell_hook)
+ (*FRAME_TERMINAL (f)->ring_bell_hook) (f);
+}
+
+void
+update_begin (struct frame *f)
+{
+ if (FRAME_TERMINAL (f)->update_begin_hook)
+ (*FRAME_TERMINAL (f)->update_begin_hook) (f);
+}
+
+void
+update_end (struct frame *f)
+{
+ if (FRAME_TERMINAL (f)->update_end_hook)
+ (*FRAME_TERMINAL (f)->update_end_hook) (f);
+}
+
+/* Specify how many text lines, from the top of the window,
+ should be affected by insert-lines and delete-lines operations.
+ This, and those operations, are used only within an update
+ that is bounded by calls to update_begin and update_end. */
+
+void
+set_terminal_window (struct frame *f, int size)
+{
+ if (FRAME_TERMINAL (f)->set_terminal_window_hook)
+ (*FRAME_TERMINAL (f)->set_terminal_window_hook) (f, size);
+}
+
+/* Move cursor to row/column position VPOS/HPOS. HPOS/VPOS are
+ frame-relative coordinates. */
+
+void
+cursor_to (struct frame *f, int vpos, int hpos)
+{
+ if (FRAME_TERMINAL (f)->cursor_to_hook)
+ (*FRAME_TERMINAL (f)->cursor_to_hook) (f, vpos, hpos);
+}
+
+/* Similar but don't take any account of the wasted characters. */
+
+void
+raw_cursor_to (struct frame *f, int row, int col)
+{
+ if (FRAME_TERMINAL (f)->raw_cursor_to_hook)
+ (*FRAME_TERMINAL (f)->raw_cursor_to_hook) (f, row, col);
+}
+
+/* Erase operations */
+
+/* Clear from cursor to end of frame. */
+void
+clear_to_end (struct frame *f)
+{
+ if (FRAME_TERMINAL (f)->clear_to_end_hook)
+ (*FRAME_TERMINAL (f)->clear_to_end_hook) (f);
+}
+
+/* Clear entire frame */
+
+void
+clear_frame (struct frame *f)
+{
+ if (FRAME_TERMINAL (f)->clear_frame_hook)
+ (*FRAME_TERMINAL (f)->clear_frame_hook) (f);
+}
+
+/* Clear from cursor to end of line.
+ Assume that the line is already clear starting at column first_unused_hpos.
+
+ Note that the cursor may be moved, on terminals lacking a `ce' string. */
+
+void
+clear_end_of_line (struct frame *f, int first_unused_hpos)
+{
+ if (FRAME_TERMINAL (f)->clear_end_of_line_hook)
+ (*FRAME_TERMINAL (f)->clear_end_of_line_hook) (f, first_unused_hpos);
+}
+
+/* Output LEN glyphs starting at STRING at the nominal cursor position.
+ Advance the nominal cursor over the text. */
+
+void
+write_glyphs (struct frame *f, struct glyph *string, int len)
+{
+ if (FRAME_TERMINAL (f)->write_glyphs_hook)
+ (*FRAME_TERMINAL (f)->write_glyphs_hook) (f, string, len);
+}
+
+/* Insert LEN glyphs from START at the nominal cursor position.
+
+ If start is zero, insert blanks instead of a string at start */
+
+void
+insert_glyphs (struct frame *f, struct glyph *start, int len)
+{
+ if (len <= 0)
+ return;
+
+ if (FRAME_TERMINAL (f)->insert_glyphs_hook)
+ (*FRAME_TERMINAL (f)->insert_glyphs_hook) (f, start, len);
+}
+
+/* Delete N glyphs at the nominal cursor position. */
+
+void
+delete_glyphs (struct frame *f, int n)
+{
+ if (FRAME_TERMINAL (f)->delete_glyphs_hook)
+ (*FRAME_TERMINAL (f)->delete_glyphs_hook) (f, n);
+}
+
+/* Insert N lines at vpos VPOS. If N is negative, delete -N lines. */
+
+void
+ins_del_lines (struct frame *f, int vpos, int n)
+{
+ if (FRAME_TERMINAL (f)->ins_del_lines_hook)
+ (*FRAME_TERMINAL (f)->ins_del_lines_hook) (f, vpos, n);
+}
+
+
+
+
+/* Return the terminal object specified by TERMINAL. TERMINAL may be a
+ terminal id, a frame, or nil for the terminal device of the current
+ frame. If THROW is zero, return NULL for failure, otherwise throw
+ an error. */
+
+struct terminal *
+get_terminal (Lisp_Object terminal, int throw)
+{
+ struct terminal *result = NULL;
+
+ if (NILP (terminal))
+ terminal = selected_frame;
+
+ if (TERMINALP (terminal))
+ result = XTERMINAL (terminal);
+
+ else if (FRAMEP (terminal))
+ {
+ result = FRAME_TERMINAL (XFRAME (terminal));
+ }
+
+ if (result && !result->name)
+ result = NULL;
+
+ if (result == NULL && throw)
+ wrong_type_argument (Qterminal_live_p, terminal);
+
+ return result;
+}
+
+
+
+/* Create a new terminal object and add it to the terminal list. */
+
+struct terminal *
+create_terminal (void)
+{
+ struct terminal *terminal = allocate_terminal ();
+
+ terminal->name = NULL;
+ terminal->next_terminal = terminal_list;
+ terminal_list = terminal;
+
+ terminal->id = next_terminal_id++;
+
+ terminal->keyboard_coding =
+ (struct coding_system *) xmalloc (sizeof (struct coding_system));
+ terminal->terminal_coding =
+ (struct coding_system *) xmalloc (sizeof (struct coding_system));
+
+ setup_coding_system (Qnil, terminal->keyboard_coding);
+ setup_coding_system (Qnil, terminal->terminal_coding);
+
+ terminal->param_alist = Qnil;
+ return terminal;
+}
+
+/* Low-level function to close all frames on a terminal, remove it
+ from the terminal list and free its memory. */
+
+void
+delete_terminal (struct terminal *terminal)
+{
+ struct terminal **tp;
+ Lisp_Object tail, frame;
+
+ /* Protect against recursive calls. Fdelete_frame calls the
+ delete_terminal_hook when we delete our last frame. */
+ if (!terminal->name)
+ return;
+ xfree (terminal->name);
+ terminal->name = NULL;
+
+ /* Check for live frames that are still on this terminal. */
+ FOR_EACH_FRAME (tail, frame)
+ {
+ struct frame *f = XFRAME (frame);
+ if (FRAME_LIVE_P (f) && f->terminal == terminal)
+ {
+ Fdelete_frame (frame, Qt);
+ }
+ }
+
+ for (tp = &terminal_list; *tp != terminal; tp = &(*tp)->next_terminal)
+ if (! *tp)
+ abort ();
+ *tp = terminal->next_terminal;
+
+ xfree (terminal->keyboard_coding);
+ terminal->keyboard_coding = NULL;
+ xfree (terminal->terminal_coding);
+ terminal->terminal_coding = NULL;
+
+#ifdef MULTI_KBOARD
+ if (terminal->kboard && --terminal->kboard->reference_count == 0)
+ {
+ delete_kboard (terminal->kboard);
+ terminal->kboard = NULL;
+ }
+#endif
+}
+
+DEFUN ("delete-terminal", Fdelete_terminal, Sdelete_terminal, 0, 2, 0,
+ doc: /* Delete TERMINAL by deleting all frames on it and closing the terminal.
+TERMINAL may be a terminal id, a frame, or nil (meaning the selected
+frame's terminal).
+
+Normally, you may not delete a display if all other displays are suspended,
+but if the second argument FORCE is non-nil, you may do so. */)
+ (terminal, force)
+ Lisp_Object terminal, force;
+{
+ struct terminal *t, *p;
+
+ t = get_terminal (terminal, 0);
+
+ if (!t)
+ return Qnil;
+
+ p = terminal_list;
+ while (p && (p == t || !TERMINAL_ACTIVE_P (p)))
+ p = p->next_terminal;
+
+ if (NILP (force) && !p)
+ error ("Attempt to delete the sole active display terminal");
+
+ if (t->delete_terminal_hook)
+ (*t->delete_terminal_hook) (t);
+ else
+ delete_terminal (t);
+
+ return Qnil;
+}
+
+
+DEFUN ("frame-terminal", Fframe_terminal, Sframe_terminal, 0, 1, 0,
+ doc: /* Return the terminal that FRAME is displayed on.
+If FRAME is nil, the selected frame is used.
+
+The terminal device is represented by its integer identifier. */)
+ (frame)
+ Lisp_Object frame;
+{
+ struct terminal *t;
+
+ if (NILP (frame))
+ frame = selected_frame;
+
+ CHECK_LIVE_FRAME (frame);
+
+ t = FRAME_TERMINAL (XFRAME (frame));
+
+ if (!t)
+ return Qnil;
+ else
+ {
+ Lisp_Object terminal;
+ XSETTERMINAL (terminal, t);
+ return terminal;
+ }
+}
+
+DEFUN ("terminal-live-p", Fterminal_live_p, Sterminal_live_p, 1, 1, 0,
+ doc: /* Return non-nil if OBJECT is a terminal which has not been deleted.
+Value is nil if OBJECT is not a live display terminal.
+If object is a live display terminal, the return value indicates what
+sort of output terminal it uses. See the documentation of `framep' for
+possible return values. */)
+ (object)
+ Lisp_Object object;
+{
+ struct terminal *t;
+
+ t = get_terminal (object, 0);
+
+ if (!t)
+ return Qnil;
+
+ switch (t->type)
+ {
+ case output_initial: /* The initial frame is like a termcap frame. */
+ case output_termcap:
+ return Qt;
+ case output_x_window:
+ return Qx;
+ case output_w32:
+ return Qw32;
+ case output_msdos_raw:
+ return Qpc;
+ case output_mac:
+ return Qmac;
+ default:
+ abort ();
+ }
+}
+
+DEFUN ("terminal-list", Fterminal_list, Sterminal_list, 0, 0, 0,
+ doc: /* Return a list of all terminal devices. */)
+ ()
+{
+ Lisp_Object terminal, terminals = Qnil;
+ struct terminal *t;
+
+ for (t = terminal_list; t; t = t->next_terminal)
+ {
+ XSETTERMINAL (terminal, t);
+ terminals = Fcons (terminal, terminals);
+ }
+
+ return terminals;
+}
+
+DEFUN ("terminal-name", Fterminal_name, Sterminal_name, 0, 1, 0,
+ doc: /* Return the name of the terminal device TERMINAL.
+It is not guaranteed that the returned value is unique among opened devices.
+
+TERMINAL may be a terminal id, a frame, or nil (meaning the
+selected frame's terminal). */)
+ (terminal)
+ Lisp_Object terminal;
+{
+ struct terminal *t
+ = TERMINALP (terminal) ? XTERMINAL (terminal) : get_terminal (terminal, 1);
+
+ return t->name ? build_string (t->name) : Qnil;
+}
+
+
+
+/* Return the value of terminal parameter PARAM in terminal T. */
+Lisp_Object
+get_terminal_param (t, param)
+ struct terminal *t;
+ Lisp_Object param;
+{
+ Lisp_Object tem = Fassq (param, t->param_alist);
+ if (EQ (tem, Qnil))
+ return tem;
+ return Fcdr (tem);
+}
+
+/* Set the value of terminal parameter PARAMETER in terminal D to VALUE.
+ Return the previous value. */
+
+Lisp_Object
+store_terminal_param (t, parameter, value)
+ struct terminal *t;
+ Lisp_Object parameter;
+ Lisp_Object value;
+{
+ Lisp_Object old_alist_elt = Fassq (parameter, t->param_alist);
+ if (EQ (old_alist_elt, Qnil))
+ {
+ t->param_alist = Fcons (Fcons (parameter, value), t->param_alist);
+ return Qnil;
+ }
+ else
+ {
+ Lisp_Object result = Fcdr (old_alist_elt);
+ Fsetcdr (old_alist_elt, value);
+ return result;
+ }
+}
+
+
+DEFUN ("terminal-parameters", Fterminal_parameters, Sterminal_parameters, 0, 1, 0,
+ doc: /* Return the parameter-alist of terminal TERMINAL.
+The value is a list of elements of the form (PARM . VALUE), where PARM
+is a symbol.
+
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). */)
+ (terminal)
+ Lisp_Object terminal;
+{
+ struct terminal *t
+ = TERMINALP (terminal) ? XTERMINAL (terminal) : get_terminal (terminal, 1);
+ return Fcopy_alist (t->param_alist);
+}
+
+DEFUN ("terminal-parameter", Fterminal_parameter, Sterminal_parameter, 2, 2, 0,
+ doc: /* Return TERMINAL's value for parameter PARAMETER.
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). */)
+ (terminal, parameter)
+ Lisp_Object terminal;
+ Lisp_Object parameter;
+{
+ Lisp_Object value;
+ struct terminal *t
+ = TERMINALP (terminal) ? XTERMINAL (terminal) : get_terminal (terminal, 1);
+ CHECK_SYMBOL (parameter);
+ value = Fcdr (Fassq (parameter, t->param_alist));
+ return value;
+}
+
+DEFUN ("set-terminal-parameter", Fset_terminal_parameter,
+ Sset_terminal_parameter, 3, 3, 0,
+ doc: /* Set TERMINAL's value for parameter PARAMETER to VALUE.
+Return the previous value of PARAMETER.
+
+TERMINAL can be a terminal id, a frame or nil (meaning the selected
+frame's terminal). */)
+ (terminal, parameter, value)
+ Lisp_Object terminal;
+ Lisp_Object parameter;
+ Lisp_Object value;
+{
+ struct terminal *t
+ = TERMINALP (terminal) ? XTERMINAL (terminal) : get_terminal (terminal, 1);
+ return store_terminal_param (t, parameter, value);
+}
+
+
+
+/* Create the bootstrap display terminal for the initial frame.
+ Returns a terminal of type output_initial. */
+
+struct terminal *
+init_initial_terminal (void)
+{
+ if (initialized || terminal_list || tty_list)
+ abort ();
+
+ initial_terminal = create_terminal ();
+ initial_terminal->type = output_initial;
+ initial_terminal->name = xstrdup ("initial_terminal");
+#ifdef MULTI_KBOARD
+ initial_terminal->kboard = initial_kboard;
+#endif
+ initial_terminal->delete_terminal_hook = &delete_initial_terminal;
+ /* All other hooks are NULL. */
+
+ return initial_terminal;
+}
+
+/* Deletes the bootstrap terminal device.
+ Called through delete_terminal_hook. */
+
+static void
+delete_initial_terminal (struct terminal *terminal)
+{
+ if (terminal != initial_terminal)
+ abort ();
+
+ delete_terminal (terminal);
+ initial_terminal = NULL;
+}
+
+void
+syms_of_terminal ()
+{
+
+ DEFVAR_LISP ("ring-bell-function", &Vring_bell_function,
+ doc: /* Non-nil means call this function to ring the bell.
+The function should accept no arguments. */);
+ Vring_bell_function = Qnil;
+
+ defsubr (&Sdelete_terminal);
+ defsubr (&Sframe_terminal);
+ defsubr (&Sterminal_live_p);
+ defsubr (&Sterminal_list);
+ defsubr (&Sterminal_name);
+ defsubr (&Sterminal_parameters);
+ defsubr (&Sterminal_parameter);
+ defsubr (&Sset_terminal_parameter);
+
+ Fprovide (intern ("multi-tty"), Qnil);
+}
+
+/* arch-tag: e9af6f27-b483-47dc-bb1a-730c1c5cab03
+ (do not change this comment) */
diff --git a/src/termopts.h b/src/termopts.h
index 210236017d..5946666654 100644
--- a/src/termopts.h
+++ b/src/termopts.h
@@ -41,5 +41,10 @@ extern int meta_key;
/* Nonzero means truncate lines in all windows less wide than the frame */
extern int truncate_partial_width_windows;
+/* Nonzero means no need to redraw the entire frame on resuming a suspended
+ Emacs. This is useful on terminals with multiple pages, where one page is
+ used for Emacs and another for all else. */
+extern int no_redraw_on_reenter;
+
/* arch-tag: 35d4d284-dc1a-4fff-97fa-0154a21aebdb
(do not change this comment) */
diff --git a/src/w32.c b/src/w32.c
index d7e95aac7d..500e85733b 100644
--- a/src/w32.c
+++ b/src/w32.c
@@ -904,18 +904,6 @@ alarm (int seconds)
return 0;
}
-void
-unrequest_sigio (void)
-{
- return;
-}
-
-void
-request_sigio (void)
-{
- return;
-}
-
#define REG_ROOT "SOFTWARE\\GNU\\Emacs"
LPBYTE
@@ -939,6 +927,7 @@ w32_get_resource (key, lpdwtype)
&& (lpvalue = (LPBYTE) xmalloc (cbData)) != NULL
&& RegQueryValueEx (hrootkey, key, NULL, lpdwtype, lpvalue, &cbData) == ERROR_SUCCESS)
{
+ RegCloseKey (hrootkey);
return (lpvalue);
}
@@ -955,6 +944,7 @@ w32_get_resource (key, lpdwtype)
&& (lpvalue = (LPBYTE) xmalloc (cbData)) != NULL
&& RegQueryValueEx (hrootkey, key, NULL, lpdwtype, lpvalue, &cbData) == ERROR_SUCCESS)
{
+ RegCloseKey (hrootkey);
return (lpvalue);
}
diff --git a/src/w32console.c b/src/w32console.c
index f828808caf..72411d7d4b 100644
--- a/src/w32console.c
+++ b/src/w32console.c
@@ -35,11 +35,12 @@ Boston, MA 02110-1301, USA.
#include "character.h"
#include "coding.h"
#include "disptab.h"
-#include "termhooks.h"
-#include "dispextern.h"
/* Disable features in frame.h that require a Window System. */
#undef HAVE_WINDOW_SYSTEM
#include "frame.h"
+#include "termhooks.h"
+#include "termchar.h"
+#include "dispextern.h"
#include "w32inevt.h"
/* from window.c */
@@ -51,21 +52,17 @@ extern int detect_input_pending ();
/* from sysdep.c */
extern int read_input_pending ();
-extern struct frame * updating_frame;
-extern int meta_key;
-
-static void w32con_move_cursor (int row, int col);
-static void w32con_clear_to_end (void);
-static void w32con_clear_frame (void);
-static void w32con_clear_end_of_line (int);
-static void w32con_ins_del_lines (int vpos, int n);
-static void w32con_insert_glyphs (struct glyph *start, int len);
-static void w32con_write_glyphs (struct glyph *string, int len);
-static void w32con_delete_glyphs (int n);
-void w32_sys_ring_bell (void);
-static void w32con_reset_terminal_modes (void);
-static void w32con_set_terminal_modes (void);
-static void w32con_set_terminal_window (int size);
+static void w32con_move_cursor (struct frame *f, int row, int col);
+static void w32con_clear_to_end (struct frame *f);
+static void w32con_clear_frame (struct frame *f);
+static void w32con_clear_end_of_line (struct frame *f, int);
+static void w32con_ins_del_lines (struct frame *f, int vpos, int n);
+static void w32con_insert_glyphs (struct frame *f, struct glyph *start, int len);
+static void w32con_write_glyphs (struct frame *f, struct glyph *string, int len);
+static void w32con_delete_glyphs (struct frame *f, int n);
+static void w32con_reset_terminal_modes (struct terminal *t);
+static void w32con_set_terminal_modes (struct terminal *t);
+static void w32con_set_terminal_window (struct frame *f, int size);
static void w32con_update_begin (struct frame * f);
static void w32con_update_end (struct frame * f);
static WORD w32_face_attributes (struct frame *f, int face_id);
@@ -99,38 +96,31 @@ ctrl_c_handler (unsigned long type)
&& (type == CTRL_C_EVENT || type == CTRL_BREAK_EVENT));
}
-/* If we're updating a frame, use it as the current frame
- Otherwise, use the selected frame. */
-#define PICK_FRAME() (updating_frame ? updating_frame : SELECTED_FRAME ())
-/* Move the cursor to (row, col). */
+/* Move the cursor to (ROW, COL) on FRAME. */
static void
-w32con_move_cursor (int row, int col)
+w32con_move_cursor (struct frame *f, int row, int col)
{
cursor_coords.X = col;
cursor_coords.Y = row;
- if (updating_frame == (struct frame *) NULL)
- {
- SetConsoleCursorPosition (cur_screen, cursor_coords);
- }
+ /* TODO: for multi-tty support, cur_screen should be replaced with a
+ reference to the terminal for this frame. */
+ SetConsoleCursorPosition (cur_screen, cursor_coords);
}
/* Clear from cursor to end of screen. */
static void
-w32con_clear_to_end (void)
+w32con_clear_to_end (struct frame *f)
{
- struct frame * f = PICK_FRAME ();
-
- w32con_clear_end_of_line (FRAME_COLS (f) - 1);
- w32con_ins_del_lines (cursor_coords.Y, FRAME_LINES (f) - cursor_coords.Y - 1);
+ w32con_clear_end_of_line (f, FRAME_COLS (f) - 1);
+ w32con_ins_del_lines (f, cursor_coords.Y, FRAME_LINES (f) - cursor_coords.Y - 1);
}
/* Clear the frame. */
static void
-w32con_clear_frame (void)
+w32con_clear_frame (struct frame *f)
{
- struct frame * f = PICK_FRAME ();
COORD dest;
int n;
DWORD r;
@@ -145,7 +135,7 @@ w32con_clear_frame (void)
FillConsoleOutputAttribute (cur_screen, char_attr_normal, n, dest, &r);
FillConsoleOutputCharacter (cur_screen, ' ', n, dest, &r);
- w32con_move_cursor (0, 0);
+ w32con_move_cursor (f, 0, 0);
}
@@ -154,7 +144,7 @@ static BOOL ceol_initialized = FALSE;
/* Clear from Cursor to end (what's "standout marker"?). */
static void
-w32con_clear_end_of_line (int end)
+w32con_clear_end_of_line (struct frame *f, int end)
{
if (!ceol_initialized)
{
@@ -165,18 +155,17 @@ w32con_clear_end_of_line (int end)
}
ceol_initialized = TRUE;
}
- w32con_write_glyphs (glyph_base, end - cursor_coords.X); /* fencepost ? */
+ w32con_write_glyphs (f, glyph_base, end - cursor_coords.X); /* fencepost ? */
}
/* Insert n lines at vpos. if n is negative delete -n lines. */
static void
-w32con_ins_del_lines (int vpos, int n)
+w32con_ins_del_lines (struct frame *f, int vpos, int n)
{
int i, nb;
SMALL_RECT scroll;
COORD dest;
CHAR_INFO fill;
- struct frame * f = PICK_FRAME ();
if (n < 0)
{
@@ -213,8 +202,8 @@ w32con_ins_del_lines (int vpos, int n)
{
for (i = scroll.Bottom; i < dest.Y; i++)
{
- w32con_move_cursor (i, 0);
- w32con_clear_end_of_line (FRAME_COLS (f));
+ w32con_move_cursor (f, i, 0);
+ w32con_clear_end_of_line (f, FRAME_COLS (f));
}
}
}
@@ -226,8 +215,8 @@ w32con_ins_del_lines (int vpos, int n)
{
for (i = nb; i < scroll.Top; i++)
{
- w32con_move_cursor (i, 0);
- w32con_clear_end_of_line (FRAME_COLS (f));
+ w32con_move_cursor (f, i, 0);
+ w32con_clear_end_of_line (f, FRAME_COLS (f));
}
}
}
@@ -242,14 +231,13 @@ w32con_ins_del_lines (int vpos, int n)
#define RIGHT 0
static void
-scroll_line (int dist, int direction)
+scroll_line (struct frame *f, int dist, int direction)
{
/* The idea here is to implement a horizontal scroll in one line to
implement delete and half of insert. */
SMALL_RECT scroll;
COORD dest;
CHAR_INFO fill;
- struct frame * f = PICK_FRAME ();
scroll.Top = cursor_coords.Y;
scroll.Bottom = cursor_coords.Y;
@@ -277,9 +265,9 @@ scroll_line (int dist, int direction)
/* If start is zero insert blanks instead of a string at start ?. */
static void
-w32con_insert_glyphs (register struct glyph *start, register int len)
+w32con_insert_glyphs (struct frame *f, register struct glyph *start, register int len)
{
- scroll_line (len, RIGHT);
+ scroll_line (f, len, RIGHT);
/* Move len chars to the right starting at cursor_coords, fill with blanks */
if (start)
@@ -287,11 +275,11 @@ w32con_insert_glyphs (register struct glyph *start, register int len)
/* Print the first len characters of start, cursor_coords.X adjusted
by write_glyphs. */
- w32con_write_glyphs (start, len);
+ w32con_write_glyphs (f, start, len);
}
else
{
- w32con_clear_end_of_line (cursor_coords.X + len);
+ w32con_clear_end_of_line (f, cursor_coords.X + len);
}
}
@@ -299,11 +287,11 @@ extern unsigned char *encode_terminal_code P_ ((struct glyph *, int,
struct coding_system *));
static void
-w32con_write_glyphs (register struct glyph *string, register int len)
+w32con_write_glyphs (struct frame *f, register struct glyph *string,
+ register int len)
{
int produced, consumed;
DWORD r;
- struct frame * f = PICK_FRAME ();
WORD char_attr;
unsigned char *conversion_buffer;
struct coding_system *coding;
@@ -314,11 +302,11 @@ w32con_write_glyphs (register struct glyph *string, register int len)
/* If terminal_coding does any conversion, use it, otherwise use
safe_terminal_coding. We can't use CODING_REQUIRE_ENCODING here
because it always return 1 if the member src_multibyte is 1. */
- coding = (terminal_coding.common_flags & CODING_REQUIRE_ENCODING_MASK
- ? &terminal_coding : &safe_terminal_coding);
+ coding = (FRAME_TERMINAL_CODING (f)->common_flags & CODING_REQUIRE_ENCODING_MASK
+ ? FRAME_TERMINAL_CODING (f) : &safe_terminal_coding);
/* The mode bit CODING_MODE_LAST_BLOCK should be set to 1 only at
the tail. */
- terminal_coding.mode &= ~CODING_MODE_LAST_BLOCK;
+ coding->mode &= ~CODING_MODE_LAST_BLOCK;
while (len > 0)
{
@@ -360,7 +348,7 @@ w32con_write_glyphs (register struct glyph *string, register int len)
}
cursor_coords.X += coding->produced;
- w32con_move_cursor (cursor_coords.Y, cursor_coords.X);
+ w32con_move_cursor (f, cursor_coords.Y, cursor_coords.X);
}
len -= n;
string += n;
@@ -369,20 +357,20 @@ w32con_write_glyphs (register struct glyph *string, register int len)
static void
-w32con_delete_glyphs (int n)
+w32con_delete_glyphs (struct frame *f, int n)
{
/* delete chars means scroll chars from cursor_coords.X + n to
cursor_coords.X, anything beyond the edge of the screen should
come out empty... */
- scroll_line (n, LEFT);
+ scroll_line (f, n, LEFT);
}
static unsigned int sound_type = 0xFFFFFFFF;
#define MB_EMACS_SILENT (0xFFFFFFFF - 1)
void
-w32_sys_ring_bell (void)
+w32_sys_ring_bell (struct frame *f)
{
if (sound_type == 0xFFFFFFFF)
{
@@ -428,7 +416,7 @@ SOUND is nil to use the normal beep. */)
}
static void
-w32con_reset_terminal_modes (void)
+w32con_reset_terminal_modes (struct terminal *t)
{
#ifdef USE_SEPARATE_SCREEN
SetConsoleActiveScreenBuffer (prev_screen);
@@ -439,7 +427,7 @@ w32con_reset_terminal_modes (void)
}
static void
-w32con_set_terminal_modes (void)
+w32con_set_terminal_modes (struct terminal *t)
{
CONSOLE_CURSOR_INFO cci;
@@ -473,7 +461,7 @@ w32con_update_end (struct frame * f)
}
static void
-w32con_set_terminal_window (int size)
+w32con_set_terminal_window (struct frame *f, int size)
{
}
@@ -547,28 +535,38 @@ vga_stdcolor_name (int idx)
typedef int (*term_hook) ();
void
-initialize_w32_display (void)
+initialize_w32_display (struct terminal *term)
{
CONSOLE_SCREEN_BUFFER_INFO info;
- cursor_to_hook = w32con_move_cursor;
- raw_cursor_to_hook = w32con_move_cursor;
- clear_to_end_hook = w32con_clear_to_end;
- clear_frame_hook = w32con_clear_frame;
- clear_end_of_line_hook = w32con_clear_end_of_line;
- ins_del_lines_hook = w32con_ins_del_lines;
- insert_glyphs_hook = w32con_insert_glyphs;
- write_glyphs_hook = w32con_write_glyphs;
- delete_glyphs_hook = w32con_delete_glyphs;
- ring_bell_hook = w32_sys_ring_bell;
- reset_terminal_modes_hook = w32con_reset_terminal_modes;
- set_terminal_modes_hook = w32con_set_terminal_modes;
- set_terminal_window_hook = w32con_set_terminal_window;
- update_begin_hook = w32con_update_begin;
- update_end_hook = w32con_update_end;
-
- read_socket_hook = w32_console_read_socket;
- mouse_position_hook = w32_console_mouse_position;
+ term->rif = 0; /* No window based redisplay on the console. */
+ term->cursor_to_hook = w32con_move_cursor;
+ term->raw_cursor_to_hook = w32con_move_cursor;
+ term->clear_to_end_hook = w32con_clear_to_end;
+ term->clear_frame_hook = w32con_clear_frame;
+ term->clear_end_of_line_hook = w32con_clear_end_of_line;
+ term->ins_del_lines_hook = w32con_ins_del_lines;
+ term->insert_glyphs_hook = w32con_insert_glyphs;
+ term->write_glyphs_hook = w32con_write_glyphs;
+ term->delete_glyphs_hook = w32con_delete_glyphs;
+ term->ring_bell_hook = w32_sys_ring_bell;
+ term->reset_terminal_modes_hook = w32con_reset_terminal_modes;
+ term->set_terminal_modes_hook = w32con_set_terminal_modes;
+ term->set_terminal_window_hook = w32con_set_terminal_window;
+ term->update_begin_hook = w32con_update_begin;
+ term->update_end_hook = w32con_update_end;
+
+ term->read_socket_hook = w32_console_read_socket;
+ term->mouse_position_hook = w32_console_mouse_position;
+
+ /* The following are not used on the console. */
+ term->frame_rehighlight_hook = 0;
+ term->frame_raise_lower_hook = 0;
+ term->set_vertical_scroll_bar_hook = 0;
+ term->condemn_scroll_bars_hook = 0;
+ term->redeem_scroll_bar_hook = 0;
+ term->judge_scroll_bars_hook = 0;
+ term->frame_up_to_date_hook = 0;
/* Initialize interrupt_handle. */
init_crit ();
@@ -633,7 +631,6 @@ initialize_w32_display (void)
GetConsoleScreenBufferInfo (cur_screen, &info);
- meta_key = 1;
char_attr_normal = info.wAttributes;
/* Determine if the info returned by GetConsoleScreenBufferInfo
@@ -674,6 +671,7 @@ initialize_w32_display (void)
}
+
DEFUN ("set-screen-color", Fset_screen_color, Sset_screen_color, 2, 2, 0,
doc: /* Set screen colors. */)
(foreground, background)
diff --git a/src/w32fns.c b/src/w32fns.c
index 6c2beae7d9..1fbde99f30 100644
--- a/src/w32fns.c
+++ b/src/w32fns.c
@@ -49,6 +49,7 @@ Boston, MA 02110-1301, USA. */
#include "bitmaps/gray.xbm"
+#include <commctrl.h>
#include <commdlg.h>
#include <shellapi.h>
#include <ctype.h>
@@ -1823,10 +1824,8 @@ x_set_tool_bar_lines (f, value, oldval)
below the menu bar. */
if (FRAME_W32_WINDOW (f) && FRAME_TOOL_BAR_LINES (f) == 0)
{
- updating_frame = f;
- clear_frame ();
+ clear_frame (f);
clear_current_matrices (f);
- updating_frame = NULL;
}
/* If the tool bar gets smaller, the internal border below it
@@ -3389,16 +3388,20 @@ w32_wnd_proc (hwnd, msg, wParam, lParam)
return 0;
case WM_MOUSEWHEEL:
+ case WM_DROPFILES:
wmsg.dwModifiers = w32_get_modifiers ();
my_post_msg (&wmsg, hwnd, msg, wParam, lParam);
signal_user_input ();
return 0;
- case WM_DROPFILES:
+ case WM_MOUSEHWHEEL:
wmsg.dwModifiers = w32_get_modifiers ();
my_post_msg (&wmsg, hwnd, msg, wParam, lParam);
signal_user_input ();
- return 0;
+ /* Non-zero must be returned when WM_MOUSEHWHEEL messages are
+ handled, to prevent the system trying to handle it by faking
+ scroll bar events. */
+ return 1;
case WM_TIMER:
/* Flush out saved messages if necessary. */
@@ -4216,7 +4219,7 @@ This function is an internal primitive--use `make-frame' instead. */)
display = Qnil;
dpyinfo = check_x_display_info (display);
#ifdef MULTI_KBOARD
- kb = dpyinfo->kboard;
+ kb = dpyinfo->terminal->kboard;
#else
kb = &the_only_kboard;
#endif
@@ -4264,6 +4267,9 @@ This function is an internal primitive--use `make-frame' instead. */)
/* By default, make scrollbars the system standard width. */
FRAME_CONFIG_SCROLL_BAR_WIDTH (f) = GetSystemMetrics (SM_CXVSCROLL);
+ f->terminal = dpyinfo->terminal;
+ f->terminal->reference_count++;
+
f->output_method = output_w32;
f->output_data.w32 =
(struct w32_output *) xmalloc (sizeof (struct w32_output));
@@ -4498,6 +4504,22 @@ This function is an internal primitive--use `make-frame' instead. */)
/* Must have been Qnil. */
;
}
+
+ /* Initialize `default-minibuffer-frame' in case this is the first
+ frame on this terminal. */
+ if (FRAME_HAS_MINIBUF_P (f)
+ && (!FRAMEP (kb->Vdefault_minibuffer_frame)
+ || !FRAME_LIVE_P (XFRAME (kb->Vdefault_minibuffer_frame))))
+ kb->Vdefault_minibuffer_frame = frame;
+
+ /* All remaining specified parameters, which have not been "used"
+ by x_get_arg and friends, now go in the misc. alist of the frame. */
+ for (tem = parameters; !NILP (tem); tem = XCDR (tem))
+ if (CONSP (XCAR (tem)) && !NILP (XCAR (XCAR (tem))))
+ f->param_alist = Fcons (XCAR (tem), f->param_alist);
+
+ store_frame_param (f, Qwindow_system, Qw32);
+
UNGCPRO;
/* Make sure windows on this frame appear in calls to next-window
@@ -4523,7 +4545,7 @@ x_get_focus_frame (frame)
return xfocus;
}
-DEFUN ("w32-focus-frame", Fw32_focus_frame, Sw32_focus_frame, 1, 1, 0,
+DEFUN ("x-focus-frame", Fx_focus_frame, Sx_focus_frame, 1, 1, 0,
doc: /* Give FRAME input focus, raising to foreground if necessary. */)
(frame)
Lisp_Object frame;
@@ -6836,8 +6858,10 @@ terminate Emacs if we can't open the connection. */)
if (! NILP (xrm_string))
CHECK_STRING (xrm_string);
+#if 0
if (! EQ (Vwindow_system, intern ("w32")))
error ("Not using Microsoft Windows");
+#endif
/* Allow color mapping to be defined externally; first look in user's
HOME directory, then in Emacs etc dir for a file called rgb.txt. */
@@ -7339,7 +7363,7 @@ x_create_tip_frame (dpyinfo, parms, text)
Vx_resource_name = Vinvocation_name;
#ifdef MULTI_KBOARD
- kb = dpyinfo->kboard;
+ kb = dpyinfo->terminal->kboard;
#else
kb = &the_only_kboard;
#endif
@@ -7377,6 +7401,8 @@ x_create_tip_frame (dpyinfo, parms, text)
the frame is live, as per FRAME_LIVE_P. If we get a signal
from this point on, x_destroy_window might screw up reference
counts etc. */
+ f->terminal = dpyinfo->terminal;
+ f->terminal->reference_count++;
f->output_method = output_w32;
f->output_data.w32 =
(struct w32_output *) xmalloc (sizeof (struct w32_output));
@@ -7560,6 +7586,8 @@ x_create_tip_frame (dpyinfo, parms, text)
Qnil));
}
+ Fmodify_frame_parameters (frame, Fcons (Fcons (Qwindow_system, Qw32), Qnil));
+
f->no_split = 1;
UNGCPRO;
@@ -9106,10 +9134,10 @@ versions of Windows) characters. */);
defsubr (&Sx_close_connection);
defsubr (&Sx_display_list);
defsubr (&Sx_synchronize);
+ defsubr (&Sx_focus_frame);
/* W32 specific functions */
- defsubr (&Sw32_focus_frame);
defsubr (&Sw32_select_font);
defsubr (&Sw32_define_rgb_color);
defsubr (&Sw32_default_color_map);
@@ -9184,6 +9212,9 @@ void globals_of_w32fns ()
&w32_ansi_code_page,
doc: /* The ANSI code page used by the system. */);
w32_ansi_code_page = GetACP ();
+
+ /* MessageBox does not work without this when linked to comctl32.dll 6.0. */
+ InitCommonControls ();
}
#undef abort
diff --git a/src/w32inevt.c b/src/w32inevt.c
index fa2d34c299..17cfd38440 100644
--- a/src/w32inevt.c
+++ b/src/w32inevt.c
@@ -643,7 +643,9 @@ maybe_generate_resize_event ()
}
int
-w32_console_read_socket (int sd, int expected, struct input_event *hold_quit)
+w32_console_read_socket (struct terminal *terminal,
+ int expected,
+ struct input_event *hold_quit)
{
BOOL no_events = TRUE;
int nev, ret = 0, add;
diff --git a/src/w32inevt.h b/src/w32inevt.h
index 53f36e3a34..08d85a0b2e 100644
--- a/src/w32inevt.h
+++ b/src/w32inevt.h
@@ -22,7 +22,7 @@ Boston, MA 02110-1301, USA. */
#ifndef EMACS_W32INEVT_H
#define EMACS_W32INEVT_H
-extern int w32_console_read_socket (int sd, int numchars,
+extern int w32_console_read_socket (struct terminal *term, int numchars,
struct input_event *hold_quit);
extern void w32_console_mouse_position (FRAME_PTR *f, int insist,
Lisp_Object *bar_window,
diff --git a/src/w32menu.c b/src/w32menu.c
index 22389eea2a..d4c92d4dcd 100644
--- a/src/w32menu.c
+++ b/src/w32menu.c
@@ -20,15 +20,16 @@ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
#include <config.h>
-#include <signal.h>
+#include <signal.h>
#include <stdio.h>
#include <mbstring.h>
+
#include "lisp.h"
-#include "termhooks.h"
#include "keyboard.h"
#include "keymap.h"
#include "frame.h"
+#include "termhooks.h"
#include "window.h"
#include "blockinput.h"
#include "buffer.h"
@@ -675,8 +676,8 @@ cached information about equivalent key sequences. */)
enum scroll_bar_part part;
unsigned long time;
- if (mouse_position_hook)
- (*mouse_position_hook) (&new_f, 1, &bar_window,
+ if (FRAME_TERMINAL (new_f)->mouse_position_hook)
+ (*FRAME_TERMINAL (new_f)->mouse_position_hook) (&new_f, 1, &bar_window,
&part, &x, &y, &time);
if (new_f != 0)
XSETFRAME (window, new_f);
diff --git a/src/w32proc.c b/src/w32proc.c
index c625c1b1fe..6c5f9b89f7 100644
--- a/src/w32proc.c
+++ b/src/w32proc.c
@@ -217,12 +217,18 @@ delete_child (child_process *cp)
/* let the thread exit cleanly if possible */
cp->status = STATUS_READ_ERROR;
SetEvent (cp->char_consumed);
+#if 0
+ /* We used to forceably terminate the thread here, but it
+ is normally unnecessary, and in abnormal cases, the worst that
+ will happen is we have an extra idle thread hanging around
+ waiting for the zombie process. */
if (WaitForSingleObject (cp->thrd, 1000) != WAIT_OBJECT_0)
{
DebPrint (("delete_child.WaitForSingleObject (thread) failed "
"with %lu for fd %ld\n", GetLastError (), cp->fd));
TerminateThread (cp->thrd, 0);
}
+#endif
}
CloseHandle (cp->thrd);
cp->thrd = NULL;
diff --git a/src/w32term.c b/src/w32term.c
index 9ba602fe7c..a7fca780d3 100644
--- a/src/w32term.c
+++ b/src/w32term.c
@@ -64,8 +64,6 @@ Boston, MA 02110-1301, USA. */
#include "font.h"
#endif /* USE_FONT_BACKEND */
-#define abs(x) ((x) < 0 ? -(x) : (x))
-
/* Fringe bitmaps. */
@@ -265,9 +263,9 @@ static void x_font_min_bounds P_ ((XFontStruct *, int *, int *));
int x_compute_min_glyph_bounds P_ ((struct frame *));
static void x_update_end P_ ((struct frame *));
static void w32_frame_up_to_date P_ ((struct frame *));
-static void w32_set_terminal_modes P_ ((void));
-static void w32_reset_terminal_modes P_ ((void));
-static void x_clear_frame P_ ((void));
+static void w32_set_terminal_modes P_ ((struct terminal *));
+static void w32_reset_terminal_modes P_ ((struct terminal *));
+static void x_clear_frame P_ ((struct frame *));
static void frame_highlight P_ ((struct frame *));
static void frame_unhighlight P_ ((struct frame *));
static void x_new_focus_frame P_ ((struct w32_display_info *,
@@ -879,7 +877,7 @@ w32_destroy_fringe_bitmap (which)
rarely happens). */
static void
-w32_set_terminal_modes (void)
+w32_set_terminal_modes (struct terminal *term)
{
}
@@ -887,7 +885,7 @@ w32_set_terminal_modes (void)
the W32 windows go away, and suspending requires no action. */
static void
-w32_reset_terminal_modes (void)
+w32_reset_terminal_modes (struct terminal *term)
{
}
@@ -3016,7 +3014,7 @@ x_draw_glyph_string (s)
}
else
{
- w32_fill_area (s->f, s->hdc, s->face->underline_color, s->x,
+ w32_fill_area (s->f, s->hdc, s->face->strike_through_color, s->x,
s->y + dy, s->width, h);
}
}
@@ -3109,16 +3107,10 @@ w32_shift_glyphs_for_insert (f, x, y, width, height, shift_by)
for X frames. */
static void
-x_delete_glyphs (n)
+x_delete_glyphs (f, n)
+ struct frame *f;
register int n;
{
- struct frame *f;
-
- if (updating_frame)
- f = updating_frame;
- else
- f = SELECTED_FRAME ();
-
if (! FRAME_W32_P (f))
return;
@@ -3130,15 +3122,8 @@ x_delete_glyphs (n)
frame. Otherwise clear the selected frame. */
static void
-x_clear_frame ()
+x_clear_frame (struct frame *f)
{
- struct frame *f;
-
- if (updating_frame)
- f = updating_frame;
- else
- f = SELECTED_FRAME ();
-
if (! FRAME_W32_P (f))
return;
@@ -3165,18 +3150,14 @@ x_clear_frame ()
/* Make audible bell. */
static void
-w32_ring_bell (void)
+w32_ring_bell (struct frame *f)
{
- struct frame *f;
-
- f = SELECTED_FRAME ();
-
BLOCK_INPUT;
if (FRAME_W32_P (f) && visible_bell)
{
int i;
- HWND hwnd = FRAME_W32_WINDOW (SELECTED_FRAME ());
+ HWND hwnd = FRAME_W32_WINDOW (f);
for (i = 0; i < 5; i++)
{
@@ -3186,7 +3167,7 @@ w32_ring_bell (void)
FlashWindow (hwnd, FALSE);
}
else
- w32_sys_ring_bell ();
+ w32_sys_ring_bell (f);
UNBLOCK_INPUT;
}
@@ -3213,16 +3194,10 @@ w32_set_terminal_window (n)
lines or deleting -N lines at vertical position VPOS. */
static void
-x_ins_del_lines (vpos, n)
+x_ins_del_lines (f, vpos, n)
+ struct frame *f;
int vpos, n;
{
- struct frame *f;
-
- if (updating_frame)
- f = updating_frame;
- else
- f = SELECTED_FRAME ();
-
if (! FRAME_W32_P (f))
return;
@@ -3627,7 +3602,8 @@ construct_mouse_wheel (result, msg, f)
POINT p;
int delta;
- result->kind = WHEEL_EVENT;
+ result->kind = msg->msg.message == WM_MOUSEHWHEEL ? HORIZ_WHEEL_EVENT
+ : WHEEL_EVENT;
result->code = 0;
result->timestamp = msg->msg.time;
@@ -4859,7 +4835,13 @@ w32_read_socket (sd, expected, hold_quit)
only when it is active. */
if (WINDOWP(window)
&& !EQ (window, last_window)
- && !EQ (window, selected_window))
+ && !EQ (window, selected_window)
+ /* For click-to-focus window managers
+ create event iff we don't leave the
+ selected frame. */
+ && (focus_follows_mouse
+ || (EQ (XWINDOW (window)->frame,
+ XWINDOW (selected_window)->frame))))
{
inev.kind = SELECT_WINDOW_EVENT;
inev.frame_or_window = window;
@@ -4964,6 +4946,7 @@ w32_read_socket (sd, expected, hold_quit)
}
case WM_MOUSEWHEEL:
+ case WM_MOUSEHWHEEL:
{
if (dpyinfo->grabbed && last_mouse_frame
&& FRAME_LIVE_P (last_mouse_frame))
@@ -6478,8 +6461,8 @@ x_free_frame_resources (f)
free_frame_menubar (f);
- unload_color (f, f->output_data.x->foreground_pixel);
- unload_color (f, f->output_data.x->background_pixel);
+ unload_color (f, FRAME_FOREGROUND_PIXEL (f));
+ unload_color (f, FRAME_BACKGROUND_PIXEL (f));
unload_color (f, f->output_data.w32->cursor_pixel);
unload_color (f, f->output_data.w32->cursor_foreground_pixel);
unload_color (f, f->output_data.w32->border_pixel);
@@ -6518,14 +6501,13 @@ x_free_frame_resources (f)
/* Destroy the window of frame F. */
-
+void
x_destroy_window (f)
struct frame *f;
{
struct w32_display_info *dpyinfo = FRAME_W32_DISPLAY_INFO (f);
x_free_frame_resources (f);
-
dpyinfo->reference_count--;
}
@@ -6785,6 +6767,132 @@ w32_make_rdb (xrm_option)
return buffer;
}
+void
+x_flush (struct frame * f)
+{ /* Nothing to do */ }
+
+
+extern frame_parm_handler w32_frame_parm_handlers[];
+
+static struct redisplay_interface w32_redisplay_interface =
+{
+ w32_frame_parm_handlers,
+ x_produce_glyphs,
+ x_write_glyphs,
+ x_insert_glyphs,
+ x_clear_end_of_line,
+ x_scroll_run,
+ x_after_update_window_line,
+ x_update_window_begin,
+ x_update_window_end,
+ x_cursor_to,
+ x_flush,
+ 0, /* flush_display_optional */
+ x_clear_window_mouse_face,
+ w32_get_glyph_overhangs,
+ x_fix_overlapping_area,
+ w32_draw_fringe_bitmap,
+ w32_define_fringe_bitmap,
+ w32_destroy_fringe_bitmap,
+ w32_per_char_metric,
+ w32_encode_char,
+ NULL, /* w32_compute_glyph_string_overhangs */
+ x_draw_glyph_string,
+ w32_define_frame_cursor,
+ w32_clear_frame_area,
+ w32_draw_window_cursor,
+ w32_draw_vertical_window_border,
+ w32_shift_glyphs_for_insert
+};
+
+static void x_delete_terminal (struct terminal *term);
+
+static struct terminal *
+w32_create_terminal (struct w32_display_info *dpyinfo)
+{
+ struct terminal *terminal;
+
+ terminal = create_terminal ();
+
+ terminal->type = output_w32;
+ terminal->display_info.w32 = dpyinfo;
+ dpyinfo->terminal = terminal;
+
+ /* MSVC does not type K&R functions with no arguments correctly, and
+ so we must explicitly cast them. */
+ terminal->clear_frame_hook = x_clear_frame;
+ terminal->ins_del_lines_hook = x_ins_del_lines;
+ terminal->delete_glyphs_hook = x_delete_glyphs;
+ terminal->ring_bell_hook = w32_ring_bell;
+ terminal->reset_terminal_modes_hook = w32_reset_terminal_modes;
+ terminal->set_terminal_modes_hook = w32_set_terminal_modes;
+ terminal->update_begin_hook = x_update_begin;
+ terminal->update_end_hook = x_update_end;
+ terminal->set_terminal_window_hook = w32_set_terminal_window;
+ terminal->read_socket_hook = w32_read_socket;
+ terminal->frame_up_to_date_hook = w32_frame_up_to_date;
+ terminal->mouse_position_hook = w32_mouse_position;
+ terminal->frame_rehighlight_hook = w32_frame_rehighlight;
+ terminal->frame_raise_lower_hook = w32_frame_raise_lower;
+ // terminal->fullscreen_hook = XTfullscreen_hook;
+ terminal->set_vertical_scroll_bar_hook = w32_set_vertical_scroll_bar;
+ terminal->condemn_scroll_bars_hook = w32_condemn_scroll_bars;
+ terminal->redeem_scroll_bar_hook = w32_redeem_scroll_bar;
+ terminal->judge_scroll_bars_hook = w32_judge_scroll_bars;
+
+ terminal->delete_frame_hook = x_destroy_window;
+ terminal->delete_terminal_hook = x_delete_terminal;
+
+ terminal->rif = &w32_redisplay_interface;
+ terminal->scroll_region_ok = 1; /* We'll scroll partial frames. */
+ terminal->char_ins_del_ok = 1;
+ terminal->line_ins_del_ok = 1; /* We'll just blt 'em. */
+ terminal->fast_clear_end_of_line = 1; /* X does this well. */
+ terminal->memory_below_frame = 0; /* We don't remember what scrolls
+ off the bottom. */
+
+#ifdef MULTI_KBOARD
+ /* We don't yet support separate terminals on W32, so don't try to share
+ keyboards between virtual terminals that are on the same physical
+ terminal like X does. */
+ terminal->kboard = (KBOARD *) xmalloc (sizeof (KBOARD));
+ init_kboard (terminal->kboard);
+ terminal->kboard->next_kboard = all_kboards;
+ all_kboards = terminal->kboard;
+ /* Don't let the initial kboard remain current longer than necessary.
+ That would cause problems if a file loaded on startup tries to
+ prompt in the mini-buffer. */
+ if (current_kboard == initial_kboard)
+ current_kboard = terminal->kboard;
+ terminal->kboard->reference_count++;
+#endif
+
+ return terminal;
+}
+
+static void
+x_delete_terminal (struct terminal *terminal)
+{
+ struct w32_display_info *dpyinfo = terminal->display_info.w32;
+ int i;
+
+ /* Protect against recursive calls. Fdelete_frame in
+ delete_terminal calls us back when it deletes our last frame. */
+ if (!terminal->name)
+ return;
+
+ BLOCK_INPUT;
+ /* Free the fonts in the font table. */
+ for (i = 0; i < dpyinfo->n_fonts; i++)
+ if (dpyinfo->font_table[i].name)
+ {
+ DeleteObject (((XFontStruct*)(dpyinfo->font_table[i].font))->hfont);
+ }
+
+ x_delete_display (dpyinfo);
+ UNBLOCK_INPUT;
+}
+
struct w32_display_info *
w32_term_init (display_name, xrm_option, resource_name)
Lisp_Object display_name;
@@ -6792,6 +6900,7 @@ w32_term_init (display_name, xrm_option, resource_name)
char *resource_name;
{
struct w32_display_info *dpyinfo;
+ struct terminal *terminal;
HDC hdc;
BLOCK_INPUT;
@@ -6805,6 +6914,12 @@ w32_term_init (display_name, xrm_option, resource_name)
w32_initialize_display_info (display_name);
dpyinfo = &one_w32_display_info;
+ terminal = w32_create_terminal (dpyinfo);
+
+ /* Set the name of the terminal. */
+ terminal->name = (char *) xmalloc (SBYTES (display_name) + 1);
+ strncpy (terminal->name, SDATA (display_name), SBYTES (display_name));
+ terminal->name[SBYTES (display_name)] = 0;
dpyinfo->xrdb = xrm_option ? w32_make_rdb (xrm_option) : NULL;
@@ -6834,6 +6949,9 @@ w32_term_init (display_name, xrm_option, resource_name)
w32_defined_color (0, "black", &color, 1);
}
+ /* Add the default keyboard. */
+ add_keyboard_wait_descriptor (0);
+
/* Create Fringe Bitmaps and store them for later use.
On W32, bitmaps are all unsigned short, as Windows requires
@@ -6841,7 +6959,7 @@ w32_term_init (display_name, xrm_option, resource_name)
horizontally reflected compared to how they appear on X, so we
need to bitswap and convert to unsigned shorts before creating
the bitmaps. */
- w32_init_fringe ();
+ w32_init_fringe (terminal->rif);
#ifndef F_SETOWN_BUG
#ifdef F_SETOWN
@@ -6865,7 +6983,6 @@ w32_term_init (display_name, xrm_option, resource_name)
}
/* Get rid of display DPYINFO, assuming all frames are already gone. */
-
void
x_delete_display (dpyinfo)
struct w32_display_info *dpyinfo;
@@ -6916,73 +7033,9 @@ x_delete_display (dpyinfo)
DWORD WINAPI w32_msg_worker (void * arg);
-void
-x_flush (struct frame * f)
-{ /* Nothing to do */ }
-
-extern frame_parm_handler w32_frame_parm_handlers[];
-
-static struct redisplay_interface w32_redisplay_interface =
-{
- w32_frame_parm_handlers,
- x_produce_glyphs,
- x_write_glyphs,
- x_insert_glyphs,
- x_clear_end_of_line,
- x_scroll_run,
- x_after_update_window_line,
- x_update_window_begin,
- x_update_window_end,
- x_cursor_to,
- x_flush,
- 0, /* flush_display_optional */
- x_clear_window_mouse_face,
- w32_get_glyph_overhangs,
- x_fix_overlapping_area,
- w32_draw_fringe_bitmap,
- w32_define_fringe_bitmap,
- w32_destroy_fringe_bitmap,
- w32_per_char_metric,
- w32_encode_char,
- NULL, /* w32_compute_glyph_string_overhangs */
- x_draw_glyph_string,
- w32_define_frame_cursor,
- w32_clear_frame_area,
- w32_draw_window_cursor,
- w32_draw_vertical_window_border,
- w32_shift_glyphs_for_insert
-};
-
static void
w32_initialize ()
{
- rif = &w32_redisplay_interface;
-
- /* MSVC does not type K&R functions with no arguments correctly, and
- so we must explicitly cast them. */
- clear_frame_hook = (void (*)(void)) x_clear_frame;
- ring_bell_hook = (void (*)(void)) w32_ring_bell;
- update_begin_hook = x_update_begin;
- update_end_hook = x_update_end;
-
- read_socket_hook = w32_read_socket;
-
- frame_up_to_date_hook = w32_frame_up_to_date;
-
- mouse_position_hook = w32_mouse_position;
- frame_rehighlight_hook = w32_frame_rehighlight;
- frame_raise_lower_hook = w32_frame_raise_lower;
- set_vertical_scroll_bar_hook = w32_set_vertical_scroll_bar;
- condemn_scroll_bars_hook = w32_condemn_scroll_bars;
- redeem_scroll_bar_hook = w32_redeem_scroll_bar;
- judge_scroll_bars_hook = w32_judge_scroll_bars;
-
- scroll_region_ok = 1; /* we'll scroll partial frames */
- char_ins_del_ok = 1;
- line_ins_del_ok = 1; /* we'll just blt 'em */
- fast_clear_end_of_line = 1; /* X does this well */
- memory_below_frame = 0; /* we don't remember what scrolls
- off the bottom */
baud_rate = 19200;
w32_system_caret_hwnd = NULL;
diff --git a/src/w32term.h b/src/w32term.h
index cea3110ff8..f5aff57622 100644
--- a/src/w32term.h
+++ b/src/w32term.h
@@ -100,6 +100,9 @@ struct w32_display_info
/* Chain of all w32_display_info structures. */
struct w32_display_info *next;
+ /* The generic display parameters corresponding to this w32 display. */
+ struct terminal *terminal;
+
/* This is a cons cell of the form (NAME . FONT-LIST-CACHE).
The same cons cell also appears in x_display_name_list. */
Lisp_Object name_list_element;
@@ -274,8 +277,10 @@ extern Lisp_Object x_get_font_repertory P_ ((struct frame *,
diffs between X and w32 code. */
struct x_output
{
+#if 0 /* These are also defined in struct frame. Use that instead. */
PIX_TYPE background_pixel;
PIX_TYPE foreground_pixel;
+#endif
/* Keep track of focus. May be EXPLICIT if we received a FocusIn for this
frame, or IMPLICIT if we received an EnterNotify.
@@ -411,8 +416,6 @@ extern struct w32_output w32term_display;
#define FRAME_W32_WINDOW(f) ((f)->output_data.w32->window_desc)
#define FRAME_X_WINDOW(f) ((f)->output_data.w32->window_desc)
-#define FRAME_FOREGROUND_PIXEL(f) ((f)->output_data.x->foreground_pixel)
-#define FRAME_BACKGROUND_PIXEL(f) ((f)->output_data.x->background_pixel)
#define FRAME_FONT(f) ((f)->output_data.w32->font)
#define FRAME_FONTSET(f) ((f)->output_data.w32->fontset)
#define FRAME_BASELINE_OFFSET(f) ((f)->output_data.w32->baseline_offset)
@@ -600,10 +603,10 @@ do { \
} while (0)
#define w32_clear_rect(f,hdc,lprect) \
-w32_fill_rect (f,hdc,f->output_data.x->background_pixel,lprect)
+ w32_fill_rect (f, hdc, FRAME_BACKGROUND_PIXEL (f), lprect)
#define w32_clear_area(f,hdc,px,py,nx,ny) \
-w32_fill_area (f,hdc,f->output_data.x->background_pixel,px,py,nx,ny)
+ w32_fill_area (f, hdc, FRAME_BACKGROUND_PIXEL (f), px, py, nx, ny)
extern struct font_info *w32_load_font ();
extern void w32_unload_font ();
@@ -619,6 +622,9 @@ extern void w32_unload_font ();
#define WM_XBUTTONDOWN (WM_MOUSEWHEEL + 1)
#define WM_XBUTTONUP (WM_MOUSEWHEEL + 2)
#endif /* WM_XBUTTONDOWN */
+#ifndef WM_MOUSEHWHEEL
+#define WM_MOUSEHWHEEL (WM_MOUSEWHEEL + 4)
+#endif /* WM_MOUSEHWHEEL */
#define WM_EMACS_START (WM_USER + 1)
#define WM_EMACS_KILL (WM_EMACS_START + 0)
@@ -698,6 +704,9 @@ extern void wait_for_sync ();
extern BOOL parse_button ();
+extern void w32_sys_ring_bell (struct frame *f);
+extern void x_delete_display (struct w32_display_info *dpyinfo);
+
/* Keypad command key support. W32 doesn't have virtual keys defined
for the function keys on the keypad (they are mapped to the standard
fuction keys), so we define our own. */
diff --git a/src/widget.c b/src/widget.c
index 714da205a6..c76cce9e32 100644
--- a/src/widget.c
+++ b/src/widget.c
@@ -659,10 +659,10 @@ update_from_various_frame_slots (ew)
struct x_output *x = f->output_data.x;
ew->core.height = FRAME_PIXEL_HEIGHT (f) - x->menubar_height;
ew->core.width = FRAME_PIXEL_WIDTH (f);
- ew->core.background_pixel = x->background_pixel;
+ ew->core.background_pixel = FRAME_BACKGROUND_PIXEL (f);
ew->emacs_frame.internal_border_width = f->internal_border_width;
ew->emacs_frame.font = x->font;
- ew->emacs_frame.foreground_pixel = x->foreground_pixel;
+ ew->emacs_frame.foreground_pixel = FRAME_FOREGROUND_PIXEL (f);
ew->emacs_frame.cursor_color = x->cursor_pixel;
ew->core.border_pixel = x->border_pixel;
}
diff --git a/src/window.c b/src/window.c
index 43ea423dd9..c51649679d 100644
--- a/src/window.c
+++ b/src/window.c
@@ -21,6 +21,8 @@ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
#include <config.h>
+#include <stdio.h>
+
#include "lisp.h"
#include "buffer.h"
#include "keyboard.h"
@@ -34,6 +36,7 @@ Boston, MA 02110-1301, USA. */
#include "dispextern.h"
#include "blockinput.h"
#include "intervals.h"
+#include "termhooks.h" /* For FRAME_TERMINAL. */
#ifdef HAVE_X_WINDOWS
#include "xterm.h"
@@ -190,6 +193,10 @@ Lisp_Object Qtemp_buffer_show_hook;
EMACS_INT split_height_threshold;
+/* How to split windows (horizontally/vertically/hybrid). */
+
+Lisp_Object Vsplit_window_preferred_function;
+
/* Number of lines of continuity in scrolling by screenfuls. */
EMACS_INT next_screen_context_lines;
@@ -1788,12 +1795,28 @@ candidate_window_p (window, owindow, minibuf, all_frames)
else if (EQ (all_frames, Qvisible))
{
FRAME_SAMPLE_VISIBILITY (f);
- candidate_p = FRAME_VISIBLE_P (f);
+ candidate_p = FRAME_VISIBLE_P (f)
+ && (FRAME_TERMINAL (XFRAME (w->frame))
+ == FRAME_TERMINAL (XFRAME (selected_frame)));
+
}
else if (INTEGERP (all_frames) && XINT (all_frames) == 0)
{
FRAME_SAMPLE_VISIBILITY (f);
- candidate_p = FRAME_VISIBLE_P (f) || FRAME_ICONIFIED_P (f);
+ candidate_p = (FRAME_VISIBLE_P (f) || FRAME_ICONIFIED_P (f)
+#ifdef HAVE_X_WINDOWS
+ /* Yuck!! If we've just created the frame and the
+ window-manager requested the user to place it
+ manually, the window may still not be considered
+ `visible'. I'd argue it should be at least
+ something like `iconified', but don't know how to do
+ that yet. --Stef */
+ || (FRAME_X_P (f) && f->output_data.x->asked_for_visible
+ && !f->output_data.x->has_been_visible)
+#endif
+ )
+ && (FRAME_TERMINAL (XFRAME (w->frame))
+ == FRAME_TERMINAL (XFRAME (selected_frame)));
}
else if (WINDOWP (all_frames))
candidate_p = (EQ (FRAME_MINIBUF_WINDOW (f), all_frames)
@@ -2162,8 +2185,10 @@ window_loop (type, obj, mini, frames)
if (NILP (best_window))
best_window = window;
else if (EQ (window, selected_window))
- /* For compatibility with 20.x, prefer to return
- selected-window. */
+ /* Prefer to return selected-window. */
+ RETURN_UNGCPRO (window);
+ else if (EQ (Fwindow_frame (window), selected_frame))
+ /* Prefer windows on the current frame. */
best_window = window;
}
break;
@@ -3445,6 +3470,22 @@ selects the buffer of the selected window before each command. */)
if (EQ (window, selected_window))
return window;
+ sf = SELECTED_FRAME ();
+ if (XFRAME (WINDOW_FRAME (w)) != sf)
+ {
+ XFRAME (WINDOW_FRAME (w))->selected_window = window;
+ /* Use this rather than Fhandle_switch_frame
+ so that FRAME_FOCUS_FRAME is moved appropriately as we
+ move around in the state where a minibuffer in a separate
+ frame is active. */
+ Fselect_frame (WINDOW_FRAME (w));
+ /* Fselect_frame called us back so we've done all the work already. */
+ eassert (EQ (window, selected_window));
+ return window;
+ }
+ else
+ sf->selected_window = window;
+
/* Store the current buffer's actual point into the
old selected window. It belongs to that window,
and when the window is not selected, must be in the window. */
@@ -3458,18 +3499,6 @@ selects the buffer of the selected window before each command. */)
}
selected_window = window;
- sf = SELECTED_FRAME ();
- if (XFRAME (WINDOW_FRAME (w)) != sf)
- {
- XFRAME (WINDOW_FRAME (w))->selected_window = window;
- /* Use this rather than Fhandle_switch_frame
- so that FRAME_FOCUS_FRAME is moved appropriately as we
- move around in the state where a minibuffer in a separate
- frame is active. */
- Fselect_frame (WINDOW_FRAME (w));
- }
- else
- sf->selected_window = window;
if (NILP (norecord))
record_buffer (w->buffer);
@@ -3649,7 +3678,7 @@ If `even-window-heights' is non-nil, window heights will be evened out
if displaying the buffer causes two vertically adjacent windows to be
displayed. */)
(buffer, not_this_window, frame)
- register Lisp_Object buffer, not_this_window, frame;
+ Lisp_Object buffer, not_this_window, frame;
{
register Lisp_Object window, tem, swp;
struct frame *f;
@@ -3721,6 +3750,8 @@ displayed. */)
|| !NILP (XWINDOW (FRAME_ROOT_WINDOW (f))->dedicated))
{
Lisp_Object frames;
+ struct gcpro gcpro1;
+ GCPRO1 (buffer);
frames = Qnil;
if (FRAME_MINIBUF_ONLY_P (f))
@@ -3752,26 +3783,26 @@ displayed. */)
if (!NILP (window)
&& ! FRAME_NO_SPLIT_P (XFRAME (XWINDOW (window)->frame))
&& WINDOW_FULL_WIDTH_P (XWINDOW (window))
- && (window_height (window) >= split_height_threshold
- || (NILP (XWINDOW (window)->parent)))
+ && (window_height (window) >= split_height_threshold
+ || (NILP (XWINDOW (window)->parent)))
&& (window_height (window)
>= (2 * window_min_size_2 (XWINDOW (window), 0))))
- window = Fsplit_window (window, Qnil, Qnil);
+ window = call1 (Vsplit_window_preferred_function, window);
else
{
Lisp_Object upper, other;
window = Fget_lru_window (frames, Qt);
- /* If the LRU window is tall enough, and either eligible for splitting
- and selected or the only window, split it. */
+ /* If the LRU window is tall enough, and either eligible for
+ splitting and selected or the only window, split it. */
if (!NILP (window)
&& ! FRAME_NO_SPLIT_P (XFRAME (XWINDOW (window)->frame))
- && ((EQ (window, selected_window)
- && window_height (window) >= split_height_threshold)
- || (NILP (XWINDOW (window)->parent)))
- && (window_height (window)
- >= (2 * window_min_size_2 (XWINDOW (window), 0))))
- window = Fsplit_window (window, Qnil, Qnil);
+ && ((EQ (window, selected_window)
+ && window_height (window) >= split_height_threshold)
+ || (NILP (XWINDOW (window)->parent)))
+ && (window_height (window)
+ >= (2 * window_min_size_2 (XWINDOW (window), 0))))
+ window = call1 (Vsplit_window_preferred_function, window);
else
window = Fget_lru_window (frames, Qnil);
/* If Fget_lru_window returned nil, try other approaches. */
@@ -3817,6 +3848,7 @@ displayed. */)
0);
}
}
+ UNGCPRO;
}
else
window = Fget_lru_window (Qnil, Qnil);
@@ -6017,7 +6049,7 @@ zero means top of window, negative means relative to bottom of window. */)
struct save_window_data
{
- EMACS_INT size_from_Lisp_Vector_struct;
+ EMACS_UINT size;
struct Lisp_Vector *next_from_Lisp_Vector_struct;
Lisp_Object frame_cols, frame_lines, frame_menu_bar_lines;
Lisp_Object frame_tool_bar_lines;
@@ -6040,7 +6072,7 @@ struct save_window_data
struct saved_window
{
/* these first two must agree with struct Lisp_Vector in lisp.h */
- EMACS_INT size_from_Lisp_Vector_struct;
+ EMACS_UINT size;
struct Lisp_Vector *next_from_Lisp_Vector_struct;
Lisp_Object window;
@@ -6631,6 +6663,7 @@ redirection (see `redirect-frame-focus'). */)
n_windows = count_windows (XWINDOW (FRAME_ROOT_WINDOW (f)));
vec = allocate_other_vector (VECSIZE (struct save_window_data));
+ XSETPVECTYPE (vec, PVEC_WINDOW_CONFIGURATION);
data = (struct save_window_data *)vec;
XSETFASTINT (data->frame_cols, FRAME_COLS (f));
@@ -7102,11 +7135,12 @@ freeze_window_start (w, freeze_p)
struct window *w;
void *freeze_p;
{
- if (w == XWINDOW (selected_window)
- || MINI_WINDOW_P (w)
- || (MINI_WINDOW_P (XWINDOW (selected_window))
- && ! NILP (Vminibuf_scroll_window)
- && w == XWINDOW (Vminibuf_scroll_window)))
+ if (MINI_WINDOW_P (w)
+ || (WINDOWP (selected_window) /* Can be nil in corner cases. */
+ && (w == XWINDOW (selected_window)
+ || (MINI_WINDOW_P (XWINDOW (selected_window))
+ && ! NILP (Vminibuf_scroll_window)
+ && w == XWINDOW (Vminibuf_scroll_window)))))
freeze_p = NULL;
w->frozen_window_start_p = freeze_p != NULL;
@@ -7269,7 +7303,7 @@ and scrolling positions. */)
void
init_window_once ()
{
- struct frame *f = make_terminal_frame ();
+ struct frame *f = make_initial_frame ();
XSETFRAME (selected_frame, f);
Vterminal_frame = selected_frame;
minibuf_window = f->minibuffer_window;
@@ -7488,6 +7522,15 @@ by `display-buffer'. The value is in line units.
If there is only one window, it is split regardless of this value. */);
split_height_threshold = 500;
+ DEFVAR_LISP ("split-window-preferred-function",
+ &Vsplit_window_preferred_function,
+ doc: /* Function to use to split a window.
+This is used by `display-buffer' to allow the user to choose whether
+to split windows horizontally or vertically or some mix of the two.
+It is called with a window as single argument and should split it in two
+and return the new window. */);
+ Vsplit_window_preferred_function = intern ("split-window");
+
DEFVAR_INT ("window-min-height", &window_min_height,
doc: /* *Delete any window less than this tall (including its mode line).
The value is in line units. */);
diff --git a/src/window.h b/src/window.h
index ea8965392c..3b9107acaa 100644
--- a/src/window.h
+++ b/src/window.h
@@ -92,7 +92,7 @@ struct window
{
/* The first two fields are really the header of a vector */
/* The window code does not refer to them. */
- EMACS_INT size;
+ EMACS_UINT size;
struct Lisp_Vector *vec_next;
/* The frame this window is on. */
Lisp_Object frame;
@@ -744,7 +744,7 @@ extern Lisp_Object Vminibuf_scroll_window;
/* Nil or a symbol naming the window system under which emacs is
running ('x is the only current possibility) */
-extern Lisp_Object Vwindow_system;
+extern Lisp_Object Vinitial_window_system;
/* Version number of X windows: 10, 11 or nil. */
diff --git a/src/xdisp.c b/src/xdisp.c
index 3a85ef9dd2..e146fde4c1 100644
--- a/src/xdisp.c
+++ b/src/xdisp.c
@@ -587,21 +587,12 @@ Lisp_Object Vmessage_log_max;
static Lisp_Object Vmessages_buffer_name;
-/* Index 0 is the buffer that holds the current (desired) echo area message,
- or nil if none is desired right now.
-
- Index 1 is the buffer that holds the previously displayed echo area message,
- or nil to indicate no message. This is normally what's on the screen now.
-
- These two can point to the same buffer. That happens when the last
- message output by the user (or made by echoing) has been displayed. */
+/* Current, index 0, and last displayed echo area message. Either
+ buffers from echo_buffers, or nil to indicate no message. */
Lisp_Object echo_area_buffer[2];
-/* Permanent pointers to the two buffers that are used for echo area
- purposes. Once the two buffers are made, and their pointers are
- placed here, these two slots remain unchanged unless those buffers
- need to be created afresh. */
+/* The buffers referenced from echo_area_buffer. */
static Lisp_Object echo_buffer[2];
@@ -822,10 +813,6 @@ static int clear_face_cache_count;
static int clear_image_cache_count;
#endif
-/* Record the previous terminal frame we displayed. */
-
-static struct frame *previous_terminal_frame;
-
/* Non-zero while redisplay_internal is in progress. */
int redisplaying_p;
@@ -2525,7 +2512,7 @@ init_iterator (it, w, charpos, bytepos, row, base_face_id)
XSETWINDOW (it->window, w);
it->w = w;
it->f = XFRAME (w->frame);
-
+
/* Extra space between lines (on window systems only). */
if (base_face_id == DEFAULT_FACE_ID
&& FRAME_WINDOW_P (it->f))
@@ -2542,9 +2529,9 @@ init_iterator (it, w, charpos, bytepos, row, base_face_id)
/* If realized faces have been removed, e.g. because of face
attribute changes of named faces, recompute them. When running
- in batch mode, the face cache of Vterminal_frame is null. If
+ in batch mode, the face cache of the initial frame is null. If
we happen to get called, make a dummy face cache. */
- if (noninteractive && FRAME_FACE_CACHE (it->f) == NULL)
+ if (FRAME_FACE_CACHE (it->f) == NULL)
init_frame_faces (it->f);
if (FRAME_FACE_CACHE (it->f)->used == 0)
recompute_basic_faces (it->f);
@@ -3639,7 +3626,8 @@ handle_invisible_prop (it)
}
else
{
- int invis_p, newpos, next_stop, start_charpos;
+ int invis_p;
+ EMACS_INT newpos, next_stop, start_charpos;
Lisp_Object pos, prop, overlay;
/* First of all, is there invisible text at this position? */
@@ -3969,7 +3957,7 @@ handle_single_display_spec (it, spec, object, position,
&& EQ (XCAR (spec), Qheight)
&& CONSP (XCDR (spec)))
{
- if (FRAME_TERMCAP_P (it->f) || FRAME_MSDOS_P (it->f))
+ if (!FRAME_WINDOW_P (it->f))
return 0;
it->font_height = XCAR (XCDR (spec));
@@ -4035,7 +4023,7 @@ handle_single_display_spec (it, spec, object, position,
&& EQ (XCAR (spec), Qspace_width)
&& CONSP (XCDR (spec)))
{
- if (FRAME_TERMCAP_P (it->f) || FRAME_MSDOS_P (it->f))
+ if (!FRAME_WINDOW_P (it->f))
return 0;
value = XCAR (XCDR (spec));
@@ -4051,7 +4039,7 @@ handle_single_display_spec (it, spec, object, position,
{
Lisp_Object tem;
- if (FRAME_TERMCAP_P (it->f) || FRAME_MSDOS_P (it->f))
+ if (!FRAME_WINDOW_P (it->f))
return 0;
if (tem = XCDR (spec), CONSP (tem))
@@ -4077,7 +4065,7 @@ handle_single_display_spec (it, spec, object, position,
&& EQ (XCAR (spec), Qraise)
&& CONSP (XCDR (spec)))
{
- if (FRAME_TERMCAP_P (it->f) || FRAME_MSDOS_P (it->f))
+ if (!FRAME_WINDOW_P (it->f))
return 0;
#ifdef HAVE_WINDOW_SYSTEM
@@ -4118,7 +4106,7 @@ handle_single_display_spec (it, spec, object, position,
int face_id = DEFAULT_FACE_ID;
int fringe_bitmap;
- if (FRAME_TERMCAP_P (it->f) || FRAME_MSDOS_P (it->f))
+ if (!FRAME_WINDOW_P (it->f))
/* If we return here, POSITION has been advanced
across the text with this property. */
return 0;
@@ -4167,7 +4155,7 @@ handle_single_display_spec (it, spec, object, position,
it->left_user_fringe_face_id = face_id;
}
else
- {
+ {
it->right_user_fringe_bitmap = fringe_bitmap;
it->right_user_fringe_face_id = face_id;
}
@@ -4212,9 +4200,9 @@ handle_single_display_spec (it, spec, object, position,
valid_p = (STRINGP (value)
#ifdef HAVE_WINDOW_SYSTEM
- || (!FRAME_TERMCAP_P (it->f) && valid_image_p (value))
+ || (FRAME_WINDOW_P (it->f) && valid_image_p (value))
#endif /* not HAVE_WINDOW_SYSTEM */
- || (CONSP (value) && EQ (XCAR (value), Qspace)));
+ || (CONSP (value) && EQ (XCAR (value), Qspace)));
if (valid_p && !display_replaced_before_p)
{
@@ -4284,7 +4272,7 @@ handle_single_display_spec (it, spec, object, position,
}
-/* Check if SPEC is a display specification value whose text should be
+/* Check if SPEC is a display sub-property value whose text should be
treated as intangible. */
static int
@@ -7695,8 +7683,8 @@ message2_nolog (m, nbytes, multibyte)
do_pending_window_change (0);
echo_area_display (1);
do_pending_window_change (0);
- if (frame_up_to_date_hook != 0 && ! gc_in_progress)
- (*frame_up_to_date_hook) (f);
+ if (FRAME_TERMINAL (f)->frame_up_to_date_hook != 0 && ! gc_in_progress)
+ (*FRAME_TERMINAL (f)->frame_up_to_date_hook) (f);
}
}
@@ -7799,8 +7787,8 @@ message3_nolog (m, nbytes, multibyte)
do_pending_window_change (0);
echo_area_display (1);
do_pending_window_change (0);
- if (frame_up_to_date_hook != 0 && ! gc_in_progress)
- (*frame_up_to_date_hook) (f);
+ if (FRAME_TERMINAL (f)->frame_up_to_date_hook != 0 && ! gc_in_progress)
+ (*FRAME_TERMINAL (f)->frame_up_to_date_hook) (f);
}
}
@@ -8038,6 +8026,10 @@ ensure_echo_area_buffers ()
WHICH > 0 means use echo_area_buffer[1]. If that is nil, choose a
suitable buffer from echo_buffer[] and clear it.
+ If WHICH < 0, set echo_area_buffer[1] to echo_area_buffer[0], so
+ that the current message becomes the last displayed one, make
+ choose a suitable buffer for echo_area_buffer[0], and clear it.
+
Value is what FN returns. */
static int
@@ -8062,6 +8054,17 @@ with_echo_area_buffer (w, which, fn, a1, a2, a3, a4)
this_one = 0, the_other = 1;
else if (which > 0)
this_one = 1, the_other = 0;
+ else
+ {
+ this_one = 0, the_other = 1;
+ clear_buffer_p = 1;
+
+ /* We need a fresh one in case the current echo buffer equals
+ the one containing the last displayed echo area message. */
+ if (!NILP (echo_area_buffer[this_one])
+ && EQ (echo_area_buffer[this_one], echo_area_buffer[the_other]))
+ echo_area_buffer[this_one] = Qnil;
+ }
/* Choose a suitable buffer from echo_buffer[] is we don't
have one. */
@@ -8699,7 +8702,7 @@ set_message (s, string, nbytes, multibyte_p)
= ((s && multibyte_p)
|| (STRINGP (string) && STRING_MULTIBYTE (string)));
- with_echo_area_buffer (0, 0, set_message_1,
+ with_echo_area_buffer (0, -1, set_message_1,
(EMACS_INT) s, string, nbytes, multibyte_p);
message_buf_print = 0;
help_echo_showing_p = 0;
@@ -8729,7 +8732,6 @@ set_message_1 (a1, a2, nbytes, multibyte_p)
/* Insert new message at BEG. */
TEMP_SET_PT_BOTH (BEG, BEG_BYTE);
- Ferase_buffer ();
if (STRINGP (string))
{
@@ -8826,11 +8828,11 @@ clear_garbaged_frames ()
{
Lisp_Object tail, frame;
int changed_count = 0;
-
+
FOR_EACH_FRAME (tail, frame)
{
struct frame *f = XFRAME (frame);
-
+
if (FRAME_VISIBLE_P (f) && FRAME_GARBAGED_P (f))
{
if (f->resized_p)
@@ -8844,7 +8846,7 @@ clear_garbaged_frames ()
f->resized_p = 0;
}
}
-
+
frame_garbaged = 0;
if (changed_count)
++windows_or_buffers_changed;
@@ -8877,11 +8879,10 @@ echo_area_display (update_frame_p)
/* The terminal frame is used as the first Emacs frame on the Mac OS. */
#ifndef MAC_OS8
#ifdef HAVE_WINDOW_SYSTEM
- /* When Emacs starts, selected_frame may be a visible terminal
- frame, even if we run under a window system. If we let this
- through, a message would be displayed on the terminal. */
- if (EQ (selected_frame, Vterminal_frame)
- && !NILP (Vwindow_system))
+ /* When Emacs starts, selected_frame may be the initial terminal
+ frame. If we let this through, a message would be displayed on
+ the terminal. */
+ if (FRAME_INITIAL_P (XFRAME (selected_frame)))
return 0;
#endif /* HAVE_WINDOW_SYSTEM */
#endif
@@ -8932,7 +8933,7 @@ echo_area_display (update_frame_p)
Can do with a display update of the echo area,
unless we displayed some mode lines. */
update_single_window (w, 1);
- rif->flush_display (f);
+ FRAME_RIF (f)->flush_display (f);
}
else
update_frame (f, 1, 1);
@@ -8947,8 +8948,10 @@ echo_area_display (update_frame_p)
else if (!EQ (mini_window, selected_window))
windows_or_buffers_changed++;
- /* The current message is now also the last one displayed. */
+ /* Last displayed message is now the current message. */
echo_area_buffer[1] = echo_area_buffer[0];
+ /* Inform read_char that we're not echoing. */
+ echo_message_buffer = Qnil;
/* Prevent redisplay optimization in redisplay_internal by resetting
this_line_start_pos. This is done because the mini-buffer now
@@ -9502,8 +9505,8 @@ x_cursor_to (vpos, hpos, y, x)
{
BLOCK_INPUT;
display_and_set_cursor (w, 1, hpos, vpos, x, y);
- if (rif->flush_display_optional)
- rif->flush_display_optional (SELECTED_FRAME ());
+ if (FRAME_RIF (SELECTED_FRAME ())->flush_display_optional)
+ FRAME_RIF (SELECTED_FRAME ())->flush_display_optional (SELECTED_FRAME ());
UNBLOCK_INPUT;
}
}
@@ -10955,6 +10958,8 @@ select_frame_for_redisplay (frame)
Lisp_Object tail, sym, val;
Lisp_Object old = selected_frame;
+ xassert (FRAMEP (frame) && FRAME_LIVE_P (XFRAME (frame)));
+
selected_frame = frame;
for (tail = XFRAME (frame)->param_alist; CONSP (tail); tail = XCDR (tail))
@@ -11011,6 +11016,7 @@ redisplay_internal (preserve_echo_area)
int count, count1;
struct frame *sf;
int polling_stopped_here = 0;
+ Lisp_Object old_frame = selected_frame;
/* Non-zero means redisplay has to consider all windows on all
frames. Zero means, only selected_window is considered. */
@@ -11072,6 +11078,14 @@ redisplay_internal (preserve_echo_area)
}
retry:
+ if (!EQ (old_frame, selected_frame)
+ && FRAME_LIVE_P (XFRAME (old_frame)))
+ /* When running redisplay, we play a bit fast-and-loose and allow e.g.
+ selected_frame and selected_window to be temporarily out-of-sync so
+ when we come back here via `goto retry', we need to resync because we
+ may need to run Elisp code (via prepare_menu_bars). */
+ select_frame_for_redisplay (old_frame);
+
pause = 0;
reconsider_clip_changes (w, current_buffer);
last_escape_glyph_frame = NULL;
@@ -11092,17 +11106,16 @@ redisplay_internal (preserve_echo_area)
if (face_change_count)
++windows_or_buffers_changed;
- if (! FRAME_WINDOW_P (sf)
- && previous_terminal_frame != sf)
+ if (FRAME_TERMCAP_P (sf)
+ && FRAME_TTY (sf)->previous_frame != sf)
{
- /* Since frames on an ASCII terminal share the same display
- area, displaying a different frame means redisplay the whole
- thing. */
+ /* Since frames on a single ASCII terminal share the same
+ display area, displaying a different frame means redisplay
+ the whole thing. */
windows_or_buffers_changed++;
SET_FRAME_GARBAGED (sf);
- XSETFRAME (Vterminal_frame, sf);
+ FRAME_TTY (sf)->previous_frame = sf;
}
- previous_terminal_frame = sf;
/* Set the visible flags for all frames. Do this before checking
for resized or garbaged frames; they want to know if their frames
@@ -11124,6 +11137,7 @@ redisplay_internal (preserve_echo_area)
}
}
+
/* Notice any pending interrupt request to change frame size. */
do_pending_window_change (1);
@@ -11485,7 +11499,7 @@ redisplay_internal (preserve_echo_area)
{
struct frame *f = XFRAME (frame);
- if (FRAME_WINDOW_P (f) || f == sf)
+ if (FRAME_WINDOW_P (f) || FRAME_TERMCAP_P (f) || f == sf)
{
if (! EQ (frame, selected_frame))
/* Select the frame, for the sake of frame-local
@@ -11494,16 +11508,16 @@ redisplay_internal (preserve_echo_area)
/* Mark all the scroll bars to be removed; we'll redeem
the ones we want when we redisplay their windows. */
- if (condemn_scroll_bars_hook)
- condemn_scroll_bars_hook (f);
+ if (FRAME_TERMINAL (f)->condemn_scroll_bars_hook)
+ FRAME_TERMINAL (f)->condemn_scroll_bars_hook (f);
if (FRAME_VISIBLE_P (f) && !FRAME_OBSCURED_P (f))
redisplay_windows (FRAME_ROOT_WINDOW (f));
/* Any scroll bars which redisplay_windows should have
nuked should now go away. */
- if (judge_scroll_bars_hook)
- judge_scroll_bars_hook (f);
+ if (FRAME_TERMINAL (f)->judge_scroll_bars_hook)
+ FRAME_TERMINAL (f)->judge_scroll_bars_hook (f);
/* If fonts changed, display again. */
/* ??? rms: I suspect it is a mistake to jump all the way
@@ -11550,12 +11564,12 @@ redisplay_internal (preserve_echo_area)
FOR_EACH_FRAME (tail, frame)
{
struct frame *f = XFRAME (frame);
- if (f->updated_p)
- {
- mark_window_display_accurate (f->root_window, 1);
- if (frame_up_to_date_hook)
- frame_up_to_date_hook (f);
- }
+ if (f->updated_p)
+ {
+ mark_window_display_accurate (f->root_window, 1);
+ if (FRAME_TERMINAL (f)->frame_up_to_date_hook)
+ FRAME_TERMINAL (f)->frame_up_to_date_hook (f);
+ }
}
}
}
@@ -11640,8 +11654,8 @@ redisplay_internal (preserve_echo_area)
/* Say overlay arrows are up to date. */
update_overlay_arrows (1);
- if (frame_up_to_date_hook != 0)
- frame_up_to_date_hook (sf);
+ if (FRAME_TERMINAL (sf)->frame_up_to_date_hook != 0)
+ FRAME_TERMINAL (sf)->frame_up_to_date_hook (sf);
}
update_mode_lines = 0;
@@ -11751,8 +11765,9 @@ redisplay_preserve_echo_area (from_where)
else
redisplay_internal (1);
- if (rif != NULL && rif->flush_display_optional)
- rif->flush_display_optional (NULL);
+ if (FRAME_RIF (SELECTED_FRAME ()) != NULL
+ && FRAME_RIF (SELECTED_FRAME ())->flush_display_optional)
+ FRAME_RIF (SELECTED_FRAME ())->flush_display_optional (NULL);
}
@@ -11760,7 +11775,8 @@ redisplay_preserve_echo_area (from_where)
redisplay_internal. Reset redisplaying_p to the value it had
before redisplay_internal was called, and clear
prevent_freeing_realized_faces_p. It also selects the previously
- selected frame. */
+ selected frame, unless it has been deleted (by an X connection
+ failure during redisplay, for example). */
static Lisp_Object
unwind_redisplay (val)
@@ -11771,7 +11787,8 @@ unwind_redisplay (val)
old_redisplaying_p = XCAR (val);
redisplaying_p = XFASTINT (old_redisplaying_p);
old_frame = XCDR (val);
- if (! EQ (old_frame, selected_frame))
+ if (! EQ (old_frame, selected_frame)
+ && FRAME_LIVE_P (XFRAME (old_frame)))
select_frame_for_redisplay (old_frame);
return Qnil;
}
@@ -12909,7 +12926,9 @@ set_vertical_scroll_bar (w)
start = end = whole = 0;
/* Indicate what this scroll bar ought to be displaying now. */
- set_vertical_scroll_bar_hook (w, end - start, whole, start);
+ if (FRAME_TERMINAL (XFRAME (w->frame))->set_vertical_scroll_bar_hook)
+ (*FRAME_TERMINAL (XFRAME (w->frame))->set_vertical_scroll_bar_hook)
+ (w, end - start, whole, start);
}
@@ -13628,20 +13647,22 @@ redisplay_window (window, just_this_one_p)
display_menu_bar (w);
#ifdef HAVE_WINDOW_SYSTEM
+ if (FRAME_WINDOW_P (f))
+ {
#if defined (USE_GTK) || USE_MAC_TOOLBAR
- redisplay_tool_bar_p = FRAME_EXTERNAL_TOOL_BAR (f);
+ redisplay_tool_bar_p = FRAME_EXTERNAL_TOOL_BAR (f);
#else
- redisplay_tool_bar_p = WINDOWP (f->tool_bar_window)
- && (FRAME_TOOL_BAR_LINES (f) > 0
- || !NILP (Vauto_resize_tool_bars));
-
+ redisplay_tool_bar_p = WINDOWP (f->tool_bar_window)
+ && (FRAME_TOOL_BAR_LINES (f) > 0
+ || !NILP (Vauto_resize_tool_bars));
#endif
- if (redisplay_tool_bar_p && redisplay_tool_bar (f))
- {
- extern int ignore_mouse_drag_p;
- ignore_mouse_drag_p = 1;
- }
+ if (redisplay_tool_bar_p && redisplay_tool_bar (f))
+ {
+ extern int ignore_mouse_drag_p;
+ ignore_mouse_drag_p = 1;
+ }
+ }
#endif
}
@@ -13675,7 +13696,8 @@ redisplay_window (window, just_this_one_p)
/* Note that we actually used the scroll bar attached to this
window, so it shouldn't be deleted at the end of redisplay. */
- redeem_scroll_bar_hook (w);
+ if (FRAME_TERMINAL (f)->redeem_scroll_bar_hook)
+ (*FRAME_TERMINAL (f)->redeem_scroll_bar_hook) (w);
}
/* Restore current_buffer and value of point in it. */
@@ -13944,10 +13966,10 @@ try_window_reusing_current_matrix (w)
if (run.height > 0 && run.current_y != run.desired_y)
{
update_begin (f);
- rif->update_window_begin_hook (w);
- rif->clear_window_mouse_face (w);
- rif->scroll_run_hook (w, &run);
- rif->update_window_end_hook (w, 0, 0);
+ FRAME_RIF (f)->update_window_begin_hook (w);
+ FRAME_RIF (f)->clear_window_mouse_face (w);
+ FRAME_RIF (f)->scroll_run_hook (w, &run);
+ FRAME_RIF (f)->update_window_end_hook (w, 0, 0);
update_end (f);
}
@@ -14116,10 +14138,10 @@ try_window_reusing_current_matrix (w)
if (run.height)
{
update_begin (f);
- rif->update_window_begin_hook (w);
- rif->clear_window_mouse_face (w);
- rif->scroll_run_hook (w, &run);
- rif->update_window_end_hook (w, 0, 0);
+ FRAME_RIF (f)->update_window_begin_hook (w);
+ FRAME_RIF (f)->clear_window_mouse_face (w);
+ FRAME_RIF (f)->scroll_run_hook (w, &run);
+ FRAME_RIF (f)->update_window_end_hook (w, 0, 0);
update_end (f);
}
@@ -14569,7 +14591,7 @@ try_window_id (w)
/* Window must either use window-based redisplay or be full width. */
if (!FRAME_WINDOW_P (f)
- && (!line_ins_del_ok
+ && (!FRAME_LINE_INS_DEL_OK (f)
|| !WINDOW_FULL_WIDTH_P (w)))
GIVE_UP (4);
@@ -14978,10 +15000,10 @@ try_window_id (w)
if (FRAME_WINDOW_P (f))
{
- rif->update_window_begin_hook (w);
- rif->clear_window_mouse_face (w);
- rif->scroll_run_hook (w, &run);
- rif->update_window_end_hook (w, 0, 0);
+ FRAME_RIF (f)->update_window_begin_hook (w);
+ FRAME_RIF (f)->clear_window_mouse_face (w);
+ FRAME_RIF (f)->scroll_run_hook (w, &run);
+ FRAME_RIF (f)->update_window_end_hook (w, 0, 0);
}
else
{
@@ -14999,36 +15021,36 @@ try_window_id (w)
{
/* Scroll last_unchanged_at_beg_row to the end of the
window down dvpos lines. */
- set_terminal_window (end);
+ set_terminal_window (f, end);
/* On dumb terminals delete dvpos lines at the end
before inserting dvpos empty lines. */
- if (!scroll_region_ok)
- ins_del_lines (end - dvpos, -dvpos);
+ if (!FRAME_SCROLL_REGION_OK (f))
+ ins_del_lines (f, end - dvpos, -dvpos);
/* Insert dvpos empty lines in front of
last_unchanged_at_beg_row. */
- ins_del_lines (from, dvpos);
+ ins_del_lines (f, from, dvpos);
}
else if (dvpos < 0)
{
/* Scroll up last_unchanged_at_beg_vpos to the end of
the window to last_unchanged_at_beg_vpos - |dvpos|. */
- set_terminal_window (end);
+ set_terminal_window (f, end);
/* Delete dvpos lines in front of
last_unchanged_at_beg_vpos. ins_del_lines will set
the cursor to the given vpos and emit |dvpos| delete
line sequences. */
- ins_del_lines (from + dvpos, dvpos);
+ ins_del_lines (f, from + dvpos, dvpos);
/* On a dumb terminal insert dvpos empty lines at the
end. */
- if (!scroll_region_ok)
- ins_del_lines (end + dvpos, -dvpos);
+ if (!FRAME_SCROLL_REGION_OK (f))
+ ins_del_lines (f, end + dvpos, -dvpos);
}
- set_terminal_window (0);
+ set_terminal_window (f, 0);
}
update_end (f);
@@ -16602,7 +16624,7 @@ display_menu_bar (w)
/* Don't do all this for graphical frames. */
#ifdef HAVE_NTGUI
- if (!NILP (Vwindow_system))
+ if (FRAME_W32_P (f))
return;
#endif
#if defined (USE_X_TOOLKIT) || defined (USE_GTK)
@@ -16833,10 +16855,10 @@ display_mode_line (w, face_id, format)
/* Temporarily make frame's keyboard the current kboard so that
kboard-local variables in the mode_line_format will get the right
values. */
- push_frame_kboard (it.f);
+ push_kboard (FRAME_KBOARD (it.f));
record_unwind_save_match_data ();
display_mode_element (&it, 0, 0, 0, format, Qnil, 0);
- pop_frame_kboard ();
+ pop_kboard ();
unbind_to (count, Qnil);
@@ -17551,9 +17573,9 @@ are the selected window and the window's buffer). */)
= (NILP (face) ? Qnil : Fcons (Qface, Fcons (face, Qnil)));
}
- push_frame_kboard (it.f);
+ push_kboard (FRAME_KBOARD (it.f));
display_mode_element (&it, 0, 0, 0, format, Qnil, 0);
- pop_frame_kboard ();
+ pop_kboard ();
if (no_props)
{
@@ -18704,6 +18726,8 @@ calc_pixel_width_or_height (res, it, prop, font, width_p, align_to)
if (NILP (prop))
return OK_PIXELS (0);
+ xassert (FRAME_LIVE_P (it->f));
+
if (SYMBOLP (prop))
{
if (SCHARS (SYMBOL_NAME (prop)) == 2)
@@ -18820,7 +18844,8 @@ calc_pixel_width_or_height (res, it, prop, font, width_p, align_to)
if (SYMBOLP (car))
{
#ifdef HAVE_WINDOW_SYSTEM
- if (valid_image_p (prop))
+ if (FRAME_WINDOW_P (it->f)
+ && valid_image_p (prop))
{
int id = lookup_image (it->f, prop);
struct image *img = IMAGE_FROM_ID (it->f, id);
@@ -19070,7 +19095,7 @@ get_char_face_and_encoding (f, c, face_id, char2b, multibyte_p, display_p)
else
STORE_XCHAR2B (char2b, (code >> 8), (code & 0xFF));
/* Maybe encode the character in *CHAR2B. */
- rif->encode_char (c, char2b, font_info, charset, NULL);
+ FRAME_RIF (f)->encode_char (c, char2b, font_info, charset, NULL);
}
/* Make sure X resources of the face are allocated. */
@@ -19151,8 +19176,8 @@ get_glyph_face_and_encoding (f, glyph, char2b, two_byte_p)
if (CHARSET_ID (charset) != charset_ascii)
{
glyph->font_type
- = rif->encode_char (glyph->u.ch, char2b, font_info, charset,
- two_byte_p);
+ = FRAME_RIF (f)->encode_char (glyph->u.ch, char2b, font_info,
+ charset, two_byte_p);
}
}
}
@@ -19407,7 +19432,8 @@ fill_stretch_glyph_string (s, row, area, start, end)
}
static XCharStruct *
-get_per_char_metric (font, font_info, char2b, font_type)
+get_per_char_metric (f, font, font_info, char2b, font_type)
+ struct frame *f;
XFontStruct *font;
struct font_info *font_info;
XChar2b *char2b;
@@ -19433,7 +19459,7 @@ get_per_char_metric (font, font_info, char2b, font_type)
return &pcm_value;
}
#endif /* USE_FONT_BACKEND */
- return rif->per_char_metric (font, char2b, font_type);
+ return FRAME_RIF (f)->per_char_metric (font, char2b, font_type);
}
/* EXPORT for RIF:
@@ -19461,7 +19487,7 @@ x_get_glyph_overhangs (glyph, f, left, right)
font = face->font;
font_info = FONT_INFO_FROM_FACE (f, face);
if (font /* ++KFS: Should this be font_info ? */
- && (pcm = get_per_char_metric (font, font_info, &char2b, glyph->font_type)))
+ && (pcm = get_per_char_metric (f, font, font_info, &char2b, glyph->font_type)))
{
if (pcm->rbearing > pcm->width)
*right = pcm->rbearing - pcm->width;
@@ -19589,6 +19615,70 @@ right_overwriting (s)
}
+/* Get face and two-byte form of character C in face FACE_ID on frame
+ F. The encoding of C is returned in *CHAR2B. MULTIBYTE_P non-zero
+ means we want to display multibyte text. DISPLAY_P non-zero means
+ make sure that X resources for the face returned are allocated.
+ Value is a pointer to a realized face that is ready for display if
+ DISPLAY_P is non-zero. */
+
+static INLINE struct face *
+get_char_face_and_encoding (f, c, face_id, char2b, multibyte_p, display_p)
+ struct frame *f;
+ int c, face_id;
+ XChar2b *char2b;
+ int multibyte_p, display_p;
+{
+ struct face *face = FACE_FROM_ID (f, face_id);
+
+ if (!multibyte_p)
+ {
+ /* Unibyte case. We don't have to encode, but we have to make
+ sure to use a face suitable for unibyte. */
+ STORE_XCHAR2B (char2b, 0, c);
+ face_id = FACE_FOR_CHAR (f, face, c);
+ face = FACE_FROM_ID (f, face_id);
+ }
+ else if (c < 128)
+ {
+ /* Case of ASCII in a face known to fit ASCII. */
+ STORE_XCHAR2B (char2b, 0, c);
+ }
+ else
+ {
+ int c1, c2, charset;
+
+ /* Split characters into bytes. If c2 is -1 afterwards, C is
+ really a one-byte character so that byte1 is zero. */
+ SPLIT_CHAR (c, charset, c1, c2);
+ if (c2 > 0)
+ STORE_XCHAR2B (char2b, c1, c2);
+ else
+ STORE_XCHAR2B (char2b, 0, c1);
+
+ /* Maybe encode the character in *CHAR2B. */
+ if (face->font != NULL)
+ {
+ struct font_info *font_info
+ = FONT_INFO_FROM_ID (f, face->font_info_id);
+ if (font_info)
+ FRAME_RIF (f)->encode_char (c, char2b, font_info, 0);
+ }
+ }
+
+ /* Make sure X resources of the face are allocated. */
+#ifdef HAVE_X_WINDOWS
+ if (display_p)
+#endif
+ {
+ xassert (face != NULL);
+ PREPARE_FACE_FOR_DISPLAY (f, face);
+ }
+
+ return face;
+}
+
+
/* Set background width of glyph string S. START is the index of the
first glyph following S. LAST_X is the right-most x-position + 1
in the drawing area. */
@@ -19635,8 +19725,8 @@ compute_overhangs_and_x (s, x, backward_p)
{
while (s)
{
- if (rif->compute_glyph_string_overhangs)
- rif->compute_glyph_string_overhangs (s);
+ if (FRAME_RIF (s->f)->compute_glyph_string_overhangs)
+ FRAME_RIF (s->f)->compute_glyph_string_overhangs (s);
x -= s->width;
s->x = x;
s = s->prev;
@@ -19646,8 +19736,8 @@ compute_overhangs_and_x (s, x, backward_p)
{
while (s)
{
- if (rif->compute_glyph_string_overhangs)
- rif->compute_glyph_string_overhangs (s);
+ if (FRAME_RIF (s->f)->compute_glyph_string_overhangs)
+ FRAME_RIF (s->f)->compute_glyph_string_overhangs (s);
s->x = x;
x += s->width;
s = s->next;
@@ -19923,9 +20013,9 @@ draw_glyphs (w, x, row, area, start, end, hl, overlaps)
struct glyph_string *h, *t;
/* Compute overhangs for all glyph strings. */
- if (rif->compute_glyph_string_overhangs)
+ if (FRAME_RIF (f)->compute_glyph_string_overhangs)
for (s = head; s; s = s->next)
- rif->compute_glyph_string_overhangs (s);
+ FRAME_RIF (f)->compute_glyph_string_overhangs (s);
/* Prepend glyph strings for glyphs in front of the first glyph
string that are overwritten because of the first glyph
@@ -20004,7 +20094,7 @@ draw_glyphs (w, x, row, area, start, end, hl, overlaps)
/* Draw all strings. */
for (s = head; s; s = s->next)
- rif->draw_glyph_string (s);
+ FRAME_RIF (f)->draw_glyph_string (s);
if (area == TEXT_AREA
&& !row->full_width_p
@@ -20693,20 +20783,20 @@ x_produce_glyphs (it)
it->nglyphs = 1;
- pcm = get_per_char_metric (font, font_info, &char2b,
- FONT_TYPE_FOR_UNIBYTE (font, it->char_to_display));
-
- if (it->override_ascent >= 0)
- {
- it->ascent = it->override_ascent;
- it->descent = it->override_descent;
- boff = it->override_boff;
- }
- else
- {
- it->ascent = FONT_BASE (font) + boff;
- it->descent = FONT_DESCENT (font) - boff;
- }
+ pcm = get_per_char_metric (it->f, font, font_info, &char2b,
+ FONT_TYPE_FOR_UNIBYTE (font, it->char_to_display));
+
+ if (it->override_ascent >= 0)
+ {
+ it->ascent = it->override_ascent;
+ it->descent = it->override_descent;
+ boff = it->override_boff;
+ }
+ else
+ {
+ it->ascent = FONT_BASE (font) + boff;
+ it->descent = FONT_DESCENT (font) - boff;
+ }
if (pcm)
{
@@ -20924,8 +21014,8 @@ x_produce_glyphs (it)
multiplying the width of font by the width of the
character. */
- pcm = get_per_char_metric (font, font_info, &char2b,
- FONT_TYPE_FOR_MULTIBYTE (font, it->c));
+ pcm = get_per_char_metric (it->f, font, font_info, &char2b,
+ FONT_TYPE_FOR_MULTIBYTE (font, it->c));
if (font_not_found_p || !pcm)
{
@@ -21073,7 +21163,7 @@ x_produce_glyphs (it)
{
get_char_face_and_encoding (it->f, c, it->face_id,
&char2b, it->multibyte_p, 0);
- pcm = get_per_char_metric (font, font_info, &char2b,
+ pcm = get_per_char_metric (it->f, font, font_info, &char2b,
FONT_TYPE_FOR_MULTIBYTE (font, c));
}
@@ -21140,7 +21230,7 @@ x_produce_glyphs (it)
this_boff = VCENTER_BASELINE_OFFSET (font, it->f) - boff;
get_char_face_and_encoding (it->f, ch, face_id,
&char2b, it->multibyte_p, 0);
- pcm = get_per_char_metric (font, font_info, &char2b,
+ pcm = get_per_char_metric (it->f, font, font_info, &char2b,
FONT_TYPE_FOR_MULTIBYTE (font,
ch));
}
@@ -21417,8 +21507,8 @@ x_insert_glyphs (start, len)
frame_x = window_box_left (w, updated_area) + output_cursor.x;
frame_y = WINDOW_TO_FRAME_PIXEL_Y (w, output_cursor.y);
- rif->shift_glyphs_for_insert (f, frame_x, frame_y, shifted_region_width,
- line_height, shift_by_width);
+ FRAME_RIF (f)->shift_glyphs_for_insert (f, frame_x, frame_y, shifted_region_width,
+ line_height, shift_by_width);
/* Write the glyphs. */
hpos = start - row->glyphs[updated_area];
@@ -21500,8 +21590,8 @@ x_clear_end_of_line (to_x)
if (to_x > from_x && to_y > from_y)
{
BLOCK_INPUT;
- rif->clear_frame_area (f, from_x, from_y,
- to_x - from_x, to_y - from_y);
+ FRAME_RIF (f)->clear_frame_area (f, from_x, from_y,
+ to_x - from_x, to_y - from_y);
UNBLOCK_INPUT;
}
}
@@ -21644,7 +21734,7 @@ get_window_cursor_type (w, glyph, width, active_cursor)
non_selected = 1;
}
- /* Nonselected window or nonselected frame. */
+ /* Detect a nonselected window or nonselected frame. */
else if (w != XWINDOW (f->selected_window)
#ifdef HAVE_WINDOW_SYSTEM
|| f != FRAME_X_DISPLAY_INFO (f)->x_highlight_frame
@@ -21663,13 +21753,6 @@ get_window_cursor_type (w, glyph, width, active_cursor)
if (NILP (b->cursor_type))
return NO_CURSOR;
- /* Use cursor-in-non-selected-windows for non-selected window or frame. */
- if (non_selected)
- {
- alt_cursor = b->cursor_in_non_selected_windows;
- return get_specified_cursor_type (alt_cursor, width);
- }
-
/* Get the normal cursor type for this window. */
if (EQ (b->cursor_type, Qt))
{
@@ -21679,6 +21762,21 @@ get_window_cursor_type (w, glyph, width, active_cursor)
else
cursor_type = get_specified_cursor_type (b->cursor_type, width);
+ /* Use cursor-in-non-selected-windows instead
+ for non-selected window or frame. */
+ if (non_selected)
+ {
+ alt_cursor = b->cursor_in_non_selected_windows;
+ if (!EQ (Qt, alt_cursor))
+ return get_specified_cursor_type (alt_cursor, width);
+ /* t means modify the normal cursor type. */
+ if (cursor_type == FILLED_BOX_CURSOR)
+ cursor_type = HOLLOW_BOX_CURSOR;
+ else if (cursor_type == BAR_CURSOR && *width > 1)
+ --*width;
+ return cursor_type;
+ }
+
/* Use normal cursor if not blinked off. */
if (!w->cursor_off_p)
{
@@ -22014,7 +22112,7 @@ erase_phys_cursor (w)
x = WINDOW_TEXT_TO_FRAME_PIXEL_X (w, max (x, left_x));
if (width > 0)
- rif->clear_frame_area (f, x, y, width, cursor_row->visible_height);
+ FRAME_RIF (f)->clear_frame_area (f, x, y, width, cursor_row->visible_height);
}
/* Erase the cursor by redrawing the character underneath it. */
@@ -22111,9 +22209,9 @@ display_and_set_cursor (w, on, hpos, vpos, x, y)
w->phys_cursor.vpos = vpos;
}
- rif->draw_window_cursor (w, glyph_row, x, y,
- new_cursor_type, new_cursor_width,
- on, active_cursor);
+ FRAME_RIF (f)->draw_window_cursor (w, glyph_row, x, y,
+ new_cursor_type, new_cursor_width,
+ on, active_cursor);
}
@@ -22262,11 +22360,11 @@ show_mouse_face (dpyinfo, draw)
/* Change the mouse cursor. */
if (draw == DRAW_NORMAL_TEXT && !EQ (dpyinfo->mouse_face_window, f->tool_bar_window))
- rif->define_frame_cursor (f, FRAME_X_OUTPUT (f)->text_cursor);
+ FRAME_RIF (f)->define_frame_cursor (f, FRAME_X_OUTPUT (f)->text_cursor);
else if (draw == DRAW_MOUSE_FACE)
- rif->define_frame_cursor (f, FRAME_X_OUTPUT (f)->hand_cursor);
+ FRAME_RIF (f)->define_frame_cursor (f, FRAME_X_OUTPUT (f)->hand_cursor);
else
- rif->define_frame_cursor (f, FRAME_X_OUTPUT (f)->nontext_cursor);
+ FRAME_RIF (f)->define_frame_cursor (f, FRAME_X_OUTPUT (f)->nontext_cursor);
}
/* EXPORT:
@@ -22705,7 +22803,6 @@ on_hot_spot_p (hot_spot, x, y)
return inside;
}
}
- /* If we don't understand the format, pretend we're not in the hot-spot. */
return 0;
}
@@ -22785,7 +22882,7 @@ define_frame_cursor1 (f, cursor, pointer)
}
if (cursor != No_Cursor)
- rif->define_frame_cursor (f, cursor);
+ FRAME_RIF (f)->define_frame_cursor (f, cursor);
}
/* Take proper action when mouse has moved to the mode or header line
@@ -23756,8 +23853,8 @@ phys_cursor_in_rect_p (w, r)
I assume the effect is the same -- and this is portable. */
return x_intersect_rectangles (&cr, r, &result);
}
- else
- return 0;
+ /* If we don't understand the format, pretend we're not in the hot-spot. */
+ return 0;
}
@@ -23769,6 +23866,8 @@ void
x_draw_vertical_border (w)
struct window *w;
{
+ struct frame *f = XFRAME (WINDOW_FRAME (w));
+
/* We could do better, if we knew what type of scroll-bar the adjacent
windows (on either side) have... But we don't :-(
However, I think this works ok. ++KFS 2003-04-25 */
@@ -23789,9 +23888,9 @@ x_draw_vertical_border (w)
y1 -= 1;
if (WINDOW_LEFT_FRINGE_WIDTH (w) == 0)
- x1 -= 1;
+ x1 -= 1;
- rif->draw_vertical_window_border (w, x1, y0, y1);
+ FRAME_RIF (f)->draw_vertical_window_border (w, x1, y0, y1);
}
else if (!WINDOW_LEFTMOST_P (w)
&& !WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT (w))
@@ -23802,9 +23901,9 @@ x_draw_vertical_border (w)
y1 -= 1;
if (WINDOW_LEFT_FRINGE_WIDTH (w) == 0)
- x0 -= 1;
+ x0 -= 1;
- rif->draw_vertical_window_border (w, x0, y0, y1);
+ FRAME_RIF (f)->draw_vertical_window_border (w, x0, y0, y1);
}
}
@@ -24500,7 +24599,10 @@ Any other value means to autoselect window instantaneously when the
mouse pointer enters it.
Autoselection selects the minibuffer only if it is active, and never
-unselects the minibuffer if it is active. */);
+unselects the minibuffer if it is active.
+
+When customizing this variable make sure that the actual value of
+`focus-follows-mouse' matches the behavior of your window manager. */);
Vmouse_autoselect_window = Qnil;
DEFVAR_LISP ("auto-resize-tool-bars", &Vauto_resize_tool_bars,
diff --git a/src/xfaces.c b/src/xfaces.c
index c21d0a1cd5..298e9e52d5 100644
--- a/src/xfaces.c
+++ b/src/xfaces.c
@@ -197,12 +197,14 @@ Boston, MA 02110-1301, USA. */
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
+#include <stdio.h> /* This needs to be before termchar.h */
#include "lisp.h"
#include "character.h"
#include "charset.h"
#include "keyboard.h"
#include "frame.h"
+#include "termhooks.h"
#ifdef HAVE_WINDOW_SYSTEM
#include "fontset.h"
@@ -245,6 +247,7 @@ Boston, MA 02110-1301, USA. */
#include "blockinput.h"
#include "window.h"
#include "intervals.h"
+#include "termchar.h"
#ifdef HAVE_WINDOW_SYSTEM
#ifdef USE_FONT_BACKEND
@@ -273,8 +276,6 @@ Boston, MA 02110-1301, USA. */
#include <ctype.h>
-#define abs(X) ((X) < 0 ? -(X) : (X))
-
/* Number of pt per inch (from the TeXbook). */
#define PT_PER_INCH 72.27
@@ -751,10 +752,9 @@ x_free_gc (f, gc)
struct frame *f;
GC gc;
{
- BLOCK_INPUT;
+ eassert (interrupt_input_blocked);
IF_DEBUG (xassert (--ngcs >= 0));
XFreeGC (FRAME_X_DISPLAY (f), gc);
- UNBLOCK_INPUT;
}
#endif /* HAVE_X_WINDOWS */
@@ -784,10 +784,8 @@ x_free_gc (f, gc)
struct frame *f;
GC gc;
{
- BLOCK_INPUT;
IF_DEBUG (xassert (--ngcs >= 0));
xfree (gc);
- UNBLOCK_INPUT;
}
#endif /* WINDOWSNT */
@@ -814,10 +812,9 @@ x_free_gc (f, gc)
struct frame *f;
GC gc;
{
- BLOCK_INPUT;
+ eassert (interrupt_input_blocked);
IF_DEBUG (xassert (--ngcs >= 0));
XFreeGC (FRAME_MAC_DISPLAY (f), gc);
- UNBLOCK_INPUT;
}
#endif /* MAC_OS */
@@ -1269,8 +1266,10 @@ load_face_font (f, face)
face->overstrike = needs_overstrike;
if (face->gc)
{
+ BLOCK_INPUT;
x_free_gc (f, face->gc);
face->gc = 0;
+ UNBLOCK_INPUT;
}
}
else
@@ -3347,6 +3346,22 @@ push_named_merge_point (struct named_merge_point *new_named_merge_point,
+#if 0 /* Seems to be unused. */
+static Lisp_Object
+internal_resolve_face_name (nargs, args)
+ int nargs;
+ Lisp_Object *args;
+{
+ return Fget (args[0], args[1]);
+}
+
+static Lisp_Object
+resolve_face_name_error (ignore)
+ Lisp_Object ignore;
+{
+ return Qnil;
+}
+#endif
/* Resolve face name FACE_NAME. If FACE_NAME is a string, intern it
to make it a symbol. If FACE_NAME is an alias for another face,
@@ -5561,8 +5576,10 @@ free_realized_face (f, face)
if (enable_font_backend && face->font_info)
font_done_for_face (f, face);
#endif /* USE_FONT_BACKEND */
+ BLOCK_INPUT;
x_free_gc (f, face->gc);
face->gc = 0;
+ UNBLOCK_INPUT;
}
free_face_colors (f, face);
@@ -5734,8 +5751,10 @@ clear_face_gcs (c)
if (enable_font_backend && face->font_info)
font_done_for_face (c->f, face);
#endif /* USE_FONT_BACKEND */
+ BLOCK_INPUT;
x_free_gc (c->f, face->gc);
face->gc = 0;
+ UNBLOCK_INPUT;
}
}
#endif /* HAVE_WINDOW_SYSTEM */
@@ -6470,7 +6489,7 @@ tty_supports_face_attributes_p (f, attrs, def_face)
val = attrs[LFACE_INVERSE_INDEX];
if (!UNSPECIFIEDP (val))
{
- if (face_attr_equal_p (val, def_attrs[LFACE_UNDERLINE_INDEX]))
+ if (face_attr_equal_p (val, def_attrs[LFACE_INVERSE_INDEX]))
return 0; /* same as default */
else
test_caps |= TTY_CAP_INVERSE;
@@ -6513,7 +6532,7 @@ tty_supports_face_attributes_p (f, attrs, def_face)
bg = attrs[LFACE_BACKGROUND_INDEX];
if (STRINGP (bg))
{
- Lisp_Object def_bg = def_attrs[LFACE_FOREGROUND_INDEX];
+ Lisp_Object def_bg = def_attrs[LFACE_BACKGROUND_INDEX];
if (face_attr_equal_p (bg, def_bg))
return 0; /* same as default */
@@ -6551,7 +6570,7 @@ tty_supports_face_attributes_p (f, attrs, def_face)
/* See if the capabilities we selected above are supported, with the
given colors. */
if (test_caps != 0 &&
- ! tty_capable_p (f, test_caps, fg_tty_color.pixel, bg_tty_color.pixel))
+ ! tty_capable_p (FRAME_TTY (f), test_caps, fg_tty_color.pixel, bg_tty_color.pixel))
return 0;
@@ -7394,7 +7413,8 @@ realize_basic_faces (f)
{
FRAME_FACE_CACHE (f)->menu_face_changed_p = 0;
#ifdef USE_X_TOOLKIT
- x_update_menu_appearance (f);
+ if (FRAME_WINDOW_P (f))
+ x_update_menu_appearance (f);
#endif
}
@@ -7496,7 +7516,7 @@ realize_default_face (f)
LFACE_FOREGROUND (lface) = XCDR (color);
else if (FRAME_WINDOW_P (f))
return 0;
- else if (FRAME_TERMCAP_P (f) || FRAME_MSDOS_P (f))
+ else if (FRAME_INITIAL_P (f) || FRAME_TERMCAP_P (f) || FRAME_MSDOS_P (f))
LFACE_FOREGROUND (lface) = build_string (unspecified_fg);
else
abort ();
@@ -7511,7 +7531,7 @@ realize_default_face (f)
LFACE_BACKGROUND (lface) = XCDR (color);
else if (FRAME_WINDOW_P (f))
return 0;
- else if (FRAME_TERMCAP_P (f) || FRAME_MSDOS_P (f))
+ else if (FRAME_INITIAL_P (f) || FRAME_TERMCAP_P (f) || FRAME_MSDOS_P (f))
LFACE_BACKGROUND (lface) = build_string (unspecified_bg);
else
abort ();
@@ -7528,17 +7548,17 @@ realize_default_face (f)
#ifdef HAVE_WINDOW_SYSTEM
#ifdef HAVE_X_WINDOWS
- if (face->font != FRAME_FONT (f))
+ if (FRAME_X_P (f) && face->font != FRAME_FONT (f))
{
/* This can happen when making a frame on a display that does
- not support the default font. */
+ not support the default font. */
if (!face->font)
- return 0;
-
+ return 0;
+
/* Otherwise, the font specified for the frame was not
- acceptable as a font for the default face (perhaps because
- auto-scaled fonts are rejected), so we must adjust the frame
- font. */
+ acceptable as a font for the default face (perhaps because
+ auto-scaled fonts are rejected), so we must adjust the frame
+ font. */
x_set_font (f, build_string (face->font_name), Qnil);
}
#endif /* HAVE_X_WINDOWS */
@@ -7614,6 +7634,11 @@ realize_face (cache, attrs, former_face_id)
face = realize_x_face (cache, attrs);
else if (FRAME_TERMCAP_P (cache->f) || FRAME_MSDOS_P (cache->f))
face = realize_tty_face (cache, attrs);
+ else if (FRAME_INITIAL_P (cache->f))
+ {
+ /* Create a dummy face. */
+ face = make_realized_face (attrs);
+ }
else
abort ();
diff --git a/src/xfns.c b/src/xfns.c
index 52cbd758d8..54d637d859 100644
--- a/src/xfns.c
+++ b/src/xfns.c
@@ -48,6 +48,7 @@ Boston, MA 02110-1301, USA. */
#include "systime.h"
#include "termhooks.h"
#include "atimer.h"
+#include "termchar.h"
#ifdef USE_FONT_BACKEND
#include "font.h"
@@ -260,17 +261,18 @@ check_x_frame (frame)
return f;
}
-/* Let the user specify an X display with a frame.
+/* Let the user specify an X display with a Lisp object.
+ OBJECT may be nil, a frame or a terminal id.
nil stands for the selected frame--or, if that is not an X frame,
the first X display on the list. */
struct x_display_info *
-check_x_display_info (frame)
- Lisp_Object frame;
+check_x_display_info (object)
+ Lisp_Object object;
{
struct x_display_info *dpyinfo = NULL;
- if (NILP (frame))
+ if (NILP (object))
{
struct frame *sf = XFRAME (selected_frame);
@@ -281,11 +283,20 @@ check_x_display_info (frame)
else
error ("X windows are not in use or not initialized");
}
- else if (STRINGP (frame))
- dpyinfo = x_display_info_for_name (frame);
+ else if (INTEGERP (object))
+ {
+ struct terminal *t = get_terminal (object, 1);
+
+ if (t->type != output_x_window)
+ error ("Terminal %d is not an X display", XINT (object));
+
+ dpyinfo = t->display_info.x;
+ }
+ else if (STRINGP (object))
+ dpyinfo = x_display_info_for_name (object);
else
{
- FRAME_PTR f = check_x_frame (frame);
+ FRAME_PTR f = check_x_frame (object);
dpyinfo = FRAME_X_DISPLAY_INFO (f);
}
@@ -868,8 +879,8 @@ x_set_foreground_color (f, arg, oldval)
unsigned long fg, old_fg;
fg = x_decode_color (f, arg, BLACK_PIX_DEFAULT (f));
- old_fg = x->foreground_pixel;
- x->foreground_pixel = fg;
+ old_fg = FRAME_FOREGROUND_PIXEL (f);
+ FRAME_FOREGROUND_PIXEL (f) = fg;
if (FRAME_X_WINDOW (f) != 0)
{
@@ -906,8 +917,8 @@ x_set_background_color (f, arg, oldval)
unsigned long bg;
bg = x_decode_color (f, arg, WHITE_PIX_DEFAULT (f));
- unload_color (f, x->background_pixel);
- x->background_pixel = bg;
+ unload_color (f, FRAME_BACKGROUND_PIXEL (f));
+ FRAME_BACKGROUND_PIXEL (f) = bg;
if (FRAME_X_WINDOW (f) != 0)
{
@@ -955,13 +966,13 @@ x_set_mouse_color (f, arg, oldval)
Cursor cursor, nontext_cursor, mode_cursor, hand_cursor;
Cursor hourglass_cursor, horizontal_drag_cursor;
unsigned long pixel = x_decode_color (f, arg, BLACK_PIX_DEFAULT (f));
- unsigned long mask_color = x->background_pixel;
+ unsigned long mask_color = FRAME_BACKGROUND_PIXEL (f);
/* Don't let pointers be invisible. */
if (mask_color == pixel)
{
x_free_colors (f, &pixel, 1);
- pixel = x_copy_color (f, x->foreground_pixel);
+ pixel = x_copy_color (f, FRAME_FOREGROUND_PIXEL (f));
}
unload_color (f, x->mouse_pixel);
@@ -1104,13 +1115,13 @@ x_set_cursor_color (f, arg, oldval)
fore_pixel_allocated_p = 1;
}
else
- fore_pixel = x->background_pixel;
+ fore_pixel = FRAME_BACKGROUND_PIXEL (f);
pixel = x_decode_color (f, arg, BLACK_PIX_DEFAULT (f));
pixel_allocated_p = 1;
/* Make sure that the cursor color differs from the background color. */
- if (pixel == x->background_pixel)
+ if (pixel == FRAME_BACKGROUND_PIXEL (f))
{
if (pixel_allocated_p)
{
@@ -1126,7 +1137,7 @@ x_set_cursor_color (f, arg, oldval)
x_free_colors (f, &fore_pixel, 1);
fore_pixel_allocated_p = 0;
}
- fore_pixel = x->background_pixel;
+ fore_pixel = FRAME_BACKGROUND_PIXEL (f);
}
}
@@ -1411,10 +1422,8 @@ x_set_tool_bar_lines (f, value, oldval)
below the menu bar. */
if (FRAME_X_WINDOW (f) && FRAME_TOOL_BAR_LINES (f) == 0)
{
- updating_frame = f;
- clear_frame ();
+ clear_frame (f);
clear_current_matrices (f);
- updating_frame = NULL;
}
/* If the tool bar gets smaller, the internal border below it
@@ -1465,10 +1474,10 @@ x_set_scroll_bar_foreground (f, value, oldval)
if (FRAME_X_WINDOW (f) && FRAME_VISIBLE_P (f))
{
/* Remove all scroll bars because they have wrong colors. */
- if (condemn_scroll_bars_hook)
- (*condemn_scroll_bars_hook) (f);
- if (judge_scroll_bars_hook)
- (*judge_scroll_bars_hook) (f);
+ if (FRAME_TERMINAL (f)->condemn_scroll_bars_hook)
+ (*FRAME_TERMINAL (f)->condemn_scroll_bars_hook) (f);
+ if (FRAME_TERMINAL (f)->judge_scroll_bars_hook)
+ (*FRAME_TERMINAL (f)->judge_scroll_bars_hook) (f);
update_face_from_frame_parameter (f, Qscroll_bar_foreground, value);
redraw_frame (f);
@@ -1514,10 +1523,10 @@ x_set_scroll_bar_background (f, value, oldval)
if (FRAME_X_WINDOW (f) && FRAME_VISIBLE_P (f))
{
/* Remove all scroll bars because they have wrong colors. */
- if (condemn_scroll_bars_hook)
- (*condemn_scroll_bars_hook) (f);
- if (judge_scroll_bars_hook)
- (*judge_scroll_bars_hook) (f);
+ if (FRAME_TERMINAL (f)->condemn_scroll_bars_hook)
+ (*FRAME_TERMINAL (f)->condemn_scroll_bars_hook) (f);
+ if (FRAME_TERMINAL (f)->judge_scroll_bars_hook)
+ (*FRAME_TERMINAL (f)->judge_scroll_bars_hook) (f);
update_face_from_frame_parameter (f, Qscroll_bar_background, value);
redraw_frame (f);
@@ -2875,7 +2884,7 @@ x_window (f)
XSetWindowAttributes attributes;
unsigned long attribute_mask;
- attributes.background_pixel = f->output_data.x->background_pixel;
+ attributes.background_pixel = FRAME_BACKGROUND_PIXEL (f);
attributes.border_pixel = f->output_data.x->border_pixel;
attributes.bit_gravity = StaticGravity;
attributes.backing_store = NotUseful;
@@ -3002,7 +3011,9 @@ x_icon (f, parms)
Lisp_Object parms;
{
Lisp_Object icon_x, icon_y;
+#if 0
struct x_display_info *dpyinfo = FRAME_X_DISPLAY_INFO (f);
+#endif
/* Set the position of the icon. Note that twm groups all
icons in an icon window. */
@@ -3063,8 +3074,8 @@ x_make_gc (f)
/* Normal video */
gc_values.font = FRAME_FONT (f)->fid;
- gc_values.foreground = f->output_data.x->foreground_pixel;
- gc_values.background = f->output_data.x->background_pixel;
+ gc_values.foreground = FRAME_FOREGROUND_PIXEL (f);
+ gc_values.background = FRAME_BACKGROUND_PIXEL (f);
gc_values.line_width = 0; /* Means 1 using fast algorithm. */
f->output_data.x->normal_gc
= XCreateGC (FRAME_X_DISPLAY (f),
@@ -3073,8 +3084,8 @@ x_make_gc (f)
&gc_values);
/* Reverse video style. */
- gc_values.foreground = f->output_data.x->background_pixel;
- gc_values.background = f->output_data.x->foreground_pixel;
+ gc_values.foreground = FRAME_BACKGROUND_PIXEL (f);
+ gc_values.background = FRAME_FOREGROUND_PIXEL (f);
f->output_data.x->reverse_gc
= XCreateGC (FRAME_X_DISPLAY (f),
FRAME_X_WINDOW (f),
@@ -3082,7 +3093,7 @@ x_make_gc (f)
&gc_values);
/* Cursor has cursor-color background, background-color foreground. */
- gc_values.foreground = f->output_data.x->background_pixel;
+ gc_values.foreground = FRAME_BACKGROUND_PIXEL (f);
gc_values.background = f->output_data.x->cursor_pixel;
gc_values.fill_style = FillOpaqueStippled;
gc_values.stipple
@@ -3106,8 +3117,8 @@ x_make_gc (f)
= (XCreatePixmapFromBitmapData
(FRAME_X_DISPLAY (f), FRAME_X_DISPLAY_INFO (f)->root_window,
gray_bits, gray_width, gray_height,
- f->output_data.x->foreground_pixel,
- f->output_data.x->background_pixel,
+ FRAME_FOREGROUND_PIXEL (f),
+ FRAME_BACKGROUND_PIXEL (f),
DefaultDepth (FRAME_X_DISPLAY (f), FRAME_X_SCREEN_NUMBER (f))));
UNBLOCK_INPUT;
@@ -3162,6 +3173,12 @@ unwind_create_frame (frame)
{
struct frame *f = XFRAME (frame);
+ /* If frame is already dead, nothing to do. This can happen if the
+ display is disconnected after the frame has become official, but
+ before x_create_frame removes the unwind protect. */
+ if (!FRAME_LIVE_P (f))
+ return Qnil;
+
/* If frame is ``official'', nothing to do. */
if (!CONSP (Vframe_list) || !EQ (XCAR (Vframe_list), frame))
{
@@ -3248,24 +3265,27 @@ This function is an internal primitive--use `make-frame' instead. */)
Lisp_Object parent;
struct kboard *kb;
- check_x ();
-
parms = Fcopy_alist (parms);
/* Use this general default value to start with
until we know if this frame has a specified name. */
Vx_resource_name = Vinvocation_name;
- display = x_get_arg (dpyinfo, parms, Qdisplay, 0, 0, RES_TYPE_STRING);
+ display = x_get_arg (dpyinfo, parms, Qterminal, 0, 0, RES_TYPE_NUMBER);
+ if (EQ (display, Qunbound))
+ display = x_get_arg (dpyinfo, parms, Qdisplay, 0, 0, RES_TYPE_STRING);
if (EQ (display, Qunbound))
display = Qnil;
dpyinfo = check_x_display_info (display);
#ifdef MULTI_KBOARD
- kb = dpyinfo->kboard;
+ kb = dpyinfo->terminal->kboard;
#else
kb = &the_only_kboard;
#endif
+ if (!dpyinfo->terminal->name)
+ error ("Terminal is not live, can't create new frames on it");
+
name = x_get_arg (dpyinfo, parms, Qname, "name", "Name", RES_TYPE_STRING);
if (!STRINGP (name)
&& ! EQ (name, Qunbound)
@@ -3306,6 +3326,9 @@ This function is an internal primitive--use `make-frame' instead. */)
/* Note that X Windows does support scroll bars. */
FRAME_CAN_HAVE_SCROLL_BARS (f) = 1;
+ f->terminal = dpyinfo->terminal;
+ f->terminal->reference_count++;
+
f->output_method = output_x_window;
f->output_data.x = (struct x_output *) xmalloc (sizeof (struct x_output));
bzero (f->output_data.x, sizeof (struct x_output));
@@ -3332,9 +3355,6 @@ This function is an internal primitive--use `make-frame' instead. */)
image_cache_refcount = FRAME_X_IMAGE_CACHE (f)->refcount;
dpyinfo_refcount = dpyinfo->reference_count;
#endif /* GLYPH_DEBUG */
-#ifdef MULTI_KBOARD
- FRAME_KBOARD (f) = kb;
-#endif
/* These colors will be set anyway later, but it's important
to get the color reference counts right, so initialize them! */
@@ -3345,8 +3365,8 @@ This function is an internal primitive--use `make-frame' instead. */)
/* Function x_decode_color can signal an error. Make
sure to initialize color slots so that we won't try
to free colors we haven't allocated. */
- f->output_data.x->foreground_pixel = -1;
- f->output_data.x->background_pixel = -1;
+ FRAME_FOREGROUND_PIXEL (f) = -1;
+ FRAME_BACKGROUND_PIXEL (f) = -1;
f->output_data.x->cursor_pixel = -1;
f->output_data.x->cursor_foreground_pixel = -1;
f->output_data.x->border_pixel = -1;
@@ -3354,9 +3374,9 @@ This function is an internal primitive--use `make-frame' instead. */)
black = build_string ("black");
GCPRO1 (black);
- f->output_data.x->foreground_pixel
+ FRAME_FOREGROUND_PIXEL (f)
= x_decode_color (f, black, BLACK_PIX_DEFAULT (f));
- f->output_data.x->background_pixel
+ FRAME_BACKGROUND_PIXEL (f)
= x_decode_color (f, black, BLACK_PIX_DEFAULT (f));
f->output_data.x->cursor_pixel
= x_decode_color (f, black, BLACK_PIX_DEFAULT (f));
@@ -3655,7 +3675,7 @@ else
}
/* Initialize `default-minibuffer-frame' in case this is the first
- frame on this display device. */
+ frame on this terminal. */
if (FRAME_HAS_MINIBUF_P (f)
&& (!FRAMEP (kb->Vdefault_minibuffer_frame)
|| !FRAME_LIVE_P (XFRAME (kb->Vdefault_minibuffer_frame))))
@@ -3667,6 +3687,8 @@ else
if (CONSP (XCAR (tem)) && !NILP (XCAR (XCAR (tem))))
f->param_alist = Fcons (XCAR (tem), f->param_alist);
+ store_frame_param (f, Qwindow_system, Qx);
+
UNGCPRO;
/* Make sure windows on this frame appear in calls to next-window
@@ -3761,10 +3783,10 @@ DEFUN ("xw-color-values", Fxw_color_values, Sxw_color_values, 1, 2, 0,
DEFUN ("xw-display-color-p", Fxw_display_color_p, Sxw_display_color_p, 0, 1, 0,
doc: /* Internal function called by `display-color-p', which see. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
if (dpyinfo->n_planes <= 2)
return Qnil;
@@ -3786,13 +3808,13 @@ DEFUN ("x-display-grayscale-p", Fx_display_grayscale_p, Sx_display_grayscale_p,
0, 1, 0,
doc: /* Return t if the X display supports shades of gray.
Note that color displays do support shades of gray.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
if (dpyinfo->n_planes <= 1)
return Qnil;
@@ -3814,56 +3836,56 @@ If omitted or nil, that stands for the selected frame's display. */)
DEFUN ("x-display-pixel-width", Fx_display_pixel_width, Sx_display_pixel_width,
0, 1, 0,
- doc: /* Returns the width in pixels of the X display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Returns the width in pixels of the X display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
return make_number (dpyinfo->width);
}
DEFUN ("x-display-pixel-height", Fx_display_pixel_height,
Sx_display_pixel_height, 0, 1, 0,
- doc: /* Returns the height in pixels of the X display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Returns the height in pixels of the X display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
return make_number (dpyinfo->height);
}
DEFUN ("x-display-planes", Fx_display_planes, Sx_display_planes,
0, 1, 0,
- doc: /* Returns the number of bitplanes of the X display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Returns the number of bitplanes of the X display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
return make_number (dpyinfo->n_planes);
}
DEFUN ("x-display-color-cells", Fx_display_color_cells, Sx_display_color_cells,
0, 1, 0,
- doc: /* Returns the number of color cells of the X display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Returns the number of color cells of the X display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
int nr_planes = DisplayPlanes (dpyinfo->display,
XScreenNumberOfScreen (dpyinfo->screen));
@@ -3881,29 +3903,29 @@ If omitted or nil, that stands for the selected frame's display. */)
DEFUN ("x-server-max-request-size", Fx_server_max_request_size,
Sx_server_max_request_size,
0, 1, 0,
- doc: /* Returns the maximum request size of the X server of display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Returns the maximum request size of the X server of display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
return make_number (MAXREQUEST (dpyinfo->display));
}
DEFUN ("x-server-vendor", Fx_server_vendor, Sx_server_vendor, 0, 1, 0,
- doc: /* Returns the "vendor ID" string of the X server of display DISPLAY.
+ doc: /* Returns the "vendor ID" string of the X server of display TERMINAL.
\(Labelling every distributor as a "vendor" embodies the false assumption
that operating systems cannot be developed and distributed noncommercially.)
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
char *vendor = ServerVendor (dpyinfo->display);
if (! vendor) vendor = "";
@@ -3911,18 +3933,18 @@ If omitted or nil, that stands for the selected frame's display. */)
}
DEFUN ("x-server-version", Fx_server_version, Sx_server_version, 0, 1, 0,
- doc: /* Returns the version numbers of the X server of display DISPLAY.
+ doc: /* Returns the version numbers of the X server of display TERMINAL.
The value is a list of three integers: the major and minor
version numbers of the X Protocol in use, and the distributor-specific release
number. See also the function `x-server-vendor'.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
Display *dpy = dpyinfo->display;
return Fcons (make_number (ProtocolVersion (dpy)),
@@ -3931,55 +3953,55 @@ If omitted or nil, that stands for the selected frame's display. */)
}
DEFUN ("x-display-screens", Fx_display_screens, Sx_display_screens, 0, 1, 0,
- doc: /* Return the number of screens on the X server of display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Return the number of screens on the X server of display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
return make_number (ScreenCount (dpyinfo->display));
}
DEFUN ("x-display-mm-height", Fx_display_mm_height, Sx_display_mm_height, 0, 1, 0,
- doc: /* Return the height in millimeters of the X display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Return the height in millimeters of the X display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
return make_number (HeightMMOfScreen (dpyinfo->screen));
}
DEFUN ("x-display-mm-width", Fx_display_mm_width, Sx_display_mm_width, 0, 1, 0,
- doc: /* Return the width in millimeters of the X display DISPLAY.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Return the width in millimeters of the X display TERMINAL.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
return make_number (WidthMMOfScreen (dpyinfo->screen));
}
DEFUN ("x-display-backing-store", Fx_display_backing_store,
Sx_display_backing_store, 0, 1, 0,
- doc: /* Returns an indication of whether X display DISPLAY does backing store.
+ doc: /* Returns an indication of whether X display TERMINAL does backing store.
The value may be `always', `when-mapped', or `not-useful'.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
Lisp_Object result;
switch (DoesBackingStore (dpyinfo->screen))
@@ -4006,17 +4028,17 @@ If omitted or nil, that stands for the selected frame's display. */)
DEFUN ("x-display-visual-class", Fx_display_visual_class,
Sx_display_visual_class, 0, 1, 0,
- doc: /* Return the visual class of the X display DISPLAY.
+ doc: /* Return the visual class of the X display TERMINAL.
The value is one of the symbols `static-gray', `gray-scale',
`static-color', `pseudo-color', `true-color', or `direct-color'.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
Lisp_Object result;
switch (dpyinfo->visual->class)
@@ -4049,14 +4071,14 @@ If omitted or nil, that stands for the selected frame's display. */)
DEFUN ("x-display-save-under", Fx_display_save_under,
Sx_display_save_under, 0, 1, 0,
- doc: /* Returns t if the X display DISPLAY supports the save-under feature.
-The optional argument DISPLAY specifies which display to ask about.
-DISPLAY should be either a frame or a display name (a string).
+ doc: /* Returns t if the X display TERMINAL supports the save-under feature.
+The optional argument TERMINAL specifies which display to ask about.
+TERMINAL should be a terminal id, a frame or a display name (a string).
If omitted or nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
if (DoesSaveUnders (dpyinfo->screen) == True)
return Qt;
@@ -4237,8 +4259,10 @@ x_display_info_for_name (name)
CHECK_STRING (name);
- if (! EQ (Vwindow_system, intern ("x")))
- error ("Not using X Windows");
+#if 0
+ if (! EQ (Vinitial_window_system, intern ("x")))
+ error ("Not using X Windows"); /* That doesn't stop us anymore. */
+#endif
for (dpyinfo = x_display_list, names = x_display_name_list;
dpyinfo;
@@ -4285,8 +4309,10 @@ terminate Emacs if we can't open the connection. */)
if (! NILP (xrm_string))
CHECK_STRING (xrm_string);
- if (! EQ (Vwindow_system, intern ("x")))
- error ("Not using X Windows");
+#if 0
+ if (! EQ (Vinitial_window_system, intern ("x")))
+ error ("Not using X Windows"); /* That doesn't stop us anymore. */
+#endif
if (! NILP (xrm_string))
xrm_option = (unsigned char *) SDATA (xrm_string);
@@ -4321,41 +4347,19 @@ An insecure way to solve the problem may be to use `xhost'.\n",
DEFUN ("x-close-connection", Fx_close_connection,
Sx_close_connection, 1, 1, 0,
- doc: /* Close the connection to DISPLAY's X server.
-For DISPLAY, specify either a frame or a display name (a string).
-If DISPLAY is nil, that stands for the selected frame's display. */)
- (display)
- Lisp_Object display;
+ doc: /* Close the connection to TERMINAL's X server.
+For TERMINAL, specify a terminal id, a frame or a display name (a
+string). If TERMINAL is nil, that stands for the selected frame's
+terminal. */)
+ (terminal)
+ Lisp_Object terminal;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
- int i;
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
if (dpyinfo->reference_count > 0)
error ("Display still has frames on it");
- BLOCK_INPUT;
- /* Free the fonts in the font table. */
- for (i = 0; i < dpyinfo->n_fonts; i++)
- if (dpyinfo->font_table[i].name)
- {
- XFreeFont (dpyinfo->display, dpyinfo->font_table[i].font);
- }
-
- x_destroy_all_bitmaps (dpyinfo);
- XSetCloseDownMode (dpyinfo->display, DestroyAll);
-
-#ifdef USE_GTK
- xg_display_close (dpyinfo->display);
-#else
-#ifdef USE_X_TOOLKIT
- XtCloseDisplay (dpyinfo->display);
-#else
- XCloseDisplay (dpyinfo->display);
-#endif
-#endif /* ! USE_GTK */
-
- x_delete_display (dpyinfo);
- UNBLOCK_INPUT;
+ x_delete_terminal (dpyinfo->terminal);
return Qnil;
}
@@ -4379,13 +4383,13 @@ If ON is nil, allow buffering of requests.
Turning on synchronization prohibits the Xlib routines from buffering
requests and seriously degrades performance, but makes debugging much
easier.
-The optional second argument DISPLAY specifies which display to act on.
-DISPLAY should be either a frame or a display name (a string).
-If DISPLAY is omitted or nil, that stands for the selected frame's display. */)
- (on, display)
- Lisp_Object display, on;
+The optional second argument TERMINAL specifies which display to act on.
+TERMINAL should be a terminal id, a frame or a display name (a string).
+If TERMINAL is omitted or nil, that stands for the selected frame's display. */)
+ (on, terminal)
+ Lisp_Object terminal, on;
{
- struct x_display_info *dpyinfo = check_x_display_info (display);
+ struct x_display_info *dpyinfo = check_x_display_info (terminal);
XSynchronize (dpyinfo->display, !EQ (on, Qnil));
@@ -4689,10 +4693,6 @@ start_hourglass ()
EMACS_TIME delay;
int secs, usecs = 0;
- /* Don't bother for ttys. */
- if (NILP (Vwindow_system))
- return;
-
cancel_hourglass ();
if (INTEGERP (Vhourglass_delay)
@@ -4904,20 +4904,16 @@ x_create_tip_frame (dpyinfo, parms, text)
int width, height;
int count = SPECPDL_INDEX ();
struct gcpro gcpro1, gcpro2, gcpro3;
- struct kboard *kb;
int face_change_count_before = face_change_count;
Lisp_Object buffer;
struct buffer *old_buffer;
check_x ();
- parms = Fcopy_alist (parms);
+ if (!dpyinfo->terminal->name)
+ error ("Terminal is not live, can't create new frames on it");
-#ifdef MULTI_KBOARD
- kb = dpyinfo->kboard;
-#else
- kb = &the_only_kboard;
-#endif
+ parms = Fcopy_alist (parms);
/* Get the name of the frame to use for resource lookup. */
name = x_get_arg (dpyinfo, parms, Qname, "name", "Name", RES_TYPE_STRING);
@@ -4945,6 +4941,9 @@ x_create_tip_frame (dpyinfo, parms, text)
FRAME_CAN_HAVE_SCROLL_BARS (f) = 0;
record_unwind_protect (unwind_create_tip_frame, frame);
+ f->terminal = dpyinfo->terminal;
+ f->terminal->reference_count++;
+
/* By setting the output method, we're essentially saying that
the frame is live, as per FRAME_LIVE_P. If we get a signal
from this point on, x_destroy_window might screw up reference
@@ -4966,9 +4965,6 @@ x_create_tip_frame (dpyinfo, parms, text)
image_cache_refcount = FRAME_X_IMAGE_CACHE (f)->refcount;
dpyinfo_refcount = dpyinfo->reference_count;
#endif /* GLYPH_DEBUG */
-#ifdef MULTI_KBOARD
- FRAME_KBOARD (f) = kb;
-#endif
f->output_data.x->parent_desc = FRAME_X_DISPLAY_INFO (f)->root_window;
f->output_data.x->explicit_parent = 0;
@@ -4978,11 +4974,21 @@ x_create_tip_frame (dpyinfo, parms, text)
Lisp_Object black;
struct gcpro gcpro1;
+ /* Function x_decode_color can signal an error. Make
+ sure to initialize color slots so that we won't try
+ to free colors we haven't allocated. */
+ FRAME_FOREGROUND_PIXEL (f) = -1;
+ FRAME_BACKGROUND_PIXEL (f) = -1;
+ f->output_data.x->cursor_pixel = -1;
+ f->output_data.x->cursor_foreground_pixel = -1;
+ f->output_data.x->border_pixel = -1;
+ f->output_data.x->mouse_pixel = -1;
+
black = build_string ("black");
GCPRO1 (black);
- f->output_data.x->foreground_pixel
+ FRAME_FOREGROUND_PIXEL (f)
= x_decode_color (f, black, BLACK_PIX_DEFAULT (f));
- f->output_data.x->background_pixel
+ FRAME_BACKGROUND_PIXEL (f)
= x_decode_color (f, black, BLACK_PIX_DEFAULT (f));
f->output_data.x->cursor_pixel
= x_decode_color (f, black, BLACK_PIX_DEFAULT (f));
@@ -5194,6 +5200,8 @@ else
Qnil));
}
+ Fmodify_frame_parameters (frame, Fcons (Fcons (Qwindow_system, Qx), Qnil));
+
f->no_split = 1;
UNGCPRO;
diff --git a/src/xmenu.c b/src/xmenu.c
index d497324378..4e7f07c375 100644
--- a/src/xmenu.c
+++ b/src/xmenu.c
@@ -41,10 +41,10 @@ Boston, MA 02110-1301, USA. */
#include <stdio.h>
#include "lisp.h"
-#include "termhooks.h"
#include "keyboard.h"
#include "keymap.h"
#include "frame.h"
+#include "termhooks.h"
#include "window.h"
#include "blockinput.h"
#include "buffer.h"
@@ -745,6 +745,9 @@ mouse_position_for_popup (f, x, y)
Window root, dummy_window;
int dummy;
+ if (! FRAME_X_P (f))
+ abort ();
+
BLOCK_INPUT;
XQueryPointer (FRAME_X_DISPLAY (f),
@@ -940,6 +943,9 @@ no quit occurs and `x-popup-menu' returns nil. */)
xpos += XINT (x);
ypos += XINT (y);
+ if (! FRAME_X_P (f))
+ error ("Can not put X menu on non-X terminal");
+
XSETFRAME (Vmenu_updating_frame, f);
}
else
@@ -1128,6 +1134,9 @@ for instance using the window manager, then this produces a quit and
but I don't want to make one now. */
CHECK_WINDOW (window);
+ if (! FRAME_X_P (f))
+ error ("Can not put X dialog on non-X terminal");
+
#if ! defined (USE_X_TOOLKIT) && ! defined (USE_GTK)
/* Display a menu with these alternatives
in the middle of frame F. */
@@ -1309,7 +1318,7 @@ popup_get_selection (initial_event, dpyinfo, id, do_timers)
}
}
-DEFUN ("menu-bar-open", Fmenu_bar_open, Smenu_bar_open, 0, 1, "i",
+DEFUN ("x-menu-bar-open-internal", Fx_menu_bar_open_internal, Sx_menu_bar_open_internal, 0, 1, "i",
doc: /* Start key navigation of the menu bar in FRAME.
This initially opens the first menu bar item and you can then navigate with the
arrow keys, select a menu entry with the return key or cancel with the
@@ -1388,7 +1397,7 @@ If FRAME is nil or not given, use the selected frame. */)
#ifdef USE_GTK
-DEFUN ("menu-bar-open", Fmenu_bar_open, Smenu_bar_open, 0, 1, "i",
+DEFUN ("x-menu-bar-open-internal", Fx_menu_bar_open_internal, Sx_menu_bar_open_internal, 0, 1, "i",
doc: /* Start key navigation of the menu bar in FRAME.
This initially opens the first menu bar item and you can then navigate with the
arrow keys, select a menu entry with the return key or cancel with the
@@ -1464,6 +1473,9 @@ void
x_activate_menubar (f)
FRAME_PTR f;
{
+ if (! FRAME_X_P (f))
+ abort ();
+
if (!f->output_data.x->saved_menu_event->type)
return;
@@ -2098,9 +2110,14 @@ update_frame_menubar (f)
#ifdef USE_GTK
return xg_update_frame_menubar (f);
#else
- struct x_output *x = f->output_data.x;
+ struct x_output *x;
int columns, rows;
+ if (! FRAME_X_P (f))
+ abort ();
+
+ x = f->output_data.x;
+
if (!x->menubar_widget || XtIsManaged (x->menubar_widget))
return 0;
@@ -2146,7 +2163,7 @@ set_frame_menubar (f, first_time, deep_p)
int first_time;
int deep_p;
{
- xt_or_gtk_widget menubar_widget = f->output_data.x->menubar_widget;
+ xt_or_gtk_widget menubar_widget;
#ifdef USE_X_TOOLKIT
LWLIB_ID id;
#endif
@@ -2156,6 +2173,10 @@ set_frame_menubar (f, first_time, deep_p)
int *submenu_start, *submenu_end;
int *submenu_top_level_items, *submenu_n_panes;
+ if (! FRAME_X_P (f))
+ abort ();
+
+ menubar_widget = f->output_data.x->menubar_widget;
XSETFRAME (Vmenu_updating_frame, f);
@@ -2508,6 +2529,9 @@ free_frame_menubar (f)
{
Widget menubar_widget;
+ if (! FRAME_X_P (f))
+ abort ();
+
menubar_widget = f->output_data.x->menubar_widget;
f->output_data.x->menubar_height = 0;
@@ -2660,6 +2684,9 @@ create_and_show_popup_menu (f, first_wv, x, y, for_click)
struct next_popup_x_y popup_x_y;
int specpdl_count = SPECPDL_INDEX ();
+ if (! FRAME_X_P (f))
+ abort ();
+
xg_crazy_callback_abort = 1;
menu = xg_create_widget ("popup", first_wv->name, f, first_wv,
G_CALLBACK (popup_selection_callback),
@@ -2768,6 +2795,9 @@ create_and_show_popup_menu (f, first_wv, x, y, for_click)
LWLIB_ID menu_id;
Widget menu;
+ if (! FRAME_X_P (f))
+ abort ();
+
menu_id = widget_id_tick++;
menu = lw_create_widget ("popup", first_wv->name, menu_id, first_wv,
f->output_data.x->widget, 1, 0,
@@ -2844,6 +2874,9 @@ xmenu_show (f, x, y, for_click, keymaps, title, error)
int first_pane;
+ if (! FRAME_X_P (f))
+ abort ();
+
*error = NULL;
if (menu_items_used <= MENU_ITEMS_PANE_LENGTH)
@@ -3126,6 +3159,9 @@ create_and_show_dialog (f, first_wv)
{
GtkWidget *menu;
+ if (! FRAME_X_P (f))
+ abort ();
+
menu = xg_create_widget ("dialog", first_wv->name, f, first_wv,
G_CALLBACK (dialog_selection_callback),
G_CALLBACK (popup_deactivate_callback),
@@ -3175,6 +3211,9 @@ create_and_show_dialog (f, first_wv)
{
LWLIB_ID dialog_id;
+ if (!FRAME_X_P (f))
+ abort();
+
dialog_id = widget_id_tick++;
lw_create_widget (first_wv->name, "dialog", dialog_id, first_wv,
f->output_data.x->widget, 1, 0,
@@ -3227,6 +3266,9 @@ xdialog_show (f, keymaps, title, header, error_name)
/* 1 means we've seen the boundary between left-hand elts and right-hand. */
int boundary_seen = 0;
+ if (! FRAME_X_P (f))
+ abort ();
+
*error_name = NULL;
if (menu_items_n_panes > 1)
@@ -3502,6 +3544,9 @@ xmenu_show (f, x, y, for_click, keymaps, title, error)
unsigned int dummy_uint;
int specpdl_count = SPECPDL_INDEX ();
+ if (! FRAME_X_P (f))
+ abort ();
+
*error = 0;
if (menu_items_n_panes == 0)
return Qnil;
@@ -3610,13 +3655,6 @@ xmenu_show (f, x, y, for_click, keymaps, title, error)
if (!NILP (descrip))
{
int gap = maxwidth - SBYTES (item_name);
-#ifdef C_ALLOCA
- Lisp_Object spacer;
- spacer = Fmake_string (make_number (gap), make_number (' '));
- item_name = concat2 (item_name, spacer);
- item_name = concat2 (item_name, descrip);
- item_data = SDATA (item_name);
-#else
/* if alloca is fast, use that to make the space,
to reduce gc needs. */
item_data
@@ -3629,7 +3667,6 @@ xmenu_show (f, x, y, for_click, keymaps, title, error)
bcopy (SDATA (descrip), item_data + j,
SBYTES (descrip));
item_data[j + SBYTES (descrip)] = 0;
-#endif
}
else
item_data = SDATA (item_name);
@@ -3806,8 +3843,9 @@ syms_of_xmenu ()
defsubr (&Smenu_or_popup_active_p);
#if defined (USE_GTK) || defined (USE_X_TOOLKIT)
- defsubr (&Smenu_bar_open);
- Ffset (intern ("accelerate-menu"), intern (Smenu_bar_open.symbol_name));
+ defsubr (&Sx_menu_bar_open_internal);
+ Ffset (intern ("accelerate-menu"),
+ intern (Sx_menu_bar_open_internal.symbol_name));
#endif
#ifdef HAVE_MENUS
diff --git a/src/xselect.c b/src/xselect.c
index 33468f0d63..d71ac42aa7 100644
--- a/src/xselect.c
+++ b/src/xselect.c
@@ -398,12 +398,19 @@ x_own_selection (selection_name, selection_value)
Lisp_Object selection_name, selection_value;
{
struct frame *sf = SELECTED_FRAME ();
- Window selecting_window = FRAME_X_WINDOW (sf);
- Display *display = FRAME_X_DISPLAY (sf);
+ Window selecting_window;
+ Display *display;
Time time = last_event_timestamp;
Atom selection_atom;
- struct x_display_info *dpyinfo = FRAME_X_DISPLAY_INFO (sf);
+ struct x_display_info *dpyinfo;
+
+ if (! FRAME_X_P (sf))
+ return;
+ selecting_window = FRAME_X_WINDOW (sf);
+ display = FRAME_X_DISPLAY (sf);
+ dpyinfo = FRAME_X_DISPLAY_INFO (sf);
+
CHECK_SYMBOL (selection_name);
selection_atom = symbol_to_x_atom (dpyinfo, display, selection_name);
@@ -671,7 +678,8 @@ some_frame_on_display (dpyinfo)
FOR_EACH_FRAME (list, frame)
{
- if (FRAME_X_DISPLAY_INFO (XFRAME (frame)) == dpyinfo)
+ if (FRAME_X_P (XFRAME (frame))
+ && FRAME_X_DISPLAY_INFO (XFRAME (frame)) == dpyinfo)
return frame;
}
@@ -683,6 +691,10 @@ some_frame_on_display (dpyinfo)
DATA and SIZE describe the data to send, already converted.
FORMAT is the unit-size (in bits) of the data to be transmitted. */
+#ifdef TRACE_SELECTION
+static int x_reply_selection_request_cnt;
+#endif /* TRACE_SELECTION */
+
static void
x_reply_selection_request (event, format, data, size, type)
struct input_event *event;
@@ -721,10 +733,9 @@ x_reply_selection_request (event, format, data, size, type)
#ifdef TRACE_SELECTION
{
- static int cnt;
char *sel = XGetAtomName (display, reply.selection);
char *tgt = XGetAtomName (display, reply.target);
- TRACE3 ("%s, target %s (%d)", sel, tgt, ++cnt);
+ TRACE3 ("%s, target %s (%d)", sel, tgt, ++x_reply_selection_request_cnt);
if (sel) XFree (sel);
if (tgt) XFree (tgt);
}
@@ -1014,6 +1025,7 @@ x_handle_selection_clear (event)
TRACE0 ("x_handle_selection_clear");
+#ifdef MULTI_KBOARD
/* If the new selection owner is also Emacs,
don't clear the new selection. */
BLOCK_INPUT;
@@ -1021,7 +1033,7 @@ x_handle_selection_clear (event)
to see if this Emacs job now owns the selection
through that display. */
for (t_dpyinfo = x_display_list; t_dpyinfo; t_dpyinfo = t_dpyinfo->next)
- if (t_dpyinfo->kboard == dpyinfo->kboard)
+ if (t_dpyinfo->terminal->kboard == dpyinfo->terminal->kboard)
{
Window owner_window
= XGetSelectionOwner (t_dpyinfo->display, selection);
@@ -1032,7 +1044,8 @@ x_handle_selection_clear (event)
}
}
UNBLOCK_INPUT;
-
+#endif
+
selection_symbol = x_atom_to_symbol (display, selection);
local_selection_data = assq_no_quit (selection_symbol, Vselection_alist);
@@ -1380,17 +1393,26 @@ x_get_foreign_selection (selection_symbol, target_type, time_stamp)
Lisp_Object selection_symbol, target_type, time_stamp;
{
struct frame *sf = SELECTED_FRAME ();
- Window requestor_window = FRAME_X_WINDOW (sf);
- Display *display = FRAME_X_DISPLAY (sf);
- struct x_display_info *dpyinfo = FRAME_X_DISPLAY_INFO (sf);
+ Window requestor_window;
+ Display *display;
+ struct x_display_info *dpyinfo;
Time requestor_time = last_event_timestamp;
- Atom target_property = dpyinfo->Xatom_EMACS_TMP;
- Atom selection_atom = symbol_to_x_atom (dpyinfo, display, selection_symbol);
+ Atom target_property;
+ Atom selection_atom;
Atom type_atom;
int secs, usecs;
int count = SPECPDL_INDEX ();
Lisp_Object frame;
+ if (! FRAME_X_P (sf))
+ return Qnil;
+
+ requestor_window = FRAME_X_WINDOW (sf);
+ display = FRAME_X_DISPLAY (sf);
+ dpyinfo = FRAME_X_DISPLAY_INFO (sf);
+ target_property = dpyinfo->Xatom_EMACS_TMP;
+ selection_atom = symbol_to_x_atom (dpyinfo, display, selection_symbol);
+
if (CONSP (target_type))
type_atom = symbol_to_x_atom (dpyinfo, display, XCAR (target_type));
else
@@ -2206,6 +2228,9 @@ Disowning it means there is no such selection. */)
struct frame *sf = SELECTED_FRAME ();
check_x ();
+ if (! FRAME_X_P (sf))
+ return Qnil;
+
display = FRAME_X_DISPLAY (sf);
dpyinfo = FRAME_X_DISPLAY_INFO (sf);
CHECK_SYMBOL (selection);
@@ -2367,6 +2392,10 @@ DEFUN ("x-get-cut-buffer-internal", Fx_get_cut_buffer_internal,
struct frame *sf = SELECTED_FRAME ();
check_x ();
+
+ if (! FRAME_X_P (sf))
+ return Qnil;
+
display = FRAME_X_DISPLAY (sf);
dpyinfo = FRAME_X_DISPLAY_INFO (sf);
window = RootWindow (display, 0); /* Cut buffers are on screen 0 */
@@ -2407,6 +2436,10 @@ DEFUN ("x-store-cut-buffer-internal", Fx_store_cut_buffer_internal,
struct frame *sf = SELECTED_FRAME ();
check_x ();
+
+ if (! FRAME_X_P (sf))
+ return Qnil;
+
display = FRAME_X_DISPLAY (sf);
window = RootWindow (display, 0); /* Cut buffers are on screen 0 */
@@ -2463,8 +2496,12 @@ Positive means shift the values forward, negative means backward. */)
Atom props[8];
Display *display;
struct frame *sf = SELECTED_FRAME ();
-
+
check_x ();
+
+ if (! FRAME_X_P (sf))
+ return Qnil;
+
display = FRAME_X_DISPLAY (sf);
window = RootWindow (display, 0); /* Cut buffers are on screen 0 */
CHECK_NUMBER (n);
diff --git a/src/xsmfns.c b/src/xsmfns.c
index 1211c55eb0..77abf3b507 100644
--- a/src/xsmfns.c
+++ b/src/xsmfns.c
@@ -48,6 +48,7 @@ Boston, MA 02110-1301, USA. */
#include "lisp.h"
#include "systime.h"
#include "sysselect.h"
+#include "frame.h"
#include "termhooks.h"
#include "termopts.h"
#include "xterm.h"
@@ -510,6 +511,14 @@ x_session_initialize (dpyinfo)
}
}
+/* Ensure that the session manager is not contacted again. */
+
+void
+x_session_close ()
+{
+ ice_fd = -1;
+}
+
DEFUN ("handle-save-session", Fhandle_save_session,
Shandle_save_session, 1, 1, "e",
diff --git a/src/xterm.c b/src/xterm.c
index ca2e16398d..363d2183ee 100644
--- a/src/xterm.c
+++ b/src/xterm.c
@@ -54,7 +54,6 @@ Boston, MA 02110-1301, USA. */
#include <sys/ioctl.h>
#endif /* ! defined (BSD_SYSTEM) */
-#include "systty.h"
#include "systime.h"
#ifndef INCLUDED_FCNTL
@@ -160,8 +159,6 @@ extern void _XEditResCheckMessages ();
#endif
#endif
-#define abs(x) ((x) < 0 ? -(x) : (x))
-
/* Default to using XIM if available. */
#ifdef USE_XIM
int use_xim = 1;
@@ -327,6 +324,10 @@ static Lisp_Object Qalt, Qhyper, Qmeta, Qsuper, Qmodifier_value;
static Lisp_Object Qvendor_specific_keysyms;
static Lisp_Object Qlatin_1;
+/* Used in x_flush. */
+
+extern Lisp_Object Vinhibit_redisplay;
+
extern XrmDatabase x_load_resources P_ ((Display *, char *, char *, char *));
extern int x_bitmap_mask P_ ((FRAME_PTR, int));
@@ -336,13 +337,15 @@ static const XColor *x_color_cells P_ ((Display *, int *));
static void x_update_window_end P_ ((struct window *, int, int));
static int x_io_error_quitter P_ ((Display *));
+static struct terminal *x_create_terminal P_ ((struct x_display_info *));
+void x_delete_terminal P_ ((struct terminal *));
static void x_font_min_bounds P_ ((XFontStruct *, int *, int *));
static int x_compute_min_glyph_bounds P_ ((struct frame *));
static void x_update_end P_ ((struct frame *));
static void XTframe_up_to_date P_ ((struct frame *));
-static void XTset_terminal_modes P_ ((void));
-static void XTreset_terminal_modes P_ ((void));
-static void x_clear_frame P_ ((void));
+static void XTset_terminal_modes P_ ((struct terminal *));
+static void XTreset_terminal_modes P_ ((struct terminal *));
+static void x_clear_frame P_ ((struct frame *));
static void frame_highlight P_ ((struct frame *));
static void frame_unhighlight P_ ((struct frame *));
static void x_new_focus_frame P_ ((struct x_display_info *, struct frame *));
@@ -382,12 +385,18 @@ static void
x_flush (f)
struct frame *f;
{
+ /* Don't call XFlush when it is not safe to redisplay; the X
+ connection may be broken. */
+ if (!NILP (Vinhibit_redisplay))
+ return;
+
BLOCK_INPUT;
if (f == NULL)
{
Lisp_Object rest, frame;
FOR_EACH_FRAME (rest, frame)
- x_flush (XFRAME (frame));
+ if (FRAME_X_P (XFRAME (frame)))
+ x_flush (XFRAME (frame));
}
else if (FRAME_X_P (f))
XFlush (FRAME_X_DISPLAY (f));
@@ -848,7 +857,7 @@ x_draw_fringe_bitmap (w, row, p)
rarely happens). */
static void
-XTset_terminal_modes ()
+XTset_terminal_modes (struct terminal *terminal)
{
}
@@ -856,7 +865,7 @@ XTset_terminal_modes ()
the X-windows go away, and suspending requires no action. */
static void
-XTreset_terminal_modes ()
+XTreset_terminal_modes (struct terminal *terminal)
{
}
@@ -1621,7 +1630,8 @@ x_frame_of_widget (widget)
for (tail = Vframe_list; CONSP (tail); tail = XCDR (tail))
if (FRAMEP (XCAR (tail))
&& (f = XFRAME (XCAR (tail)),
- (f->output_data.nothing != 1
+ (FRAME_X_P (f)
+ && f->output_data.nothing != 1
&& FRAME_X_DISPLAY_INFO (f) == dpyinfo))
&& f->output_data.x->widget == widget)
return f;
@@ -3092,7 +3102,8 @@ x_shift_glyphs_for_insert (f, x, y, width, height, shift_by)
for X frames. */
static void
-x_delete_glyphs (n)
+x_delete_glyphs (f, n)
+ struct frame *f;
register int n;
{
abort ();
@@ -3115,19 +3126,11 @@ x_clear_area (dpy, window, x, y, width, height, exposures)
}
-/* Clear entire frame. If updating_frame is non-null, clear that
- frame. Otherwise clear the selected frame. */
+/* Clear an entire frame. */
static void
-x_clear_frame ()
+x_clear_frame (struct frame *f)
{
- struct frame *f;
-
- if (updating_frame)
- f = updating_frame;
- else
- f = SELECTED_FRAME ();
-
/* Clearing the frame will erase any cursor, so mark them all as no
longer visible. */
mark_window_cursors_off (XWINDOW (FRAME_ROOT_WINDOW (f)));
@@ -3206,8 +3209,8 @@ XTflash (f)
XGCValues values;
values.function = GXxor;
- values.foreground = (f->output_data.x->foreground_pixel
- ^ f->output_data.x->background_pixel);
+ values.foreground = (FRAME_FOREGROUND_PIXEL (f)
+ ^ FRAME_BACKGROUND_PIXEL (f));
gc = XCreateGC (FRAME_X_DISPLAY (f), FRAME_X_WINDOW (f),
GCFunction | GCForeground, &values);
@@ -3373,7 +3376,8 @@ XTset_terminal_window (n)
lines or deleting -N lines at vertical position VPOS. */
static void
-x_ins_del_lines (vpos, n)
+x_ins_del_lines (f, vpos, n)
+ struct frame *f;
int vpos, n;
{
abort ();
@@ -4010,7 +4014,8 @@ XTmouse_position (fp, insist, bar_window, part, x, y, time)
/* Clear the mouse-moved flag for every frame on this display. */
FOR_EACH_FRAME (tail, frame)
- if (FRAME_X_DISPLAY (XFRAME (frame)) == FRAME_X_DISPLAY (*fp))
+ if (FRAME_X_P (XFRAME (frame))
+ && FRAME_X_DISPLAY (XFRAME (frame)) == FRAME_X_DISPLAY (*fp))
XFRAME (frame)->mouse_moved = 0;
last_mouse_scroll_bar = Qnil;
@@ -4197,6 +4202,9 @@ x_window_to_scroll_bar (display, window_id)
if (! FRAMEP (frame))
abort ();
+ if (! FRAME_X_P (XFRAME (frame)))
+ continue;
+
/* Scan this frame's scroll bar list for a scroll bar with the
right window ID. */
condemned = FRAME_CONDEMNED_SCROLL_BARS (XFRAME (frame));
@@ -4229,11 +4237,14 @@ x_window_to_menu_bar (window)
for (tail = Vframe_list; CONSP (tail); tail = XCDR (tail))
{
- Lisp_Object frame = XCAR (tail);
- Widget menu_bar = XFRAME (frame)->output_data.x->menubar_widget;
+ if (FRAME_X_P (XFRAME (XCAR (tail))))
+ {
+ Lisp_Object frame = XCAR (tail);
+ Widget menu_bar = XFRAME (frame)->output_data.x->menubar_widget;
- if (menu_bar && xlwmenu_window_p (menu_bar, window))
- return menu_bar;
+ if (menu_bar && xlwmenu_window_p (menu_bar, window))
+ return menu_bar;
+ }
}
return NULL;
@@ -5041,7 +5052,7 @@ x_scroll_bar_create (w, top, left, width, height)
a.background_pixel = f->output_data.x->scroll_bar_background_pixel;
if (a.background_pixel == -1)
- a.background_pixel = f->output_data.x->background_pixel;
+ a.background_pixel = FRAME_BACKGROUND_PIXEL (f);
a.event_mask = (ButtonPressMask | ButtonReleaseMask
| ButtonMotionMask | PointerMotionHintMask
@@ -5218,7 +5229,7 @@ x_scroll_bar_set_handle (bar, start, end, rebuild)
/* Restore the foreground color of the GC if we changed it above. */
if (f->output_data.x->scroll_bar_foreground_pixel != -1)
XSetForeground (FRAME_X_DISPLAY (f), gc,
- f->output_data.x->foreground_pixel);
+ FRAME_FOREGROUND_PIXEL (f));
/* Draw the empty space below the handle. Note that we can't
clear zero-height areas; that means "clear to end of window." */
@@ -5620,7 +5631,7 @@ x_scroll_bar_expose (bar, event)
/* Restore the foreground color of the GC if we changed it above. */
if (f->output_data.x->scroll_bar_foreground_pixel != -1)
XSetForeground (FRAME_X_DISPLAY (f), gc,
- f->output_data.x->foreground_pixel);
+ FRAME_FOREGROUND_PIXEL (f));
UNBLOCK_INPUT;
@@ -6020,7 +6031,7 @@ handle_one_xevent (dpyinfo, eventp, finish, hold_quit)
int count = 0;
int do_help = 0;
int nbytes = 0;
- struct frame *f;
+ struct frame *f = NULL;
struct coding_system coding;
XEvent event = *eventp;
@@ -6596,19 +6607,19 @@ handle_one_xevent (dpyinfo, eventp, finish, hold_quit)
bzero (&compose_status, sizeof (compose_status));
orig_keysym = keysym;
- /* Common for all keysym input events. */
- XSETFRAME (inev.ie.frame_or_window, f);
- inev.ie.modifiers
- = x_x_to_emacs_modifiers (FRAME_X_DISPLAY_INFO (f), modifiers);
- inev.ie.timestamp = event.xkey.time;
-
- /* First deal with keysyms which have defined
- translations to characters. */
- if (keysym >= 32 && keysym < 128)
- /* Avoid explicitly decoding each ASCII character. */
- {
- inev.ie.kind = ASCII_KEYSTROKE_EVENT;
- inev.ie.code = keysym;
+ /* Common for all keysym input events. */
+ XSETFRAME (inev.ie.frame_or_window, f);
+ inev.ie.modifiers
+ = x_x_to_emacs_modifiers (FRAME_X_DISPLAY_INFO (f), modifiers);
+ inev.ie.timestamp = event.xkey.time;
+
+ /* First deal with keysyms which have defined
+ translations to characters. */
+ if (keysym >= 32 && keysym < 128)
+ /* Avoid explicitly decoding each ASCII character. */
+ {
+ inev.ie.kind = ASCII_KEYSTROKE_EVENT;
+ inev.ie.code = keysym;
goto done_keysym;
}
@@ -6626,18 +6637,18 @@ handle_one_xevent (dpyinfo, eventp, finish, hold_quit)
/* Now non-ASCII. */
if (HASH_TABLE_P (Vx_keysym_table)
&& (NATNUMP (c = Fgethash (make_number (keysym),
- Vx_keysym_table,
- Qnil))))
- {
- inev.ie.kind = (SINGLE_BYTE_CHAR_P (XFASTINT (c))
- ? ASCII_KEYSTROKE_EVENT
- : MULTIBYTE_CHAR_KEYSTROKE_EVENT);
- inev.ie.code = XFASTINT (c);
- goto done_keysym;
- }
-
- /* Random non-modifier sorts of keysyms. */
- if (((keysym >= XK_BackSpace && keysym <= XK_Escape)
+ Vx_keysym_table,
+ Qnil))))
+ {
+ inev.ie.kind = (SINGLE_BYTE_CHAR_P (XFASTINT (c))
+ ? ASCII_KEYSTROKE_EVENT
+ : MULTIBYTE_CHAR_KEYSTROKE_EVENT);
+ inev.ie.code = XFASTINT (c);
+ goto done_keysym;
+ }
+
+ /* Random non-modifier sorts of keysyms. */
+ if (((keysym >= XK_BackSpace && keysym <= XK_Escape)
|| keysym == XK_Delete
#ifdef XK_ISO_Left_Tab
|| (keysym >= XK_ISO_Left_Tab
@@ -6766,20 +6777,32 @@ handle_one_xevent (dpyinfo, eventp, finish, hold_quit)
copy_bufptr = coding.destination;
}
- /* Convert the input data to a sequence of
- character events. */
- for (i = 0; i < nbytes; i += len)
- {
- if (nchars == nbytes)
- c = copy_bufptr[i], len = 1;
- else
- c = STRING_CHAR_AND_LENGTH (copy_bufptr + i,
- nbytes - i, len);
- inev.ie.kind = (SINGLE_BYTE_CHAR_P (c)
- ? ASCII_KEYSTROKE_EVENT
- : MULTIBYTE_CHAR_KEYSTROKE_EVENT);
- inev.ie.code = c;
- kbd_buffer_store_event_hold (&inev.ie, hold_quit);
+ require = decoding_buffer_size (&coding, nbytes);
+ p = (unsigned char *) alloca (require);
+ coding.mode |= CODING_MODE_LAST_BLOCK;
+ /* We explicitly disable composition handling because
+ key data should not contain any composition sequence. */
+ coding.composing = COMPOSITION_DISABLED;
+ decode_coding (&coding, copy_bufptr, p, nbytes, require);
+ nbytes = coding.produced;
+ nchars = coding.produced_char;
+ copy_bufptr = p;
+
+ /* Convert the input data to a sequence of
+ character events. */
+ for (i = 0; i < nbytes; i += len)
+ {
+ if (nchars == nbytes)
+ c = copy_bufptr[i], len = 1;
+ else
+ c = STRING_CHAR_AND_LENGTH (copy_bufptr + i,
+ nbytes - i, len);
+ inev.ie.kind = (SINGLE_BYTE_CHAR_P (c)
+ ? ASCII_KEYSTROKE_EVENT
+ : MULTIBYTE_CHAR_KEYSTROKE_EVENT);
+ inev.ie.code = c;
+ kbd_buffer_store_event_hold (&inev.ie, hold_quit);
+ }
}
/* Previous code updated count by nchars rather than nbytes,
@@ -6846,7 +6869,7 @@ handle_one_xevent (dpyinfo, eventp, finish, hold_quit)
/* We may get an EnterNotify on the buttons in the toolbar. In that
case we moved out of any highlighted area and need to note this. */
if (!f && last_mouse_glyph_frame)
- note_mouse_movement (last_mouse_glyph_frame, &event);
+ note_mouse_movement (last_mouse_glyph_frame, &event.xmotion);
#endif
goto OTHER;
@@ -6879,7 +6902,7 @@ handle_one_xevent (dpyinfo, eventp, finish, hold_quit)
#ifdef USE_GTK
/* See comment in EnterNotify above */
else if (last_mouse_glyph_frame)
- note_mouse_movement (last_mouse_glyph_frame, &event);
+ note_mouse_movement (last_mouse_glyph_frame, &event.xmotion);
#endif
goto OTHER;
@@ -6922,7 +6945,13 @@ handle_one_xevent (dpyinfo, eventp, finish, hold_quit)
will be selected only when it is active. */
if (WINDOWP (window)
&& !EQ (window, last_window)
- && !EQ (window, selected_window))
+ && !EQ (window, selected_window)
+ /* For click-to-focus window managers
+ create event iff we don't leave the
+ selected frame. */
+ && (focus_follows_mouse
+ || (EQ (XWINDOW (window)->frame,
+ XWINDOW (selected_window)->frame))))
{
inev.ie.kind = SELECT_WINDOW_EVENT;
inev.ie.frame_or_window = window;
@@ -7282,8 +7311,8 @@ x_dispatch_event (event, display)
EXPECTED is nonzero if the caller knows input is available. */
static int
-XTread_socket (sd, expected, hold_quit)
- register int sd;
+XTread_socket (terminal, expected, hold_quit)
+ struct terminal *terminal;
int expected;
struct input_event *hold_quit;
{
@@ -7306,6 +7335,31 @@ XTread_socket (sd, expected, hold_quit)
++handling_signal;
+#ifdef HAVE_X_SM
+ /* Only check session manager input for the primary display. */
+ if (terminal->id == 1 && x_session_have_connection ())
+ {
+ struct input_event inev;
+ BLOCK_INPUT;
+ /* We don't need to EVENT_INIT (inev) here, as
+ x_session_check_input copies an entire input_event. */
+ if (x_session_check_input (&inev))
+ {
+ kbd_buffer_store_event_hold (&inev, hold_quit);
+ count++;
+ }
+ UNBLOCK_INPUT;
+ }
+#endif
+
+ /* For debugging, this gives a way to fake an I/O error. */
+ if (terminal->display_info.x == XTread_socket_fake_io_error)
+ {
+ XTread_socket_fake_io_error = 0;
+ x_io_error_quitter (dpyinfo->display);
+ }
+
+#if 0 /* This loop is a noop now. */
/* Find the display we are supposed to read input for.
It's the one communicating on descriptor SD. */
for (dpyinfo = x_display_list; dpyinfo; dpyinfo = dpyinfo->next)
@@ -7336,52 +7390,31 @@ XTread_socket (sd, expected, hold_quit)
#endif /* HAVE_SELECT */
#endif /* SIGIO */
#endif
-
- /* For debugging, this gives a way to fake an I/O error. */
- if (dpyinfo == XTread_socket_fake_io_error)
- {
- XTread_socket_fake_io_error = 0;
- x_io_error_quitter (dpyinfo->display);
- }
-
-#ifdef HAVE_X_SM
- {
- struct input_event inev;
- BLOCK_INPUT;
- /* We don't need to EVENT_INIT (inev) here, as
- x_session_check_input copies an entire input_event. */
- if (x_session_check_input (&inev))
- {
- kbd_buffer_store_event_hold (&inev, hold_quit);
- count++;
- }
- UNBLOCK_INPUT;
- }
+ }
#endif
#ifndef USE_GTK
- while (XPending (dpyinfo->display))
- {
- int finish;
+ while (XPending (terminal->display_info.x->display))
+ {
+ int finish;
- XNextEvent (dpyinfo->display, &event);
+ XNextEvent (terminal->display_info.x->display, &event);
#ifdef HAVE_X_I18N
- /* Filter events for the current X input method. */
- if (x_filter_event (dpyinfo, &event))
- break;
+ /* Filter events for the current X input method. */
+ if (x_filter_event (terminal->display_info.x, &event))
+ break;
#endif
- event_found = 1;
+ event_found = 1;
- count += handle_one_xevent (dpyinfo, &event, &finish, hold_quit);
+ count += handle_one_xevent (terminal->display_info.x,
+ &event, &finish, hold_quit);
- if (finish == X_EVENT_GOTO_OUT)
- goto out;
- }
-#endif /* not USE_GTK */
+ if (finish == X_EVENT_GOTO_OUT)
+ goto out;
}
-#ifdef USE_GTK
+#else /* USE_GTK */
/* For GTK we must use the GTK event loop. But XEvents gets passed
to our filter function above, and then to the big event switch.
@@ -7692,8 +7725,7 @@ x_draw_window_cursor (w, glyph_row, x, y, cursor_type, cursor_width, on_p, activ
}
#ifndef XFlush
- if (updating_frame != f)
- XFlush (FRAME_X_DISPLAY (f));
+ XFlush (FRAME_X_DISPLAY (f));
#endif
}
@@ -7931,6 +7963,8 @@ x_clear_errors (dpy)
x_error_message->string[0] = 0;
}
+#if 0 /* See comment in unwind_to_catch why calling this is a bad
+ * idea. --lorentey */
/* Close off all unclosed x_catch_errors calls. */
void
@@ -7939,6 +7973,7 @@ x_fully_uncatch_errors ()
while (x_error_message)
x_uncatch_errors ();
}
+#endif
/* Nonzero if x_catch_errors has been done and not yet canceled. */
@@ -8004,6 +8039,7 @@ x_connection_closed (dpy, error_message)
{
struct x_display_info *dpyinfo = x_display_info_for_display (dpy);
Lisp_Object frame, tail;
+ int index = SPECPDL_INDEX ();
error_msg = (char *) alloca (strlen (error_message) + 1);
strcpy (error_msg, error_message);
@@ -8015,6 +8051,44 @@ x_connection_closed (dpy, error_message)
the original message here. */
x_catch_errors (dpy);
+ /* Inhibit redisplay while frames are being deleted. */
+ specbind (Qinhibit_redisplay, Qt);
+
+ if (dpyinfo)
+ {
+ /* Protect display from being closed when we delete the last
+ frame on it. */
+ dpyinfo->reference_count++;
+ dpyinfo->terminal->reference_count++;
+ }
+
+ /* First delete frames whose mini-buffers are on frames
+ that are on the dead display. */
+ FOR_EACH_FRAME (tail, frame)
+ {
+ Lisp_Object minibuf_frame;
+ minibuf_frame
+ = WINDOW_FRAME (XWINDOW (FRAME_MINIBUF_WINDOW (XFRAME (frame))));
+ if (FRAME_X_P (XFRAME (frame))
+ && FRAME_X_P (XFRAME (minibuf_frame))
+ && ! EQ (frame, minibuf_frame)
+ && FRAME_X_DISPLAY_INFO (XFRAME (minibuf_frame)) == dpyinfo)
+ Fdelete_frame (frame, Qt);
+ }
+
+ /* Now delete all remaining frames on the dead display.
+ We are now sure none of these is used as the mini-buffer
+ for another frame that we need to delete. */
+ FOR_EACH_FRAME (tail, frame)
+ if (FRAME_X_P (XFRAME (frame))
+ && FRAME_X_DISPLAY_INFO (XFRAME (frame)) == dpyinfo)
+ {
+ /* Set this to t so that Fdelete_frame won't get confused
+ trying to find a replacement. */
+ FRAME_KBOARD (XFRAME (frame))->Vdefault_minibuffer_frame = Qt;
+ Fdelete_frame (frame, Qt);
+ }
+
/* We have to close the display to inform Xt that it doesn't
exist anymore. If we don't, Xt will continue to wait for
events from the display. As a consequence, a sequence of
@@ -8047,43 +8121,23 @@ x_connection_closed (dpy, error_message)
xg_display_close (dpyinfo->display);
#endif
- /* Indicate that this display is dead. */
if (dpyinfo)
- dpyinfo->display = 0;
-
- /* First delete frames whose mini-buffers are on frames
- that are on the dead display. */
- FOR_EACH_FRAME (tail, frame)
{
- Lisp_Object minibuf_frame;
- minibuf_frame
- = WINDOW_FRAME (XWINDOW (FRAME_MINIBUF_WINDOW (XFRAME (frame))));
- if (FRAME_X_P (XFRAME (frame))
- && FRAME_X_P (XFRAME (minibuf_frame))
- && ! EQ (frame, minibuf_frame)
- && FRAME_X_DISPLAY_INFO (XFRAME (minibuf_frame)) == dpyinfo)
- Fdelete_frame (frame, Qt);
- }
+ /* Indicate that this display is dead. */
+ dpyinfo->display = 0;
- /* Now delete all remaining frames on the dead display.
- We are now sure none of these is used as the mini-buffer
- for another frame that we need to delete. */
- FOR_EACH_FRAME (tail, frame)
- if (FRAME_X_P (XFRAME (frame))
- && FRAME_X_DISPLAY_INFO (XFRAME (frame)) == dpyinfo)
- {
- /* Set this to t so that Fdelete_frame won't get confused
- trying to find a replacement. */
- FRAME_KBOARD (XFRAME (frame))->Vdefault_minibuffer_frame = Qt;
- Fdelete_frame (frame, Qt);
- }
+ dpyinfo->reference_count--;
+ dpyinfo->terminal->reference_count--;
+ if (dpyinfo->reference_count != 0)
+ /* We have just closed all frames on this display. */
+ abort ();
- if (dpyinfo)
- x_delete_display (dpyinfo);
+ x_delete_display (dpyinfo);
+ }
x_uncatch_errors ();
- if (x_display_list == 0)
+ if (terminal_list == 0)
{
fprintf (stderr, "%s\n", error_msg);
shut_down_emacs (0, 0, Qnil);
@@ -8097,6 +8151,7 @@ x_connection_closed (dpy, error_message)
sigunblock (sigmask (SIGALRM));
TOTALLY_UNBLOCK_INPUT;
+ unbind_to (index, Qnil);
clear_waiting_for_input ();
error ("%s", error_msg);
}
@@ -8386,7 +8441,7 @@ xim_destroy_callback (xim, client_data, call_data)
FOR_EACH_FRAME (tail, frame)
{
struct frame *f = XFRAME (frame);
- if (FRAME_X_DISPLAY_INFO (f) == dpyinfo)
+ if (FRAME_X_P (f) && FRAME_X_DISPLAY_INFO (f) == dpyinfo)
{
FRAME_XIC (f) = NULL;
xic_free_xfontset (f);
@@ -8485,7 +8540,8 @@ xim_instantiate_callback (display, client_data, call_data)
{
struct frame *f = XFRAME (frame);
- if (FRAME_X_DISPLAY_INFO (f) == xim_inst->dpyinfo)
+ if (FRAME_X_P (f)
+ && FRAME_X_DISPLAY_INFO (f) == xim_inst->dpyinfo)
if (FRAME_XIC (f) == NULL)
{
create_frame_xic (f);
@@ -9709,8 +9765,8 @@ x_free_frame_resources (f)
XDestroyWindow (FRAME_X_DISPLAY (f), FRAME_X_WINDOW (f));
#endif /* !USE_X_TOOLKIT */
- unload_color (f, f->output_data.x->foreground_pixel);
- unload_color (f, f->output_data.x->background_pixel);
+ unload_color (f, FRAME_FOREGROUND_PIXEL (f));
+ unload_color (f, FRAME_BACKGROUND_PIXEL (f));
unload_color (f, f->output_data.x->cursor_pixel);
unload_color (f, f->output_data.x->cursor_foreground_pixel);
unload_color (f, f->output_data.x->border_pixel);
@@ -11008,9 +11064,12 @@ get_bits_and_offset (mask, bits, offset)
*bits = nr;
}
+/* Return 1 if display DISPLAY is available for use, 0 otherwise.
+ But don't permanently open it, just test its availability. */
+
int
x_display_ok (display)
- const char * display;
+ const char *display;
{
int dpy_ok = 1;
Display *dpy;
@@ -11023,6 +11082,10 @@ x_display_ok (display)
return dpy_ok;
}
+/* Open a connection to X display DISPLAY_NAME, and return
+ the structure that describes the open display.
+ If we cannot contact the display, return null. */
+
struct x_display_info *
x_term_init (display_name, xrm_option, resource_name)
Lisp_Object display_name;
@@ -11031,6 +11094,7 @@ x_term_init (display_name, xrm_option, resource_name)
{
int connection;
Display *dpy;
+ struct terminal *terminal;
struct x_display_info *dpyinfo;
XrmDatabase xrdb;
@@ -11042,6 +11106,9 @@ x_term_init (display_name, xrm_option, resource_name)
++x_initialized;
}
+ if (! x_display_ok (SDATA (display_name)))
+ error ("Display %s can't be opened", SDATA (display_name));
+
#ifdef USE_GTK
{
#define NUM_ARGV 10
@@ -11050,14 +11117,21 @@ x_term_init (display_name, xrm_option, resource_name)
char **argv2 = argv;
GdkAtom atom;
+#ifndef HAVE_GTK_MULTIDISPLAY
+ if (!EQ (Vinitial_window_system, intern ("x")))
+ error ("Sorry, you cannot connect to X servers with the GTK toolkit");
+#endif
+
if (x_initialized++ > 1)
{
+#ifdef HAVE_GTK_MULTIDISPLAY
/* Opening another display. If xg_display_open returns less
than zero, we are probably on GTK 2.0, which can only handle
one display. GTK 2.2 or later can handle more than one. */
if (xg_display_open (SDATA (display_name), &dpy) < 0)
+#endif
error ("Sorry, this version of GTK can only handle one display");
- }
+ }
else
{
for (argc = 0; argc < NUM_ARGV; ++argc)
@@ -11161,6 +11235,8 @@ x_term_init (display_name, xrm_option, resource_name)
dpyinfo = (struct x_display_info *) xmalloc (sizeof (struct x_display_info));
bzero (dpyinfo, sizeof *dpyinfo);
+ terminal = x_create_terminal (dpyinfo);
+
#ifdef MULTI_KBOARD
{
struct x_display_info *share;
@@ -11172,30 +11248,30 @@ x_term_init (display_name, xrm_option, resource_name)
SDATA (display_name)))
break;
if (share)
- dpyinfo->kboard = share->kboard;
+ terminal->kboard = share->terminal->kboard;
else
{
- dpyinfo->kboard = (KBOARD *) xmalloc (sizeof (KBOARD));
- init_kboard (dpyinfo->kboard);
+ terminal->kboard = (KBOARD *) xmalloc (sizeof (KBOARD));
+ init_kboard (terminal->kboard);
if (!EQ (XSYMBOL (Qvendor_specific_keysyms)->function, Qunbound))
{
char *vendor = ServerVendor (dpy);
UNBLOCK_INPUT;
- dpyinfo->kboard->Vsystem_key_alist
+ terminal->kboard->Vsystem_key_alist
= call1 (Qvendor_specific_keysyms,
vendor ? build_string (vendor) : empty_unibyte_string);
BLOCK_INPUT;
}
- dpyinfo->kboard->next_kboard = all_kboards;
- all_kboards = dpyinfo->kboard;
+ terminal->kboard->next_kboard = all_kboards;
+ all_kboards = terminal->kboard;
/* Don't let the initial kboard remain current longer than necessary.
That would cause problems if a file loaded on startup tries to
prompt in the mini-buffer. */
if (current_kboard == initial_kboard)
- current_kboard = dpyinfo->kboard;
+ current_kboard = terminal->kboard;
}
- dpyinfo->kboard->reference_count++;
+ terminal->kboard->reference_count++;
}
#endif
@@ -11210,6 +11286,11 @@ x_term_init (display_name, xrm_option, resource_name)
dpyinfo->display = dpy;
+ /* Set the name of the terminal. */
+ terminal->name = (char *) xmalloc (SBYTES (display_name) + 1);
+ strncpy (terminal->name, SDATA (display_name), SBYTES (display_name));
+ terminal->name[SBYTES (display_name)] = 0;
+
#if 0
XSetAfterFunction (x_current_display, x_trace_wire);
#endif /* ! 0 */
@@ -11505,8 +11586,10 @@ x_term_init (display_name, xrm_option, resource_name)
}
#ifdef HAVE_X_SM
- /* Only do this for the first display. */
- if (!x_session_initialized++)
+ /* Only do this for the very first display in the Emacs session.
+ Ignore X session management when Emacs was first started on a
+ tty. */
+ if (terminal->id == 1)
x_session_initialize (dpyinfo);
#endif
@@ -11515,7 +11598,7 @@ x_term_init (display_name, xrm_option, resource_name)
return dpyinfo;
}
-/* Get rid of display DPYINFO, assuming all frames are already gone,
+/* Get rid of display DPYINFO, deleting all frames on it,
and without sending any more commands to the X server. */
void
@@ -11523,6 +11606,21 @@ x_delete_display (dpyinfo)
struct x_display_info *dpyinfo;
{
int i;
+ struct terminal *t;
+
+ /* Close all frames and delete the generic struct terminal for this
+ X display. */
+ for (t = terminal_list; t; t = t->next_terminal)
+ if (t->type == output_x_window && t->display_info.x == dpyinfo)
+ {
+#ifdef HAVE_X_SM
+ /* Close X session management when we close its display. */
+ if (t->id == 1 && x_session_have_connection ())
+ x_session_close();
+#endif
+ delete_terminal (t);
+ break;
+ }
delete_keyboard_wait_descriptor (dpyinfo->connection);
@@ -11566,10 +11664,6 @@ x_delete_display (dpyinfo)
XrmDestroyDatabase (dpyinfo->xrdb);
#endif
#endif
-#ifdef MULTI_KBOARD
- if (--dpyinfo->kboard->reference_count == 0)
- delete_kboard (dpyinfo->kboard);
-#endif
#ifdef HAVE_X_I18N
if (dpyinfo->xim)
xim_close_dpy (dpyinfo);
@@ -11651,71 +11745,131 @@ x_activate_timeout_atimer ()
extern frame_parm_handler x_frame_parm_handlers[];
static struct redisplay_interface x_redisplay_interface =
-{
- x_frame_parm_handlers,
- x_produce_glyphs,
- x_write_glyphs,
- x_insert_glyphs,
- x_clear_end_of_line,
- x_scroll_run,
- x_after_update_window_line,
- x_update_window_begin,
- x_update_window_end,
- x_cursor_to,
- x_flush,
+ {
+ x_frame_parm_handlers,
+ x_produce_glyphs,
+ x_write_glyphs,
+ x_insert_glyphs,
+ x_clear_end_of_line,
+ x_scroll_run,
+ x_after_update_window_line,
+ x_update_window_begin,
+ x_update_window_end,
+ x_cursor_to,
+ x_flush,
#ifdef XFlush
- x_flush,
+ x_flush,
#else
- 0, /* flush_display_optional */
-#endif
- x_clear_window_mouse_face,
- x_get_glyph_overhangs,
- x_fix_overlapping_area,
- x_draw_fringe_bitmap,
- 0, /* define_fringe_bitmap */
- 0, /* destroy_fringe_bitmap */
- x_per_char_metric,
- x_encode_char,
- x_compute_glyph_string_overhangs,
- x_draw_glyph_string,
- x_define_frame_cursor,
- x_clear_frame_area,
- x_draw_window_cursor,
- x_draw_vertical_window_border,
- x_shift_glyphs_for_insert
-};
+ 0, /* flush_display_optional */
+#endif
+ x_clear_window_mouse_face,
+ x_get_glyph_overhangs,
+ x_fix_overlapping_area,
+ x_draw_fringe_bitmap,
+ 0, /* define_fringe_bitmap */
+ 0, /* destroy_fringe_bitmap */
+ x_per_char_metric,
+ x_encode_char,
+ x_compute_glyph_string_overhangs,
+ x_draw_glyph_string,
+ x_define_frame_cursor,
+ x_clear_frame_area,
+ x_draw_window_cursor,
+ x_draw_vertical_window_border,
+ x_shift_glyphs_for_insert
+ };
+
+
+/* This function is called when the last frame on a display is deleted. */
+void
+x_delete_terminal (struct terminal *terminal)
+{
+ struct x_display_info *dpyinfo = terminal->display_info.x;
+ int i;
+
+ /* Protect against recursive calls. Fdelete_frame in
+ delete_terminal calls us back when it deletes our last frame. */
+ if (!terminal->name)
+ return;
+
+ BLOCK_INPUT;
+ /* Free the fonts in the font table. */
+ for (i = 0; i < dpyinfo->n_fonts; i++)
+ if (dpyinfo->font_table[i].name)
+ {
+ XFreeFont (dpyinfo->display, dpyinfo->font_table[i].font);
+ }
+
+ x_destroy_all_bitmaps (dpyinfo);
+ XSetCloseDownMode (dpyinfo->display, DestroyAll);
+
+#ifdef USE_GTK
+ xg_display_close (dpyinfo->display);
+#else
+#ifdef USE_X_TOOLKIT
+ XtCloseDisplay (dpyinfo->display);
+#else
+ XCloseDisplay (dpyinfo->display);
+#endif
+#endif /* ! USE_GTK */
+
+ x_delete_display (dpyinfo);
+ UNBLOCK_INPUT;
+}
+
+/* Create a struct terminal, initialize it with the X11 specific
+ functions and make DISPLAY->TERMINAL point to it. */
+
+static struct terminal *
+x_create_terminal (struct x_display_info *dpyinfo)
+{
+ struct terminal *terminal;
+
+ terminal = create_terminal ();
+
+ terminal->type = output_x_window;
+ terminal->display_info.x = dpyinfo;
+ dpyinfo->terminal = terminal;
+
+ /* kboard is initialized in x_term_init. */
+
+ terminal->clear_frame_hook = x_clear_frame;
+ terminal->ins_del_lines_hook = x_ins_del_lines;
+ terminal->delete_glyphs_hook = x_delete_glyphs;
+ terminal->ring_bell_hook = XTring_bell;
+ terminal->reset_terminal_modes_hook = XTreset_terminal_modes;
+ terminal->set_terminal_modes_hook = XTset_terminal_modes;
+ terminal->update_begin_hook = x_update_begin;
+ terminal->update_end_hook = x_update_end;
+ terminal->set_terminal_window_hook = XTset_terminal_window;
+ terminal->read_socket_hook = XTread_socket;
+ terminal->frame_up_to_date_hook = XTframe_up_to_date;
+ terminal->mouse_position_hook = XTmouse_position;
+ terminal->frame_rehighlight_hook = XTframe_rehighlight;
+ terminal->frame_raise_lower_hook = XTframe_raise_lower;
+ terminal->fullscreen_hook = XTfullscreen_hook;
+ terminal->set_vertical_scroll_bar_hook = XTset_vertical_scroll_bar;
+ terminal->condemn_scroll_bars_hook = XTcondemn_scroll_bars;
+ terminal->redeem_scroll_bar_hook = XTredeem_scroll_bar;
+ terminal->judge_scroll_bars_hook = XTjudge_scroll_bars;
+
+ terminal->delete_frame_hook = x_destroy_window;
+ terminal->delete_terminal_hook = x_delete_terminal;
+
+ terminal->rif = &x_redisplay_interface;
+ terminal->scroll_region_ok = 1; /* We'll scroll partial frames. */
+ terminal->char_ins_del_ok = 1;
+ terminal->line_ins_del_ok = 1; /* We'll just blt 'em. */
+ terminal->fast_clear_end_of_line = 1; /* X does this well. */
+ terminal->memory_below_frame = 0; /* We don't remember what scrolls
+ off the bottom. */
+
+ return terminal;
+}
void
x_initialize ()
{
- rif = &x_redisplay_interface;
-
- clear_frame_hook = x_clear_frame;
- ins_del_lines_hook = x_ins_del_lines;
- delete_glyphs_hook = x_delete_glyphs;
- ring_bell_hook = XTring_bell;
- reset_terminal_modes_hook = XTreset_terminal_modes;
- set_terminal_modes_hook = XTset_terminal_modes;
- update_begin_hook = x_update_begin;
- update_end_hook = x_update_end;
- set_terminal_window_hook = XTset_terminal_window;
- read_socket_hook = XTread_socket;
- frame_up_to_date_hook = XTframe_up_to_date;
- mouse_position_hook = XTmouse_position;
- frame_rehighlight_hook = XTframe_rehighlight;
- frame_raise_lower_hook = XTframe_raise_lower;
- set_vertical_scroll_bar_hook = XTset_vertical_scroll_bar;
- condemn_scroll_bars_hook = XTcondemn_scroll_bars;
- redeem_scroll_bar_hook = XTredeem_scroll_bar;
- judge_scroll_bars_hook = XTjudge_scroll_bars;
- fullscreen_hook = XTfullscreen_hook;
-
- scroll_region_ok = 1; /* we'll scroll partial frames */
- char_ins_del_ok = 1;
- line_ins_del_ok = 1; /* we'll just blt 'em */
- fast_clear_end_of_line = 1; /* X does this well */
- memory_below_frame = 0; /* we don't remember what scrolls
- off the bottom */
baud_rate = 19200;
x_noop_count = 0;
@@ -11731,7 +11885,7 @@ x_initialize ()
#endif
/* Try to use interrupt input; if we can't, then start polling. */
- Fset_input_mode (Qt, Qnil, Qt, Qnil);
+ Fset_input_interrupt_mode (Qt);
#ifdef USE_X_TOOLKIT
XtToolkitInitialize ();
@@ -11762,9 +11916,11 @@ x_initialize ()
XSetIOErrorHandler (x_io_error_quitter);
/* Disable Window Change signals; they are handled by X events. */
+#if 0 /* Don't. We may want to open tty frames later. */
#ifdef SIGWINCH
signal (SIGWINCH, SIG_DFL);
#endif /* SIGWINCH */
+#endif
signal (SIGPIPE, x_connection_signal);
}
diff --git a/src/xterm.h b/src/xterm.h
index 0480b0c805..ad522c1dd7 100644
--- a/src/xterm.h
+++ b/src/xterm.h
@@ -149,6 +149,9 @@ struct x_display_info
/* Chain of all x_display_info structures. */
struct x_display_info *next;
+ /* The generic display parameters corresponding to this X display. */
+ struct terminal *terminal;
+
/* Connection number (normally a file descriptor number). */
int connection;
@@ -327,9 +330,6 @@ struct x_display_info
/* Atom used in toolkit scroll bar client messages. */
Atom Xatom_Scrollbar;
-#ifdef MULTI_KBOARD
- struct kboard *kboard;
-#endif
int cut_buffers_initialized; /* Whether we're sure they all exist */
/* The frame (if any) which has the X window that has keyboard focus.
@@ -539,8 +539,10 @@ struct x_output
/* Pixel values used for various purposes.
border_pixel may be -1 meaning use a gray tile. */
+#if 0 /* These are also defined in struct frame. Use that instead. */
unsigned long background_pixel;
unsigned long foreground_pixel;
+#endif
unsigned long cursor_pixel;
unsigned long border_pixel;
unsigned long mouse_pixel;
@@ -1001,7 +1003,6 @@ extern int x_had_errors_p P_ ((Display *));
extern int x_catching_errors P_ ((void));
extern void x_uncatch_errors P_ ((void));
extern void x_clear_errors P_ ((Display *));
-extern void x_fully_uncatch_errors P_ ((void));
extern void x_set_window_size P_ ((struct frame *, int, int, int));
extern void x_set_mouse_position P_ ((struct frame *, int, int));
extern void x_set_mouse_pixel_position P_ ((struct frame *, int, int));
@@ -1017,6 +1018,7 @@ extern void x_wm_set_size_hint P_ ((struct frame *, long, int));
extern void x_wm_set_window_state P_ ((struct frame *, int));
extern void x_wm_set_icon_pixmap P_ ((struct frame *, int));
extern void x_delete_display P_ ((struct x_display_info *));
+extern void x_delete_terminal P_ ((struct terminal *terminal));
extern void x_initialize P_ ((void));
extern unsigned long x_copy_color P_ ((struct frame *, unsigned long));
#ifdef USE_X_TOOLKIT
@@ -1117,6 +1119,7 @@ extern void widget_store_internal_border P_ ((Widget));
extern void x_session_initialize P_ ((struct x_display_info *dpyinfo));
extern int x_session_check_input P_ ((struct input_event *bufp));
extern int x_session_have_connection P_ ((void));
+extern void x_session_close P_ ((void));
#endif
#define FONT_TYPE_FOR_UNIBYTE(font, ch) 0