File: //usr/share/emacs/27.1/lisp/tutorial.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.
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(byte-code "\300\301!\210\302\303\304\305\306\307%\207" [require help-mode custom-declare-face tutorial-warning-face ((t :inherit font-lock-warning-face)) "Face used to highlight warnings in the tutorial." :group help] 6)
#@38 Point before display of key changes.
(defvar tutorial--point-before-chkeys 0 (#$ . 630))
(make-variable-buffer-local 'tutorial--point-before-chkeys)
#@37 Point after display of key changes.
(defvar tutorial--point-after-chkeys 0 (#$ . 785))
(make-variable-buffer-local 'tutorial--point-after-chkeys)
#@20 Tutorial language.
(defvar tutorial--lang nil (#$ . 937))
(make-variable-buffer-local 'tutorial--lang)
#@934 Give more information about a changed key binding.
This is used in `help-with-tutorial'.  The information includes
the key sequence that no longer has a default binding, the
default binding and the current binding.  It also tells in what
keymap the new binding has been done and how to access the
function in the default binding from the keyboard.
For `cua-mode' key bindings that try to combine CUA key bindings
with default Emacs bindings information about this is shown.
VALUE should have either of these formats:
  (cua-mode)
  (current-binding KEY-FUN DEF-FUN KEY WHERE)
Where
  KEY         is a key sequence whose standard binding has been changed
  KEY-FUN     is the actual binding for KEY
  DEF-FUN     is the standard binding of KEY
  WHERE       is a text describing the key sequences to which DEF-FUN is
              bound now (or, if it is remapped, a key sequence
              for the function it is remapped to)
(defalias 'tutorial--describe-nonstandard-key #[(value) "r\306\307 !q\210p\310 \210	\311\211\312\211\3126\313 \210\314\315!\210+\21178\316\3179D\320\321!\"\210r\307 q\210\322\323\261\210\31269@\324=\203L \325c\210\2029@\326=\2039A@\32798\33098\33198\311\332 \311:;<=>?@;\203\241 ;@A\333A>\312#B;A;B@=\203\235 A<\311;*\202v <\203\252 \334\335!\210\336\337\340>!?#c\210\341@\203\303 \336\342@\"\202\304 \343\261\210\344c\210:\203\330 \345\336\346:\"\261\210=\347\230\203\363 \350?!\204\351\352\353?\"\354\261\210\202\355\356\357=\311\312C\360#)\266\203\203\347\202\f\361=\336\362?\"\261\210.\363e`\"\210)\364 )\3657!\210+\207" [default-directory #1=#:old-dir buffer-read-only buffer-file-name buffer-undo-list inhibit-modification-hooks get-buffer-create help-buffer kill-all-local-variables nil t erase-buffer run-hooks temp-buffer-setup-hook help-setup-xref tutorial--describe-nonstandard-key called-interactively-p interactive "Your Emacs customizations override the default binding for this key:" "\n\n" cua-mode "CUA mode is enabled.\n\nWhen CUA mode is enabled, you can use C-z, C-x, C-c, and C-v to\nundo, cut, copy, and paste in addition to the normal Emacs\nbindings.  The C-x and C-c keys only do cut and copy when the\nregion is active, so in most cases, they do not conflict with the\nnormal function of these prefix keys.\n\nIf you really need to perform a command which starts with one of\nthe prefix keys even when the region is active, you have three\noptions:\n- press the prefix key twice very quickly (within 0.2 seconds),\n- press the prefix key and the following key within 0.2 seconds, or\n- use the SHIFT key with the prefix key, i.e. C-S-x or C-S-c." current-binding 2 3 4 current-active-maps lookup-key mapatoms #[(s) "?\205# \303	!\205# \304	J!\205# 	\302=?\205# \n	J=\205# 	\211\207" [mapsym s map boundp keymapp] 2] format-message "The default Emacs binding for the key %s is the command `%s'.  " key-description "However, your customizations have " "rebound it to the command `%s'" "unbound it" "." "  (For the more advanced user:" " This binding is in the keymap `%s'.)" "" keymapp "\n\nYou can use M-x " format "%s" " RET instead." "\n\nWith your current key bindings" " you can use " "^the .*menus?$" string-match "the key" " to get the function `%s'." fill-region help-print-return-message internal-temp-output-buffer-show inhibit-read-only #2=#:buf standard-output value mapsym maps map where key db cb m mb inhibit-changing-match-data] 10 (#$ . 1047)])
#@219 Sort predicate for use with `tutorial--default-keys'.
This is a predicate function to `sort'.
The sorting is for presentation purpose only and is done on the
key sequence.
LEFT and RIGHT are the elements to compare.
(defalias 'tutorial--sort-keys #[(left right) "\306A@\307\"\306	A@\307\"\2031 \n\2031 <\2031 \n<\2031 @\n@\232\2031 A\nA\202 @\n@\211\203P \f\203P 
<\203P \f<\203P \310
\f\"\202\207 \311
!\203b \311\f!\203b 
\fV\202\207 \311
!\203l \312\202\207 \311\f!\203v \307\202\207 
9\205\207 \f9\205\207 \313\f!\313
!\231,\207" [left right y x cy cx append nil tutorial--sort-keys wholenump t symbol-name] 5 (#$ . 4548)])
#@58 Default Emacs key bindings that the tutorial depends on.
(defconst tutorial--default-keys (byte-code "\302\303\304\305\306\307\310\311\312\313\314\315\316\317\320\321\322\323\324\325\326\327\330\331\332\333\334\335\336\337\340\341\342\343\344\345\346\347\350\351\352\353\354\355\356\357\360\361\362\363\364\365\366\367\370\371B\2577\372	\373\"*\207" [suspend-emacs default-keys suspend-frame (ESC-prefix [27]) (Control-X-prefix [24]) (mode-specific-command-prefix [3]) (save-buffers-kill-terminal [24 3]) (scroll-up-command [22]) (scroll-down-command [134217846]) (recenter-top-bottom [12]) (forward-char [6]) (backward-char [2]) (forward-word [134217830]) (backward-word [134217826]) (next-line [14]) (previous-line [16]) (move-beginning-of-line [1]) (move-end-of-line [5]) (backward-sentence [134217825]) (forward-sentence [134217829]) (newline "
") (beginning-of-buffer [134217788]) (end-of-buffer [134217790]) (universal-argument [21]) (keyboard-quit [7]) (downcase-region [24 12]) (delete-other-windows [24 49]) (delete-backward-char "") (delete-char [4]) (backward-kill-word [134217855]) (kill-word [134217828]) (kill-line [11]) (kill-sentence [134217835]) (set-mark-command [0]) (set-mark-command [67108896]) (kill-region [23]) (yank [25]) (yank-pop [134217849]) (undo [24 117]) (find-file [24 6]) (save-buffer [24 19]) (list-buffers [24 2]) (switch-to-buffer [24 98]) (save-some-buffers [24 115]) (execute-extended-command [134217848]) (describe-mode [8 109]) (set-fill-column [24 102]) (fill-paragraph [134217841]) (isearch-forward [19]) (isearch-backward [18]) (split-window-below [24 50]) (scroll-other-window [134217750]) (other-window [24 111]) (find-file-other-window [24 52 6]) (keyboard-escape-quit [27 27 27]) (describe-key-briefly [8 99]) (describe-key [8 107]) ([26]) sort tutorial--sort-keys] 56) (#$ . 5197))
#@40 Give detailed help about changed keys.
(defalias 'tutorial--detailed-help #[(button) "r\306\307 !q\210p\310 \210	\311\211\312\211\3127\313 \210\314\315!\210+\21189\316\317:D\320\321!\"\210r\307 q\210\322:\323\"\322:\324\"rq\210\212eb\210\325;!*\211<\203\326c\210\327=\330=\331\332\333$c\210)<\311>\211?\203?@\211>A@@>@A\334>8B\335>8C\336>8D\337A!Erq\210\340A!)F@F=\204\fE\230\203\301 \341\342EG\343\344E%\210\345E\346\261\210\347j\210\350B\351@\352\353\354\312&\210\355j\210C<\203\344 \356C\330\357C\360\230\203\365 \330\361B\"\202\367 C\"c\210\350D@\352\362\351DA\354\312&\210\363c\210.?A\211?\204s *\364c\210\365 ,\3668!\210+\207" [default-directory #1=#:old-dir buffer-read-only buffer-file-name buffer-undo-list inhibit-modification-hooks get-buffer-create help-buffer kill-all-local-variables nil t erase-buffer run-hooks temp-buffer-setup-hook help-setup-xref tutorial--detailed-help called-interactively-p interactive button-get tutorial-buffer explain-key-desc tutorial--find-changed-keys "The following key bindings used in the tutorial have been changed\nfrom the Emacs default:\n\n" "   %-14s %-27s %-16s\n" format "Standard Key" "Command" "In Your Emacs" 2 3 4 key-description key-binding put-text-property 0 face tutorial-warning-face "   " " " 18 insert-button value action #[(button) "\301\302\303\"!\207" [button describe-function button-get value] 4 nil nil] follow-link 45 "list" " %-16s " "" "M-x %s" #[(b) "\302\301\"\303	!)\207" [b value button-get tutorial--describe-nonstandard-key] 3 nil nil] "\n" "\nIt is OK to change key bindings, but changed bindings do not\ncorrespond to what the tutorial says.\n\n" help-print-return-message internal-temp-output-buffer-show inhibit-read-only #2=#:buf standard-output button tutorial--default-keys changed-keys frm tk --dolist-tail-- def-fun key def-fun-txt where remark key-txt key-fun] 9 (#$ . 7037)])
#@1068 Find the key bindings used in the tutorial that have changed.
Return a list with elements of the form
  '(KEY DEF-FUN DEF-FUN-TXT WHERE REMARK QUIET)
where
  KEY         is a key sequence whose standard binding has been changed
  DEF-FUN     is the standard binding of KEY
  DEF-FUN-TXT is a short descriptive text for DEF-FUN
  WHERE       is a text describing the key sequences to which DEF-FUN is
              bound now (or, if it is remapped, a key sequence
              for the function it is remapped to)
  REMARK      is a list with info about rebinding. It has either of
              these formats:
                (TEXT cua-mode)
                (TEXT current-binding KEY-FUN DEF-FUN KEY WHERE)
              Here TEXT is a link text to show to the user.  The
              rest of the list is used to show information when
              the user clicks the link.
              KEY-FUN is the actual binding for KEY.
  QUIET       is t if this changed keybinding should be handled quietly.
              This is used by `tutorial--display-changes'.
(defalias 'tutorial--find-changed-keys #[(default-keys) "\306\211\307\310!r\nq\210\311\216\312 \210\306\211\203\332
@\211A@?\f@@\313\314@\"A\315@!B@\316=\203A \317C\320\"\202T @\321=\203P \317C\322\"\202T \323?!D\324B\203a B\202c @!E\306FE\203\303 E@F\325F!E\326EGW\203\306 \327E\330\331G#\331\230\203\306 \332F!\203\275 F\333\234\211F\203\275 \334F\317C\335\"\"A@\211F\203\275 F;\203\275 \336\337F\"\202\276 \340E\202\306 \341E\306D@=\204\321D\203\337 D\315@!=\204\321'\203?\342\232\203\362 D\343=\204 ?\344\232\203D\345=\203\346\347D\202\262'\203U@\316=\203!D\350\232\203!\351\211A\204K@\352=\2036D\353\232\2036\354\211A\204K@\321=\203UD\355\232\203U\356\211A\203U\357\347D\360E\202\262\361\362!\203\204\361\363!\203\2043\364=\203\204@\365=\203vD\366=\204\321@\367=\203\204D\370=\204\321G\203\245?\371\232\203\227D\372=\204\321?\373\232\203\245D\374=\204\321\375\376D@?E\257?@AE\306\257\211H	\235\203\313	\210\202\320H	B).
A\211\204 -	*\207" [remark changed-keys #1=#:temp-buffer default-keys kdf --dolist-tail-- nil generate-new-buffer " *temp*" #[nil "\301!\205	 \302!\207" [#1# buffer-name kill-buffer] 2] fundamental-mode format "%s" command-remapping ESC-prefix lookup-key [27] Control-X-prefix [24] key-binding where-is-internal key-description 10 substring 0 "<menu-bar>" vectorp 1 assoc [menu-bar] format-message "the `%s' menu" "the menus" "" [22] cua-paste [26] undo "cua-mode, more info" cua-mode (keymap (118 . cua-repeat-replace-region)) "\"ESC prefix\"" mode-specific-command-prefix (keymap (timeout . copy-region-as-kill)) "\"C-c prefix\"" (keymap (timeout . kill-region)) "\"C-x prefix\"" "cua-mode replacement" "Same key" boundp viper-mode-string viper-current-state vi-state isearch-forward viper-isearch-forward isearch-backward viper-isearch-backward [C-delete] kill-word [C-backspace] backward-kill-word "more info" current-binding key def-fun def-fun-txt rem-fun global-map key-fun where cwhere normal-erase-is-backspace #2=#:x] 7 (#$ . 8988)])
(defalias 'tutorial--key-description #[(key) "\302!\211\303\230\203 \304\202# 	\305\230\203 \306\202# 	\307\230\203\"