;ELC   
;;; Compiled by pot@pot.cnuce.cnr.it on Tue Mar 18 15:51:33 2003
;;; from file /home/pot/gnu/emacs-pretest.new/lisp/progmodes/sh-script.el
;;; in Emacs version 21.3
;;; with bytecomp version 2.85.4.1
;;; with all optimizations.

;;; This file uses dynamic docstrings, first added in Emacs 19.29.
(if (and (boundp 'emacs-version)
	 (< (aref emacs-version (1- (length emacs-version))) ?A)
	 (or (and (boundp 'epoch::version) epoch::version)
	     (string-lessp emacs-version "19.29")))
    (error "`sh-script.el' was compiled for Emacs 19.29 or later"))

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;


(byte-code "\300\301!\210\302\303\304\305\306\307\306\310&\210\302\311\304\312\306\303\313\314&\207" [require executable custom-declare-group sh nil "Shell programming utilities" :group unix languages sh-script "Shell script mode" :prefix "sh-"] 8)
#@656 *Alist showing the direct ancestor of various shells.
This is the basis for `sh-feature'.  See also `sh-alias-alist'.
By default we have the following three hierarchies:

csh		C Shell
  jcsh		C Shell with Job Control
  tcsh		Toronto C Shell
    itcsh	? Toronto C Shell
rc		Plan 9 Shell
  es		Extensible Shell
sh		Bourne Shell
  ash		? Shell
  jsh		Bourne Shell with Job Control
    bash	GNU Bourne Again Shell
    ksh88	Korn Shell '88
      ksh	Korn Shell '93
	dtksh	CDE Desktop Korn Shell
      pdksh	Public Domain Korn Shell
      wksh	Window Korn Shell
      zsh	Z Shell
  oash		SCO OA (curses) Shell
  posix		IEEE 1003.2 Shell Standard
  wsh		? Shell
(custom-declare-variable 'sh-ancestor-alist ''((ash . sh) (bash . jsh) (bash2 . jsh) (dtksh . ksh) (es . rc) (itcsh . tcsh) (jcsh . csh) (jsh . sh) (ksh . ksh88) (ksh88 . jsh) (oash . sh) (pdksh . ksh88) (posix . sh) (tcsh . csh) (wksh . ksh88) (wsh . sh) (zsh . ksh88) (rpm . sh)) '(#$ . -882) :type '(repeat (cons symbol symbol)) :group 'sh-script)
#@158 *Alist for transforming shell names to what they really are.
Use this where the name of the executable doesn't correspond to the type of
shell it really is.
(custom-declare-variable 'sh-alias-alist '(nconc (if (eq system-type 'gnu/linux) '((csh . tcsh) (ksh . pdksh))) '((ksh . ksh88) (bash2 . bash) (sh5 . sh))) '(#$ . -1895) :type '(repeat (cons symbol symbol)) :group 'sh-script)
#@59 *The executable file name for the shell being programmed.
(custom-declare-variable 'sh-shell-file '(or (and (memq system-type '(ms-dos windows-nt)) (let* ((shell (getenv "SHELL")) (shell-base (and shell (file-name-nondirectory shell)))) (if (or (null shell) (member (downcase shell-base) '("command.com" "cmd.exe" "4dos.com" "ndos.com" "cmdproxy.exe"))) "/bin/sh" (file-name-sans-extension (downcase shell))))) (getenv "SHELL") "/bin/sh") '(#$ . -2284) :type 'string :group 'sh-script)
#@66 *Single argument string for the magic number.  See `sh-feature'.
(custom-declare-variable 'sh-shell-arg ''((bash) (csh . "-f") (pdksh) (ksh88) (rc . "-p") (wksh) (zsh . "-f")) '(#$ . -2776) :type '(repeat (cons (symbol :tag "Shell") (choice (const :tag "No Arguments" nil) (string :tag "Arguments") (cons :format "Evaluate: %v" (const :format "" eval) sexp)))) :group 'sh-script)
#@124 *Alist of regular expressions for recognizing shell function definitions.
See `sh-feature' and `imenu-generic-expression'.
(custom-declare-variable 'sh-imenu-generic-expression '`((sh (nil "^\\s-*\\(function\\s-+\\)?\\([A-Za-z_][A-Za-z_0-9]+\\)\\s-*()" 2))) '(#$ . -3163) :type '(alist :key-type (symbol :tag "Shell") :value-type (alist :key-type (choice :tag "Title" string (const :tag "None" nil)) :value-type (repeat :tag "Regexp, index..." sexp))) :group 'sh-script :version "20.4")
#@246 Alist of shell variable names that should be included in completion.
These are used for completion in addition to all the variables named
in `process-environment'.  Each element looks like (VAR . VAR), where
the car and cdr are the same symbol.
(defvar sh-shell-variables nil (#$ . 3657))
#@49 Non-nil if `sh-shell-variables' is initialized.
(defvar sh-shell-variables-initialized nil (#$ . 3952))
#@63 Convert a shell name SHELL to the one we should handle it as.
(defalias 'sh-canonicalize-shell #[(shell) "\302\303\"\203 \304\211\224O9\204 \305!	\236A\206 \207" [shell sh-alias-alist string-match "\\.exe\\'" 0 intern] 3 (#$ . 4062)])
#@62 The shell being programmed.  This is set by \[sh-set-shell].
(defvar sh-shell (byte-code "\301\302!!\207" [sh-shell-file sh-canonicalize-shell file-name-nondirectory] 3) (#$ . 4314))
(autoload 'easy-mmode-define-syntax "easy-mmode")
#@41 Syntax-table used in Shell-Script mode.
(defconst sh-mode-syntax-table (easy-mmode-define-syntax '((35 . "<") (12 . ">#") (10 . ">#") (34 . "\"\"") (39 . "\"'") (96 . "\"`") (33 . "_") (37 . "_") (58 . "_") (46 . "_") (94 . "_") (126 . "_") (60 . ".") (62 . ".")) nil) (#$ . 4554))
#@35 Keymap used in Shell-Script mode.
(defvar sh-mode-map (byte-code "\302 \302\303!\304	\305\306#\210\304	\307\310#\210\304	\311\312#\210\304	\313\314#\210\304	\315\316#\210\304	\317\320#\210\304	\321\322#\210\304	\323\324#\210\304	\325\326#\210\304	\327\330#\210\304	\331\332#\210\304	\333\334#\210\304	\335\336#\210\304	\337\340#\210\304	\341\342#\210\304	\343\344#\210\304	\345\346#\210\304	\347\350#\210\304	\351\352#\210\304	\353\354#\210\304	\355\356#\210\304	\357\356#\210\304	\360\356#\210\304	\361\356#\210\304	\362\356#\210\304	\363\356#\210\364\365\366	\367 $\210\364\370\371	\367 $\210\364\372\373	\367 $\210\304	\374\375#\210\364\376\377	\367 $\210\364\201@ \201A 	\367 $\210\364\201B \201C 	\367 $\210\304	\201D \303B#\210\304\201E \201F #\210\304\201G \201H #\210\304\201I \201J #\210\304\201K \201L #\210\304\201M \201N #\210\304\201O \201P #\210\304\201Q \201R #\210\304\201S \201T #\210\304\201U \201V #\210\304\201W \201X #\210	*\207" [menu-map map make-sparse-keymap "Insert" define-key "(" sh-function "" sh-while "" sh-until "" sh-tmp-file "" sh-select "" sh-repeat "" sh-while-getopts "\f" sh-indexed-loop "	" sh-if "" sh-for "" sh-case "?" sh-show-indent "=" sh-set-indent "<" sh-learn-line-indent ">" sh-learn-buffer-indent "=" sh-assignment "+" sh-add "\230" sh-execute-region "" executable-interpret "<" sh-maybe-here-document "(" skeleton-pair-insert-maybe "{" "[" "'" "`" "\"" substitute-key-definition complete-tag comint-dynamic-complete current-global-map newline-and-indent sh-newline-and-indent delete-backward-char backward-delete-char-untabify ":" sh-set-shell beginning-of-defun sh-beginning-of-compound-command backward-sentence sh-beginning-of-command forward-sentence sh-end-of-command [menu-bar insert] [sh-while] ("While Loop" . sh-while) [sh-until] ("Until Loop" . sh-until) [sh-tmp-file] ("Temporary File" . sh-tmp-file) [sh-select] ("Select Statement" . sh-select) [sh-repeat] ("Repeat Loop" . sh-repeat) [sh-getopts] ("Options Loop" . sh-while-getopts) [sh-indexed-loop] ("Indexed Loop" . sh-indexed-loop) [sh-if] ("If Statement" . sh-if) [sh-for] ("For Loop" . sh-for) [sh-case] ("Case Statement" . sh-case)] 5) (#$ . 4842))
#@46 *Functions for doing TAB dynamic completion.
(custom-declare-variable 'sh-dynamic-complete-functions ''(shell-dynamic-complete-environment-variable shell-dynamic-complete-command comint-dynamic-complete-filename) '(#$ . -7057) :type '(repeat function) :group 'sh-script)
#@83 *Value of `require-final-newline' in Shell-Script mode buffers.
See `sh-feature'.
(custom-declare-variable 'sh-require-final-newline ''((csh . t) (pdksh . t) (rc eval . require-final-newline) (sh eval . require-final-newline)) '(#$ . -7334) :type '(repeat (cons (symbol :tag "Shell") (choice (const :tag "require" t) (cons :format "Evaluate: %v" (const :format "" eval) sexp)))) :group 'sh-script)
#@172 *Regexp for the variable name and what may follow in an assignment.
First grouping matches the variable name.  This is upto and including the `='
sign.  See `sh-feature'.
(custom-declare-variable 'sh-assignment-regexp ''((csh . "\\<\\([a-zA-Z0-9_]+\\)\\(\\[.+\\]\\)?[ 	]*[-+*/%^]?=") (ksh88 . "\\<\\([a-zA-Z0-9_]+\\)\\(\\[.+\\]\\)?[ 	]*\\([-+*/%&|~^]\\|<<\\|>>\\)?=") (rc . "\\<\\([a-zA-Z0-9_*]+\\)[ 	]*=") (sh . "\\<\\([a-zA-Z0-9_]+\\)=")) '(#$ . -7739) :type '(repeat (cons (symbol :tag "Shell") (choice regexp (cons :format "Evaluate: %v" (const :format "" eval) sexp)))) :group 'sh-script)
#@57 The width for further indentation in Shell-Script mode.
(custom-declare-variable 'sh-indentation '4 '(#$ . 8339) :type 'integer :group 'sh-script)
#@71 *Don't remember variables less than this length for completing reads.
(custom-declare-variable 'sh-remember-variable-min '3 '(#$ . -8492) :type 'integer :group 'sh-script)
#@128 When non-nil is the end of header for prepending by \[sh-execute-region].
That command is also used for setting this variable.
(defvar sh-header-marker nil (#$ . 8671))
#@127 *Regexp to determine the beginning of a shell command.
The actual command starts at the beginning of the second \(grouping\).
(custom-declare-variable 'sh-beginning-of-command '"\\([;({`|&]\\|\\`\\|[^\\]\n\\)[ 	]*\\([/~a-zA-Z0-9:]\\)" '(#$ . -8847) :type 'regexp :group 'sh-script)
#@112 *Regexp to determine the end of a shell command.
The actual command ends at the end of the first \(grouping\).
(custom-declare-variable 'sh-end-of-command '"\\([/~a-zA-Z0-9:]\\)[ 	]*\\([;#)}`|&]\\|$\\)" '(#$ . -9136) :type 'regexp :group 'sh-script)
#@33 Word to delimit here documents.
(defvar sh-here-document-word "EOF" (#$ . 9392))
#@75 Initial input in Bourne if, while and until skeletons.  See `sh-feature'.
(defvar sh-test '((sh "[  ]" . 3) (ksh88 "[[  ]]" . 4)) (#$ . 9479))
#@180 *List of all shell builtins for completing read and fontification.
Note that on some systems not all builtins are available or some are
implemented as aliases.  See `sh-feature'.
(custom-declare-variable 'sh-builtins ''((bash eval sh-append posix "alias" "bg" "bind" "builtin" "declare" "dirs" "enable" "fc" "fg" "help" "history" "jobs" "kill" "let" "local" "popd" "pushd" "source" "suspend" "typeset" "unalias") (bourne eval sh-append shell "eval" "export" "getopts" "newgrp" "pwd" "read" "readonly" "times" "ulimit") (csh eval sh-append shell "alias" "chdir" "glob" "history" "limit" "nice" "nohup" "rehash" "setenv" "source" "time" "unalias" "unhash") (dtksh eval identity wksh) (es "access" "apids" "cd" "echo" "eval" "false" "let" "limit" "local" "newpgrp" "result" "time" "umask" "var" "vars" "wait" "whatis") (jsh eval sh-append sh "bg" "fg" "jobs" "kill" "stop" "suspend") (jcsh eval sh-append csh "bg" "fg" "jobs" "kill" "notify" "stop" "suspend") (ksh88 eval sh-append bourne "alias" "bg" "false" "fc" "fg" "jobs" "kill" "let" "print" "time" "typeset" "unalias" "whence") (oash eval sh-append sh "checkwin" "dateline" "error" "form" "menu" "newwin" "oadeinit" "oaed" "oahelp" "oainit" "pp" "ppfile" "scan" "scrollok" "wattr" "wclear" "werase" "win" "wmclose" "wmmessage" "wmopen" "wmove" "wmtitle" "wrefresh") (pdksh eval sh-append ksh88 "bind") (posix eval sh-append sh "command") (rc "builtin" "cd" "echo" "eval" "limit" "newpgrp" "shift" "umask" "wait" "whatis") (sh eval sh-append bourne "hash" "test" "type") (shell "cd" "echo" "eval" "set" "shift" "umask" "unset" "wait") (wksh eval sh-append ksh88 "Xt[A-Z][A-Za-z]*") (zsh eval sh-append ksh88 "autoload" "bindkey" "builtin" "chdir" "compctl" "declare" "dirs" "disable" "disown" "echotc" "enable" "functions" "getln" "hash" "history" "integer" "limit" "local" "log" "popd" "pushd" "r" "readonly" "rehash" "sched" "setopt" "source" "suspend" "true" "ttyctl" "type" "unfunction" "unhash" "unlimit" "unsetopt" "vared" "which")) '(#$ . -9629) :type '(repeat (cons (symbol :tag "Shell") (choice (repeat string) (cons :format "Evaluate: %v" (const :format "" eval) sexp)))) :group 'sh-script)
#@271 *List of keywords that may be immediately followed by a builtin or keyword.
Given some confusion between keywords and builtins depending on shell and
system, the distinction here has been based on whether they influence the
flow of control or syntax.  See `sh-feature'.
(custom-declare-variable 'sh-leading-keywords ''((csh "else") (es "true" "unwind-protect" "whatis") (rc "else") (sh "do" "elif" "else" "if" "then" "trap" "type" "until" "while")) '(#$ . -11790) :type '(repeat (cons (symbol :tag "Shell") (choice (repeat string) (cons :format "Evaluate: %v" (const :format "" eval) sexp)))) :group 'sh-script)
#@67 *List of keywords not in `sh-leading-keywords'.
See `sh-feature'.
(custom-declare-variable 'sh-other-keywords ''((bash eval sh-append bourne "bye" "logout") (bourne eval sh-append sh "function") (csh eval sh-append shell "breaksw" "default" "end" "endif" "endsw" "foreach" "goto" "if" "logout" "onintr" "repeat" "switch" "then" "while") (es "break" "catch" "exec" "exit" "fn" "for" "forever" "fork" "if" "return" "throw" "while") (ksh88 eval sh-append bourne "select") (rc "break" "case" "exec" "exit" "fn" "for" "if" "in" "return" "switch" "while") (sh eval sh-append shell "done" "esac" "fi" "for" "in" "return") (shell "break" "case" "continue" "exec" "exit") (zsh eval sh-append bash "select")) '(#$ . -12408) :type '(repeat (cons (symbol :tag "Shell") (choice (repeat string) (cons :format "Evaluate: %v" (const :format "" eval) sexp)))) :group 'sh-script)
#@78 List of all shell variables available for completing read.
See `sh-feature'.
(defvar sh-variables '((bash eval sh-append sh "allow_null_glob_expansion" "auto_resume" "BASH" "BASH_VERSION" "cdable_vars" "ENV" "EUID" "FCEDIT" "FIGNORE" "glob_dot_filenames" "histchars" "HISTFILE" "HISTFILESIZE" "history_control" "HISTSIZE" "hostname_completion_file" "HOSTTYPE" "IGNOREEOF" "ignoreeof" "LINENO" "MAIL_WARNING" "noclobber" "nolinks" "notify" "no_exit_on_failed_exec" "NO_PROMPT_VARS" "OLDPWD" "OPTERR" "PPID" "PROMPT_COMMAND" "PS4" "pushd_silent" "PWD" "RANDOM" "REPLY" "SECONDS" "SHLVL" "TMOUT" "UID") (csh eval sh-append shell "argv" "cdpath" "child" "echo" "histchars" "history" "home" "ignoreeof" "mail" "noclobber" "noglob" "nonomatch" "path" "prompt" "shell" "status" "time" "verbose") (es eval sh-append shell "apid" "cdpath" "CDPATH" "history" "home" "ifs" "noexport" "path" "pid" "prompt" "signals") (jcsh eval sh-append csh "notify") (ksh88 eval sh-append sh "ENV" "ERRNO" "FCEDIT" "FPATH" "HISTFILE" "HISTSIZE" "LINENO" "OLDPWD" "PPID" "PS3" "PS4" "PWD" "RANDOM" "REPLY" "SECONDS" "TMOUT") (oash eval sh-append sh "FIELD" "FIELD_MAX" "LAST_KEY" "OALIB" "PP_ITEM" "PP_NUM") (rc eval sh-append shell "apid" "apids" "cdpath" "CDPATH" "history" "home" "ifs" "path" "pid" "prompt" "status") (sh eval sh-append shell "CDPATH" "IFS" "OPTARG" "OPTIND" "PS1" "PS2") (shell "COLUMNS" "EDITOR" "HOME" "HUSHLOGIN" "LANG" "LC_COLLATE" "LC_CTYPE" "LC_MESSAGES" "LC_MONETARY" "LC_NUMERIC" "LC_TIME" "LINES" "LOGNAME" "MAIL" "MAILCHECK" "MAILPATH" "PAGER" "PATH" "SHELL" "TERM" "TERMCAP" "TERMINFO" "VISUAL") (tcsh eval sh-append csh "addsuffix" "ampm" "autocorrect" "autoexpand" "autolist" "autologout" "chase_symlinks" "correct" "dextract" "edit" "el" "fignore" "gid" "histlit" "HOST" "HOSTTYPE" "HPATH" "ignore_symlinks" "listjobs" "listlinks" "listmax" "matchbeep" "nobeep" "NOREBIND" "oid" "printexitvalue" "prompt2" "prompt3" "pushdsilent" "pushdtohome" "recexact" "recognize_only_executables" "rmstar" "savehist" "SHLVL" "showdots" "sl" "SYSTYPE" "tcsh" "term" "tperiod" "tty" "uid" "version" "visiblebell" "watch" "who" "wordchars") (zsh eval sh-append ksh88 "BAUD" "bindcmds" "cdpath" "DIRSTACKSIZE" "fignore" "FIGNORE" "fpath" "HISTCHARS" "hostcmds" "hosts" "HOSTS" "LISTMAX" "LITHISTSIZE" "LOGCHECK" "mailpath" "manpath" "NULLCMD" "optcmds" "path" "POSTEDIT" "prompt" "PROMPT" "PROMPT2" "PROMPT3" "PROMPT4" "psvar" "PSVAR" "READNULLCMD" "REPORTTIME" "RPROMPT" "RPS1" "SAVEHIST" "SPROMPT" "STTY" "TIMEFMT" "TMOUT" "TMPPREFIX" "varcmds" "watch" "WATCH" "WATCHFMT" "WORDCHARS" "ZDOTDIR")) (#$ . 13276))
(byte-code "\302\301\303\304\305\306%\210\301B\307\301!\204 \301\302\207" [current-load-list sh-heredoc-face custom-declare-face ((((class color) (background dark)) (:foreground "yellow" :bold t)) (((class color) (background light)) (:foreground "tan")) (t (:bold t))) "Face to show a here-document" :group sh-indentation boundp] 6)
#@76 Default expressions to highlight in Shell Script modes.  See `sh-feature'.
(defvar sh-font-lock-keywords '((csh eval sh-append shell '("\\${?[#?]?\\([A-Za-z_][A-Za-z0-9_]*\\|0\\)" 1 font-lock-variable-name-face)) (es eval sh-append executable-font-lock-keywords '("\\$#?\\([A-Za-z_][A-Za-z0-9_]*\\|[0-9]+\\)" 1 font-lock-variable-name-face)) (rc eval identity es) (sh eval sh-append shell '("\\$\\({#?\\)?\\([A-Za-z_][A-Za-z0-9_]*\\|[-#?@!]\\)" 2 font-lock-variable-name-face) '("^\\(\\sw+\\)[ 	]*(" 1 font-lock-function-name-face) '("\\<\\(function\\)\\>[ 	]*\\(\\sw+\\)?" (1 font-lock-keyword-face) (2 font-lock-function-name-face nil t))) (shell eval sh-append executable-font-lock-keywords '("\\\\[^A-Za-z0-9]" 0 font-lock-string-face) '("\\${?\\([A-Za-z_][A-Za-z0-9_]*\\|[0-9]+\\|[$*_]\\)" 1 font-lock-variable-name-face)) (rpm eval sh-append rpm2 '("%{?\\(\\sw+\\)" 1 font-lock-keyword-face)) (rpm2 eval sh-append shell '("^\\(\\sw+\\):" 1 font-lock-variable-name-face))) (#$ . 16222))
#@52 Subdued level highlighting for Shell Script modes.
(defvar sh-font-lock-keywords-1 '((sh "[ 	]in\\>")) (#$ . 17220))
#@50 Gaudy level highlighting for Shell Script modes.
(defvar sh-font-lock-keywords-2 nil (#$ . 17343))
(byte-code "\301B\304\305!\302B\304\306!\303B\304\307!\301\207" [current-load-list sh-st-punc sh-st-symbol sh-here-doc-syntax string-to-syntax "." "_" "|"] 2)
#@51 Determine the syntax of the \n after a <<HEREDOC.
(defalias 'sh-font-lock-heredoc #[(start string quoted) "\306!?\205Y \307	\205 \310\311\312\313\314\n#!\315R\316\f\"\204V \317\311\n!\320Q\321\322\323\324BBD\325B\326\322\327\330BBDD\331\304\332\316\333BB\334BBE\335BBE \f\336\337 E!C\244*)!\207" [start quoted string ere font-lock-syntactic-keywords sre sh-in-comment-or-string "^" "[ 	]*" regexp-quote replace-regexp-in-string "['\"]" "" "\\(\n\\)" assoc "<<\\(-\\)?\\s-*\\\\?['\"]?" "['\"]?[ 	\n]" cond save-excursion re-search-backward (nil t) (sh-here-doc-syntax) not re-search-forward (nil t) setq delq (font-lock-syntactic-keywords) (font-lock-syntactic-keywords) (nil) font-lock-compile-keyword 1 code sh-here-doc-syntax] 9 (#$ . 17616)])
(defalias 'sh-font-lock-paren #[(start) "\212b\210\302d[!\210\303\304!\305U\203	 \306\307x\305U\203	 `Sf\310>\203( \307\311\312\217\204	 \302d[!\210`Sf\313=\203; \314u\210\202 \212\315u\210\316\317!)\205G 	)\207" [start sh-st-punc forward-comment skip-syntax-backward "w_" 0 "?*/" nil (34 39) (byte-code "\300\301!\210\302\207" [backward-sexp 1 t] 2) ((error)) 124 -1 -2 looking-at ";;\\|in"] 3])
(byte-code "\302B\303\304	E\305B\302\207" [current-load-list sh-st-symbol sh-font-lock-syntactic-keywords "[^|&;<>()`\\\"' 	\n]\\(#+\\)" 1 (("[^<>]<<\\(-\\)?\\s-*\\\\?\\(\\(['\"][^'\"]+['\"]\\|\\sw\\|\\s_\\)+\\).*\\(\n\\)" 4 (sh-font-lock-heredoc (match-beginning 0) (match-string 2) (match-end 1))) (")" 0 (sh-font-lock-paren (match-beginning 0))))] 3)
(defalias 'sh-font-lock-syntactic-face-function #[(state) "\3048\203 \305\3048!\203 	\207\n\207\207" [state font-lock-string-face sh-heredoc-face font-lock-comment-face 3 char-valid-p] 3])
(custom-declare-group 'sh-indentation nil "Variables controlling indentation in shell scripts.\n\nNote: customizing these variables will not affect existing buffers if\n`sh-make-vars-local' is no-nil.  See the documentation for\nvariable `sh-make-vars-local', command `sh-make-vars-local'\nand command `sh-reset-indent-vars-to-global-values'." :group 'sh-script)
#@30 *Hook run by `sh-set-shell'.
(custom-declare-variable 'sh-set-shell-hook 'nil '(#$ . -19694) :type 'hook :group 'sh-script)
#@25 *Hook run by `sh-mode'.
(custom-declare-variable 'sh-mode-hook 'nil '(#$ . -19824) :type 'hook :group 'sh-script)
#@233 *When `sh-guess-basic-offset' should learn `sh-basic-offset'.

nil mean:              never.
t means:               only if there seems to be an obvious value.
Anything else means:   whenever we have a "good guess" as to the value.
(custom-declare-variable 'sh-learn-basic-offset 'nil '(#$ . -19945) :type '(choice (const :tag "Never" nil) (const :tag "Only if sure" t) (const :tag "If have a good guess" usually)) :group 'sh-indentation)
#@145 *Controls when  `sh-learn-buffer-indent' pops the *indent* buffer.
If t it is always shown.  If nil, it is shown only when there
are conflicts.
(custom-declare-variable 'sh-popup-occur-buffer 'nil '(#$ . -20391) :type '(choice (const :tag "Only when there are conflicts." nil) (const :tag "Always" t)) :group 'sh-indentation)
#@216 *If non-nil, `sh-show-indent' shows the line indentation is relative to.
The position on the line is not necessarily meaningful.
In some cases the line will be the matching keyword, but this is not
always the case.
(custom-declare-variable 'sh-blink 't '(#$ . -20724) :type 'boolean :group 'sh-indentation)
#@153 *The indentation of the first non-blank non-comment line.
Usually 0 meaning first column.
Can be set to a number, or to nil which means leave it as is.
(custom-declare-variable 'sh-first-lines-indent '0 '(#$ . -21038) :type '(choice (const :tag "Leave as is" nil) (integer :tag "Column number" :menu-tag "Indent to this col (0 means first col)")) :group 'sh-indentation)
#@108 *The default indentation increment.
This value is used for the + and - symbols in an indentation variable.
(custom-declare-variable 'sh-basic-offset '4 '(#$ . -21416) :type 'integer :group 'sh-indentation)
#@224 *How a comment line is to be indented.
nil means leave it as it is;
t  means indent it as a normal line, aligning it to previous non-blank
   non-comment line;
a number means align to that column, e.g. 0 means fist column.
(custom-declare-variable 'sh-indent-comment 'nil '(#$ . -21629) :type '(choice (const :tag "Leave as is." nil) (const :tag "Indent as a normal line." t) (integer :menu-tag "Indent to this col (0 means first col)." :tag "Indent to column number.")) :group 'sh-indentation)
#@68 Enable lots of debug messages - if function `sh-debug' is enabled.
(defvar sh-debug nil (#$ . 22130))
(defalias 'sh-debug '(macro . #[(&rest args) "\300\207" [nil] 1]))
(byte-code "\301B\302\301\207" [current-load-list sh-symbol-list ((const :tag "+ " :value + :menu-tag "+   Indent right by sh-basic-offset") (const :tag "- " :value - :menu-tag "-   Indent left  by sh-basic-offset") (const :tag "++" :value ++ :menu-tag "++  Indent right twice sh-basic-offset") (const :tag "--" :value -- :menu-tag "--  Indent left  twice sh-basic-offset") (const :tag "* " :value * :menu-tag "*   Indent right half sh-basic-offset") (const :tag "/ " :value / :menu-tag "/   Indent left  half sh-basic-offset"))] 2)
#@60 *How much to indent an else relative to an if.  Usually 0.
(custom-declare-variable 'sh-indent-for-else '0 '(#$ . -22841) :type `(choice (integer :menu-tag "A number (positive=>indent right)" :tag "A number") (const :tag "--") ,@sh-symbol-list) :group 'sh-indentation)
(byte-code "\302B\303\304	\"\302\207" [current-load-list sh-symbol-list sh-number-or-symbol-list append ((integer :menu-tag "A number (positive=>indent right)" :tag "A number") (const :tag "--"))] 3)
#@57 *How much to indent a fi relative to an if.  Usually 0.
(custom-declare-variable 'sh-indent-for-fi '0 '(#$ . -23319) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@71 *How much to indent a done relative to its matching stmt.  Usually 0.
(custom-declare-variable 'sh-indent-for-done ''0 '(#$ . -23509) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@58 *How much to indent a statement after an else statement.
(custom-declare-variable 'sh-indent-after-else ''+ '(#$ . -23716) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@177 *How much to indent a statement after an if statement.
This includes lines after else and elif statements, too, but
does not affect then else elif or fi statements themselves.
(custom-declare-variable 'sh-indent-after-if ''+ '(#$ . -23913) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@47 *How much to indent a then relative to an if.
(custom-declare-variable 'sh-indent-for-then ''+ '(#$ . -24226) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@125 *How much to indent a do statement.
This is relative to the statement before the do, i.e. the
while until or for statement.
(custom-declare-variable 'sh-indent-for-do ''* '(#$ . -24410) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@200 *How much to indent a line after a do statement.
This is used when the do is the first word of the line.
This is relative to the statement before the do, e.g. a
while for repeat or select statement.
(custom-declare-variable 'sh-indent-after-do ''* '(#$ . -24670) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@256 *How much to indent a statement after a loop construct.

This variable is used when the keyword "do" is on the same line as the
loop statement (e.g.  "until", "while" or "for").
If the do is on a line by itself, then `sh-indent-after-do' is used instead.
(custom-declare-variable 'sh-indent-after-loop-construct ''+ '(#$ . -25007) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@251 *How much to indent a statement after a "done" keyword.
Normally this is 0, which aligns the "done" to the matching
looping construct line.
Setting it non-zero allows you to have the "do" statement on a line
by itself and align the done under to do.
(custom-declare-variable 'sh-indent-after-done '0 '(#$ . -25412) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@105 *How much to indent a case label statement.
This is relative to the line containing the case statement.
(custom-declare-variable 'sh-indent-for-case-label ''+ '(#$ . -25801) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@114 *How much to indent statements after the case label.
This is relative to the line containing the case statement.
(custom-declare-variable 'sh-indent-for-case-alt ''++ '(#$ . -26049) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@51 *How much to indent for a continuation statement.
(custom-declare-variable 'sh-indent-for-continuation ''+ '(#$ . -26304) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@143 *How much to indent after a line with an opening parenthesis or brace.
For an open paren after a function `sh-indent-after-function' is used.
(custom-declare-variable 'sh-indent-after-open ''+ '(#$ . -26500) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@44 *How much to indent after a function line.
(custom-declare-variable 'sh-indent-after-function ''+ '(#$ . -26781) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@98 *How much to indent a case statement relative to the switch statement.
This is for the rc shell.
(custom-declare-variable 'sh-indent-after-switch ''+ '(#$ . -26967) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@91 *How much to indent a statement relative to the case statement.
This is for the rc shell.
(custom-declare-variable 'sh-indent-after-case ''+ '(#$ . -27205) :type `(choice ,@sh-number-or-symbol-list) :group 'sh-indentation)
#@139 Make a regexp which matches WORD as a word.
This specifically excludes an occurrence of WORD followed by
punctuation characters like '-'.
(defalias 'sh-mkword-regexpr #[(word) "\301P\207" [word "\\([^-a-z0-9_]\\|$\\)"] 2 (#$ . 27435)])
(byte-code "\301B\302\303!\301\207" [current-load-list sh-re-done sh-mkword-regexpr "done"] 2)
#@57 Which keywords can match the word `done' in this shell.
(defconst sh-kws-for-done '((sh "while" "until" "for") (bash "while" "until" "for" "select") (ksh88 "while" "until" "for" "select") (zsh "while" "until" "for" "repeat" "select")) (#$ . 27776))
#@57 Shell types that shell indenting can do something with.
(defconst sh-indent-supported '((sh . t) (csh) (rc . t)) (#$ . 28031))
#@72 Non-nil if we support indentation for the current buffer's shell type.
(defvar sh-indent-supported-here nil (#$ . 28164))
#@76 Non-nil if the shell type needs an electric handling of case alternatives.
(defconst sh-electric-rparen-needed '((sh . t)) (#$ . 28292))
#@198 A list of variables used by script mode to control indentation.
This list is used when switching between buffer-local and global
values of variables, and for the commands using indentation styles.
(defconst sh-var-list '(sh-basic-offset sh-first-lines-indent sh-indent-after-case sh-indent-after-do sh-indent-after-done sh-indent-after-else sh-indent-after-if sh-indent-after-loop-construct sh-indent-after-open sh-indent-comment sh-indent-for-case-alt sh-indent-for-case-label sh-indent-for-continuation sh-indent-for-do sh-indent-for-done sh-indent-for-else sh-indent-for-fi sh-indent-for-then) (#$ . 28436))
#@341 *Controls whether indentation variables are local to the buffer.
If non-nil, indentation variables are made local initially.
If nil, you can later make the variables local by invoking
command `sh-make-vars-local'.
The default is t because I assume that in one Emacs session one is
frequently editing existing scripts with different styles.
(defvar sh-make-vars-local t (#$ . -29054))
(byte-code "\303\304\305\306#\210\301B\307\301!\204 \310 \302B\307\302!\204\" \311\312\313\"\314B\315\314\313\"\210\303\304\316\317#\207" [current-load-list sh-mode-map sh-mode-syntax-table put sh-mode mode-class special boundp make-sparse-keymap make-char-table syntax-table nil sh-mode-abbrev-table define-abbrev-table derived-mode-parent fundamental-mode] 4)
#@2565 Major mode for editing shell scripts.
This mode works for many shells, since they all have roughly the same syntax,
as far as commands, arguments, variables, pipes, comments etc. are concerned.
Unless the file's magic number indicates the shell, your usual shell is
assumed.  Since filenames rarely give a clue, they are not further analyzed.

This mode adapts to the variations between shells (see `sh-set-shell') by
means of an inheritance based feature lookup (see `sh-feature').  This
mechanism applies to all variables (including skeletons) that pertain to
shell-specific features.

The default style of this mode is that of Rosenblatt's Korn shell book.
The syntax of the statements varies with the shell being used.  The
following commands are available, based on the current shell's syntax:

\[sh-case]	 case statement
\[sh-for]	 for loop
\[sh-function]	 function definition
\[sh-if]	 if statement
\[sh-indexed-loop]	 indexed loop from 1 to n
\[sh-while-getopts]	 while getopts loop
\[sh-repeat]	 repeat loop
\[sh-select]	 select loop
\[sh-until]	 until loop
\[sh-while]	 while loop

For sh and rc shells indentation commands are:
\[sh-show-indent]	Show the variable controlling this line's indentation.
\[sh-set-indent]	Set then variable controlling this line's indentation.
\[sh-learn-line-indent]	Change the indentation variable so this line
would indent to the way it currently is.
\[sh-learn-buffer-indent]  Set the indentation variables so the
buffer indents as it currently is indented.


\[backward-delete-char-untabify]	 Delete backward one position, even if it was a tab.
\[sh-newline-and-indent]	 Delete unquoted space and indent new line same as this one.
\[sh-end-of-command]	 Go to end of successive commands.
\[sh-beginning-of-command]	 Go to beginning of successive commands.
\[sh-set-shell]	 Set this buffer's shell, and maybe its magic number.
\[sh-execute-region]	 Have optional header and region be executed in a subshell.

\[sh-maybe-here-document]	 Without prefix, following an unquoted < inserts here document.
{, (, [, ', ", `
	Unless quoted with \, insert the pairs {}, (), [], or '', "", ``.

If you generally program a shell different from your login shell you can
set `sh-shell-file' accordingly.  If your shell's file name doesn't correctly
indicate what shell it is use `sh-alias-alist' to translate.

If your shell gives error messages with line numbers, you can use \[executable-interpret]
with your script for an edit-interpret-debug cycle.

This mode runs the hook `sh-mode-hook', as the final step
during initialization.
(defalias 'sh-mode #[nil "\306 \210\306\307N\203 \310\311\307\312#\210\311\313\314\n!\204 \315\n\316 \"\210\317!\211\203. \f\320 =\2034 \321\322 \"\210)\203> \323\324\"\210\325\n!\210\326!\210@\327\330!\210\327\331!\210\327\332!\210\327\333!\210\327\334!\210\327\335!\210\327\336!\210\327\337!\210\327\340!\210\327\341!\210\327\342!\210\327\343!\210\327\344!\210\327\345!\210\327\346!\210\327\347!\210\327\350!\210\327\351!\210\327\352!\210\327\353!\210\354A\355P\211\356B#\357$\360\361\211\362\361\363\364C!B\365BBBBBB%\366!\367\"\370D\371&\312'\361+\327\372!\312L\210\212eb\210\373\374!\203\353 \375\376!\202\375 E\205\375 \377\201G E\"\205\375 \201H )F\201I F\206\n\361\211#\210)\201J \201K !\207" [major-mode mode-name sh-mode-map sh-mode-syntax-table parent local-abbrev-table fundamental-mode special put sh-mode t "Shell-script" keymap-parent set-keymap-parent current-local-map char-table-parent standard-syntax-table set-char-table-parent syntax-table mapatoms #[(symbol) "\302\303!	\"\206 \304	\303!JK$\207" [symbol sh-mode-abbrev-table intern-soft symbol-name define-abbrev] 5] use-local-map set-syntax-table make-local-variable skeleton-end-hook paragraph-start paragraph-separate comment-start comment-start-skip require-final-newline sh-header-marker sh-shell-file sh-shell skeleton-pair-alist skeleton-pair-filter comint-dynamic-complete-functions comint-prompt-regexp font-lock-defaults skeleton-filter skeleton-newline-indent-rigidly sh-shell-variables sh-shell-variables-initialized imenu-generic-expression sh-indent-supported-here #[nil "l\206 \300 \206 \301 \207" [newline indent-relative] 1] "\\|$" "# " "^[ 	]*" (sh-font-lock-keywords sh-font-lock-keywords-1 sh-font-lock-keywords-2) nil ((47 . "w") (126 . "w") (46 . "w") (45 . "w") (95 . "w")) font-lock-syntactic-keywords copy-sequence ((font-lock-syntactic-face-function . sh-font-lock-syntactic-face-function)) ((96 _ 96)) sh-quoted-p ((< '(- (min sh-indentation (current-column))))) sh-feature parse-sexp-ignore-comments looking-at "#![ 	]?\\([^ 	\n]*/bin/env[ 	]\\)?\\([^ 	\n]+\\)" match-string 2 string-match sh-mode-abbrev-table page-delimiter sh-dynamic-complete-functions sh-font-lock-syntactic-keywords skeleton-further-elements buffer-file-name interpreter "\\.m?spec$" "rpm" sh-set-shell run-hooks sh-mode-hook] 9 (#$ . 29817) nil])
(defalias 'shell-script-mode 'sh-mode)
#@118 Function to get simple fontification based on `sh-font-lock-keywords'.
This adds rules for comments and assignments.
(defalias 'sh-font-lock-keywords #[(&optional keywords) "\302\302	!;\205\n \303\"\207" [sh-font-lock-keywords sh-assignment-regexp sh-feature #[(list) "\303!\304B\305	\n\"B\207" [sh-assignment-regexp keywords list sh-feature (1 font-lock-variable-name-face) append] 4]] 4 (#$ . 34793)])
#@58 Function to get better fontification including keywords.
(defalias 'sh-font-lock-keywords-1 #[(&optional builtins) "\306\307\310\311!\312#\313\307\310\314\311!\311	!\"\312#\315\260\316\314\2050 \n\317\307\310\311\f!\312#\320R\321B\311!B\n\320P\322BC\311!#!)\207" [sh-leading-keywords sh-other-keywords keywords builtins sh-builtins sh-font-lock-keywords-2 "\\([;(){}`|&]\\|^\\)[ 	]*\\(\\(\\(" mapconcat identity sh-feature "\\|" "\\)[ 	]+\\)?\\(" append "\\)" sh-font-lock-keywords "[ 	]+\\)?\\(" "\\)\\>" ((2 font-lock-keyword-face nil t) (6 font-lock-builtin-face)) (2 font-lock-keyword-face) sh-font-lock-keywords-1] 9 (#$ . 35205)])
#@71 Function to get better fontification including keywords and builtins.
(defalias 'sh-font-lock-keywords-2 #[nil "\300\301!\207" [sh-font-lock-keywords-1 t] 2 (#$ . 35856)])
#@58 A buffer-local regexp to match opening keyword for done.
(defvar sh-regexp-for-done nil (#$ . 36034))
#@69 A buffer-local, since it is shell-type dependent, list of keywords.
(defvar sh-kw-alist nil (#$ . 36142))
(byte-code "\301B\302\301\207" [current-load-list sh-kw ((sh ("if" nil sh-handle-prev-if) ("elif" sh-handle-this-else sh-handle-prev-else) ("else" sh-handle-this-else sh-handle-prev-else) ("fi" sh-handle-this-fi sh-handle-prev-fi) ("then" sh-handle-this-then sh-handle-prev-then) ("(" nil sh-handle-prev-open) ("{" nil sh-handle-prev-open) ("[" nil sh-handle-prev-open) ("}" sh-handle-this-close nil) (")" sh-handle-this-close nil) ("]" sh-handle-this-close nil) ("case" nil sh-handle-prev-case) ("esac" sh-handle-this-esac sh-handle-prev-esac) (case-label nil sh-handle-after-case-label) (";;" nil sh-handle-prev-case-alt-end) ("done" sh-handle-this-done sh-handle-prev-done) ("do" sh-handle-this-do sh-handle-prev-do)) (rc ("{" nil sh-handle-prev-open) ("}" sh-handle-this-close nil) ("case" sh-handle-this-rc-case sh-handle-prev-rc-case)))] 2)
#@218 Set this buffer's shell to SHELL (a string).
Makes this script executable via `executable-set-magic', and sets up the
proper starting #!-line, if INSERT-FLAG is non-nil.
Calls the value of `sh-set-shell-hook' if set.
(defalias 'sh-set-shell #[(shell &optional no-query-flag insert-flag) "\306\307\"\203 \310\211\224O\311\312!!\211\n\236A\206 	\203* \313\314\f!$$\314%!&\315'\316\317	\"(\320)\320*\314+!,\320-\314.!\320/\2110\203h 0@/\321/!\2100A\2110\204U *\322\323!\210\3141!\2112\203\271 \324\325	\"\210\322\326!\327L\210\322\330!\3143!L\210\3144!\2115\203\241 \322\331!\332\3335\327\"!L\210)\324\334!\210\335\203\261 \336 \210\324\337	\"\210\202\300 \324\340!\210\341\342\343!\207" [shell sh-shell sh-alias-alist insert-flag sh-shell-arg no-query-flag string-match "\\.exe\\'" 0 intern file-name-nondirectory executable-set-magic sh-feature "#+[	 ]*" format "[%s]" nil sh-remember-variable make-local-variable indent-line-function message "Setting up indent for shell type %s" parse-sexp-lookup-properties t sh-kw-alist sh-regexp-for-done sh-mkword-regexpr regexp-opt "setting up indent stuff" sh-indent-line sh-make-vars-local "Indentation setup for shell type %s" "No indentation for this shell type." sh-basic-indent-line run-hooks sh-set-shell-hook sh-shell-file sh-require-final-newline require-final-newline comment-start-skip mode-line-process sh-shell-variables sh-shell-variables-initialized sh-imenu-generic-expression imenu-generic-expression imenu-case-fold-search sh-variables var #1=#:--dolist-temp--97271 sh-indent-supported sh-indent-supported-here sh-kw sh-kws-for-done regexp] 6 (#$ . 37105) (list (completing-read "Name or path of shell: " interpreter-mode-alist (lambda (x) (eq (cdr x) 'sh-mode))) (eq executable-query 'function) t)])
#@933 Index ALIST by the current shell.
If ALIST isn't a list where every element is a cons, it is returned as is.
Else indexing follows an inheritance logic which works in two ways:

  - Fall back on successive ancestors (see `sh-ancestor-alist') as long as
    the alist contains no value for the current shell.
    The ultimate default is always `sh'.

  - If the value thus looked up is a list starting with `eval' its `cdr' is
    first evaluated.  If that is also a list and the first argument is a
    symbol in ALIST it is not evaluated, but rather recursively looked up in
    ALIST to allow the function called to define the value for one shell to be
    derived from another shell.  While calling the function, is the car of the
    alist element is the current shell.
    The value thus determined is physically replaced into the alist.

Optional FUNCTION is applied to the determined value and the result is cached
in ALIST.
(defalias 'sh-feature #[(list &optional function) ":\203! \211\203 	@:\203 	A\211\204 	\205 )\206\243 \n\2031 \306\nB\211\"A\206\243 \307\211\211\203M \236\211\204M \f\236A\211\204; \204U \310\236A\211:\203\216 \f@\311=\203\216 \311\fA\211:\203\210 \fA@\307\211\236\203\203 \fA\312\313!D\240\210\f*\202\211 \f!\211\241\210\n\203\241 \n\211@\nA\f!\211BC\244\210\f+\207" [list l function sh-shell val elt assoc nil sh eval quote sh-feature sh-ancestor-alist] 7 (#$ . 38912)])
#@78 Return list composed of first argument (a list) physically appended to rest.
(defalias 'sh-append #[(ancestor &rest list) "	\244\207" [list ancestor] 2 (#$ . 40361)])
#@73 Modify a copy of SKELETON by replacing I1 with REPL1, I2 with REPL2 ...
(defalias 'sh-modify #[(skeleton &rest list) "\302!	\203! 	@\233\206 \303\304	@\"	A@\240\210	AA\211\204 \207" [skeleton list copy-sequence error "Index %d out of bounds"] 4 (#$ . 40535)])
#@179 Indent a line for Sh mode (shell script mode).
Indent as far as preceding non-empty line, then by steps of `sh-indentation'.
Lines containing only comments are considered empty.
(defalias 'sh-basic-indent-line #[nil "\212\304 \210o\204 \305y\210\306 \210l\204 g\307=\204 i)\310\212\n\311=\203( 	\202[ i\306 \210i\211W\203? l\203; 	\202[ \312\202[ `\304 \210`|\210l\203U 	\245T_]\202[ \245T_j\210)i\313 W\205h \314\310w*\207" [current previous this-command sh-indentation beginning-of-line -1 back-to-indentation 35 nil newline-and-indent 0 current-indentation " 	"] 3 (#$ . 40809) nil])
#@398 Pass optional header and region to a subshell for noninteractive execution.
The working directory is that of the buffer, and only environment variables
are already set which is why you can mark a header within the script.

With a positive prefix ARG, instead of sending region, define header from
beginning of buffer to point.  With a negative prefix ARG, instead of sending
region, clear header.
(defalias 'sh-execute-region #[(start end &optional flag) "\203 \306!\307V\205 \310 \211\207	\2032 \212\311	b\210\312p\f#\210\313e	\fZ\\\211#\210	\f|*\207\313\f\314P#\207" [flag sh-header-marker buffer-undo-list start end sh-shell-file prefix-numeric-value 0 point-marker nil append-to-buffer shell-command-on-region " -"] 5 (#$ . 41415) "r\nP"])
#@69 Make VARIABLE available for future completing reads in this buffer.
(defalias 'sh-remember-variable #[(var) "G	W\204 \303!\204 \304\n\"\204 \211B\nB\207" [var sh-remember-variable-min sh-shell-variables getenv assoc] 3 (#$ . 42177)])
#@52 Is point preceded by an odd number of backslashes?
(defalias 'sh-quoted-p #[nil "\212\300\301x)\302\246\303=\207" ["\\\\" nil 2 -1] 2 (#$ . 42426)])
#@46 Signal an error if not in Shell-script mode.
(defalias 'sh-must-be-shell-mode #[nil "\301=?\205\n \302\303!\207" [major-mode sh-mode error "This buffer is not in Shell-script mode"] 2 (#$ . 42581)])
#@117 *Signal an error if the shell type for this buffer is not supported.
Also, the buffer must be in Shell-script mode.
(defalias 'sh-must-support-indent #[nil "\301 \210?\205 \302\303!\207" [sh-indent-supported-here sh-must-be-shell-mode error "This buffer's shell type is not supported for this command"] 2 (#$ . -42788)])
#@278 Make the indentation variables local to this buffer.
Normally they already are local.  This command is provided in case
variable `sh-make-vars-local' has been set to nil.

To revert all these variables to the global values, use
command `sh-reset-indent-vars-to-global-values'.
(defalias 'sh-make-vars-local #[nil "\301 \210\302\303\"\210\304\305!\207" [sh-var-list sh-must-be-shell-mode mapcar make-local-variable message "Indentation variable are now local."] 3 (#$ . 43118) nil])
#@125 Reset local indentation variables to the global values.
Then, if variable `sh-make-vars-local' is non-nil, make them local.
(defalias 'sh-reset-indent-vars-to-global-values #[nil "\302 \210\303\304\"\210	\205 \303\305\"\207" [sh-var-list sh-make-vars-local sh-must-be-shell-mode mapcar kill-local-variable make-local-variable] 3 (#$ . 43608) nil])
(byte-code "\301B\302\301\207" [current-load-list sh-special-keywords "then\\|do"] 2)
#@72 Construct a string for `sh-read-variable' when changing variable VAR .
(defalias 'sh-help-string-for-variable #[(var) "\305\306\"\307\310>\204 \311\312\313\314\f\315##\n	P*\207" [var msg2 msg sh-basic-offset sh-symbol-list documentation-property variable-documentation "" (sh-first-lines-indent sh-indent-comment) format "\n\nYou can enter a number (positive to increase indentation,\nnegative to decrease indentation, zero for no change to indentation).\n\nOr, you can enter one of the following symbols which are relative to\nthe value of variable `sh-basic-offset'\nwhich in this buffer is currently %s.\n\n	%s." mapconcat #[(x) "GS8\207" [x] 2] "\n	"] 7 (#$ . 44054)])
#@48 Read a new value for indentation variable VAR.
(defalias 'sh-read-variable #[(var) "\304\305DD\306\307\310\311\312!#\310\313J\"\306\314$\211*\207" [var val minibuffer-help-form help-char sh-help-string-for-variable quote nil read-from-minibuffer format "New value for %s (press %s for help): " single-key-description "%s" t] 7 (#$ . 44742) "*variable? "])
#@52 Return non-nil if START is in a comment or string.
(defalias 'sh-in-comment-or-string #[(start) "\212\302\303 \210\304`	\302\211\211\305&\3068\206 \3078*\207" [state start nil beginning-of-line parse-partial-sexp t 3 4] 7 (#$ . 45111)])
#@67 Go to the matching if for a fi.
This handles nested if..fi pairs.
(defalias 'sh-goto-matching-if #[nil "\301\302\303\304#\211\205\f b)\207" [found sh-find-prev-matching "\\bif\\b" "\\bfi\\b" 1] 5 (#$ . 45360)])
(defalias 'sh-handle-prev-if #[nil "\300C\207" [(+ sh-indent-after-if)] 1])
(defalias 'sh-handle-this-else #[nil "\300 \205 \301\302D\207" [sh-goto-matching-if "aligned to if" (+ sh-indent-for-else)] 2])
(defalias 'sh-handle-prev-else #[nil "\300 \205 \301C\207" [sh-goto-matching-if (+ sh-indent-after-if)] 1])
(defalias 'sh-handle-this-fi #[nil "\300 \205 \301\302D\207" [sh-goto-matching-if "aligned to if" (+ sh-indent-for-fi)] 2])
(defalias 'sh-handle-prev-fi #[nil "\300 \210\301\207" [sh-goto-matching-if nil] 1])
(defalias 'sh-handle-this-then #[nil "\301 \211\205	 \302C)\207" [p sh-goto-matching-if (+ sh-indent-for-then)] 2])
(defalias 'sh-handle-prev-then #[nil "\301 \211\205	 \302C)\207" [p sh-goto-matching-if (+ sh-indent-after-if)] 2])
(defalias 'sh-handle-prev-open #[nil "\212\301 \211\203 b\210\302\303!\204 \302\304!\203 \305C\202 \306C*\207" [x sh-prev-stmt looking-at "function\\b" "\\s-*\\S-+\\s-*()" (+ sh-indent-after-function) (+ sh-indent-after-open)] 3])
(defalias 'sh-handle-this-close #[nil "\300u\210\301\302!\205 \303C\207" [1 sh-safe-forward-sexp -1 "aligned to opening paren"] 2])
(defalias 'sh-goto-matching-case #[nil "\301\302\303\304#\211\205\f b)\207" [found sh-find-prev-matching "\\bcase\\b" "\\besac\\b" 1] 5])
(defalias 'sh-handle-prev-case #[nil "\300\301!\203	 \302C\207\303\304!\207" [looking-at ".*\\<case\\>" (+ sh-indent-for-case-label) error "We don't seem to be on a line with a case"] 2])
(defalias 'sh-handle-this-esac #[nil "\300 \205 \301C\207" [sh-goto-matching-case "aligned to matching case"] 1])
(defalias 'sh-handle-prev-esac #[nil "\300 \205 \301C\207" [sh-goto-matching-case "matching case"] 1])
(defalias 'sh-handle-after-case-label #[nil "\300 \205 \301C\207" [sh-goto-matching-case (+ sh-indent-for-case-alt)] 1])
(defalias 'sh-handle-prev-case-alt-end #[nil "\300 \205 \301C\207" [sh-goto-matching-case (+ sh-indent-for-case-label)] 1])
#@106 Try and do a `forward-sexp', but do not error.
Return new point if successful, nil if an error occurred.
(defalias 'sh-safe-forward-sexp #[(&optional arg) "\300\301\302\217\207" [nil (byte-code "\301\206 \302!\210`\207" [arg forward-sexp 1] 2) ((error))] 3 (#$ . 47502)])
(defalias 'sh-goto-match-for-done #[nil "\303	\304#\211\205\f \nb)\207" [sh-regexp-for-done sh-re-done found sh-find-prev-matching 1] 5])
(defalias 'sh-handle-this-done #[nil "\300 \205 \301\302D\207" [sh-goto-match-for-done "aligned to do stmt" (+ sh-indent-for-done)] 2])
(defalias 'sh-handle-prev-done #[nil "\300 \205 \301C\207" [sh-goto-match-for-done "previous done"] 1])
(defalias 'sh-handle-this-do #[nil "\300 \205 \301C\207" [sh-goto-match-for-done (+ sh-indent-for-do)] 1])
(defalias 'sh-handle-prev-do #[nil "\214`\212\300 \210`)}\210\301 )\203 \302C\207\301 \203 \303C\207\304\305!\210\306\207" [beginning-of-line sh-goto-match-for-done (+ sh-indent-after-loop-construct) (+ sh-indent-after-do) message "match for done NOT found" nil] 2])
#@73 Find the line for the switch keyword matching this line's case keyword.
(defalias 'sh-find-prev-switch #[nil "\300\301\302\303#\207" [re-search-backward "\\<switch\\>" nil t] 4 (#$ . 48541)])
(defalias 'sh-handle-this-rc-case #[nil "\300 \205 \301C\207" [sh-find-prev-switch (+ sh-indent-after-switch)] 1])
(defalias 'sh-handle-prev-rc-case #[nil "\300C\207" [(+ sh-indent-after-case)] 1])
(defalias 'sh-check-rule #[(n thing) "\305	\n\"8\306\211\203 \f *\207" [n thing sh-kw-alist val rule assoc nil] 5])
#@903 Return indent-info for this line.
This is a list.  nil means the line is to be left as is.
Otherwise it contains one or more of the following sublists:
(t NUMBER)   NUMBER is the base location in the buffer that indentation is
	     relative to.  If present, this is always the first of the
	     sublists.  The indentation of the line in question is
	     derived from the indentation of this point, possibly
	     modified by subsequent sublists.
(+ VAR)
(- VAR)      Get the value of variable VAR and add to or subtract from
	     the indentation calculated so far.
(= VAR)	     Get the value of variable VAR and *replace* the
	     indentation with its value.  This only occurs for
	     special variables such as `sh-indent-comment'.
STRING	     This is ignored for the purposes of calculating
	     indentation, it is printed in certain cases to help show
	     what the indentation is based on.
(defalias 'sh-get-indent-info #[nil "\212\306\211\211\211\211\211\211\211\211\211\211\211\211\211\211\211\211\211\211*+,-./0123456\307 \210\310\311!\203G \312`\313\"	=\204Q \312`\313\"7=\203Z \314*\3144\202u \315\316!\203u o\203j \314*\202u \317C*\320\306!\30644\204\267 \321 \203\215 \320\306!\322C*\3144\202\230 \307 \210\323\306w\210\324 11\203\267 \325\3261\"\211+\203\267 `\327*+\"*\3144`4\204\300 \320\330!	\203\201\212`-	b\210\314\203\200\331 \211\203\200\332\232\203	\312`S\333\"8\232\203	\334\325\335\"\211+\203\377 \327*+\"*`\336u\210\337\306w\210\202\315 \340\341\"\203%\342\336!\211\203\315 `\327*\343C\"*\202\315 \340\344\"\203F\325\335\"\211+\203>\327*+\"*\336u\210`\202\315 \340\345\"\203U\342\336!\211\202\316 ;\203x\325\335\"\211+\203l\327*+\"*`n\204\315 \336u\210\202\315 \346\347\"\210\202\315 )\n\203\217\327\314\nDC*\"**\204\247	\203\241\314	DC*\202\247\350\351DC**\314=\203\261\306**.\207" [x prev-line-end align-point this-list prev-list prev-lines-indent nil beginning-of-line boundp font-lock-string-face get-text-property face t looking-at "\\s-*#" (= sh-indent-comment) sh-prev-line sh-this-is-a-continuation (+ sh-indent-for-continuation) " 	" sh-get-kw sh-check-rule 1 append end sh-prev-thing ")" syntax-table case-label 2 -1 "[a-z0-9]*?" string-match "[])}]" sh-safe-forward-sexp "aligned to opening paren" "[[({]" "[\"'`]" error "Don't know what to do with %s" = sh-first-lines-indent result val func start depth-prev-bol state-bol state this-kw depth-eol depth-bol have-result prev-stmt prev-kw sh-heredoc-face sh-st-punc] 20 (#$ . 49061)])
#@197 Return the variable controlling indentation for this line.
If there is not [just] one such variable, return a string
indicating the problem.
If INFO is supplied it is used, else it is calculated.
(defalias 'sh-get-indent-var-for-line #[(&optional info) "\306\211\211\211\211\204 \307 \204 \310\202q \203q \204q @\211;\203/ \202j <\204< \311\312\"\210\202j @\313=\204j A@\2119\203e \f\314=\203W \f\202j \f\203` \315\202j 	\202j \311\316\"\210A\211\204 \204w \f\204} \n\204\203 \317-\207" [elt sym reason result var info nil sh-get-indent-info "this line to be left as is" error "sh-get-indent-var-for-line invalid elt: %s" t sh-indent-comment "this line is controlled by more than 1 variable." "sh-get-indent-var-for-line invalid list elt: %s" "line has default indentation"] 6 (#$ . 51647)])
#@196 Back to end of previous non-comment non-empty line.
Go to beginning of logical line unless END is non-nil, in which case
we go to the end of the previous line and do not check for continuations.
(defalias 'sh-prev-line #[(&optional end) "\303 \210\212\304 \210\305d[!\210\204 \304 \210o\204< \306`S\307\"	\232\203< \310`S\307\"\211\203; \nb\210\2038 \311\210\202; \304 \210)\204S \312 \203L \313\314yY\204@ \304 \210\315\311w\210`)\207" [end sh-heredoc-face p1 sh-must-be-shell-mode beginning-of-line forward-comment get-text-property face previous-single-property-change nil sh-this-is-a-continuation 0 -1 " 	"] 4 (#$ . 52482)])
#@49 Return the address of the previous stmt or nil.
(defalias 'sh-prev-stmt #[nil "\212\306`\307\211\310\307x\210	\204t o\204t \203t \311\312!\203/ \313\f!\203* \202O `\202O \314\315\307x!\203: \312u\210n\203O \316\307!\211\203L b\210\202N \307)	\204 \317\307x\210n\203` \320 \203n `Sf\321=\204n \313\322!\203 `\211\203 	\203{ 	b\210	\203\205 \323\307w\210``\nY\203\224 \324\325!\210\307\202\226 	\210	-\207" [prev found start going sh-special-keywords back t nil " 	;|&({[" sh-safe-forward-sexp -1 looking-at zerop " 	()[]{};`'" sh-prev-line " 	" sh-this-is-a-continuation 59 "\\s-*[|&]" " 	|&({[" debug "We didn't move!"] 5 (#$ . 53124) nil])
#@50 Get a shell word skipping whitespace from point.
(defalias 'sh-get-word #[nil "\301\302w\210`\303\304!\203 \305 \202 \306\302w\307V\204 `{)\207" [start "	 " nil looking-at "[\"'`]" sh-safe-forward-sexp "-_a-zA-Z$0-9" 0] 2 (#$ . 53788) nil])
#@46 Return the previous thing this logical line.
(defalias 'sh-prev-thing #[nil "n?\205| \306\307\211\211`\307\214\310 \203 \311\307!\211\202' \212\312 \210`\211)`}\210\313\307x\210\314\315!\204< \316\307x\210`Sf)`\nW\203I \317\320`\n#\210\314\315!\203S \321\202z \f\322=\204e \f\307=\204e \f\323=\203w \212\324\307w\210`	Y?\205s \325 )\202z \326\f!.\207" [found start min-point n c going t nil sh-this-is-a-continuation sh-prev-line beginning-of-line " 	;" looking-at "\\s-*;;" "^)}];\"'`({[" error "point %d < min-point %d" ";;" 10 59 " 	\n\\\\" sh-get-word char-to-string] 6 (#$ . 54040)])
#@68 Return non-nil if current line is a continuation of previous line.
(defalias 'sh-this-is-a-continuation #[nil "\212\300\301y!\205 \302\303!\205 \304\305\306\224\306\225\307\211\211\310&8?)\207" [zerop -1 looking-at ".*\\\\$" 4 parse-partial-sexp 0 nil t] 8 (#$ . 54646)])
#@88 Return first word of line from WHERE.
If AND-MOVE is non-nil then move to end of word.
(defalias 'sh-get-kw #[(&optional where and-move) "`	\203	 	b\210`\303\304w\210`{\n\204 b\210)\207" [start where and-move "^ 	\n;" nil] 3 (#$ . 54927)])
#@263 Find a matching token for a set of opening and closing keywords.
This takes into account that there may be nested open..close pairings.
OPEN and CLOSE are regexps denoting the tokens to be matched.
Optional parameter DEPTH (usually 1) says how many to look for.
(defalias 'sh-find-prev-matching #[(open close &optional depth) "\303\304\n\206	 \305\212\304\306\307\217\210\n\310=\205 +\207" [prev parse-sexp-ignore-comments depth t nil 1 (byte-code "\304U\204; o\204; \305 \211\203; 	b\210\212\306\307!\203\" \310u\210\311\312w\210\306\n!\203. S\2027 \306!\2037 T)\202  \312\207" [depth prev open close 0 sh-prev-stmt looking-at "\\\\\n" 2 " 	" nil] 2) ((error)) 0] 3 (#$ . 55177)])
#@181 Return the value of variable VAR, interpreting symbols.
It can also return t or nil.
If an illegal value is found, throw an error unless Optional argument
IGNORE-ERROR is non-nil.
(defalias 'sh-var-value #[(var &optional ignore-error) "J\211\247\203\f 	\202z 	\304=\203 	\202z 	\204 	\202z 	\305=\203( \n\202z 	\306=\2033 \n[\202z 	\307=\203A \n\211\\\310\\\202z 	\311=\203N \n[\312_\202z 	\313=\203Z \n\312\245\202z 	\314=\203g \n[\312\245\202z \203u \315\316	#\210\310\202z \317\316	#)\207" [var val sh-basic-offset ignore-error t + - ++ 0 -- 2 * / message "Don't know how to handle %s's value of %s" error] 5 (#$ . 55878)])
#@135 Set variable VAR to VALUE.
Unless optional argument NO-SYMBOL is non-nil, then if VALUE is
can be represented by a symbol then do so.
(defalias 'sh-set-var-value #[(var value &optional no-symbol) "\203 	\nL\207\nU\203 	\304L\207\n[U\203 	\305L\207\n\211\\\306\\=\203+ 	\307L\207\n[\310_=\2038 	\311L\207\n\310\245=\203D 	\312L\207\n[\310\245=\203Q 	\313L\207	\nL\207" [no-symbol var value sh-basic-offset + - 0 ++ 2 -- * /] 3 (#$ . 56519)])
#@119 Return the indentation for the current line.
If INFO is supplied it is used, else it is calculated from current line.
(defalias 'sh-calculate-indent #[(&optional info) "\306\211\307\211\211\211\211\204 \310 \205\350 \203\301 @\211;\204\270 \f<\203\263 @@@A@\311=\203N \212\nb\210\312 )\202\270 \n9\203\252 \313\n!\314=\203\203 \204l \307\307\307\202\270 \311=\203x \306\202\270 \306\307\202\270 \315=\203\222 \\\202\270 \316=\203\241 Z\202\270 \317\320\n#\210\202\270 \317\321\n#\210\202\270 \317\322\f\"\210A\211\204\" \203\312 \204\316 \307\202\350 \247\203\340 \247\203\340 \\\202\350 \317\323#\210\307.\207" [val var b a elt base-value 0 nil sh-get-indent-info t current-indentation sh-var-value = + - error "sh-calculate-indent invalid a a=%s b=%s" "sh-calculate-indent invalid elt: a=%s b=%s" "sh-calculate-indent invalid elt %s" "sh-calculate-indent:  Help.  base-value=%s ofs=%s" ofs info] 8 (#$ . 56977)])
#@26 Indent the current line.
(defalias 'sh-indent-line #[(&optional prefix-arg) "\305 \210\306 \307\211\211d`Z\211\205: \310 \210`\311\307w\210\fiZ\312!\204. \n`|\210\fj\210dZ`V\205: dZb-\207" [pos end beg shift-amt indent sh-must-be-shell-mode sh-calculate-indent nil beginning-of-line " 	" zerop] 7 (#$ . 57976) nil])
#@54 Move cursor momentarily to BLINKPOS and display MSG.
(defalias 'sh-blink #[(blinkpos &optional msg) "\247\203 \212b\210\303	!\210\304\n!)\207\303	!\207" [blinkpos msg blink-matching-delay message sit-for] 2 (#$ . 58308)])
#@352 Show the how the currently line would be indented.
This tells you which variable, if any, controls the indentation of
this line.
If optional arg ARG is non-null (called interactively with a prefix),
a pop up window describes this variable.
If variable `sh-blink' is non-nil then momentarily go to the line
we are indenting relative to, if applicable.
(defalias 'sh-show-indent #[(arg) "\306 \210\307 \310!\311 \312\312	;\203 \313	\211!\210\202U \314!\n=\2033 \315\316	\211J#\202I \203B \315\317	\211J\n%\202H \315\320	\211J#\203U 	\203U \321	!\210\203\200 \307 \211\203y @<\203y @@\322=\203y \323@A@\f\"\202| \313\f!)\202\203 \313\f!-\207" [info var curr-indent val msg arg sh-must-support-indent sh-get-indent-info sh-get-indent-var-for-line current-indentation nil message sh-calculate-indent format "%s is %s" "%s (%s) would change indent from %d to: %d" "%s (%s) would leave line as is" describe-variable t sh-blink] 7 (#$ . 58540) "P"])
#@136 Set the indentation for the current line.
If the current line is controlled by an indentation variable, prompt
for a new value for it.
(defalias 'sh-set-indent #[nil "\306 \210\307 \310!\311\311\311\311\311	;\203# \312\313\314	\"!\202. 	J\315	!\311\316\317\217.\207" [info var val val0 new-val old-val sh-must-support-indent sh-get-indent-info sh-get-indent-var-for-line nil message format "Cannot set indent - %s" sh-read-variable (byte-code "	L\210\304\n!\211\203 \305\306\211J$\207\305\307\211J#\207" [var val info indent-val sh-calculate-indent message "Variable: %s  Value: %s  would indent to: %d" "Variable: %s  Value: %s  would leave line as is."] 6) ((error (byte-code "	L\210\302\303	#\210\304\305!\210\306\207" [var old-val message "Bad value for %s, restoring to previous value %s" sit-for 1 nil] 4))) indent-val] 4 (#$ . 59511) nil])
#@347 Learn how to indent a line as it currently is indented.

If there is an indentation variable which controls this line's indentation,
then set it to a value which would indent the line the way it
presently is.

If the value can be represented by one of the symbols then do so
unless optional argument ARG (the prefix when interactive) is non-nil.
(defalias 'sh-learn-line-indent #[(arg) "\306 \210\212\307 \210\310\311!)\203 \312\313!\207\314 \315!\316\316\316\316\317 	;\2037 \312\320\321	\"!\202\226 	\322=\203i \323U\203H \323\202^ \324\325!\211U\203[ \324\202] *\312\326	\211J#\202\226 \327	!\211\247\203\217 \325!\nZ\f\\\330	#\210\312\326	\211J#\202\226 \331 \210\312\332	\".\207" [info var ival sval diff new-val sh-must-support-indent beginning-of-line looking-at "\\s-*$" message "sh-learn-line-indent ignores empty lines." sh-get-indent-info sh-get-indent-var-for-line nil current-indentation format "Cannot learn line - %s" sh-indent-comment 0 t sh-calculate-indent "%s set to %s" sh-var-value sh-set-var-value debug "Cannot change %s" arg no-symbol curr-indent val2] 5 (#$ . 60385) "*P"])
#@51 Initialize a BUFFER to be used by `sh-mark-line'.
(defalias 'sh-mark-init #[(buffer) "p\212\303	!q\210\304 \210\305 \210\211*\207" [main-buffer buffer occur-buffer get-buffer-create erase-buffer occur-mode] 2 (#$ . 61529)])
#@298 Insert MESSAGE referring to location POINT in current buffer into BUFFER.
Buffer BUFFER is in `occur-mode'.
If ADD-LINENUM is non-nil the message is preceded by the line number.
If OCCUR-POINT is non-nil then the line is marked as a new occurrence
so that `occur-next' and `occur-prev' will work.
(defalias 'sh-mark-line #[(message point buffer &optional add-linenum occur-point) "\306 p\307\310\f\203 \fp\223\210\203 \311\312\313\314\f\"T\"\212\315!\2030 \315!q\210\202< \316!q\210\317 \210\ndb\210`c\210\203L `c\210\f\203Z \320	`\321#\210\322c\210\f\205u \323	`\324$\210\205u \323\211T\325\326$-\207" [line start main-buffer m1 point add-linenum make-marker nil "" format "%d: " count-lines 1 get-buffer get-buffer-create occur-mode add-text-properties (mouse-face highlight help-echo "mouse-2: go to the line where I learned this") "\n" put-text-property occur occur-point t buffer occur-buffer message] 5 (#$ . 61763)])
#@63 *An abnormal hook, called with an alist of learned variables.
(defvar sh-learned-buffer-hook nil (#$ . -62723))
#@963 Learn how to indent the buffer the way it currently is.

Output in buffer "*indent*" shows any lines which have conflicting
values of a variable, and the final value of all variables learned.
This buffer is popped to automatically if there are any discrepancies.

If no prefix ARG is given, then variables are set to numbers.
If a prefix arg is given, then variables are set to symbols when
applicable -- e.g. to symbol `+' if the value is that of the
basic indent.
If a positive numerical prefix is given, then  `sh-basic-offset'
is set to the prefix's numerical value.
Otherwise, sh-basic-offset may or may not be changed, according
to the value of variable `sh-learn-basic-offset'.

Abnormal hook `sh-learned-buffer-hook' if non-nil is called when the
function completes.  The function is abnormal because it is called
with an alist of variables learned.  This feature may be changed or
removed in the future.

This command can often take a long time to run.
(defalias 'sh-learn-buffer-indent #[(&optional arg) "\306 \210\212eb\210\307\310\311\307\211\312\307\211\211\313\307\205 \247\205 \311V\311\307@ABCDEFGH\314C\311\"B\315G!\210\203S ,\316\317,\"\202Y \316\320,\"`dW\203q\nT\321\322\n\"\210\323\324!\204k\313$\325 I\326I!J\307K\307L\307M\307N\327 OJ\203iJ;\204i\330J\331\"\211K\247\203?\332 LOLZMKM\\N\333JN\334#\210\323\335!\204i\336JH\"\211D\203	JJDA@=\204\337\316\340J\211J#`G\313\211%\210\337\316\341DA@\"\342D8G\313$\210FTFDJJ`D\241\210\202\343J\211J`ECH\"HN\247\203iN\311W\203(N[NNCW\203iBNBNHTI\210\202iJ\344=\203iO\332I!U\204i\307@\203e@O=\204i\313@\202iO@.\345y\210\202Y P\203\206\316\346@#A\337A\307G#\210@\311=\203\223\347A\202\266\203\240\350A\313@\202\266@\247\203\260\316\351@\"A\202\266\352A\307@\337A\307G#\210\337\f\307G\313\211%\210\353B!\211\203=\204=Q\313=\203\344	\247\203\344	\202\377Q\203\376	\247\203\362	\202\377	G\345U\205\377	@\202\377\307\211R\203\"\343\354R\211,dECH\"H\337\316\355,\"\307G#\210\202<\337	<\2033\316\356\357\360	\361#\"\2027\316\362	\"\307G#\210)\343\344@dECH\"H@$\363 e\345=\203ad\364 T=\203a\365\202n\316\366\367\345e\"T\367\345d\"T#ST\337\370\307G#\210\203\267\371H!\307U\211V\203\266V@\211U@UA@W\211J\354=\204\254W\247\203\254\333JW\"\210*VA\211V\204\212*\371H!\307U\211X\203\347X@\211U@J\337\316\372J\211J#\342U8G#\210)XA\211X\204\304*\212Gq\210eb\210\316\373T\"\316\374F\211\345U\203\375\202\376\377F!\203\201Z \202\201[ $\261\210+\201\\ \201] H\"\210Y\204/F\311V\2055\201^ G!.\207" [arg suggested linenum specified-basic-offset initial-msg comments-always-default sh-must-support-indent nil "*indent*" 0 17 t make-vector sh-mark-init format "Using specified sh-basic-offset of %d" "Initial value of sh-basic-offset: %s" message "line %d" looking-at "\\s-*$" sh-get-indent-info sh-get-indent-var-for-line current-indentation sh-var-value no-error sh-calculate-indent sh-set-var-value no-symbol "\\s-*#" assoc sh-mark-line "Variable %s was set to %s" "  but was previously set to %s" 2 append sh-indent-comment 1 "comment-col = %s  comments-always-default = %s" "\nComments are all in 1st column.\n" "\nComments follow default indentation.\n" "\nComments are in col %d." "\nComments seem to be mixed, leaving them as is.\n" sh-guess-basic-offset sh-basic-offset "Changed sh-basic-offset to: %d" "Possible value(s) for sh-basic-offset:  %s" mapconcat int-to-string " " "Suggested sh-basic-offset:  %d" buffer-name buffer-size "" "lines %d to %d of " count-lines "\nLearned variable settings:" reverse "  %s %s" "Indentation values for buffer %s.\n" "%d indentation variable%s different values%s\n\n" " has" "s have" zerop comment-col msg vec max previous-set-info last-pos num-diffs out-buffer learned-var-list info var sval ival diff new-val curr-indent sh-debug sh-learn-basic-offset new-value lines name learned-var #1=#:--dolist-temp--97272 val #2=#:--dolist-temp--97273 sh-popup-occur-buffer "." ":" run-hook-with-args sh-learned-buffer-hook pop-to-buffer] 15 (#$ . 62842) "P"])
#@405 See if we can determine a reasonable value for `sh-basic-offset'.
This is experimental, heuristic and arbitrary!
Argument VEC is a vector of information collected by
`sh-learn-buffer-indent'.
Return values:
  number          - there appears to be a good single value
  list of numbers - no obvious one, here is a list of one or more
		    reasonable choices
  nil		  - we couldn't find a reasonable one.
(defalias 'sh-guess-basic-offset #[(vec) "GS\306\307	\310\"\311\311\n	W\203[ \n\nH\nH\312_\\I\210\n\313\245\314\n\313\246!\203; \n\nH\n\313\245H\\I\210\n\211\\\310\\	W\203T \n\nH\n\211\\\310\\H\\I\210\nT\211\202 \311\211\211\211\211 \306\306	W\203\215 \nH\310U\204\206 \315 \n\nHBC\" \nT\211\202m \316 \317\" \320\321\315\311\"\"\314 G!\203\254 \322\323!\210\202^ G\306U\203\305 \322\324 @@\"\210 @@\202^ @A\313\245V\203\342 \322\325 @@\"\210 @@\202^ @A A@A\313_Y\203\322\326 @@\"\210 @@\202^ @A A@A\\\313\245Y\203V \310\311\203I@A\\\211\313\245X\203I\315@@C\"A\211\204#\322\327\330\331\332#\"\210\202^\322\333 @@\"\210.\n\207" [vec max i totals return j 1 make-vector 0 nil 4 2 zerop append sort #[(a b) "A	AV\207" [a b] 2] apply + message "no values!" "only value is %d" "basic-offset is probably %d" "basic-offset could be %d" "Possible choices for sh-basic-offset: %s" mapconcat int-to-string " " "No obvious value for sh-basic-offset.  Perhaps %d" p sum tot result x] 7 (#$ . 67015)])
#@47 A list of all known shell indentation styles.
(defvar sh-styles-alist nil (#$ . 68520))
#@273 Name the current indentation settings as a style called NAME.
If this name exists, the command will prompt whether it should be
overwritten if
- - it was called interactively with a prefix argument, or
- - called non-interactively with optional CONFIRM-OVERWRITE non-nil.
(defalias 'sh-name-style #[(name &optional confirm-overwrite) "\306\307	\"B\310\n\"\203- \203! \311\312!\204! \313\314\"\2027 \313\315\"\210\fA\241\2027 \313\316\"\210\f\nB\211*\207" [name sh-var-list sh-styles-alist style slist confirm-overwrite mapcar #[(var) "\211JB\207" [var] 2] assoc y-or-n-p "This style exists.  Overwrite it? " message "Not changing style %s" "Updating style %s" "Creating new style %s"] 4 (#$ . 68615) (list (read-from-minibuffer "Name for this style? ") (not current-prefix-arg))])
#@72 Set shell indentation values for this buffer from those in style NAME.
(defalias 'sh-load-style #[(name) "\305	\"\211\204 \306\307\"\202+ \nA\310\211\203) \f@\211@AL\210\fA\211\204 *\310)\207" [name sh-styles-alist sl var #1=#:--dolist-temp--97274 assoc error "sh-load-style - style %s not known" nil] 4 (#$ . 69414) (list (completing-read "Which style to use for this buffer? " sh-styles-alist nil t))])
#@97 Save all current styles in elisp to buffer BUFF.
This is always added to the end of the buffer.
(defalias 'sh-save-styles-to-buffer #[(buff) "r\302!q\210db\210\303c\210\304\305\301\306	DEp\")\207" [buff sh-styles-alist get-buffer-create "\n" pp setq quote] 5 (#$ . 69835) (list (read-from-minibuffer "Buffer to save styles in? " "*scratch*"))])
#@555 Insert a case/switch statement.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-case #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((csh "expression: " "switch( " str " )" n > "case " (read-string "pattern: ") 58 n > _ n "breaksw" n ("other pattern, %s: " < "case " str 58 n > _ n "breaksw" n) < "default:" n > _ n resume: < < "endsw") (es) (rc "expression: " > "switch( " str " ) {" n > "case " (read-string "pattern: ") n > _ n ("other pattern, %s: " "case " str > n > _ n) "case *" > n > _ n resume: 125 >) (sh "expression: " > "case " str " in" n > (read-string "pattern: ") (propertize ")" 'syntax-table sh-st-punc) n > _ n ";;" n ("other pattern, %s: " > str (propertize ")" 'syntax-table sh-st-punc) n > _ n ";;" n) > "*" (propertize ")" 'syntax-table sh-st-punc) n > _ n resume: "esac" >))] 4 (#$ . 70188) "*P\nP"])
#@542 Insert a for loop.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-for #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((csh eval sh-modify sh 1 "" 2 "foreach " 4 " ( " 6 " )" 15 '< 16 "end") (es eval sh-modify rc 4 " = ") (rc eval sh-modify sh 2 "for( " 6 " ) {" 15 125) (sh "Index variable: " > "for " str " in " _ "; do" n > _ | 36 & (sh-remember-variable str) n "done" >))] 4 (#$ . 71529) "*P\nP"])
#@559 Insert an indexed loop from 1 to n.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-indexed-loop #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((bash eval identity posix) (csh "Index variable: " "@ " str " = 1" n "while( $" str " <= " (read-string "upper limit: ") " )" n > _ 36 str n "@ " str "++" n < "end") (es eval sh-modify rc 4 " =") (ksh88 "Index variable: " > "integer " str "=0" n > "while (( ( " str " += 1 ) <= " (read-string "upper limit: ") " )); do" n > _ 36 (sh-remember-variable str) > n "done" >) (posix "Index variable: " > str "=1" n "while [ $" str " -le " (read-string "upper limit: ") " ]; do" n > _ 36 str n str 61 (sh-add (sh-remember-variable str) 1) n "done" >) (rc "Index variable: " > "for( " str " in" " `{awk 'BEGIN { for( i=1; i<=" (read-string "upper limit: ") "; i++ ) print i }'`}) {" n > _ 36 (sh-remember-variable str) n 125 >) (sh "Index variable: " > "for " str " in `awk 'BEGIN { for( i=1; i<=" (read-string "upper limit: ") "; i++ ) print i }'`; do" n > _ 36 (sh-remember-variable str) n "done" >))] 4 (#$ . 72447) "*P\nP"])
#@88 Scan the buffer for variable assignments.
Add these variables to `sh-shell-variables'.
(defalias 'sh-shell-initialize-variables #[nil "\301\302\303 \"\210\212eb\210\304\305\306\307\304#\203 \310\311!\210\202\f )\301\312\303 \"\207" [sh-shell-variables-initialized message "Scanning buffer `%s' for variable assignments..." buffer-name t search-forward "=" nil sh-assignment 0 "Scanning buffer `%s' for variable assignments...done"] 4 (#$ . 74028)])
(byte-code "\301B\301\207" [current-load-list sh-add-buffer] 2)
#@547 Do completion using `sh-shell-variables', but initialize it first.
This function is designed for use as the "completion table",
so it takes three arguments:
  STRING, the current buffer contents;
  PREDICATE, the predicate for filtering possible matches;
  CODE, which says what kind of things to do.
CODE can be nil, t or `lambda'.
nil means to return the best completion of STRING, or nil if there is none.
t means to return a list of all possible completions of STRING.
`lambda' means to return t if STRING is a valid completion as it stands.
(defalias 'sh-add-completer #[(string predicate code) "\212q\210	\204 \306 \210\307\310\n\"\244)\f\204  \311#\2029 \f\312=\203/ \313#\2029 \f\314=\2059 \315\")\207" [sh-add-buffer sh-shell-variables-initialized process-environment sh-shell-variables code string sh-shell-initialize-variables mapcar #[(var) "\301\302\303\"O\211B\207" [var 0 string-match "="] 6] try-completion t all-completions lambda assoc predicate] 4 (#$ . 74552)])
#@69 Insert an addition of VAR and prefix DELTA for Bourne (type) shell.
(defalias 'sh-add #[(var delta) "\302\303!\304!	\305W\203 \306\202 \307\310\311	!!\302\312!\261\207" [var delta sh-feature ((bash . "$[ ") (ksh88 . "$(( ") (posix . "$(( ") (rc . "`{expr $") (sh . "`expr $") (zsh . "$[ ")) sh-remember-variable 0 " - " " + " number-to-string abs ((bash . " ]") (ksh88 . " ))") (posix . " ))") (rc . "}") (sh . "`") (zsh . " ]"))] 6 (#$ . 75556) (let ((sh-add-buffer (current-buffer))) (list (completing-read "Variable: " 'sh-add-completer) (prefix-numeric-value current-prefix-arg)))])
#@553 Insert a function definition.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-function #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((bash eval sh-modify ksh88 3 "() {") (ksh88 "name: " "function " str " {" n > _ n < "}") (rc eval sh-modify ksh88 1 "fn ") (sh nil "() {" n > _ n < "}"))] 4 (#$ . 76154) "*P\nP"])
#@547 Insert an if statement.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-if #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((csh "condition: " "if( " str " ) then" n > _ n ("other condition, %s: " < "else if( " str " ) then" n > _ n) < "else" n > _ n resume: < "endif") (es "condition: " > "if { " str " } {" n > _ n ("other condition, %s: " "} { " str " } {" > n > _ n) "} {" > n > _ n resume: 125 >) (rc "condition: " > "if( " str " ) {" n > _ n ("other condition, %s: " "} else if( " str " ) {" > n > _ n) "} else {" > n > _ n resume: 125 >) (sh "condition: " '(setq input (sh-feature sh-test)) > "if " str "; then" n > _ n ("other condition, %s: " > "elif " str "; then" > n > n) "else" > n > n resume: "fi" >))] 4 (#$ . 76985) "*P\nP"])
#@556 Insert a repeat loop definition.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-repeat #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((es nil > "forever {" n > _ n 125 >) (zsh "factor: " > "repeat " str "; do" > n > n "done" >))] 4 (#$ . 78242) "*P\nP"])
#@550 Insert a select statement.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-select #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((ksh88 "Index variable: " > "select " str " in " _ "; do" n > 36 str n "done" >) (bash eval sh-append ksh88))] 4 (#$ . 79015) "*P\nP"])
#@569 Insert code to setup temporary file handling.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-tmp-file #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((bash eval identity ksh88) (csh (file-name-nondirectory (buffer-file-name)) "set tmp = /tmp/" str ".$$" n "onintr exit" n _ (and (goto-char (point-max)) (not (bolp)) 10) "exit:\n" "rm $tmp* >&/dev/null" >) (es (file-name-nondirectory (buffer-file-name)) > "local( signals = $signals sighup sigint; tmp = /tmp/" str ".$pid ) {" n > "catch @ e {" n > "rm $tmp^* >[2]/dev/null" n "throw $e" n "} {" > n _ n 125 > n 125 >) (ksh88 eval sh-modify sh 7 "EXIT") (rc (file-name-nondirectory (buffer-file-name)) > "tmp = /tmp/" str ".$pid" n "fn sigexit { rm $tmp^* >[2]/dev/null }") (sh (file-name-nondirectory (buffer-file-name)) > "TMP=${TMPDIR:-/tmp}/" str ".$$" n "trap \"rm $TMP* 2>/dev/null\" " 48))] 4 (#$ . 79797) "*P\nP"])
#@545 Insert an until loop.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-until #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((sh "condition: " '(setq input (sh-feature sh-test)) > "until " str "; do" n > _ n "done" >))] 4 (#$ . 81187) "*P\nP"])
#@544 Insert a while loop.  See `sh-feature'.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-while #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((csh eval sh-modify sh 2 "" 3 "while( " 5 " )" 10 '< 11 "end") (es eval sh-modify sh 3 "while { " 5 " } {" 10 125) (rc eval sh-modify sh 3 "while( " 5 " ) {" 10 125) (sh "condition: " '(setq input (sh-feature sh-test)) > "while " str "; do" n > _ n "done" >))] 4 (#$ . 81947) "*P\nP"])
#@694 Insert a while getopts loop.  See `sh-feature'.
Prompts for an options string which consists of letters for each recognized
option followed by a colon `:' if the option accepts an argument.

This is a skeleton command (see `skeleton-insert').
Normally the skeleton text is inserted at point, with nothing "inside".
If there is a highlighted region, the skeleton text is wrapped
around the region text.

A prefix argument ARG says to wrap the skeleton around the next ARG words.
A prefix argument of -1 says to wrap around region, even if not highlighted.
A prefix argument of zero says to wrap around zero words---that is, nothing.
This is a way of overriding the use of a highlighted region.
(defalias 'sh-while-getopts #[(&optional str arg) "\302\303	#\207" [str arg skeleton-proxy-new ((bash eval sh-modify sh 18 "${0##*/}") (csh nil "while( 1 )" n > "switch( \"$1\" )" n '(setq input '("- x" . 2)) > > ("option, %s: " < "case " '(eval str) '(if (string-match " +" str) (setq v1 (substring str (match-end 0)) str (substring str 0 (match-beginning 0))) (setq v1 nil)) str 58 n > "set " v1 & " = $2" | -4 & _ n (if v1 "shift") & n "breaksw" n) < "case --:" n > "shift" n < "default:" n > "break" n resume: < < "endsw" n "shift" n < "end") (ksh88 eval sh-modify sh 16 "print" 18 "${0##*/}" 36 "OPTIND-1") (posix eval sh-modify sh 18 "$(basename $0)") (sh "optstring: " > "while getopts :" str " OPT; do" n > "case $OPT in" n '(setq v1 (append (vconcat str) nil)) ((prog1 (if v1 (char-to-string (car v1))) (if (eq (nth 1 v1) 58) (setq v1 (nthcdr 2 v1) v2 "\"$OPTARG\"") (setq v1 (cdr v1) v2 nil))) > str "|+" str (propertize ")" 'syntax-table sh-st-punc) n > _ v2 n > ";;" n) > "*" (propertize ")" 'syntax-table sh-st-punc) n > "echo" " \"usage: " "`basename $0`" " [+-" '(setq v1 (point)) str '(save-excursion (while (search-backward ":" v1 t) (replace-match " ARG] [+-" t t))) (if (eq (preceding-char) 45) -5) (if (and (sequencep v1) (length v1)) "] " "} ") "[--] ARGS...\"" n "exit 2" > n "esac" > n "done" > n "shift " (sh-add "OPTIND" -1)))] 4 (#$ . 82872) "*P\nP"])
#@73 Remember preceding identifier for future completion and do self-insert.
(defalias 'sh-assignment #[(arg) "\302!\210\303X\205 \304\212\305\306	!`\307\303!\210\310#\205 \311\303!)!\207" [arg sh-assignment-regexp self-insert-command 1 sh-remember-variable re-search-forward sh-feature beginning-of-line t match-string] 6 (#$ . 84950) "p"])
#@129 Insert self.  Without prefix, following unquoted `<' inserts here document.
The document is bounded by `sh-here-document-word'.
(defalias 'sh-maybe-here-document #[(arg) "\303\304!!\210\206E `\305Zf	=?\206E \212\306u\210\307 )\206E \nc\210l\204. \310\311!\204. \312c\210\313\210\307 \203< \305\210\2021 \314 \210\212\315\n\261)\207" [arg last-command-char sh-here-document-word self-insert-command prefix-numeric-value 2 -2 sh-quoted-p looking-at "[ 	]" 32 1 newline 10] 3 (#$ . 85298) "*P"])
#@42 Dynamically perform completion at point.
(autoload 'comint-dynamic-complete "comint" '(#$ . 85802) t)
#@44 Dynamically complete the command at point.
(autoload 'shell-dynamic-complete-command "shell" '(#$ . 85910) t)
#@45 Dynamically complete the filename at point.
(autoload 'comint-dynamic-complete-filename "comint" '(#$ . 86026) t)
#@57 Dynamically complete the environment variable at point.
(autoload 'shell-dynamic-complete-environment-variable "shell" '(#$ . 86146) t)
#@74 Strip unquoted whitespace, insert newline, and indent like current line.
(defalias 'sh-newline-and-indent #[nil "\300 `\301\302\303x!\204 \304 \203 \303u\210`|\210\305 \210j\207" [current-indentation zerop " 	" nil sh-quoted-p newline] 5 (#$ . 86288) "*"])
#@50 Move point to successive beginnings of commands.
(defalias 'sh-beginning-of-command #[nil "\301\302\303#\205 \304\224b\207" [sh-beginning-of-command re-search-backward nil t 2] 4 (#$ . 86553) nil])
#@44 Move point to successive ends of commands.
(defalias 'sh-end-of-command #[nil "\301\302\303#\205 \304\225b\207" [sh-end-of-command re-search-forward nil t 1] 4 (#$ . 86759) nil])
(provide 'sh-script)
