Mercurial > hg > xemacs-beta
view man/lispref/maps.texi @ 939:025200a2163c
[xemacs-hg @ 2002-07-31 07:23:39 by michaels]
2002-07-17 Marcus Crestani <crestani@informatik.uni-tuebingen.de>
Markus Kaltenbach <makalten@informatik.uni-tuebingen.de>
Mike Sperber <mike@xemacs.org>
configure flag to turn these changes on: --use-kkcc
First we added a dumpable flag to lrecord_implementation. It shows,
if the object is dumpable and should be processed by the dumper.
* lrecord.h (struct lrecord_implementation): added dumpable flag
(MAKE_LRECORD_IMPLEMENTATION): fitted the different makro definitions
to the new lrecord_implementation and their calls.
Then we changed mark_object, that it no longer needs a mark method for
those types that have pdump descritions.
* alloc.c:
(mark_object): If the object has a description, the new mark algorithm
is called, and the object is marked according to its description.
Otherwise it uses the mark method like before.
These procedures mark objects according to their descriptions. They
are modeled on the corresponding pdumper procedures.
(mark_with_description):
(get_indirect_count):
(structure_size):
(mark_struct_contents):
These procedures still call mark_object, this is needed while there are
Lisp_Objects without descriptions left.
We added pdump descriptions for many Lisp_Objects:
* extents.c: extent_auxiliary_description
* database.c: database_description
* gui.c: gui_item_description
* scrollbar.c: scrollbar_instance_description
* toolbar.c: toolbar_button_description
* event-stream.c: command_builder_description
* mule-charset.c: charset_description
* device-msw.c: devmode_description
* dialog-msw.c: mswindows_dialog_id_description
* eldap.c: ldap_description
* postgresql.c: pgconn_description
pgresult_description
* tooltalk.c: tooltalk_message_description
tooltalk_pattern_description
* ui-gtk.c: emacs_ffi_description
emacs_gtk_object_description
* events.c:
* events.h:
* event-stream.c:
* event-Xt.c:
* event-gtk.c:
* event-tty.c:
To write a pdump description for Lisp_Event, we converted every struct
in the union event to a Lisp_Object. So we created nine new
Lisp_Objects: Lisp_Key_Data, Lisp_Button_Data, Lisp_Motion_Data,
Lisp_Process_Data, Lisp_Timeout_Data, Lisp_Eval_Data,
Lisp_Misc_User_Data, Lisp_Magic_Data, Lisp_Magic_Eval_Data.
We also wrote makro selectors and mutators for the fields of the new
designed Lisp_Event and added everywhere these new abstractions.
We implemented XD_UNION support in (mark_with_description), so
we can describe exspecially console/device specific data with XD_UNION.
To describe with XD_UNION, we added a field to these objects, which
holds the variant type of the object. This field is initialized in
the appendant constructor. The variant is an integer, it has also to
be described in an description, if XD_UNION is used.
XD_UNION is used in following descriptions:
* console.c: console_description
(get_console_variant): returns the variant
(create_console): added variant initialization
* console.h (console_variant): the different console types
* console-impl.h (struct console): added enum console_variant contype
* device.c: device_description
(Fmake_device): added variant initialization
* device-impl.h (struct device): added enum console_variant devtype
* objects.c: image_instance_description
font_instance_description
(Fmake_color_instance): added variant initialization
(Fmake_font_instance): added variant initialization
* objects-impl.h (struct Lisp_Color_Instance): added color_instance_type
* objects-impl.h (struct Lisp_Font_Instance): added font_instance_type
* process.c: process_description
(make_process_internal): added variant initialization
* process.h (process_variant): the different process types
author | michaels |
---|---|
date | Wed, 31 Jul 2002 07:23:39 +0000 |
parents | 576fb035e263 |
children |
line wrap: on
line source
@c -*-texinfo-*- @c This is part of the XEmacs Lisp Reference Manual. @c Copyright (C) 1990, 1991, 1992, 1993 Free Software Foundation, Inc. @c See the file lispref.texi for copying conditions. @setfilename ../../info/maps.info @node Standard Keymaps, Standard Hooks, Standard Buffer-Local Variables, Top @appendix Standard Keymaps The following symbols are used as the names for various keymaps. Some of these exist when XEmacs is first started, others are loaded only when their respective mode is used. This is not an exhaustive list. Almost all of these maps are used as local maps. Indeed, of the modes that presently exist, only Vip mode and Terminal mode ever change the global keymap. @table @code @item bookmark-map @vindex bookmark-map A keymap containing bindings to bookmark functions. @item Buffer-menu-mode-map @vindex Buffer-menu-mode-map A keymap used by Buffer Menu mode. @item c++-mode-map @vindex c++-mode-map A keymap used by C++ mode. @item c-mode-map @vindex c-mode-map A keymap used by C mode. A sparse keymap used by C mode. @item command-history-map @vindex command-history-map A keymap used by Command History mode. @item ctl-x-4-map @vindex ctl-x-4-map A keymap for subcommands of the prefix @kbd{C-x 4}. @item ctl-x-5-map @vindex ctl-x-5-map A keymap for subcommands of the prefix @kbd{C-x 5}. @item ctl-x-map @vindex ctl-x-map A keymap for @kbd{C-x} commands. @item debugger-mode-map @vindex debugger-mode-map A keymap used by Debugger mode. @item dired-mode-map @vindex dired-mode-map A keymap for @code{dired-mode} buffers. @item edit-abbrevs-map @vindex edit-abbrevs-map A keymap used in @code{edit-abbrevs}. @item edit-tab-stops-map @vindex edit-tab-stops-map A keymap used in @code{edit-tab-stops}. @item electric-buffer-menu-mode-map @vindex electric-buffer-menu-mode-map A keymap used by Electric Buffer Menu mode. @item electric-history-map @vindex electric-history-map A keymap used by Electric Command History mode. @item emacs-lisp-mode-map @vindex emacs-lisp-mode-map A keymap used by Emacs Lisp mode. @item help-map @vindex help-map A keymap for characters following the Help key. @item Helper-help-map @vindex Helper-help-map A keymap used by the help utility package.@* It has the same keymap in its value cell and in its function cell. @item Info-edit-map @vindex Info-edit-map A keymap used by the @kbd{e} command of Info. @item Info-mode-map @vindex Info-mode-map A keymap containing Info commands. @item isearch-mode-map @vindex isearch-mode-map A keymap that defines the characters you can type within incremental search. @item itimer-edit-map @vindex itimer-edit-map A keymap used when in Itimer Edit mode. @item lisp-interaction-mode-map @vindex lisp-interaction-mode-map A keymap used by Lisp mode. @item lisp-mode-map @vindex lisp-mode-map A keymap used by Lisp mode. @vindex minibuffer-local-completion-map A keymap for minibuffer input with completion. @item minibuffer-local-isearch-map @vindex minibuffer-local-isearch-map A keymap for editing isearch strings in the minibuffer. @item minibuffer-local-map @vindex minibuffer-local-map Default keymap to use when reading from the minibuffer. @item minibuffer-local-must-match-map @vindex minibuffer-local-must-match-map A keymap for minibuffer input with completion, for exact match. @item mode-specific-map @vindex mode-specific-map The keymap for characters following @kbd{C-c}. Note, this is in the global map. This map is not actually mode specific: its name was chosen to be informative for the user in @kbd{C-h b} (@code{display-bindings}), where it describes the main use of the @kbd{C-c} prefix key. @item modeline-map @vindex modeline-map The keymap consulted for mouse-clicks on the modeline of a window. @item objc-mode-map @vindex objc-mode-map A keymap used in Objective C mode as a local map. @item occur-mode-map @vindex occur-mode-map A local keymap used by Occur mode. @item overriding-local-map @vindex overriding-local-map A keymap that overrides all other local keymaps. @item query-replace-map @vindex query-replace-map A local keymap used for responses in @code{query-replace} and related commands; also for @code{y-or-n-p} and @code{map-y-or-n-p}. The functions that use this map do not support prefix keys; they look up one event at a time. @item read-expression-map @vindex read-expression-map The minibuffer keymap used for reading Lisp expressions. @item read-shell-command-map @vindex read-shell-command-map The minibuffer keymap used by @code{shell-command} and related commands. @item shared-lisp-mode-map @vindex shared-lisp-mode-map A keymap for commands shared by all sorts of Lisp modes. @item text-mode-map @vindex text-mode-map A keymap used by Text mode. @item toolbar-map @vindex toolbar-map The keymap consulted for mouse-clicks over a toolbar. @item view-mode-map @vindex view-mode-map A keymap used by View mode. @end table