scheme.elc 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. (provide (quote scheme))
  2. (defvar scheme-mode-abbrev-table nil "\
  3. ")
  4. (define-abbrev-table (quote scheme-mode-abbrev-table) nil)
  5. (defvar scheme-mode-syntax-table nil "\
  6. ")
  7. (if scheme-mode-syntax-table nil (let ((i 0)) (setq scheme-mode-syntax-table (make-syntax-table)) (set-syntax-table scheme-mode-syntax-table) (while (< i 48) (modify-syntax-entry i "_ " scheme-mode-syntax-table) (setq i (1+ i))) (setq i (1+ 57)) (while (< i 65) (modify-syntax-entry i "_ " scheme-mode-syntax-table) (setq i (1+ i))) (setq i (1+ 90)) (while (< i 97) (modify-syntax-entry i "_ " scheme-mode-syntax-table) (setq i (1+ i))) (setq i (1+ 122)) (while (< i 128) (modify-syntax-entry i "_ " scheme-mode-syntax-table) (setq i (1+ i))) (modify-syntax-entry 32 " " scheme-mode-syntax-table) (modify-syntax-entry 9 " " scheme-mode-syntax-table) (modify-syntax-entry 10 "> " scheme-mode-syntax-table) (modify-syntax-entry 12 "> " scheme-mode-syntax-table) (modify-syntax-entry 59 "< " scheme-mode-syntax-table) (modify-syntax-entry 96 "' " scheme-mode-syntax-table) (modify-syntax-entry 39 "' " scheme-mode-syntax-table) (modify-syntax-entry 44 "' " scheme-mode-syntax-table) (modify-syntax-entry 46 "' " scheme-mode-syntax-table) (modify-syntax-entry 35 "' " scheme-mode-syntax-table) (modify-syntax-entry 34 "\" " scheme-mode-syntax-table) (modify-syntax-entry 92 "\\ " scheme-mode-syntax-table) (modify-syntax-entry 40 "() " scheme-mode-syntax-table) (modify-syntax-entry 41 ")( " scheme-mode-syntax-table)))
  8. (defun scheme-mode-variables nil (byte-code "Ë!ˆ
  9. ‰ˆÌÃ!ˆÍ P‰ˆÌÅ!ˆ ‰ˆÌÆ!ˆÎ‰ˆÌÇ!ˆÏ‰ˆÌÈ!ˆÐ‰ˆÌÉ!ˆÑ‰ ˆÌÊ!ˆÒ‰
  10. ‡" [scheme-mode-syntax-table local-abbrev-table scheme-mode-abbrev-table paragraph-start page-delimiter paragraph-separate indent-line-function comment-start comment-start-skip comment-column comment-indent-hook set-syntax-table make-local-variable "^$\\|" scheme-indent-line ";" ";+ *" 40 scheme-comment-indent] 10))
  11. (defun scheme-mode-commands (map) (byte-code "ÁÂÃ#ˆÁÄÅ#ˆÁÆÇ#ˆÁÈÉ#ˆÁÊË#ˆÁÌÍ#ˆÁÎÏ#ˆÁÐÑ#‡" [map define-key " " scheme-indent-line "" backward-delete-char-untabify "o" scheme-send-buffer "z" scheme-zap-define "" scheme-indent-sexp "" find-scheme-definition "" scheme-zap-define-and-resume "" resume-scheme] 11))
  12. (defvar scheme-mode-map nil)
  13. (if scheme-mode-map nil (setq scheme-mode-map (make-sparse-keymap)) (scheme-mode-commands scheme-mode-map))
  14. (defun scheme-mode nil "\
  15. Major mode for editing Scheme code.
  16. Commands:
  17. Delete converts tabs to spaces as it moves back.
  18. Blank lines separate paragraphs. Semicolons start comments.
  19. \\{scheme-mode-map}
  20. Entry to this mode calls the value of scheme-mode-hook
  21. if that value is non-nil." (interactive) (byte-code "ÃˆÄ ˆÅ!ˆÆ‰ˆÇ‰ˆÈ ˆÉÊ!‡" [scheme-mode-map major-mode mode-name nil kill-all-local-variables use-local-map scheme-mode "Scheme" scheme-mode-variables run-hooks scheme-mode-hook] 5))
  22. (defun scheme-send-definition nil "\
  23. Send the current definition to the Scheme process made by M-x run-scheme." (interactive) (byte-code "ÀˆÁÂ!‡" [nil error "Process scheme does not exist"] 2))
  24. (defun scheme-comment-indent (&optional pos) (byte-code "Šƒ
  25. b‚ ÈÄÅ!ƒi‚/ÄÆ!ƒ.Ç  <ƒ) @‚* )‚/
  26. )‡" [pos tem comment-column nil looking-at ";;;" ";;" calculate-scheme-indent] 4))
  27. (defvar scheme-indent-offset nil "\
  28. ")
  29. (defvar scheme-indent-hook (quote scheme-indent-hook) "\
  30. ")
  31. (defun scheme-indent-line (&optional whole-exp) "\
  32. Indent current line as Scheme code.
  33. With argument, indent any additional lines of the same expression
  34. rigidly along with this one." (interactive "P") (byte-code "ÅˆÇ ÅÅÅd`ZÈ ˆ`‰ˆÉÊ!ˆËÌ!ƒ$Å‚Š<ƒ0@‰‚1ňiZ‰ˆÍ !ƒBÅ‚IÎ
  35. `\"ˆjˆd Z`VƒYd Zb‚Zň…ŠÍ !?…ŠŠ
  36. bˆÏÐ!ˆ`‰ˆ
  37. bˆÑÐ!ˆ`‰ˆ
  38. V)…ŠÒ
  39. #-‡" [indent shift-amt beg end pos nil whole-exp calculate-scheme-indent beginning-of-line skip-chars-forward " " looking-at "[ ]*;;;" zerop delete-region forward-sexp 1 forward-line indent-code-rigidly] 13))
  40. (defun calculate-scheme-indent (&optional parse-start) "\
  41. Return appropriate indentation for current line as scheme code.
  42. In usual case returns an integer: the column to indent to.
  43. Can instead return a list, whose car is the column to indent to.
  44. This means that following lines at the same level of indentation
  45. should not necessarily be indented the same way.
  46. The second element of the list is the buffer position
  47. of the start of the containing expression." (byte-code "ŠÍ ˆ`ÉÉÉÅÉɃb‚!Î ˆ`W…3Ï`Ð#‰ˆ‚\"ˆ …B @‰…B
  48. ÐV…$ɉˆÑ 8‰ˆ A@‰ˆTbˆ…e`Vƒ…ÏÐ#
  49. 
  50. A@‰ƒ€
  51. ‰‚�É)‚†Éˆ ?ƒTbˆ?ƒ�i‰‚Ï`ÐÅ$ˆÒÓ!ƒÕŠÔÕ!ˆ`)V?ƒÊbˆÍ ˆÏ`ÐÅ$‚ËÉˆÖ ˆi‰‚ŠÔÕ!ˆ`)VƒÏ`ÐÅ$ˆ×`\"ƒØÕ!ˆÏ`ÐÅ$‚ÉˆÖ ‚Å…bˆÍ ˆÏ`ÐÅ$ˆÖ ‚ Ɉ‚4ˆÙÚ \"@ƒ:bˆÛÜ!ˆi‰‚vÝ !…CƒSbˆ i\\‰‚v †oÞÌ!…o …o ?…oß  #‰?…vi‰ˆ .)‡" [indent-point state paren-depth desired-indent retry t last-sexp containing-sexp parse-start nil peek scheme-indent-offset scheme-indent-hook beginning-of-line beginning-of-defun parse-partial-sexp 0 2 looking-at "\\s(" forward-line 1 backward-prefix-chars /= forward-sexp nthcdr 3 skip-chars-forward " " integerp boundp funcall] 27))
  52. (defun scheme-indent-hook (indent-point state) (byte-code "iŠ A@TbˆÅÆ!ˆÇ` A@\"ƒfÈÉÊ!ˆ`ËÌ!ˆ`\"ÍÎ
  53. !‰ˆÏ
  54. !ÐN‰ˆÑ !ƒAÒ #‚b ƒMÓ #‚b
  55. GÔV…[Õ
  56. ÖÔO×\"…bØ \"*‚gÍ))‡" [normal-indent state function method indent-point re-search-forward "\\sw\\|\\s_" /= buffer-substring forward-char -1 forward-sexp 1 nil downcase intern-soft scheme-indent-hook integerp scheme-indent-specform funcall 3 string-equal 0 "def" scheme-indent-defform] 14))
  57. (defvar scheme-body-indent 2 "\
  58. ")
  59. (defun scheme-indent-specform (count state indent-point) (byte-code " A@ ÉÉbˆi‰ˆ \\‰ˆËÌ!ˆÍÌ!ˆÎ`ÌÈ$ˆ`W…3ÉÏÐ�…;Ɉ‚(ˆ ÑVƒ]
  60. ZÌXƒV ÒÓ\"\\D‚Z
  61. D‚|
  62. ÑU…f ÑU†s ÑU…s 
  63. Xƒz ‚|
  64. ,‡" [containing-form-start state i count body-indent containing-form-column scheme-body-indent indent-point t nil normal-indent forward-char 1 forward-sexp parse-partial-sexp (byte-code "S‰ˆÃÄ!ˆÅ` ÄÂ$‡" [count indent-point t forward-sexp 1 parse-partial-sexp] 6) ((error (byte-code "À‡" [nil] 1))) 0 * 2] 7))
  65. (defun scheme-indent-defform (state indent-point) (byte-code "A@bˆÂÃ!ˆ`AA@VƒA@bˆ i\\‚ć" [state scheme-body-indent forward-line 1 nil] 3))
  66. (defun would-be-symbol (string) (byte-code "ÁÂHÃ\"?‡" [string char-equal 0 40] 3))
  67. (defun next-sexp-as-string nil (byte-code "ÁÂ!ˆ`ÃÂ!ˆÄ`\")‡" [the-end forward-sexp 1 backward-sexp buffer-substring] 5))
  68. (defun scheme-let-indent (state indent-point) (byte-code "ÂÃ!ˆÄÅ!ƒÆÇ #‚ÆÈ #‡" [state indent-point skip-chars-forward " " looking-at "[a-zA-Z0-9+-*/?!@$%^&_:~]" scheme-indent-specform 2 1] 7))
  69. (put (quote begin) (quote scheme-indent-hook) 0)
  70. (put (quote case) (quote scheme-indent-hook) 1)
  71. (put (quote do) (quote scheme-indent-hook) 2)
  72. (put (quote fluid-let) (quote scheme-indent-hook) 1)
  73. (put (quote if) (quote scheme-indent-hook) 3)
  74. (put (quote in-package) (quote scheme-indent-hook) 1)
  75. (put (quote lambda) (quote scheme-indent-hook) 1)
  76. (put (quote let) (quote scheme-indent-hook) (quote scheme-let-indent))
  77. (put (quote let*) (quote scheme-indent-hook) 1)
  78. (put (quote let-syntax) (quote scheme-indent-hook) 1)
  79. (put (quote letrec) (quote scheme-indent-hook) 1)
  80. (put (quote local-declare) (quote scheme-indent-hook) 1)
  81. (put (quote macro) (quote scheme-indent-hook) 1)
  82. (put (quote make-environment) (quote scheme-indent-hook) 0)
  83. (put (quote make-package) (quote scheme-indent-hook) 2)
  84. (put (quote named-lambda) (quote scheme-indent-hook) 1)
  85. (put (quote sequence) (quote scheme-indent-hook) 0)
  86. (put (quote using-syntax) (quote scheme-indent-hook) 1)
  87. (defun scheme-indent-sexp nil "\
  88. Indent each line of the list starting just after point." (interactive) (byte-code "ÁˆÁCÌÁÁÁÁÁŠÍÎ!)ˆŠÁ‰ˆ ?…:
  89. Á‰ ˆ ?…5m‰?…‰Ï`Ð ˆ`ÁÁ%‰ˆ@‰ˆÑÒ\"@ƒgÓ ˆÐ ˆÔÑÒ\"Á\"‚hÁˆÑÕ\"@ƒ�ÖÎ!ˆÔÑ×\"Á\"‚…ʉ ˆ‚+ˆ
  90. ÌX‰ƒ–Á‚6
  91. V…ªAS‰ˆ‚–ˆ
  92. W…ÀÁBT‰ˆ‚«ˆÖÎ!ˆ`‰ˆØÙ!ˆm†ÔÚÛ!ƒÛÁ‚6@…ä@ÌYƒï@‰‚!Ü@ƒû@[‚üÁ! Ý !ƒÔ ‰\"‚ Ô A@[\"ˆ @‰)ˆÞi\"ƒ5ß `\"ˆj‚6Áˆ‚).‡" [indent-stack nil next-depth bol outer-loop-done inner-loop-done state this-indent last-depth innerloop-done t val 0 forward-sexp 1 parse-partial-sexp end-of-line nthcdr 4 indent-for-comment setcar 3 forward-line 5 skip-chars-forward " " looking-at "[;
  93. ]" calculate-scheme-indent integerp /= delete-region] 24))
  94. (defvar scheme-zap-name (expand-file-name "fromedit.zap" nil) "\
  95. Name of transfer file between Scheme and Emacs")
  96. (defvar scheme-invocation-string "%scheme" "\
  97. *String to give to the Cshell to proceed a sibling Scheme")
  98. (defun goto-parallel-scheme-fork nil (byte-code "Á!‡" [scheme-invocation-string suspend-emacs] 2))
  99. (fset (quote goto-scheme) (quote suspend-emacs))
  100. (defun resume-scheme nil "\
  101. Suspend Emacs and resume Scheme" (interactive) (byte-code "ÅˆÆ !pƒ(ŠÇŽqˆ † ‰ˆÈ ˆÉ ˆÅ‰))‚)Å*ˆÊ ‡" [zap-buffer scheme-zap-name this-buffer buffer-file-name buffer-modified-p nil get-buffer ((byte-code "q‡" [this-buffer] 1)) save-buffer erase-buffer goto-scheme] 5))
  102. (defun scheme-do-zap-region (start end buffer &optional separate) "\
  103. Internal routine which zaps a region of text for Scheme." (byte-code "Æ
  104. \"ŠÇŽÈ !qˆÉ!ˆ ƒÊË!‚Ì)))‡" [the-text start end scheme-zap-name separate buffer buffer-substring ((byte-code "q‡" [buffer] 1)) get-buffer-create insert-string newline 2 nil] 5))
  105. (defun scheme-zap-region (start end) "\
  106. Zap region between point and mark into Scheme." (interactive "r") (byte-code "ˆÃ p#‡" [start end nil scheme-do-zap-region] 4))
  107. (defun scheme-zap-expression (arg) "\
  108. Zap sexp before point into Scheme." (interactive "P") (byte-code "ÈÄÅ ÆŽŠÇ !ˆÈÉ!ˆ`)))`pÂ$‡" [stab lisp-mode-syntax-table t nil scheme-do-zap-region syntax-table ((byte-code "Á!‡" [stab set-syntax-table] 2)) set-syntax-table forward-sexp -1] 8))
  109. (defun scheme-zap-define (arg) "\
  110. Zap current definition into Scheme." (interactive "P") (byte-code "ĈŠÆŽŠÇ !ˆ`dU?ƒÈÉ!‚ĈÊÉ!ˆ`ËÉ!ˆÌ
  111. `pÃ$))))‡" [stab scheme-mode-syntax-table start t nil syntax-table ((byte-code "Á!‡" [stab set-syntax-table] 2)) set-syntax-table forward-char 1 beginning-of-defun forward-sexp scheme-do-zap-region] 10))
  112. (defun scheme-send-buffer (arg) "\
  113. Zap whole buffer and resume Scheme" (interactive "P") (byte-code "ÀˆÁedp#ˆÂ ‡" [nil scheme-do-zap-region resume-scheme] 4))
  114. (defun scheme-zap-define-and-resume (arg) "\
  115. Zap current definition and resume Scheme" (interactive "P") (byte-code "ÁˆÂ!ˆÃ ‡" [arg nil scheme-zap-define resume-scheme] 3))
  116. (defun defining-p nil (byte-code "Š`ÃÄÅ!ˆ`\"ÆÅ!ˆÇ`fÈ\"ƒIÉÅ!ˆÊ ËÌOÍ
  117. Î\"†-Í
  118. Ï\"ƒDÐÅ!ˆÑÅ!ˆÒÅ!ˆÍ Ê \"‚EÓ)‚JÓ*)‡" [here name sub buffer-substring backward-sexp 1 beginning-of-defun char-equal 40 forward-char next-sexp-as-string 0 3 string-equal "def" "DEF" forward-sexp forward-word backward-word nil] 15))
  119. (defun find-scheme-definition (name) "\
  120. Find the definition of its argument in the current buffer" (interactive "sFind Scheme definition of: ") (byte-code "ÁˆÃ ˆÁ?…Ä
  121. !ˆÅ ‰ˆ‚)‡" [stop nil name beginning-of-buffer search-forward defining-p] 6))
  122. (autoload (quote scheme) "xscheme" "\
  123. Run an inferior Scheme process reading a command line from the terminal." t)
  124. (autoload (quote run-scheme) "xscheme" "\
  125. Run an inferior Scheme process." t)
  126. (autoload (quote scheme-send-definition) "xscheme" "\
  127. Send the current definition to the Scheme process made by M-x run-scheme." t)
  128. (autoload (quote scheme-send-definition-and-go) "xscheme" "\
  129. Send the current definition to the inferior Scheme, and switch to *scheme* buffer." t)