MMCT TEAM
Server IP : 111.118.215.189  /  Your IP : 18.117.158.174
Web Server : Apache
System : Linux md-in-83.webhostbox.net 4.19.286-203.ELK.el7.x86_64 #1 SMP Wed Jun 14 04:33:55 CDT 2023 x86_64
User : a1673wkz ( 2475)
PHP Version : 8.2.25
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0755) :  /usr/share/emacs/24.3/lisp/progmodes/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : //usr/share/emacs/24.3/lisp/progmodes/simula.elc
;ELC
;;; Compiled by mockbuild@buildfarm06-new.corp.cloudlinux.com on Fri Oct 11 10:09:30 2024
;;; from file /builddir/build/BUILD/emacs-24.3/lisp/progmodes/simula.el
;;; in Emacs version 24.3.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.

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


(custom-declare-group 'simula nil "Major mode for editing Simula code." :link '(custom-group-link :tag "Font Lock Faces group" font-lock-faces) :prefix "simula-" :group 'languages)
#@175 Non-nil means TAB in SIMULA mode should always reindent the current line.
Otherwise TAB indents only when point is within
the run of whitespace at the beginning of the line.
(defconst simula-tab-always-indent-default nil (#$ . 741))
#@175 Non-nil means TAB in SIMULA mode should always reindent the current line.
Otherwise TAB indents only when point is within
the run of whitespace at the beginning of the line.
(custom-declare-variable 'simula-tab-always-indent 'simula-tab-always-indent-default '(#$ . 981) :type 'boolean :group 'simula)
#@68 Indentation of SIMULA statements with respect to containing block.
(defconst simula-indent-level-default 3 (#$ . 1289))
#@68 Indentation of SIMULA statements with respect to containing block.
(custom-declare-variable 'simula-indent-level 'simula-indent-level-default '(#$ . 1415) :type 'integer :group 'simula)
#@61 Extra indentation after DO, THEN, ELSE, WHEN and OTHERWISE.
(defconst simula-substatement-offset-default 3 (#$ . 1607))
#@61 Extra indentation after DO, THEN, ELSE, WHEN and OTHERWISE.
(custom-declare-variable 'simula-substatement-offset 'simula-substatement-offset-default '(#$ . 1733) :type 'integer :group 'simula)
#@239 Extra indentation for lines not starting a statement or substatement.
If value is a list, each line in a multipleline continued statement
will have the car of the list extra indentation with respect to
the previous line of the statement.
(defconst simula-continued-statement-offset-default 3 (#$ . 1933))
#@239 Extra indentation for lines not starting a statement or substatement.
If value is a list, each line in a multipleline continued statement
will have the car of the list extra indentation with respect to
the previous line of the statement.
(custom-declare-variable 'simula-continued-statement-offset 'simula-continued-statement-offset-default '(#$ . 2245) :type 'integer :group 'simula)
#@61 Offset of SIMULA label lines relative to usual indentation.
(defconst simula-label-offset-default -4711 (#$ . 2636))
#@61 Offset of SIMULA label lines relative to usual indentation.
(custom-declare-variable 'simula-label-offset 'simula-label-offset-default '(#$ . 2759) :type 'integer :group 'simula)
#@208 Extra indentation of THEN and ELSE with respect to the starting IF.
Value is a cons cell, the car is extra THEN indentation and the cdr
extra ELSE indentation.  IF after ELSE is indented as the starting IF.
(defconst simula-if-indent-default '(0 . 0) (#$ . 2945))
#@208 Extra indentation of THEN and ELSE with respect to the starting IF.
Value is a cons cell, the car is extra THEN indentation and the cdr
extra ELSE indentation.  IF after ELSE is indented as the starting IF.
(custom-declare-variable 'simula-if-indent 'simula-if-indent-default '(#$ . 3216) :type '(cons integer integer) :group 'simula)
#@167 Extra indentation of WHEN and OTHERWISE with respect to the INSPECT.
Value is a cons cell, the car is extra WHEN indentation
and the cdr extra OTHERWISE indentation.
(defconst simula-inspect-indent-default '(0 . 0) (#$ . 3558))
#@167 Extra indentation of WHEN and OTHERWISE with respect to the INSPECT.
Value is a cons cell, the car is extra WHEN indentation
and the cdr extra OTHERWISE indentation.
(custom-declare-variable 'simula-inspect-indent 'simula-inspect-indent-default '(#$ . 3793) :type '(cons integer integer) :group 'simula)
#@73 Non-nil means `simula-indent-line' function may reindent previous line.
(defconst simula-electric-indent-default nil (#$ . 4103))
#@73 Non-nil means `simula-indent-line' function may reindent previous line.
(custom-declare-variable 'simula-electric-indent 'simula-electric-indent-default '(#$ . 4239) :type 'boolean :group 'simula)
#@175 Specify how to convert case for SIMULA keywords.
Value is one of the symbols `upcase', `downcase', `capitalize',
(as in) `abbrev-table' or nil if they should not be changed.
(defconst simula-abbrev-keyword-default 'upcase (#$ . 4443))
#@175 Specify how to convert case for SIMULA keywords.
Value is one of the symbols `upcase', `downcase', `capitalize',
(as in) `abbrev-table' or nil if they should not be changed.
(custom-declare-variable 'simula-abbrev-keyword 'simula-abbrev-keyword-default '(#$ . 4685) :type '(choice (const upcase) (const downcase) (const capitalize) (const nil)) :group 'simula)
#@202 Specify how to convert case for standard SIMULA procedure and class names.
Value is one of the symbols `upcase', `downcase', `capitalize',
(as in) `abbrev-table', or nil if they should not be changed.
(defconst simula-abbrev-stdproc-default 'abbrev-table (#$ . 5053))
(byte-code "\300\301\302\303\304\305\306\307&\210\300\310\311\312\304\313\306\307&\207" [custom-declare-variable simula-abbrev-stdproc simula-abbrev-stdproc-default "Specify how to convert case for standard SIMULA procedure and class names.\nValue is one of the symbols `upcase', `downcase', `capitalize',\n(as in) `abbrev-table', or nil if they should not be changed." :type (choice (const upcase) (const downcase) (const capitalize) (const abbrev-table) (const nil)) :group simula simula-abbrev-file nil "File with extra abbrev definitions for use in SIMULA mode.\nThese are used together with the standard abbrev definitions for SIMULA.\nPlease note that the standard definitions are required\nfor SIMULA mode to function correctly." (choice file (const nil))] 8)
#@38 Syntax table in SIMULA mode buffers.
(defvar simula-mode-syntax-table nil (#$ . 6096))
(defconst simula-syntax-propertize-function #[(start end) "b\210`	W\205\\\302\303	\304#\205\\\305\224\203\"\306\305\224\305\225\307\310$\210\202\311\224\204,\312\224\203K\311\224\203:\306\311\224\311\225\307\313$\210\312\224\203\306\312\224\312\225\307\314$\210\202\315\224\203\306\315\224\315\225\307\316$\210\202\207" [start end re-search-forward "\\<\\(c\\)omment\\>\\|\\<end\\>\\([^;\n]\\).*?\\(\n\\|\\(.\\)\\(;\\|\\(?:e\\(?:lse\\|nd\\)\\|otherwise\\|when\\)\\)\\)\\|'\\('\\)'" t 1 put-text-property syntax-table (11) 2 4 (2097163) (2097164) 6 (1)] 5])
#@45 Subdued level highlighting for Simula mode.
(defconst simula-font-lock-keywords-1 '(("^%\\([^ 	\n].*\\)" 1 font-lock-constant-face t) ("\\<\\(class\\|procedure\\)\\>[ 	]*\\(\\sw+\\)?" (1 font-lock-keyword-face) (2 font-lock-function-name-face nil t))) (#$ . 6763))
#@44 Medium level highlighting for Simula mode.
(defconst simula-font-lock-keywords-2 (byte-code "\301\302\303\304\305BE\"\207" [simula-font-lock-keywords-1 append ("\\<\\(false\\|none\\|notext\\|true\\)\\>" . font-lock-constant-face) "\\<\\(a\\(?:ctivate\\|fter\\|nd\\|t\\)\\|be\\(?:fore\\|gin\\)\\|d\\(?:elay\\|o\\)\\|e\\(?:lse\\|nd\\|qv?\\|xternal\\)\\|for\\|g\\(?:oto\\|[eot]\\)\\|hidden\\|i\\(?:mp\\|n\\(?:ner\\|spect\\)\\|[fns]\\)\\|l\\(?:abel\\|[et]\\)\\|n\\(?:ew?\\|ot\\)\\|o\\(?:r\\|therwise\\)\\|pr\\(?:ior\\|otected\\)\\|qua\\|reactivate\\|s\\(?:tep\\|witch\\)\\|t\\(?:h\\(?:en\\|is\\)\\|o\\)\\|until\\|virtual\\|wh\\(?:en\\|ile\\)\\)\\>" "\\<\\(array\\|boolean\\|character\\|integer\\|long\\|name\\|re\\(?:al\\|f\\)\\|short\\|text\\|value\\)\\>" font-lock-type-face] 6) (#$ . 7034))
#@43 Gaudy level highlighting for Simula mode.
(defconst simula-font-lock-keywords-3 (byte-code "\301\302\303\304D\305E\"\207" [simula-font-lock-keywords-2 append ("\\<\\(\\sw+\\)[ 	]+class\\>" 1 font-lock-function-name-face) "\\<\\(array\\|boolean\\|character\\|integer\\|long\\|name\\|real\\|short\\|text\\|value\\)\\>\\([ 	]+\\sw+\\>\\)*" (font-lock-match-c-style-declaration-item-and-skip-to-next (goto-char (or (match-beginning 2) (match-end 1))) (goto-char (match-end 1)) (1 font-lock-variable-name-face)) ("\\<\\(ref\\)\\>[ 	]*\\((\\(\\sw+\\))\\)?" (3 font-lock-function-name-face nil t) (font-lock-match-c-style-declaration-item-and-skip-to-next nil nil (1 font-lock-variable-name-face)))] 5) (#$ . 7831))
#@50 Default expressions to highlight in Simula mode.
(defvar simula-font-lock-keywords simula-font-lock-keywords-1 (#$ . 8547))
#@35 Lucid Emacs menu for SIMULA mode.
(defvar simula-mode-menu '(["Report Bug" simula-submit-bug-report t] ["Indent Line" simula-indent-line t] ["Backward Statement" simula-previous-statement t] ["Forward Statement" simula-next-statement t] ["Backward Up Level" simula-backward-up-level t] ["Forward Down Statement" simula-forward-down-level t]) (#$ . 8677))
(byte-code "\204c\301\302 !\303\304\305#\210\303\306\307#\210\303\310\311#\210\303\312\313#\210\303\314\315#\210\303\316\317#\210\303\320\321#\210\303\322\323#\210\303\324\307#\210\303\325\307#\210\303\326\307#\210\303\327\330#\210\303\331\307#\210\303\332\307#\210\303\333\307#\210\301\207" [simula-mode-syntax-table copy-syntax-table standard-syntax-table modify-syntax-entry 33 "<" 36 "." 37 "< b" 10 "> b" 39 "\"" 40 "()" 41 ")(" 59 ">" 91 92 93 95 "_" 124 123 125] 4)
#@31 Keymap used in `simula-mode'.
(defvar simula-mode-map (byte-code "\301 \302\303\304#\210\302\305\306#\210\302\307\310#\210\302\311\312#\210\302\313\314#\210\302\315\316#\210\302\317\320#\210\302\321\322#\210\302\323\324\301\324!B#\210\302\325\326#\210\302\327\330#\210\302\331\332#\210\302\333\334#\210\302\335\336#\210\302\337\340#\210\302\341\342#\210\302\343\344#\210\302\345\346#\210\347\312\350\351#\210\347\306\350\352#\210\347\310\350\353#\210\347\304\350\354#\210\347\322\350\355#\210\347\320\350\356#\210)\207" [map make-sparse-keymap define-key "" simula-backward-up-level "" simula-previous-statement "" simula-forward-down-level "" simula-next-statement "" backward-delete-char-untabify ":" simula-electric-label "" simula-indent-exp "	" simula-indent-command [menu-bar simula] "SIMULA" [menu-bar simula bug-report] ("Submit Bug Report" . simula-submit-bug-report) [menu-bar simula separator-indent] ("--") [menu-bar simula indent-exp] ("Indent Expression" . simula-indent-exp) [menu-bar simula indent-line] ("Indent Line" . simula-indent-command) [menu-bar simula separator-navigate] ("--") [menu-bar simula backward-stmt] ("Previous Statement" . simula-previous-statement) [menu-bar simula forward-stmt] ("Next Statement" . simula-next-statement) [menu-bar simula backward-up] ("Backward Up Level" . simula-backward-up-level) [menu-bar simula forward-down] ("Forward Down Statement" . simula-forward-down-level) put menu-enable (not (eobp)) (not (bobp)) (not (eobp)) (not (bobp)) (not buffer-read-only) (not buffer-read-only)] 6) (#$ . 9529))
#@26 Pops up the SIMULA menu.
(defalias 'simula-popup-menu #[(_e) "\302\303P	B!\207" [mode-name simula-mode-menu popup-menu " Mode Commands"] 3 (#$ . 11123) "@e"])
(byte-code "\300\301N\204\302\300\301\303\304!#\210\305\306!\204\302\306\307\310#\210\300\207" [simula-mode-hook variable-documentation put purecopy "Hook run when entering Simula mode.\nNo problems result if this variable is not bound.\n`add-hook' automatically binds it.  (This is true for all hook variables.)" boundp simula-mode-map definition-name simula-mode] 5)
(defvar simula-mode-map (make-sparse-keymap))
(byte-code "\300\301N\204\302\300\301\303\304!#\210\305\306!\204\302\306\307\310#\210\300\207" [simula-mode-map variable-documentation put purecopy "Keymap for `simula-mode'." boundp simula-mode-syntax-table definition-name simula-mode] 5)
(defvar simula-mode-syntax-table (make-syntax-table))
(byte-code "\300\301N\204\302\300\301\303\304!#\210\302\305\306\307#\207" [simula-mode-syntax-table variable-documentation put purecopy "Syntax table for `simula-mode'." simula-mode-abbrev-table definition-name simula-mode] 5)
(defvar simula-mode-abbrev-table (progn (define-abbrev-table 'simula-mode-abbrev-table nil) simula-mode-abbrev-table))
(byte-code "\300\301N\204\302\300\301\303\304!#\210\302\305\306\307#\207" [simula-mode-abbrev-table variable-documentation put purecopy "Abbrev table for `simula-mode'." simula-mode derived-mode-parent prog-mode] 5)
#@2096 Major mode for editing SIMULA code.
\{simula-mode-map}
Variables controlling indentation style:
 `simula-tab-always-indent'
    Non-nil means TAB in SIMULA mode should always reindent the current line,
    regardless of where in the line point is when the TAB command is used.
 `simula-indent-level'
    Indentation of SIMULA statements with respect to containing block.
 `simula-substatement-offset'
    Extra indentation after DO, THEN, ELSE, WHEN and OTHERWISE.
 `simula-continued-statement-offset' 3
    Extra indentation for lines not starting a statement or substatement,
    e.g. a nested FOR-loop.  If value is a list, each line in a multiple-
    line continued statement will have the car of the list extra indentation
    with respect to the previous line of the statement.
 `simula-label-offset' -4711
    Offset of SIMULA label lines relative to usual indentation.
 `simula-if-indent' '(0 . 0)
    Extra indentation of THEN and ELSE with respect to the starting IF.
    Value is a cons cell, the car is extra THEN indentation and the cdr
    extra ELSE indentation.  IF after ELSE is indented as the starting IF.
 `simula-inspect-indent' '(0 . 0)
    Extra indentation of WHEN and OTHERWISE with respect to the
    corresponding INSPECT.  Value is a cons cell, the car is
    extra WHEN indentation and the cdr extra OTHERWISE indentation.
 `simula-electric-indent' nil
    If this variable is non-nil, `simula-indent-line'
    will check the previous line to see if it has to be reindented.
 `simula-abbrev-keyword' 'upcase
    Determine how SIMULA keywords will be expanded.  Value is one of
    the symbols `upcase', `downcase', `capitalize', (as in) `abbrev-table',
    or nil if they should not be changed.
 `simula-abbrev-stdproc' 'abbrev-table
    Determine how standard SIMULA procedure and class names will be
    expanded.  Value is one of the symbols `upcase', `downcase', `capitalize',
    (as in) `abbrev-table', or nil if they should not be changed.

Turning on SIMULA mode calls the value of the variable simula-mode-hook
with no arguments, if that value is non-nil.
(defalias 'simula-mode #[nil "\306\300!\210\307\310 \210\311\312\310\313N\203\314\311\313\310\313N#\210\315!\204'\316\317 \"\210\320\f!\211\2036
\321 =\203<\322\f\323 \"\210)\3240\325\"\204V01=\204V\3260\3251C#\210\327!\210\330\f!\21001\306\331!\210\332\306\333!\210\334\306\335!\210\306\336!\210\337\306\340!\210\341 \306\342!\210\343\"\306\344!\210\345$\306\346!\210\347&\306\350!\210\307(\306\351!\210\352)\306\353!\2102+\354\355!\210)\356\357!\207" [delay-mode-hooks major-mode mode-name simula-mode-map simula-mode-syntax-table parent make-local-variable t prog-mode simula-mode "Simula" mode-class put keymap-parent set-keymap-parent current-local-map char-table-parent standard-syntax-table set-char-table-parent syntax-table abbrev-table-get :parents abbrev-table-put use-local-map set-syntax-table comment-column 40 paragraph-start "[ 	]*$\\|\\f" paragraph-separate indent-line-function simula-indent-line comment-start "! " comment-end " ;" comment-start-skip "!+ *" parse-sexp-ignore-comments nil comment-multi-line font-lock-defaults ((simula-font-lock-keywords simula-font-lock-keywords-1 simula-font-lock-keywords-2 simula-font-lock-keywords-3) nil t ((95 . "w"))) syntax-propertize-function abbrev-mode 1 run-mode-hooks simula-mode-hook simula-mode-abbrev-table local-abbrev-table simula-syntax-propertize-function] 6 (#$ . 12574) nil])
#@43 Indent SIMULA expression following point.
(defalias 'simula-indent-exp #[nil "`\303\211\304 \210m\203\nb\2028\305\216\306\307!\210\310 \311\307!\210\312 \210`W\2057\313\314!\2041\315 \210\307y\210\202\")+\207" [end simula-electric-indent here nil simula-skip-comment-forward ((byte-code "\203	\301\211\223\210\301\207" [end nil] 3)) simula-next-statement 1 point-marker simula-previous-statement beginning-of-line looking-at "[ 	]*$" simula-indent-line] 3 (#$ . 16066) nil])
#@109 Indent this line as SIMULA code.
If `simula-electric-indent' is non-nil, indent previous line if necessary.
(defalias 'simula-indent-line #[nil "d`Z\305 \306\307\216\2059\310\210\311 \210\312 \210\313\314w\210\315\316!\2059\317 ?\2059\305 \320 \f=?\2058\321 \210\fj),\207" [case-fold-search indent origin simula-electric-indent post-indent simula-calculate-indent t ((byte-code "dZb\210\302 	=\203\303 \210\202\304 \210	j\210\302\207" [origin indent current-indentation back-to-indentation delete-horizontal-space] 2)) 0 expand-abbrev beginning-of-line " 	\f" nil looking-at "\\(end\\|if\\|then\\|else\\|when\\|otherwise\\)\\>" simula-context current-indentation delete-horizontal-space] 3 (#$ . 16562)])
#@451 Indent current line as SIMULA code, or insert TAB character.
If `simula-tab-always-indent' is non-nil, always indent current line.
Otherwise, indent only if point is before any non-whitespace
character on the line.

A numeric argument, regardless of its value, means indent rigidly
all the lines of the SIMULA statement after point so that this line
becomes properly indented.
The relative indentation among the lines of the statement are preserved.
(defalias 'simula-indent-command #[(&optional whole-exp) "\306	\204\n\204\212\307\310x\210n)\203\216\212\311 \210\312 )\313 d`Z\212\307\310x\210n)\310\211\314\216=\203L\212\307\310x\210n)\203V\315 \210\202V\311 \210\316 \210j\210)`	\205\211\212\311\317!\210`b\210\320\321!\210`\211\fV\205\210=?\205\210\322\fZ\323$).\202\220\324 )\207" [case-fold-search whole-exp simula-tab-always-indent end beg bol t " 	\f" nil beginning-of-line simula-calculate-indent current-indentation ((byte-code "\204	d	Zb\210\302\207" [bol origin nil] 2)) back-to-indentation delete-horizontal-space 2 simula-next-statement 1 indent-code-rigidly "%" insert-tab origin current indent] 7 (#$ . 17289) "P"])
#@273 Return value according to syntactic SIMULA context of point.
    0    point inside COMMENT comment
    1    point on SIMULA-compiler directive line
    2    point inside END comment
    3    point inside string
    4    point inside character constant
  nil    otherwise.
(defalias 'simula-context #[nil "\212\304 \210g)\305=\203
\306\207\212\307`\310ex\210\307o\204\216\304 \210g\305=\204\200`\nW\203|\311\307w\210\306u\210h\312=\203?`\202'h\313=\203\\\314\307w\210g\312=\203V`\315\202'\306u\210\202'g\316=\203e\306u\210\317\307w\210g\312=\203v`\315\202'\306u\210\202'\203\216\320u\210\310\307x\210`\307\202*`W\203Y\321\322\323#\203Yh\324>\203\343\325\321\326\323#\203\305h\327>\204\245h\305=\203\277\304\325!\204\245\307\211\204\245hz\330=\203\217gz\330=\203\217\212\320v\210\331\332!\203\337\307)\202\217h\333>\203\334\335w\210	\203\217`W\203\217g\312=\203\307\211\202\360n\203\304\325!\210\202\306u\210\335w\210\202\357h\313=\203-\336\337\323#\204\217\340\202\217h\316=\203R`=\204=m\203B\341\202\217\306u\210\336\342\323#\204\217\341\202\217\304\325!\210\202\217	+\207" [origin return-value saved-point loopvalue beginning-of-line 37 1 nil "^;" "^;\"'" 59 34 "^\";" t 39 "^';" -1 re-search-forward "\\<end\\>\\|!\\|\"\\|'\\|^%\\|\\<comment\\>" move (100 68) 2 ";\\|\\<end\\>\\|\\<else\\>\\|\\<otherwise\\>\\|\\<when\\>\\|^%" (100 68) 119 looking-at "end\\>\\|else\\>\\|otherwise\\>\\|when\\>" (33 116 84) 0 "^%;" search-forward "\"" 3 4 "'"] 5 (#$ . 18474)])
#@61 If this is a label that starts the line, reindent the line.
(defalias 'simula-electric-label #[nil "\304 \210\305c\210d`Z\306\307 \310\216\311C\"\211,\207" [next-char case-fold-search origin unread-command-events expand-abbrev 58 t read-event ((byte-code "\304>\204D\305>\204\306=\203	\204g\307>\204D\310 \204D\311u\210\312\313x\210\314\313x\210\315\316!\204D\312\313x\210n\203D\317 \320 \210\nj\210)dZb\207" [next-char simula-tab-always-indent amount origin (61 45) (10 13) 9 (61 45) simula-context -1 " 	\f" nil "a-zA-Z0-9_" looking-at "virtual\\>" simula-calculate-indent delete-horizontal-space] 2)) append] 3 (#$ . 20024) nil])
#@97 Move backward up COUNT block levels.
If COUNT is negative, move forward up block level instead.
(defalias 'simula-backward-up-level #[(count) "`\302\303\304\305\217*\207" [case-fold-search origin t nil (byte-code "\301V\203'\301V\205M\302\303!\210\304 \204g\305>\203 S\202\"T\211\202\301W\205M\306\303!\210\307v\210\304 \204Gg\310>\203DT\202FS\311v\210\202'\207" [count 0 re-search-backward "\\<begin\\>\\|\\<end\\>" simula-context (98 66) re-search-forward -1 (101 69) 1] 3) ((error (byte-code "b\210\301\302!\207" [origin error "No higher block level"] 2)) (quit (byte-code "b\210\301\302\303\"\207" [origin signal quit nil] 3)))] 3 (#$ . 20685) "p"])
#@101 Move forward down COUNT block levels.
If COUNT is negative, move backward down block level instead.
(defalias 'simula-forward-down-level #[(count) "`\304\305\306\307\217+\207" [count case-fold-search origin start-count t nil (byte-code "\302W\2031\302W\205b\303\304!\210\305 \204#g\306>\203 T\202\"S	W\203\307\310\311\"\210\202\302V\205b\312\304!\210\313v\210\305 \204Qg\314>\203NS\202PT\315v\210	V\2031\307\310\311\"\210\2021\207" [count start-count 0 re-search-backward "\\<begin\\>\\|\\<end\\>" simula-context (101 69) signal error nil re-search-forward -1 (98 66) 1] 3) ((error (byte-code "b\210\301\302!\207" [origin error "No containing block level"] 2)) (quit (byte-code "b\210\301\302\303\"\207" [origin signal quit nil] 3)))] 3 (#$ . 21372) "p"])
#@77 Move backward COUNT statements.
If COUNT is negative, move forward instead.
(defalias 'simula-previous-statement #[(count) "\304W\203\305[!\207\306\307`\306\310\311\217+\207" [count origin case-fold-search status 0 simula-next-statement nil t (byte-code "\302 \210h\303>\203\304v\210\305\306!\204!\307v\210\202!h\310=\203!\304u\210\311S\211!\2034\312\313\314\315#\211\204!	\203Gg\310=\203D\307u\210\202G\307v\210\316 \207" [count status simula-skip-comment-backward (110 78) -1 looking-at "\\<begin\\>" 1 59 natnump simula-search-backward ";\\|\\<begin\\>" nil move simula-skip-comment-forward] 4) ((error (byte-code "b\210\301\302!\207" [origin error "Incomplete statement (too many ENDs)"] 2)) (quit (byte-code "b\210\301\302\303\"\207" [origin signal quit nil] 3)))] 3 (#$ . 22166) "p"])
#@77 Move forward COUNT statements.
If COUNT is negative, move backward instead.
(defalias 'simula-next-statement #[(count) "\304W\203\305[!\207\306\307`\306\310\311\217+\207" [count origin case-fold-search status 0 simula-previous-statement nil t (byte-code "\302 \210\303\304!\203\f\305v\210\306S\211!\203\307\310d\311#\211\204\f	\205/h\312U?\205/\313v\210\314 \207" [count status simula-skip-comment-forward looking-at "\\<end\\>" 1 natnump simula-search-forward ";\\|\\<end\\>" move 59 -1 simula-skip-comment-backward] 4) ((error (byte-code "b\210\301\302!\207" [origin error "Incomplete statement (too few ENDs)"] 2)) (quit (byte-code "b\210\301\302\303\"\207" [origin signal quit nil] 3)))] 3 (#$ . 22985) "p"])
#@66 Search towards bob to find first char that is outside a comment.
(defalias 'simula-skip-comment-backward #[(&optional stop-at-end) "\300\301\215\207" [simula-out (byte-code "\302\303\302x\210h\304=\203#\212\305u\210\306 	\203\307=\203\302)\202&\306 \310>\203Sh\311=\203Kg\312>\204K\212\313\302x\210\314\315!)\204K\313\302x\210\202\316\317\302\"\210\202\320=\203i\321\322!\203\306 \323>\204Y\202\324=\203\204\325 \210o\203~\316\317\302\"\210\202\305u\210\202\307=\203\321\326!\210\324v\210\316\317\302\"\210\202" [context stop-at-end nil " 	\n\f" 59 -1 simula-context 2 (nil 3 4) 58 (45 61) ": 	\fa-zA-Z0-9_" looking-at "virtual\\>" throw simula-out 0 re-search-backward "!\\|\\<comment\\>" (0 1) 1 beginning-of-line "\\<end\\>"] 3)] 2 (#$ . 23722) nil])
#@66 Search towards eob to find first char that is outside a comment.
(defalias 'simula-skip-comment-forward #[nil "\300\301\215\207" [simula-out (byte-code "\300\301w\210\302\303!\203\304\305\301\306#\210\202n\203$g\307=\203$\310\311!\210\202\302\312!\2037\302\313!\2047\314\301w\210\202\315\316\317\"\210\202" [" 	\n\f" nil looking-at "!\\|\\<comment\\>" search-forward ";" move 37 beginning-of-line 2 "[a-z0-9_]*[ 	\f]*:[^-=]" "virtual\\>" "a-zA-Z0-9_ 	\f:" throw simula-out t] 4)] 2 (#$ . 24521) nil])
(defalias 'simula-forward-up-level #[nil "\305`\305\306\211\211\2035\307\310e\311#\203/\312 h\313>\205\"\314>\211?\205*\315 \211\202\306\211\204	\203=\305\202Ab\210\306-\207" [temp return-value case-fold-search origin continue-loop t nil re-search-backward "\\<begin\\>\\|\\<end\\>" move simula-context (100 68) (nil 2) simula-forward-up-level] 6])
(defalias 'simula-calculate-indent #[nil "\212\306 `\307\310\211\211\211\211:\211;\307=\203<\311\310x\210n\2040\306 \307=\2030\312\313!\210\202\311\310w\210i:b\210\202N;\314=\203G\307\202N;\315=\203T\316\317!\202N;\320=\203a\316\321!\202N\322 \211\203l\n\202N\323\310w\210\324\325!\203<[\326\202\326\324\327!\203\252g\330>\203\222=@\202\244g\331>\203\237=A\202\244\314v\210\307\332 \210\202\326\324\333!\203\307g\334>\203\275>@\202\301>A\335 \210\202\326\324\336!\204\326\324\337!\203\326?\340\341!\210	\203h\342=\204h\343>\203\366\212\344v\210\324\345!)?\202\367\326\203\346\314!\210\340 \210\347 \212o?\205hz\350=\203\344v\210\324\351!?\202h\352>?)n\204M\312\353\354#\203\330\306 \204!g\211\342=\203A\346\314!\210\202\273\324\345!\203O
<\\\202\273\324\325!\203_\314v\210\346\314!\210\202\273\324\355!\203p
@\\\356 \210\202\273\324\357!\203\235\n\360>\203\202\314v\210\202\227\361
@\n\362>\203\222=@\202\225=A#\332 \210\202\273\324\363!\203\273\361
@\n\364>\203\263=@\202\266=A#\335 \210\f\203\320
A<\203\314A@\202\316A\\\347 \310\202!\306 ?\205\356\212\323\310w\210\324\365!\206\355\324\366!?)\f\n\203\372
\367 \\\340 \210o?\205hz\350=\203\212\344v\210\324\351!)?\202h\370>?\203\"\f\203,\f\203=A<\203=
A<\2039A@\202;A\\\n\204G\347 \202!\371 \210\202!
.	\207" [prev-cont found-end temp start-line continued indent simula-context 0 nil " 	\n\f" re-search-backward "^\\|!\\|\\<comment\\>" 1 3 error "Inside string" 4 "Inside character constant" simula-inside-parens " 	\f" looking-at "end\\>" t "if\\>\\|then\\>\\|else\\>" (84 116) (69 101) simula-find-if "when\\>\\|otherwise\\>" (87 119) simula-find-inspect "virtual\\>" "[a-z0-9_]*[ 	\f]*:[^-=]" simula-skip-comment-backward dont-skip-end 59 (78 110) -1 "begin\\>" simula-previous-statement line-beginning-position 119 "begin\\|then\\|else\\|when\\|otherwise\\|do" (58 59) ";\\|\\<\\(begin\\|end\\|if\\|else\\|then\\|when\\|otherwise\\|do\\)\\>" move "do\\>" simula-find-do-match "\\(if\\|then\\|else\\)\\>" (73 105) + (84 116) "\\<when\\>\\|\\<otherwise\\>" (87 119) "virtual" "!\\|comment\\>\\|[a-z0-9_]*[ 	\f]*:[^-=]" current-indentation (58 59) beginning-of-line origin where simula-indent-level simula-if-indent simula-inspect-indent simula-label-offset simula-substatement-offset simula-continued-statement-offset] 9])
#@62 Find starting IF of a IF-THEN[-ELSE[-IF-THEN...]] statement.
(defalias 'simula-find-if #[nil "\300\301\215\207" [simula-out (byte-code "\300\301\302\303#\203+g\304>\203+\212\305 \210hz\306=\203\"\307v\210\310\311!\204'\312\313\303\"\210)\202\310\314!\2048\315\316!\210\202\312\313\303\"\210\202" [simula-search-backward "\\<if\\>\\|;\\|\\<begin\\>" nil t (73 105) simula-skip-comment-backward 119 -1 looking-at "else\\>" throw simula-out "\\<if\\>" error "Missing IF or misplaced BEGIN or ';' (can't find IF)"] 4)] 2 (#$ . 27834)])
#@42 Find INSPECT matching WHEN or OTHERWISE.
(defalias 'simula-find-inspect #[nil "\300\301\215\207" [simula-out (byte-code "\301\302\303\304\305#\2030g\306U\2040g\307>\203T\202\310!\203*\311\312\305\"\210\202S\202\313\314!\210\202" [level 0 simula-search-backward "\\<inspect\\>\\|\\<otherwise\\>\\|;" nil t 59 (79 111) zerop throw simula-out error "Missing INSPECT or misplaced ';' (can't find INSPECT)"] 4)] 2 (#$ . 28383)])
#@56 Find keyword matching DO: FOR, WHILE, INSPECT or WHEN.
(defalias 'simula-find-do-match #[nil "\300\301\302\303#\203
\304 \204\305\306!\205\304 ??\205\307\310!\207" [re-search-backward "\\<\\(do\\|for\\|while\\|inspect\\|when\\|end\\|begin\\)\\>\\|;" nil move simula-context looking-at "\\<\\(for\\|while\\|inspect\\|when\\)\\>" error "No matching FOR, WHILE or INSPECT for DO, or misplaced ';'"] 4 (#$ . 28832)])
#@73 Return position after `(' on line if inside parentheses, nil otherwise.
(defalias 'simula-inside-parens #[nil "\212\301\302\303\215*\207" [parlevel 0 simula-out (byte-code "\301\302\303\304#\203K\305 \303=\203g\306=\203*\307!\203#\310\311\303\"\210\202\312\313!\210\202g\314=\203E\307!\203?\310\311iT\"\210\202S\202T\202\310\311\303\"\210\202" [parlevel re-search-backward "(\\|)\\|;" nil t simula-context 59 zerop throw simula-out error "Parenthesis mismatch or misplaced ';'" 40] 4)] 2 (#$ . 29258)])
#@59 Goto point of definition of variable, procedure or class.
(defalias 'simula-goto-definition #[nil "\300\207" [nil] 1 (#$ . 29793) nil])
(defalias 'simula-expand-stdproc #[nil "\203	\303 \203\f\304 \207\305=\203\306\307!\207\310=\203 \311\307!\207\312=\203*\313\307!\207\314=\205?\315	!\n\232?\205?\311\307!\210\316 \207" [simula-abbrev-stdproc last-abbrev last-abbrev-text simula-context unexpand-abbrev upcase upcase-word -1 downcase downcase-word capitalize capitalize-word abbrev-table symbol-name expand-abbrev] 2])
(defalias 'simula-expand-keyword #[nil "\203	\304 \203\f\305 \207\306=\203\307\310!\207\311=\203 \312\310!\207\313=\203*\314\310!\207	\315=\205?\316\n!\232?\205?\312\310!\210\317 \207" [simula-abbrev-keyword simula-abbrev-stdproc last-abbrev last-abbrev-text simula-context unexpand-abbrev upcase upcase-word -1 downcase downcase-word capitalize capitalize-word abbrev-table symbol-name expand-abbrev] 2])
#@58 Expand SIMULA keyword.  If it starts the line, reindent.
(defalias 'simula-electric-keyword #[nil "\306=\211\203\307\n\310\"\210\311\312!\210\313u\210\314 \315\211\2053\f\316=\2053hz\317=\2053\212\313v\210\320\321!)?*\203<\322 \202v
\204F\322 \210\202j
\323=\203S\324\313!\210\202j
\325=\203`\326\313!\210\202j
\327=\203j\330\313!\210d`Z\315\331\332\333\217*)\207" [this-command show-char last-command-event case-fold-search where simula-abbrev-keyword self-insert-command insert-char 1 sit-for 0 -1 simula-context t 2 119 looking-at "end\\>" unexpand-abbrev upcase upcase-word downcase downcase-word capitalize capitalize-word nil (byte-code "hz\303=\203H\304v\210\305\306!\203,\212\307\310!\210\311 \203!\312\310!\210\202+\313\314``\315 \\{\"\210)\316\317x\210n\203H\320 \211\321 =\204D\322 \210j\210)\202L\316\317w\210d	Zb\210\n\205X\323\310!\207" [indent pos show-char 119 -1 looking-at "end\\>" simula-backward-up-level 1 pos-visible-in-window-p sit-for message "Matches %s" window-width " 	\f" nil simula-calculate-indent current-indentation delete-horizontal-space delete-char] 6) ((quit (byte-code "dZb\207" [pos] 2))) pos] 4 (#$ . 30751)])
#@485 Search backward from point for regular expression REGEXP,
ignoring matches found inside SIMULA comments, string literals,
and BEGIN..END blocks.
Set point to the end of the occurrence found, and return point.
An optional second argument BOUND bounds the search, it is a buffer position.
The match found must not extend after that position.  Optional third argument
NOERROR, if t, means if fail just return nil (no error).
If not nil and not t, move to limit of search and return nil.
(defalias 'simula-search-backward #[(regexp &optional bound noerror) "\305P`\306\211\307\310\215,\207" [regexp match context start-point comb-regexp "\\|\\<end\\>" nil simula-backward (byte-code "\306	\307#\203\277\310 \311\216\312 \211\313=\203%\314\f!\203 \315\202!\316\202H\317=\203F\314\f!\203;\314\320!\203;\315\202B\314\321!\205B\316\202H\313*
\315=\203T\322\323`\"\210
\316=\203\324\325!\203\273\306\326	\307#\203\230\312 \211\313=\203\203g\327>\203\203S\202\224\330>\203\224g\331>\203\224T)\202]\203\244\315=\203\250b\210\204\263\332\333\fC\"\210\322\323\313\"\210\202])\202\203\313\315=\203\317b\210?\205\332\332\333\fC\"\207" [comb-regexp bound save-match-data-internal context regexp match re-search-backward 1 match-data ((byte-code "\301\302\"\207" [save-match-data-internal set-match-data evaporate] 3)) simula-context nil looking-at t BLOCK 2 ";\\|\\<end\\>\\|\\<else\\>\\|\\<otherwise\\>\\|\\<when\\>" "\\<end\\>" throw simula-backward 0 natnump "\\<begin\\>\\|\\<end\\>" (98 66) (nil 2) (101 69) signal search-failed level noerror start-point] 5)] 4 (#$ . 31939)])
#@484 Search forward from point for regular expression REGEXP,
ignoring matches found inside SIMULA comments, string literals,
and BEGIN..END blocks.
Set point to the end of the occurrence found, and return point.
An optional second argument BOUND bounds the search, it is a buffer position.
The match found must not extend after that position.  Optional third argument
NOERROR, if t, means if fail just return nil (no error).
If not nil and not t, move to limit of search and return nil.
(defalias 'simula-search-forward #[(regexp &optional bound noerror) "\305P`\306\211\307\310\215,\207" [regexp match context start-point comb-regexp "\\|\\<begin\\>" nil simula-forward (byte-code "\306	\307#\203\262\310 \311\216\212\312\224b\210\313 \211\204(\314\f!\203#\315\202$\316\202A\317=\203?\314\f!\205;\314\320!\205;\315\202A\321+
\315=\203M\322\323`\"\210
\316=\203\312\324!\203\256\306\325	\307#\203\213\313 \211\321=\203vT\202\207\317=\203\207h\326>\203\207S)\202V\203\227\315=\203\233b\210\204\246\327\330\fC\"\210\322\323\321\"\210\202V)\202\203\276\315=\203\302b\210?\205\315\327\330\fC\"\207" [comb-regexp bound save-match-data-internal context regexp match re-search-forward 1 match-data ((byte-code "\301\302\"\207" [save-match-data-internal set-match-data evaporate] 3)) 0 simula-context looking-at t BLOCK 2 ";\\|\\<end\\>\\|\\<else\\>\\|\\<otherwise\\>\\|\\<when\\>" nil throw simula-forward natnump "\\<begin\\>\\|\\<end\\>" (100 68) signal search-failed level noerror start-point] 5)] 4 (#$ . 33586)])
#@71 Define Simula keywords, procedures and classes in local abbrev table.
(defalias 'simula-install-standard-abbrevs #[nil "\303\304\211\205\"	@\305\n@A@\3068\304\307&\210	A\211\204\304*\207" [args --dolist-tail-- simula-mode-abbrev-table (("abs" "Abs" simula-expand-stdproc) ("accum" "Accum" simula-expand-stdproc) ("activate" "ACTIVATE" simula-expand-keyword) ("addepsilon" "AddEpsilon" simula-expand-stdproc) ("after" "AFTER" simula-expand-keyword) ("and" "AND" simula-expand-keyword) ("arccos" "ArcCos" simula-expand-stdproc) ("arcsin" "ArcSin" simula-expand-stdproc) ("arctan" "ArcTan" simula-expand-stdproc) ("arctan2" "ArcTan2" simula-expand-stdproc) ("array" "ARRAY" simula-expand-keyword) ("at" "AT" simula-expand-keyword) ("before" "BEFORE" simula-expand-keyword) ("begin" "BEGIN" simula-expand-keyword) ("blanks" "Blanks" simula-expand-stdproc) ("boolean" "BOOLEAN" simula-expand-keyword) ("breakoutimage" "BreakOutImage" simula-expand-stdproc) ("bytefile" "ByteFile" simula-expand-stdproc) ("call" "Call" simula-expand-stdproc) ("cancel" "Cancel" simula-expand-stdproc) ("cardinal" "Cardinal" simula-expand-stdproc) ("char" "Char" simula-expand-stdproc) ("character" "CHARACTER" simula-expand-keyword) ("checkpoint" "CheckPoint" simula-expand-stdproc) ("class" "CLASS" simula-expand-keyword) ("clear" "Clear" simula-expand-stdproc) ("clocktime" "ClockTime" simula-expand-stdproc) ("close" "Close" simula-expand-stdproc) ("comment" "COMMENT" simula-expand-keyword) ("constant" "Constant" simula-expand-stdproc) ("copy" "Copy" simula-expand-stdproc) ("cos" "Cos" simula-expand-stdproc) ("cosh" "CosH" simula-expand-stdproc) ("cotan" "CoTan" simula-expand-stdproc) ("cputime" "CpuTime" simula-expand-stdproc) ("current" "Current" simula-expand-stdproc) ("datetime" "DateTime" simula-expand-stdproc) ("decimalmark" "DecimalMark" simula-expand-stdproc) ("delay" "DELAY" simula-expand-keyword) ("deleteimage" "DeleteImage" simula-expand-stdproc) ("detach" "Detach" simula-expand-stdproc) ("digit" "Digit" simula-expand-stdproc) ("directbytefile" "DirectByteFile" simula-expand-stdproc) ("directfile" "DirectFile" simula-expand-stdproc) ("discrete" "Discrete" simula-expand-stdproc) ("do" "DO" simula-expand-keyword) ("downcase" "Downcase" simula-expand-stdproc) ("draw" "Draw" simula-expand-stdproc) ("eject" "Eject" simula-expand-stdproc) ("else" "ELSE" simula-electric-keyword) ("empty" "Empty" simula-expand-stdproc) ("end" "END" simula-electric-keyword) ("endfile" "Endfile" simula-expand-stdproc) ("entier" "Entier" simula-expand-stdproc) ("eq" "EQ" simula-expand-keyword) ("eqv" "EQV" simula-expand-keyword) ("erlang" "Erlang" simula-expand-stdproc) ("error" "Error" simula-expand-stdproc) ("evtime" "EvTime" simula-expand-stdproc) ("exp" "Exp" simula-expand-stdproc) ("external" "EXTERNAL" simula-expand-keyword) ("false" "FALSE" simula-expand-keyword) ("field" "Field" simula-expand-stdproc) ("file" "File" simula-expand-stdproc) ("first" "First" simula-expand-stdproc) ("follow" "Follow" simula-expand-stdproc) ("for" "FOR" simula-expand-keyword) ("ge" "GE" simula-expand-keyword) ("getchar" "GetChar" simula-expand-stdproc) ("getfrac" "GetFrac" simula-expand-stdproc) ("getint" "GetInt" simula-expand-stdproc) ("getreal" "GetReal" simula-expand-stdproc) ("go" "GO" simula-expand-keyword) ("goto" "GOTO" simula-expand-keyword) ("gt" "GT" simula-expand-keyword) ("head" "Head" simula-expand-stdproc) ("hidden" "HIDDEN" simula-expand-keyword) ("histd" "HistD" simula-expand-stdproc) ("histo" "Histo" simula-expand-stdproc) ("hold" "Hold" simula-expand-stdproc) ("idle" "Idle" simula-expand-stdproc) ("if" "IF" simula-expand-keyword) ("image" "Image" simula-expand-stdproc) ("imagefile" "ImageFile" simula-expand-stdproc) ("imp" "IMP" simula-expand-keyword) ("in" "IN" simula-expand-keyword) ("inbyte" "InByte" simula-expand-stdproc) ("inbytefile" "InByteFile" simula-expand-stdproc) ("inchar" "InChar" simula-expand-stdproc) ("infile" "InFile" simula-expand-stdproc) ("infrac" "InFrac" simula-expand-stdproc) ("inimage" "InImage" simula-expand-stdproc) ("inint" "InInt" simula-expand-stdproc) ("inner" "INNER" simula-expand-keyword) ("inreal" "InReal" simula-expand-stdproc) ("inrecord" "InRecord" simula-expand-stdproc) ("inspect" "INSPECT" simula-expand-keyword) ("integer" "INTEGER" simula-expand-keyword) ("intext" "InText" simula-expand-stdproc) ("into" "Into" simula-expand-stdproc) ("is" "IS" simula-expand-keyword) ("isochar" "ISOChar" simula-expand-stdproc) ("isopen" "IsOpen" simula-expand-stdproc) ("isorank" "ISORank" simula-expand-stdproc) ("label" "LABEL" simula-expand-keyword) ("last" "Last" simula-expand-stdproc) ("lastitem" "LastItem" simula-expand-stdproc) ("lastloc" "LastLoc" simula-expand-stdproc) ("le" "LE" simula-expand-keyword) ("length" "Length" simula-expand-stdproc) ("letter" "Letter" simula-expand-stdproc) ("line" "Line" simula-expand-stdproc) ("linear" "Linear" simula-expand-stdproc) ("linesperpage" "LinesPerPage" simula-expand-stdproc) ("link" "Link" simula-expand-stdproc) ("linkage" "Linkage" simula-expand-stdproc) ("ln" "Ln" simula-expand-stdproc) ("locate" "Locate" simula-expand-stdproc) ("location" "Location" simula-expand-stdproc) ("lock" "Lock" simula-expand-stdproc) ("locked" "Locked" simula-expand-stdproc) ("log10" "Log10" simula-expand-stdproc) ("long" "LONG" simula-expand-keyword) ("lowcase" "LowCase" simula-expand-stdproc) ("lowerbound" "LowerBound" simula-expand-stdproc) ("lowten" "LowTen" simula-expand-stdproc) ("lt" "LT" simula-expand-keyword) ("main" "Main" simula-expand-stdproc) ("max" "Max" simula-expand-stdproc) ("maxint" "MaxInt" simula-expand-stdproc) ("maxlongreal" "MaxLongReal" simula-expand-stdproc) ("maxloc" "MaxLoc" simula-expand-stdproc) ("maxrank" "MaxRank" simula-expand-stdproc) ("maxreal" "MaxReal" simula-expand-stdproc) ("min" "Min" simula-expand-stdproc) ("minint" "MinInt" simula-expand-stdproc) ("minlongreal" "MinLongReal" simula-expand-stdproc) ("minrank" "MinRank" simula-expand-stdproc) ("minreal" "MinReal" simula-expand-stdproc) ("mod" "Mod" simula-expand-stdproc) ("more" "More" simula-expand-stdproc) ("name" "NAME" simula-expand-keyword) ("ne" "NE" simula-expand-keyword) ("negexp" "NegExp" simula-expand-stdproc) ("new" "NEW" simula-expand-keyword) ("nextev" "NextEv" simula-expand-stdproc) ("none" "NONE" simula-expand-keyword) ("normal" "Normal" simula-expand-stdproc) ("not" "NOT" simula-expand-keyword) ("notext" "NOTEXT" simula-expand-keyword) ("open" "Open" simula-expand-stdproc) ("or" "OR" simula-expand-keyword) ("otherwise" "OTHERWISE" simula-electric-keyword) ("out" "Out" simula-expand-stdproc) ("outbyte" "OutByte" simula-expand-stdproc) ("outbytefile" "OutByteFile" simula-expand-stdproc) ("outchar" "OutChar" simula-expand-stdproc) ("outfile" "OutFile" simula-expand-stdproc) ("outfix" "OutFix" simula-expand-stdproc) ("outfrac" "OutFrac" simula-expand-stdproc) ("outimage" "OutImage" simula-expand-stdproc) ("outint" "OutInt" simula-expand-stdproc) ("outreal" "OutReal" simula-expand-stdproc) ("outrecord" "OutRecord" simula-expand-stdproc) ("outtext" "OutText" simula-expand-stdproc) ("page" "Page" simula-expand-stdproc) ("passivate" "Passivate" simula-expand-stdproc) ("poisson" "Poisson" simula-expand-stdproc) ("pos" "Pos" simula-expand-stdproc) ("precede" "Precede" simula-expand-stdproc) ("pred" "Pred" simula-expand-stdproc) ("prev" "Prev" simula-expand-stdproc) ("printfile" "PrintFile" simula-expand-stdproc) ("prior" "PRIOR" simula-expand-keyword) ("procedure" "PROCEDURE" simula-expand-keyword) ("process" "Process" simula-expand-stdproc) ("protected" "PROTECTED" simula-expand-keyword) ("putchar" "PutChar" simula-expand-stdproc) ("putfix" "PutFix" simula-expand-stdproc) ("putfrac" "PutFrac" simula-expand-stdproc) ("putint" "PutInt" simula-expand-stdproc) ("putreal" "PutReal" simula-expand-stdproc) ("qua" "QUA" simula-expand-keyword) ("randint" "RandInt" simula-expand-stdproc) ("rank" "Rank" simula-expand-stdproc) ("reactivate" "REACTIVATE" simula-expand-keyword) ("real" "REAL" simula-expand-keyword) ("ref" "REF" simula-expand-keyword) ("resume" "Resume" simula-expand-stdproc) ("setaccess" "SetAccess" simula-expand-stdproc) ("setpos" "SetPos" simula-expand-stdproc) ("short" "SHORT" simula-expand-keyword) ("sign" "Sign" simula-expand-stdproc) ("simset" "SimSet" simula-expand-stdproc) ("simulaid" "SimulaId" simula-expand-stdproc) ("simulation" "Simulation" simula-expand-stdproc) ("sin" "Sin" simula-expand-stdproc) ("sinh" "SinH" simula-expand-stdproc) ("sourceline" "SourceLine" simula-expand-stdproc) ("spacing" "Spacing" simula-expand-stdproc) ("sqrt" "Sqrt" simula-expand-stdproc) ("start" "Start" simula-expand-stdproc) ("step" "STEP" simula-expand-keyword) ("strip" "Strip" simula-expand-stdproc) ("sub" "Sub" simula-expand-stdproc) ("subepsilon" "SubEpsilon" simula-expand-stdproc) ("suc" "Suc" simula-expand-stdproc) ("switch" "SWITCH" simula-expand-keyword) ("sysin" "SysIn" simula-expand-stdproc) ("sysout" "SysOut" simula-expand-stdproc) ("tan" "Tan" simula-expand-stdproc) ("tanh" "TanH" simula-expand-stdproc) ("terminate_program" "Terminate_Program" simula-expand-stdproc) ("terminated" "Terminated" simula-expand-stdproc) ("text" "TEXT" simula-expand-keyword) ("then" "THEN" simula-electric-keyword) ("this" "THIS" simula-expand-keyword) ("time" "Time" simula-expand-stdproc) ("to" "TO" simula-expand-keyword) ("true" "TRUE" simula-expand-keyword) ("uniform" "Uniform" simula-expand-stdproc) ("unlock" "Unlock" simula-expand-stdproc) ("until" "UNTIL" simula-expand-keyword) ("upcase" "Upcase" simula-expand-stdproc) ("upperbound" "UpperBound" simula-expand-stdproc) ("value" "VALUE" simula-expand-keyword) ("virtual" "VIRTUAL" simula-expand-keyword) ("wait" "Wait" simula-expand-stdproc) ("when" "WHEN" simula-electric-keyword) ("while" "WHILE" simula-expand-keyword)) nil define-abbrev 2 system] 8 (#$ . 35170) nil])
(byte-code "\203\303!\210\304\305 \210)\306\307!\203(\310\302!\203(\311\312\n\"\204(\307\312\313\304\314$\210\304\207" [simula-abbrev-file abbrevs-changed hilit-patterns-alist read-abbrev-file nil simula-install-standard-abbrevs fboundp hilit-set-mode-patterns boundp assoc simula-mode (("^%\\([ 	\f].*\\)?$" nil comment) ("^%include\\>" nil include) ("\"[^\"\n]*\"\\|'.'\\|'![0-9]+!'" nil string) ("\\<\\(ACTIVATE\\|AFTER\\|AND\\|ARRAY\\|AT\\|BEFORE\\|BEGIN\\|BOOLEAN\\|CHARACTER\\|CLASS\\|DELAY\\|DO\\|ELSE\\|END\\|EQ\\|EQV\\|EXTERNAL\\|FALSE\\|FOR\\|GE\\|GO\\|GOTO\\|GT\\|HIDDEN\\|IF\\|IMP\\|IN\\|INNER\\|INSPECT\\|INTEGER\\|IS\\|LABEL\\|LE\\|LONG\\|LT\\|NAME\\|NE\\|NEW\\|NONE\\|NOT\\|NOTEXT\\|OR\\|OTHERWISE\\|PRIOR\\|PROCEDURE\\|PROTECTED\\|QUA\\|REACTIVATE\\|REAL\\|REF\\|SHORT\\|STEP\\|SWITCH\\|TEXT\\|THEN\\|THIS\\|TO\\|TRUE\\|UNTIL\\|VALUE\\|VIRTUAL\\|WHEN\\|WHILE\\)\\>" nil keyword) ("!\\|\\<COMMENT\\>" ";" comment)) case-insensitive] 5)
#@60 Address accepting submission of `simula-mode' bug reports.
(defconst simula-mode-help-address "bug-gnu-emacs@gnu.org" (#$ . 46026))
#@48 Submit via mail a bug report on `simula-mode'.
(defalias 'simula-submit-bug-report #[nil "\302\303!\205\304\305	P\306\307\310\311\312\313\314\315\316\317\320\257#\207" [simula-mode-help-address emacs-version y-or-n-p "Do you want to submit a report on simula-mode? " reporter-submit-bug-report "simula-mode from Emacs " simula-indent-level simula-substatement-offset simula-continued-statement-offset simula-label-offset simula-if-indent simula-inspect-indent simula-electric-indent simula-abbrev-keyword simula-abbrev-stdproc simula-abbrev-file simula-tab-always-indent] 14 (#$ . 46164) nil])
(provide 'simula)

MMCT - 2023