changeset 5847:039f4a1bcb0a

Add notes about pixel_to_glyph_translation and related code.
author Mike Kupfer <mike.kupfer@xemacs.org>
date Mon, 23 Feb 2015 17:13:01 -0800
parents 83e5c3cd6be6
children f5f72f18c310 eabf763bc6f9
files man/ChangeLog man/internals/internals.texi
diffstat 2 files changed, 40 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/man/ChangeLog	Sat Jan 10 19:43:28 2015 +0900
+++ b/man/ChangeLog	Mon Feb 23 17:13:01 2015 -0800
@@ -1,3 +1,9 @@
+2015-02-23  Mike Kupfer  <mike.kupfer@xemacs.org>
+
+	* internals/internals.texi (The Redisplay Mechanism):
+	Add notes about pixel_to_glyph_translation and related code.
+	(pixel_to_glyph_translation): New section.	
+
 2014-03-28  Jerry James  <james@xemacs.org>
 
 	* Makefile.in: Do not build texinfo files.
--- a/man/internals/internals.texi	Sat Jan 10 19:43:28 2015 +0900
+++ b/man/internals/internals.texi	Mon Feb 23 17:13:01 2015 -0800
@@ -625,6 +625,7 @@
 * Critical Redisplay Sections::  
 * Line Start Cache::            
 * Redisplay Piece by Piece::    
+* pixel_to_glyph_translation::  
 * Modules for the Redisplay Mechanism::  
 * Modules for other Display-Related Lisp Objects::  
 
@@ -19049,12 +19050,18 @@
 @chapter The Redisplay Mechanism
 @cindex redisplay mechanism, the
 
-  The redisplay mechanism is one of the most complicated sections of
+  The redisplay mechanism is responsible for updating the display,
+such as after an edit or a highlighting change.  It is one of the most
+complicated sections of
 XEmacs, especially from a conceptual standpoint.  This is doubly so
 because, unlike for the basic aspects of the Lisp interpreter, the
 computer science theories of how to efficiently handle redisplay are not
 well-developed.
 
+  The redisplay code also provides a low-level operation to 
+map window system coordinates to XEmacs objects.  This is used
+elsewhere in XEmacs, most notably for dealing with mouse events.
+
   When working with the redisplay mechanism, remember the Golden Rules
 of Redisplay:
 
@@ -19071,6 +19078,7 @@
 * Critical Redisplay Sections::  
 * Line Start Cache::            
 * Redisplay Piece by Piece::    
+* pixel_to_glyph_translation::  
 * Modules for the Redisplay Mechanism::  
 * Modules for other Display-Related Lisp Objects::  
 @end menu
@@ -19485,7 +19493,7 @@
   In case you're wondering, the Second Golden Rule of Redisplay is not
 applicable.
 
-@node Redisplay Piece by Piece, Modules for the Redisplay Mechanism, Line Start Cache, The Redisplay Mechanism
+@node Redisplay Piece by Piece, pixel_to_glyph_translation, Line Start Cache, The Redisplay Mechanism
 @section Redisplay Piece by Piece
 @cindex redisplay piece by piece
 
@@ -19582,7 +19590,30 @@
 @code{ensure_face_cachel_complete}, with the actual work being done by
 @code{ensure_face_cachel_contains_charset}.
 
-@node Modules for the Redisplay Mechanism, Modules for other Display-Related Lisp Objects, Redisplay Piece by Piece, The Redisplay Mechanism
+@node pixel_to_glyph_translation, Modules for the Redisplay Mechanism, Redisplay Piece by Piece, The Redisplay Mechanism
+@section pixel_to_glyph_translation
+@cindex pixel_to_glyph_translation
+@cindex events, mouse motion
+@cindex mouse motion events
+
+The data structures described in @ref{Redisplay Piece by Piece} are
+also the basis for mapping native window system coordinates to
+higher-level objects, such as a toolbar button, a modeline character,
+a glyph, or a text character.  @code{pixel_to_glyph_translation} does
+the bulk of this translation, with some further tweaking done by the
+functions in @file{events.c}.
+
+@code{pixel_to_glyph_translation} is called very frequently when
+XEmacs is processing mouse-motion events.  To improve performance,
+@code{pixel_to_glyph_translation} caches the most recently returned
+values.  The cache includes the pixel coordinate boundaries for which
+the cached results are valid.  So if the next event is within those
+boundaries, @code{pixel_to_glyph_translation} returns the cached
+results (fast path).  Otherwise, @code{pixel_to_glyph_translation}
+walks through the redisplay data structures, then updates the cache
+with the new results (slow path).
+
+@node Modules for the Redisplay Mechanism, Modules for other Display-Related Lisp Objects, pixel_to_glyph_translation, The Redisplay Mechanism
 @section Modules for the Redisplay Mechanism
 @cindex modules for the redisplay mechanism
 @cindex redisplay mechanism, modules for the