File: //usr/share/emacs/27.1/lisp/strokes.elc
;ELC   
;;; Compiled
;;; in Emacs version 27.1
;;; with all optimizations.
;;; This file uses dynamic docstrings, first added in Emacs 19.29.
;;; This file does not contain utf-8 non-ASCII characters,
;;; and so can be loaded in Emacs versions earlier than 23.
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(autoload 'mail-position-on-field "sendmail")
#@130 Symbol representing a stroke lift event for complex strokes.
Complex strokes are those which contain two or more simple strokes.
(defconst strokes-lift :strokes-lift (#$ . 455))
#@51 The header to all XPM buffers created by strokes.
(defconst strokes-xpm-header "/* XPM */\nstatic char * stroke_xpm[] = {\n/* width height ncolors cpp [x_hot y_hot] */\n\"33 33 9 1 26 23\",\n/* colors */\n\" 	c none s none\",\n\"*	c #000000 s foreground\",\n\"R	c #FFFF00000000\",\n\"O	c #FFFF80000000\",\n\"Y	c #FFFFFFFF0000\",\n\"G	c #0000FFFF0000\",\n\"B	c #00000000FFFF\",\n\"P	c #FFFF0000FFFF\",\n\".	c #45458B8B0000\",\n/* pixels */\n" (#$ . 639))
(byte-code "\302\303\304\305\306\307\310\311&\210\312\313\314\304#\210\315\304\211\2037 	@\313N\2030 \314N\2040 \316\314\313N#\210	A\211\204 *\317\313\314\320#\210\321\314\322\323\324\325\310\303&\210\321\326\327\330\324\331\310\303&\210\321\332\333\334\324\335\310\303&\210\321\336\337\340\324\335\310\303&\210\321\341\342\343\344\345\324\346\310\303&	\207" [prop --dolist-tail-- custom-declare-group strokes nil "Control Emacs through mouse strokes." :link (emacs-commentary-link "strokes") :group mouse defvaralias strokes-modeline-string strokes-lighter (saved-value saved-variable-comment) put make-obsolete-variable "24.3" custom-declare-variable " Strokes" "Mode line identifier for Strokes mode." :type string strokes-character 64 "Character used when drawing strokes in the strokes buffer.\n(The default is `@', which works well.)" character strokes-minimum-match-score 1000 "Minimum score for a stroke to be considered a possible match.\nSetting this variable to 0 would require a perfectly precise match.\nThe default value is 1000, but it's mostly dependent on how precisely\nyou manage to replicate your user-defined strokes.  It also depends on\nthe value of `strokes-grid-resolution', since a higher grid resolution\nwill correspond to more sample points, and thus more distance\nmeasurements.  Usually, this is not a problem since you first set\n`strokes-grid-resolution' based on what your computer seems to be able\nto handle (though the defaults are usually more than sufficient), and\nthen you can set `strokes-minimum-match-score' to something that works\nfor you.  The only purpose of this variable is to insure that if you\ndo a bogus stroke that really doesn't match any of the predefined\nones, then strokes should NOT pick the one that came closest." integer strokes-grid-resolution 9 "Integer defining dimensions of the stroke grid.\nThe grid is a square grid, where `strokes-grid-resolution' defaults to\n`9', making a 9x9 grid whose coordinates go from (0 . 0) on the top\nleft to ((strokes-grid-resolution - 1) . (strokes-grid-resolution - 1))\non the bottom right.  The greater the resolution, the more intricate\nyour strokes can be.\nNOTE: This variable should be odd and MUST NOT be less than 3 and need\n      not be greater than 33, which is the resolution of the pixmaps.\nWARNING: Changing the value of this variable will gravely affect the\n         strokes you have already programmed in.  You should try to\n         figure out what it should be based on your needs and on how\n         quick the particular platform(s) you're operating on, and\n         only then start programming in your custom strokes." strokes-file (locate-user-emacs-file "strokes" ".strokes") "File containing saved strokes for Strokes mode." :version "24.4" file] 11)
#@56 The name of the buffer that the strokes take place in.
(defvar strokes-buffer-name " *strokes*" (#$ . 3897))
#@249 If non-nil, the strokes buffer is used and strokes are displayed.
If nil, strokes will be read the same, however the user will not be
able to see the strokes.  This be helpful for people who don't like
the delay in switching to the strokes buffer.
(custom-declare-variable 'strokes-use-strokes-buffer t '(#$ . 4013) :type 'boolean :group 'strokes)
#@138 The special window configuration used when entering strokes.
This is set properly in the function `strokes-update-window-configuration'.
(defvar strokes-window-configuration nil (#$ . 4368))
#@161 Last stroke entered by the user.
Its value gets set every time the function `strokes-fill-stroke'
gets called, since that is the best time to set the variable.
(defvar strokes-last-stroke nil (#$ . 4566))
#@288 Association list of strokes and their definitions.
Each entry is (STROKE . COMMAND) where STROKE is itself a list of
coordinates (X . Y) where X and Y are lists of positions on the
normalized stroke grid, with the top left at (0 . 0).  COMMAND is
the corresponding interactive function.
(defvar strokes-global-map nil (#$ . 4778))
#@48 Functions to be called when Strokes is loaded.
(defvar strokes-load-hook nil (#$ . 5115))
#@36 Non-nil if STROKE is really click.
(defalias 'strokes-click-p #[(stroke) "G\301W\207" [stroke 2] 2 (#$ . 5211)])
(put 'strokes-click-p 'byte-optimizer 'byte-compile-inline-expand)
(defalias 'strokes-remassoc #[(key list) "\303\304	\n\"\211\203 \305\n\"\202 )\n\207" [elt key list nil assoc delete] 3])
(put 'strokes-remassoc 'byte-optimizer 'byte-compile-inline-expand)
#@56 Add STROKE to STROKE-MAP alist with given command DEF.
(defalias 'strokes-define-stroke '(macro . #[(stroke-map stroke def) "\303\304D\305\306	\307\211\nE\310	EEEF\207" [stroke stroke-map def if strokes-click-p (error "That's a click, not a stroke") setq cons strokes-remassoc] 10 (#$ . 5594)]))
#@36 Return the square of the number X.
(defalias 'strokes-square #[(x) "\211_\207" [x] 2 (#$ . 5899)])
(put 'strokes-square 'byte-optimizer 'byte-compile-inline-expand)
#@107 Compute the distance (squared) between to points P1 and P2.
P1 and P2 are cons cells in the form (X . Y).
(defalias 'strokes-distance-squared #[(p1 p2) "@A	@	A
Z\211\211_)\n\fZ\211\211_)\\,\207" [p1 p2 y2 x2 y1 x1 x] 5 (#$ . 6072)])
(put 'strokes-distance-squared 'byte-optimizer 'byte-compile-inline-expand)
(defalias 'strokes-mouse-event-p #[(event) ":\205* @9\205* @\301=\206* \302@\303N>\206* \304@\303N>\206* \305@\303N>\207" [event mouse-movement click event-symbol-elements down drag] 3])
(put 'strokes-mouse-event-p 'byte-optimizer 'byte-compile-inline-expand)
(defalias 'strokes-button-press-event-p #[(event) ":\205 @9\205 \301@\302N>\207" [event down event-symbol-elements] 3])
(put 'strokes-button-press-event-p 'byte-optimizer 'byte-compile-inline-expand)
(defalias 'strokes-button-release-event-p #[(event) ":\205 @9\205 \301@\302N>\206 \303@\302N>\207" [event click event-symbol-elements drag] 3])
(put 'strokes-button-release-event-p 'byte-optimizer 'byte-compile-inline-expand)
#@110 Return position of start of line LINE in WINDOW.
If LINE is nil, return the last position visible in WINDOW.
(defalias 'strokes-event-closest-point-1 #[(window &optional line) "\304!\305!\203
 \306\202 \307Z\n\206 	\212\310!b\210\311!U\203+ \n\204+ \312u\210`+\207" [window total line distance window-height window-minibuffer-p 0 1 window-start vertical-motion -1] 3 (#$ . 7103)])
#@173 Return the nearest position to where EVENT ended its motion.
This is computed for the window where EVENT's motion started,
or for window START-WINDOW if that is specified.
(defalias 'strokes-event-closest-point #[(event &optional start-window) "\204\f \305	!\211@\262\306	!\211@\262=\203@ \307\306	!!\310=\203, \311\312\306	!!A\"\207\307\306	!!\313=\203: \311!\207\307\306	!!\207\306	!\211@\262\314\315!A@\316\n!\203^ \315\n!A@\202k \306	!\3178\262A\320\n!\245\211\fY\203x \311!\202{ \321!+\207" [start-window event end-w end-w-top w-top event-start event-end posn-point vertical-line strokes-event-closest-point-1 posn-col-row mode-line nil window-edges windowp 2 frame-char-height window-start] 6 (#$ . 7500)])
#@44 Return non-nil if OBJECT is a stroke-lift.
(defalias 'strokes-lift-p #[(object) "	=\207" [object strokes-lift] 2 (#$ . 8236)])
#@34 Undo the last stroke definition.
(defalias 'strokes-unset-last-stroke #[nil "@A\302\303\304	\"!\203 A\305\306!\202 \305\307!)\207" [strokes-global-map command y-or-n-p format-message "Really delete last stroke definition, defined to `%s'? " message "That stroke has been deleted" "Nothing done"] 4 (#$ . 8370) nil])
#@356 Interactively give STROKE the global binding as COMMAND.
Works just like `global-set-key', except for strokes.  COMMAND is
a symbol naming an interactively-callable function.  STROKE is a
list of sampled positions on the stroke grid as described in the
documentation for the `strokes-define-stroke' function.
See also `strokes-global-set-stroke-string'.
(defalias 'strokes-global-set-stroke #[(stroke command) "\211G\306W)\203 \307\310!\207	B\n\311\312\f\"\211\203( \313
\"\202 )*B\211\207" [stroke command strokes-global-map list key elt 2 error "That's a click, not a stroke" nil assoc delete] 5 (#$ . 8699) (list (and (or strokes-mode (strokes-mode t)) (strokes-read-complex-stroke "Draw with mouse button 1 (or 2).  End with button 3...")) (read-command "Command to map stroke to: "))])
#@333 Interactively give STROKE the global binding as STRING.
Works just like `global-set-key', except for strokes.  STRING
is a string to be inserted by the stroke.  STROKE is a list of
sampled positions on the stroke grid as described in the
documentation for the `strokes-define-stroke' function.
Compare `strokes-global-set-stroke'.
(defalias 'strokes-global-set-stroke-string #[(stroke string) "\211G\306W)\203 \307\310!\207	B\n\311\312\f\"\211\203( \313
\"\202 )*B\211\207" [stroke string strokes-global-map list key elt 2 error "That's a click, not a stroke" nil assoc delete] 5 (#$ . 9513) (list (and (or strokes-mode (strokes-mode t)) (strokes-read-complex-stroke "Draw with mouse button 1 (or 2).  End with button 3...")) (read-string "String to map stroke to: "))])
#@345 Map POSITION to a new grid position.
Do so based on its STROKE-EXTENT and GRID-RESOLUTION.
STROKE-EXTENT is a list ((XMIN . YMIN) (XMAX . YMAX)).
If POSITION is a `strokes-lift', then it is itself returned.
Optional GRID-RESOLUTION may be used in place of `strokes-grid-resolution'.
The grid is a square whose dimension is [0,GRID-RESOLUTION).
(defalias 'strokes-get-grid-position #[(stroke-extent position &optional grid-resolution) ":\203M 	\206\n \n@A@@@AA@@TA@AT	\n\f\306	\307\f\nZ!
\nZ\245_!\306	\307	Z!\f	Z\245_!.B\207\310!\205U 
\207" [position grid-resolution strokes-grid-resolution stroke-extent ymax xmax floor float strokes-lift-p ymin xmin y x strokes-lift] 7 (#$ . 10307)])
#@132 From a list of absolute PIXEL-POSITIONS, return absolute spatial extent.
The return value is a list ((XMIN . YMIN) (XMAX . YMAX)).
(defalias 'strokes-get-stroke-extent #[(pixel-positions) "\205\237 @@@@@A@AA	\203Z 	@:\203S 	@@	@A\211
W\2034 \fV\203>