annotate lisp/term/bg-mouse.el @ 5127:a9c41067dd88 ben-lisp-object

more cleanups, terminology clarification, lots of doc work -------------------- ChangeLog entries follow: -------------------- man/ChangeLog addition: 2010-03-05 Ben Wing <ben@xemacs.org> * internals/internals.texi (Introduction to Allocation): * internals/internals.texi (Integers and Characters): * internals/internals.texi (Allocation from Frob Blocks): * internals/internals.texi (lrecords): * internals/internals.texi (Low-level allocation): Rewrite section on allocation of Lisp objects to reflect the new reality. Remove references to nonexistent XSETINT and XSETCHAR. modules/ChangeLog addition: 2010-03-05 Ben Wing <ben@xemacs.org> * postgresql/postgresql.c (allocate_pgconn): * postgresql/postgresql.c (allocate_pgresult): * postgresql/postgresql.h (struct Lisp_PGconn): * postgresql/postgresql.h (struct Lisp_PGresult): * ldap/eldap.c (allocate_ldap): * ldap/eldap.h (struct Lisp_LDAP): Same changes as in src/ dir. See large log there in ChangeLog, but basically: ALLOC_LISP_OBJECT -> ALLOC_NORMAL_LISP_OBJECT LISP_OBJECT_HEADER -> NORMAL_LISP_OBJECT_HEADER ../hlo/src/ChangeLog addition: 2010-03-05 Ben Wing <ben@xemacs.org> * alloc.c: * alloc.c (old_alloc_sized_lcrecord): * alloc.c (very_old_free_lcrecord): * alloc.c (copy_lisp_object): * alloc.c (zero_sized_lisp_object): * alloc.c (zero_nonsized_lisp_object): * alloc.c (lisp_object_storage_size): * alloc.c (free_normal_lisp_object): * alloc.c (FREE_FIXED_TYPE_WHEN_NOT_IN_GC): * alloc.c (ALLOC_FROB_BLOCK_LISP_OBJECT): * alloc.c (Fcons): * alloc.c (noseeum_cons): * alloc.c (make_float): * alloc.c (make_bignum): * alloc.c (make_bignum_bg): * alloc.c (make_ratio): * alloc.c (make_ratio_bg): * alloc.c (make_ratio_rt): * alloc.c (make_bigfloat): * alloc.c (make_bigfloat_bf): * alloc.c (size_vector): * alloc.c (make_compiled_function): * alloc.c (Fmake_symbol): * alloc.c (allocate_extent): * alloc.c (allocate_event): * alloc.c (make_key_data): * alloc.c (make_button_data): * alloc.c (make_motion_data): * alloc.c (make_process_data): * alloc.c (make_timeout_data): * alloc.c (make_magic_data): * alloc.c (make_magic_eval_data): * alloc.c (make_eval_data): * alloc.c (make_misc_user_data): * alloc.c (Fmake_marker): * alloc.c (noseeum_make_marker): * alloc.c (size_string_direct_data): * alloc.c (make_uninit_string): * alloc.c (make_string_nocopy): * alloc.c (mark_lcrecord_list): * alloc.c (alloc_managed_lcrecord): * alloc.c (free_managed_lcrecord): * alloc.c (sweep_lcrecords_1): * alloc.c (malloced_storage_size): * buffer.c (allocate_buffer): * buffer.c (compute_buffer_usage): * buffer.c (DEFVAR_BUFFER_LOCAL_1): * buffer.c (nuke_all_buffer_slots): * buffer.c (common_init_complex_vars_of_buffer): * buffer.h (struct buffer_text): * buffer.h (struct buffer): * bytecode.c: * bytecode.c (make_compiled_function_args): * bytecode.c (size_compiled_function_args): * bytecode.h (struct compiled_function_args): * casetab.c (allocate_case_table): * casetab.h (struct Lisp_Case_Table): * charset.h (struct Lisp_Charset): * chartab.c (fill_char_table): * chartab.c (Fmake_char_table): * chartab.c (make_char_table_entry): * chartab.c (copy_char_table_entry): * chartab.c (Fcopy_char_table): * chartab.c (put_char_table): * chartab.h (struct Lisp_Char_Table_Entry): * chartab.h (struct Lisp_Char_Table): * console-gtk-impl.h (struct gtk_device): * console-gtk-impl.h (struct gtk_frame): * console-impl.h (struct console): * console-msw-impl.h (struct Lisp_Devmode): * console-msw-impl.h (struct mswindows_device): * console-msw-impl.h (struct msprinter_device): * console-msw-impl.h (struct mswindows_frame): * console-msw-impl.h (struct mswindows_dialog_id): * console-stream-impl.h (struct stream_console): * console-stream.c (stream_init_console): * console-tty-impl.h (struct tty_console): * console-tty-impl.h (struct tty_device): * console-tty.c (allocate_tty_console_struct): * console-x-impl.h (struct x_device): * console-x-impl.h (struct x_frame): * console.c (allocate_console): * console.c (nuke_all_console_slots): * console.c (DEFVAR_CONSOLE_LOCAL_1): * console.c (common_init_complex_vars_of_console): * data.c (make_weak_list): * data.c (make_weak_box): * data.c (make_ephemeron): * database.c: * database.c (struct Lisp_Database): * database.c (allocate_database): * database.c (finalize_database): * device-gtk.c (allocate_gtk_device_struct): * device-impl.h (struct device): * device-msw.c: * device-msw.c (mswindows_init_device): * device-msw.c (msprinter_init_device): * device-msw.c (finalize_devmode): * device-msw.c (allocate_devmode): * device-tty.c (allocate_tty_device_struct): * device-x.c (allocate_x_device_struct): * device.c: * device.c (nuke_all_device_slots): * device.c (allocate_device): * dialog-msw.c (handle_question_dialog_box): * elhash.c: * elhash.c (struct Lisp_Hash_Table): * elhash.c (finalize_hash_table): * elhash.c (make_general_lisp_hash_table): * elhash.c (Fcopy_hash_table): * elhash.h (htentry): * emacs.c (main_1): * eval.c: * eval.c (size_multiple_value): * event-stream.c (finalize_command_builder): * event-stream.c (allocate_command_builder): * event-stream.c (free_command_builder): * event-stream.c (event_stream_generate_wakeup): * event-stream.c (event_stream_resignal_wakeup): * event-stream.c (event_stream_disable_wakeup): * event-stream.c (event_stream_wakeup_pending_p): * events.h (struct Lisp_Timeout): * events.h (struct command_builder): * extents-impl.h: * extents-impl.h (struct extent_auxiliary): * extents-impl.h (struct extent_info): * extents-impl.h (set_extent_no_chase_aux_field): * extents-impl.h (set_extent_no_chase_normal_field): * extents.c: * extents.c (gap_array_marker): * extents.c (gap_array): * extents.c (extent_list_marker): * extents.c (extent_list): * extents.c (stack_of_extents): * extents.c (gap_array_make_marker): * extents.c (extent_list_make_marker): * extents.c (allocate_extent_list): * extents.c (SLOT): * extents.c (mark_extent_auxiliary): * extents.c (allocate_extent_auxiliary): * extents.c (attach_extent_auxiliary): * extents.c (size_gap_array): * extents.c (finalize_extent_info): * extents.c (allocate_extent_info): * extents.c (uninit_buffer_extents): * extents.c (allocate_soe): * extents.c (copy_extent): * extents.c (vars_of_extents): * extents.h: * faces.c (allocate_face): * faces.h (struct Lisp_Face): * faces.h (struct face_cachel): * file-coding.c: * file-coding.c (finalize_coding_system): * file-coding.c (sizeof_coding_system): * file-coding.c (Fcopy_coding_system): * file-coding.h (struct Lisp_Coding_System): * file-coding.h (MARKED_SLOT): * fns.c (size_bit_vector): * font-mgr.c: * font-mgr.c (finalize_fc_pattern): * font-mgr.c (print_fc_pattern): * font-mgr.c (Ffc_pattern_p): * font-mgr.c (Ffc_pattern_create): * font-mgr.c (Ffc_name_parse): * font-mgr.c (Ffc_name_unparse): * font-mgr.c (Ffc_pattern_duplicate): * font-mgr.c (Ffc_pattern_add): * font-mgr.c (Ffc_pattern_del): * font-mgr.c (Ffc_pattern_get): * font-mgr.c (fc_config_create_using): * font-mgr.c (fc_strlist_to_lisp_using): * font-mgr.c (fontset_to_list): * font-mgr.c (Ffc_config_p): * font-mgr.c (Ffc_config_up_to_date): * font-mgr.c (Ffc_config_build_fonts): * font-mgr.c (Ffc_config_get_cache): * font-mgr.c (Ffc_config_get_fonts): * font-mgr.c (Ffc_config_set_current): * font-mgr.c (Ffc_config_get_blanks): * font-mgr.c (Ffc_config_get_rescan_interval): * font-mgr.c (Ffc_config_set_rescan_interval): * font-mgr.c (Ffc_config_app_font_add_file): * font-mgr.c (Ffc_config_app_font_add_dir): * font-mgr.c (Ffc_config_app_font_clear): * font-mgr.c (size): * font-mgr.c (Ffc_config_substitute): * font-mgr.c (Ffc_font_render_prepare): * font-mgr.c (Ffc_font_match): * font-mgr.c (Ffc_font_sort): * font-mgr.c (finalize_fc_config): * font-mgr.c (print_fc_config): * font-mgr.h: * font-mgr.h (struct fc_pattern): * font-mgr.h (XFC_PATTERN): * font-mgr.h (struct fc_config): * font-mgr.h (XFC_CONFIG): * frame-gtk.c (allocate_gtk_frame_struct): * frame-impl.h (struct frame): * frame-msw.c (mswindows_init_frame_1): * frame-x.c (allocate_x_frame_struct): * frame.c (nuke_all_frame_slots): * frame.c (allocate_frame_core): * gc.c: * gc.c (GC_CHECK_NOT_FREE): * glyphs.c (finalize_image_instance): * glyphs.c (allocate_image_instance): * glyphs.c (Fcolorize_image_instance): * glyphs.c (allocate_glyph): * glyphs.c (unmap_subwindow_instance_cache_mapper): * glyphs.c (register_ignored_expose): * glyphs.h (struct Lisp_Image_Instance): * glyphs.h (struct Lisp_Glyph): * glyphs.h (struct glyph_cachel): * glyphs.h (struct expose_ignore): * gui.c (allocate_gui_item): * gui.h (struct Lisp_Gui_Item): * keymap.c (struct Lisp_Keymap): * keymap.c (make_keymap): * lisp.h: * lisp.h (struct Lisp_String_Direct_Data): * lisp.h (struct Lisp_String_Indirect_Data): * lisp.h (struct Lisp_Vector): * lisp.h (struct Lisp_Bit_Vector): * lisp.h (DECLARE_INLINE_LISP_BIT_VECTOR): * lisp.h (struct weak_box): * lisp.h (struct ephemeron): * lisp.h (struct weak_list): * lrecord.h: * lrecord.h (struct lrecord_implementation): * lrecord.h (MC_ALLOC_CALL_FINALIZER): * lrecord.h (struct lcrecord_list): * lstream.c (finalize_lstream): * lstream.c (sizeof_lstream): * lstream.c (Lstream_new): * lstream.c (Lstream_delete): * lstream.h (struct lstream): * marker.c: * marker.c (finalize_marker): * marker.c (compute_buffer_marker_usage): * mule-charset.c: * mule-charset.c (make_charset): * mule-charset.c (compute_charset_usage): * objects-impl.h (struct Lisp_Color_Instance): * objects-impl.h (struct Lisp_Font_Instance): * objects-tty-impl.h (struct tty_color_instance_data): * objects-tty-impl.h (struct tty_font_instance_data): * objects-tty.c (tty_initialize_color_instance): * objects-tty.c (tty_initialize_font_instance): * objects.c (finalize_color_instance): * objects.c (Fmake_color_instance): * objects.c (finalize_font_instance): * objects.c (Fmake_font_instance): * objects.c (reinit_vars_of_objects): * opaque.c: * opaque.c (sizeof_opaque): * opaque.c (make_opaque_ptr): * opaque.c (free_opaque_ptr): * opaque.h: * opaque.h (Lisp_Opaque): * opaque.h (Lisp_Opaque_Ptr): * print.c (printing_unreadable_lcrecord): * print.c (external_object_printer): * print.c (debug_p4): * process.c (finalize_process): * process.c (make_process_internal): * procimpl.h (struct Lisp_Process): * rangetab.c (Fmake_range_table): * rangetab.c (Fcopy_range_table): * rangetab.h (struct Lisp_Range_Table): * scrollbar.c: * scrollbar.c (create_scrollbar_instance): * scrollbar.c (compute_scrollbar_instance_usage): * scrollbar.h (struct scrollbar_instance): * specifier.c (finalize_specifier): * specifier.c (sizeof_specifier): * specifier.c (set_specifier_caching): * specifier.h (struct Lisp_Specifier): * specifier.h (struct specifier_caching): * symeval.h: * symeval.h (SYMBOL_VALUE_MAGIC_P): * symeval.h (DEFVAR_SYMVAL_FWD): * symsinit.h: * syntax.c (init_buffer_syntax_cache): * syntax.h (struct syntax_cache): * toolbar.c: * toolbar.c (allocate_toolbar_button): * toolbar.c (update_toolbar_button): * toolbar.h (struct toolbar_button): * tooltalk.c (struct Lisp_Tooltalk_Message): * tooltalk.c (make_tooltalk_message): * tooltalk.c (struct Lisp_Tooltalk_Pattern): * tooltalk.c (make_tooltalk_pattern): * ui-gtk.c: * ui-gtk.c (allocate_ffi_data): * ui-gtk.c (emacs_gtk_object_finalizer): * ui-gtk.c (allocate_emacs_gtk_object_data): * ui-gtk.c (allocate_emacs_gtk_boxed_data): * ui-gtk.h: * window-impl.h (struct window): * window-impl.h (struct window_mirror): * window.c (finalize_window): * window.c (allocate_window): * window.c (new_window_mirror): * window.c (mark_window_as_deleted): * window.c (make_dummy_parent): * window.c (compute_window_mirror_usage): * window.c (compute_window_usage): Overall point of this change and previous ones in this repository: (1) Introduce new, clearer terminology: everything other than int or char is a "record" object, which comes in two types: "normal objects" and "frob-block objects". Fix up all places that referred to frob-block objects as "simple", "basic", etc. (2) Provide an advertised interface for doing operations on Lisp objects, including creating new types, that is clean and consistent in its naming, uses the above-referenced terms and avoids referencing "lrecords", "old lcrecords", etc., which should hide under the surface. (3) Make the size_in_bytes and finalizer methods take a Lisp_Object rather than a void * for consistency with other methods. (4) Separate finalizer method into finalizer and disksaver, so that normal finalize methods don't have to worry about disksaving. Other specifics: (1) Renaming: LISP_OBJECT_HEADER -> NORMAL_LISP_OBJECT_HEADER ALLOC_LISP_OBJECT -> ALLOC_NORMAL_LISP_OBJECT implementation->basic_p -> implementation->frob_block_p ALLOCATE_FIXED_TYPE_AND_SET_IMPL -> ALLOC_FROB_BLOCK_LISP_OBJECT *FCCONFIG*, wrap_fcconfig -> *FC_CONFIG*, wrap_fc_config *FCPATTERN*, wrap_fcpattern -> *FC_PATTERN*, wrap_fc_pattern (the last two changes make the naming of these macros consistent with the naming of all other macros, since the objects are named fc-config and fc-pattern with a hyphen) (2) Lots of documentation fixes in lrecord.h. (3) Eliminate macros for copying, freeing, zeroing objects, getting their storage size. Instead, new functions: zero_sized_lisp_object() zero_nonsized_lisp_object() lisp_object_storage_size() free_normal_lisp_object() (copy_lisp_object() already exists) LISP_OBJECT_FROB_BLOCK_P() (actually a macro) Eliminated: free_lrecord() zero_lrecord() copy_lrecord() copy_sized_lrecord() old_copy_lcrecord() old_copy_sized_lcrecord() old_zero_lcrecord() old_zero_sized_lcrecord() LISP_OBJECT_STORAGE_SIZE() COPY_SIZED_LISP_OBJECT() COPY_SIZED_LCRECORD() COPY_LISP_OBJECT() ZERO_LISP_OBJECT() FREE_LISP_OBJECT() (4) Catch the remaining places where lrecord stuff was used directly and use the advertised interface, e.g. alloc_sized_lrecord() -> ALLOC_SIZED_LISP_OBJECT(). (5) Make certain statically-declared pseudo-objects (buffer_local_flags, console_local_flags) have their lheader initialized correctly, so things like copy_lisp_object() can work on them. Make extent_auxiliary_defaults a proper heap object Vextent_auxiliary_defaults, and make extent auxiliaries dumpable so that this object can be dumped. allocate_extent_auxiliary() now just creates the object, and attach_extent_auxiliary() creates an extent auxiliary and attaches to an extent, like the old allocate_extent_auxiliary(). (6) Create EXTENT_AUXILIARY_SLOTS macro, similar to the foo-slots.h files but in a macro instead of a file. The purpose is to avoid duplication when iterating over all the slots in an extent auxiliary. Use it. (7) In lstream.c, don't zero out object after allocation because allocation routines take care of this. (8) In marker.c, fix a mistake in computing marker overhead. (9) In print.c, clean up printing_unreadable_lcrecord(), external_object_printer() to avoid lots of ifdef NEW_GC's. (10) Separate toolbar-button allocation into a separate allocate_toolbar_button() function for use in the example code in lrecord.h.
author Ben Wing <ben@xemacs.org>
date Fri, 05 Mar 2010 04:08:17 -0600
parents d682c0f82a71
children 85bd42a1e544 308d34e9f07d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 ;;; bg-mouse.el --- GNU Emacs code for BBN Bitgraph mouse.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3 ;; Copyright (C) Free Software Foundation, Inc. Oct 1985.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
5 ;; Author: John Robinson <jr@bbn-unix.arpa>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
6 ;; Stephen Gildea <gildea@bbn.com>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
7 ;; Maintainer: FSF
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8 ;; Keywords: hardware
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
9
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
10 ;; This file is part of GNU Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
11
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
12 ;; GNU Emacs is free software; you can redistribute it and/or modify
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13 ;; it under the terms of the GNU General Public License as published by
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 ;; the Free Software Foundation; either version 2, or (at your option)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 ;; any later version.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17 ;; GNU Emacs is distributed in the hope that it will be useful,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20 ;; GNU General Public License for more details.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
22 ;; You should have received a copy of the GNU General Public License
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
23 ;; along with GNU Emacs; see the file COPYING. If not, write to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
24 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26 ;;; Code:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
27
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
28 ;;; #### utterly broken. I've put in hacks so we don't get byte-comp
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
29 ;;; warnings, but this shit should go NOW. --ben
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
30
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31 ;;; Original version by John Robinson (jr@bbn-unix.arpa, bbncca!jr), Oct 1985
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32 ;;; Modularized and enhanced by gildea@bbn.com Nov 1987
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33 ;;; Time stamp <89/03/21 14:27:08 gildea>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
35 ;;; User customization option:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
36
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37 (defvar bg-mouse-fast-select-window nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 "*Non-nil for mouse hits to select new window, then execute; else just select.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40 ;;; These numbers are summed to make the index into the mouse-map.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41 ;;; The low three bits correspond to what the mouse actually sends.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
42 (defconst bg-button-r 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
43 (defconst bg-button-m 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
44 (defconst bg-button-c 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
45 (defconst bg-button-l 4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46 (defconst bg-in-modeline 8)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
47 (defconst bg-in-scrollbar 16)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48 (defconst bg-in-minibuf 24)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
49
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
50 ;;; semicolon screws up indenting, so use this instead
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51 (defconst semicolon ?\;)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53 ;;; Defuns:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
55 ;; #### bunch of crap.
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
56 (globally-declare-boundp 'mouse-map)
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
57
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
58 (defun bg-window-edges (&optional win)
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
59 (error "not implemented")
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
60 (window-pixel-edges win))
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
61
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
62 (defun bg-mouse-report (prefix-arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
63 "Read, parse, and execute a BBN BitGraph mouse click.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 L-- move point | These apply for mouse click in a window.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 --R set mark | If bg-mouse-fast-select-window is nil,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67 L-R kill region | these commands on a nonselected window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 -C- move point and yank | just select that window.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
69 LC- yank-pop |
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 -CR or LCR undo | \"Scroll bar\" is right-hand window column.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
71
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72 on modeline: on \"scroll bar\": in minibuffer:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 L-- scroll-up line to top execute-extended-command
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
74 --R scroll-down line to bottom eval-expression
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
75 -C- proportional goto-char line to middle suspend-emacs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 To reinitialize the mouse if the terminal is reset, type ESC : RET"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
78 (interactive "P")
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
79 (declare (special bg-mouse-x bg-mouse-y bg-cursor-window))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
80 (bg-get-tty-num semicolon)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
81 (let*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
82 ((screen-mouse-x (min (1- (frame-width)) ;don't hit column 86!
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
83 (/ (bg-get-tty-num semicolon) 9)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
84 (screen-mouse-y (- (1- (frame-height)) ;assume default font size.
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
85 (/ (bg-get-tty-num semicolon) 16)))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86 (bg-mouse-buttons (% (bg-get-tty-num ?c) 8))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
87 (bg-mouse-window (bg-window-from-x-y screen-mouse-x screen-mouse-y))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
88 (bg-cursor-window (selected-window))
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
89 (edges (bg-window-edges bg-mouse-window))
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
90 (minibuf-p (= screen-mouse-y (1- (frame-height))))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
91 (in-modeline-p (and (not minibuf-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
92 (= screen-mouse-y (1- (nth 3 edges)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
93 (in-scrollbar-p (and (not minibuf-p) (not in-modeline-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
94 (>= screen-mouse-x (1- (nth 2 edges)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
95 (same-window-p (eq bg-mouse-window bg-cursor-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
96 (in-minibuf-p (and minibuf-p
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
97 (not bg-mouse-window))) ;minibuf must be inactive
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
98 (bg-mode-bits (+ (if in-minibuf-p bg-in-minibuf 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
99 (if in-modeline-p bg-in-modeline 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
100 (if in-scrollbar-p bg-in-scrollbar 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101 (bg-command
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
102 (lookup-key mouse-map
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
103 (char-to-string (+ bg-mode-bits bg-mouse-buttons))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
104 (bg-mouse-x (- screen-mouse-x (nth 0 edges)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
105 (bg-mouse-y (- screen-mouse-y (nth 1 edges))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106 (cond ((or in-modeline-p in-scrollbar-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
107 (select-window bg-mouse-window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 (bg-command-execute bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109 (select-window bg-cursor-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110 ((or same-window-p in-minibuf-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 (bg-command-execute bg-command))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112 (t ;in another window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
113 (select-window bg-mouse-window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
114 (if bg-mouse-fast-select-window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
115 (bg-command-execute bg-command)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
116 )))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119 ;;; Library of commands:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
120
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
121 (defun bg-set-point ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122 "Move point to location of BitGraph mouse."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123 (interactive)
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
124 (declare (special bg-mouse-x bg-mouse-y))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
125 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
126 (setq this-command 'next-line) ;make subsequent line moves work
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
127 (setq temporary-goal-column bg-mouse-x))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
128
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
129 (defun bg-set-mark ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
130 "Set mark at location of BitGraph mouse."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
131 (interactive)
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
132 (declare (special bg-mouse-x bg-mouse-y))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
133 (push-mark)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
135 (exchange-point-and-mark))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
136
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
137 (defun bg-yank ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
138 "Move point to location of BitGraph mouse and yank."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
139 (interactive "*")
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
140 (declare (special bg-mouse-x bg-mouse-y))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
141 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
142 (setq this-command 'yank)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
143 (yank))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
144
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
145 (defun yank-pop-1 ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
146 (interactive "*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
147 (yank-pop 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
148
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
149 (defun bg-yank-or-pop ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
150 "Move point to location of BitGraph mouse and yank. If last command
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
151 was a yank, do a yank-pop."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
152 (interactive "*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
153 (if (eql last-command 'yank)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
154 (yank-pop 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155 (bg-yank)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
157 ;;; In 18.51, Emacs Lisp doesn't provide most-positive-fixnum
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158 (defconst bg-most-positive-fixnum 8388607)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 (defun bg-move-by-percentage ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161 "Go to location in buffer that is the same percentage of the way
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
162 through the buffer as the BitGraph mouse's X position in the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
163 (interactive)
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
164 (declare (special bg-mouse-x bg-mouse-y))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
165 ;; check carefully for overflow in intermediate calculations
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
166 (goto-char
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
167 (cond ((zerop bg-mouse-x)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
169 ((< (buffer-size) (/ bg-most-positive-fixnum bg-mouse-x))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
170 ;; no danger of overflow: compute it exactly
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
171 (/ (* bg-mouse-x (buffer-size))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
172 (1- (window-width))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
173 (t
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
174 ;; overflow possible: approximate
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
175 (* (/ (buffer-size) (1- (window-width)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
176 bg-mouse-x))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
177 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
178 (what-cursor-position))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
179
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
180 (defun bg-mouse-line-to-top ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
181 "Scroll the line pointed to by the BitGraph mouse to the top of the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
182 (interactive)
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
183 (declare (special bg-mouse-x bg-mouse-y))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
184 (scroll-up bg-mouse-y))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
185
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
186 (defun bg-mouse-line-to-center ()
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
187 "Scroll the line pointed to by the BitGraph mouse to the center
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
188 of the window."
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
189 (interactive)
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
190 (declare (special bg-mouse-x bg-mouse-y))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
191 (scroll-up (/ (+ 2 bg-mouse-y bg-mouse-y (- (window-height))) 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
192
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
193 (defun bg-mouse-line-to-bottom ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
194 "Scroll the line pointed to by the mouse to the bottom of the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
195 (interactive)
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
196 (declare (special bg-mouse-x bg-mouse-y))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
197 (scroll-up (+ bg-mouse-y (- 2 (window-height)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
198
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
199 (defun bg-kill-region ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
200 (interactive "*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
201 (kill-region (region-beginning) (region-end)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
202
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
203 (defun bg-insert-moused-sexp ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
204 "Insert a copy of the word (actually sexp) that the mouse is pointing at.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
205 Sexp is inserted into the buffer at point (where the text cursor is)."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
206 (interactive)
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
207 (declare (special bg-mouse-x bg-mouse-y bg-cursor-window))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
208 (let ((moused-text
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
209 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
210 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
211 (if (looking-at "\\s)")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
212 (forward-char 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
213 (forward-sexp 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
214 (buffer-substring (save-excursion (backward-sexp 1) (point))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
215 (point)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
216 (select-window bg-cursor-window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
217 (delete-horizontal-space)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
218 (cond
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
219 ((bolp)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
220 (indent-according-to-mode))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
221 ;; In Lisp assume double-quote is closing; in Text assume opening.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
222 ;; Why? Because it does the right thing most often.
446
1ccc32a20af4 Import from CVS: tag r21-2-38
cvs
parents: 444
diff changeset
223 ((save-excursion (backward-char 1)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
224 (and (not (looking-at "\\s\""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
225 (looking-at "[`'\"\\]\\|\\s(")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
226 nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
227 (t
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
228 (insert-string " ")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
229 (insert-string moused-text)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
230 (or (eolp)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
231 (looking-at "\\s.\\|\\s)")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
232 (and (looking-at "'") (looking-at "\\sw")) ;hack for text mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
233 (save-excursion (insert-string " ")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
234
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
235 ;;; Utility functions:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
236
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
237 (defun bg-get-tty-num (term-char)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
238 "Read from terminal until TERM-CHAR is read, and return intervening number.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
239 If non-numeric not matching TERM-CHAR, reprogram the mouse and signal an error."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
240 (let
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
241 ((num 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
242 (char (- (read-char) 48)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
243 (while (and (>= char 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
244 (<= char 9))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
245 (setq num (+ (* num 10) char))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
246 (setq char (- (read-char) 48)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
247 (or (eq term-char (+ char 48))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
248 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
249 (bg-program-mouse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
250 (error
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
251 "Invalid data format in bg-mouse command: mouse reinitialized.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
252 num))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
253
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
254 ;;; Note that this fails in the minibuf because move-to-column doesn't
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
255 ;;; allow for the width of the prompt.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
256 (defun bg-move-point-to-x-y (x y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
257 "Position cursor in window coordinates.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
258 X and Y are 0-based character positions in the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
259 (move-to-window-line y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
260 ;; if not on a wrapped line, zero-column will be 0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
261 (let ((zero-column (current-column))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
262 (scroll-offset (window-hscroll)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
263 ;; scrolling takes up column 0 to display the $
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
264 (if (> scroll-offset 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
265 (setq scroll-offset (1- scroll-offset)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
266 (move-to-column (+ zero-column scroll-offset x))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
267 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
268
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
269 ;;; Returns the window that screen position (x, y) is in or nil if none,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
270 ;;; meaning we are in the echo area with a non-active minibuffer.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
271 ;;; If coordinates-in-window-p were not in an X-windows-specific file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
272 ;;; we could use that. In Emacs 19 can even use locate-window-from-coordinates
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
273 (defun bg-window-from-x-y (x y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
274 "Find window corresponding to screen coordinates.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
275 X and Y are 0-based character positions on the screen."
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
276 (let ((edges (bg-window-edges))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
277 (window nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
278 (while (and (not (eq window (selected-window)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
279 (or (< y (nth 1 edges))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
280 (>= y (nth 3 edges))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
281 (< x (nth 0 edges))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
282 (>= x (nth 2 edges))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
283 (setq window (next-window window))
772
d682c0f82a71 [xemacs-hg @ 2002-03-13 10:00:06 by ben]
ben
parents: 446
diff changeset
284 (setq edges (bg-window-edges window)))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
285 (cond ((eq window (selected-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
286 nil) ;we've looped: not found
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
287 ((not window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
288 (selected-window)) ;just starting: current window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
289 (t
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
290 window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
291 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
292
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
293 (defun bg-command-execute (bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
294 (if (commandp bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
295 (command-execute bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
296 (ding)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
297
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
298 (defun bg-program-mouse ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
299 (send-string-to-terminal "\e:0;7;;;360;512;9;16;9;16c"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
300
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
301 ;;; Note that the doc string for mouse-map (as defined in subr.el)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
302 ;;; says it is for the X-window mouse. This is wrong; that keymap
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
303 ;;; should be used for your mouse no matter what terminal you have.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
304
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
305 (or (keymapp mouse-map)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
306 (setq mouse-map (make-keymap)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
307
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
308 (defun bind-bg-mouse-click (click-code function)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
309 "Bind bg-mouse CLICK-CODE to run FUNCTION."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
310 (define-key mouse-map (char-to-string click-code) function))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
311
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
312 (bind-bg-mouse-click bg-button-l 'bg-set-point)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
313 (bind-bg-mouse-click bg-button-m 'bg-yank)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
314 (bind-bg-mouse-click bg-button-r 'bg-set-mark)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
315 (bind-bg-mouse-click (+ bg-button-l bg-button-m) 'yank-pop-1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
316 (bind-bg-mouse-click (+ bg-button-l bg-button-r) 'bg-kill-region)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
317 (bind-bg-mouse-click (+ bg-button-m bg-button-r) 'undo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
318 (bind-bg-mouse-click (+ bg-button-l bg-button-m bg-button-r) 'undo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
319 (bind-bg-mouse-click (+ bg-in-modeline bg-button-l) 'scroll-up)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
320 (bind-bg-mouse-click (+ bg-in-modeline bg-button-m) 'bg-move-by-percentage)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
321 (bind-bg-mouse-click (+ bg-in-modeline bg-button-r) 'scroll-down)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
322 (bind-bg-mouse-click (+ bg-in-scrollbar bg-button-l) 'bg-mouse-line-to-top)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
323 (bind-bg-mouse-click (+ bg-in-scrollbar bg-button-m) 'bg-mouse-line-to-center)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
324 (bind-bg-mouse-click (+ bg-in-scrollbar bg-button-r) 'bg-mouse-line-to-bottom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
325 (bind-bg-mouse-click (+ bg-in-minibuf bg-button-l) 'execute-extended-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
326 (bind-bg-mouse-click (+ bg-in-minibuf bg-button-m) 'suspend-emacs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
327 (bind-bg-mouse-click (+ bg-in-minibuf bg-button-r) 'eval-expression)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
328
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
329 (provide 'bg-mouse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
330
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
331 ;;; bg-mouse.el ends here