--- gforth/gforth.el 1995/10/11 19:39:34 1.15 +++ gforth/gforth.el 2000/09/23 15:06:00 1.43 @@ -1,11 +1,10 @@ -;; This file is part of GNU Emacs. -;; Changes by anton -;; This is a variant of forth.el that came with TILE. -;; I left most of this stuff untouched and made just a few changes for -;; the things I use (mainly indentation and syntax tables). -;; So there is still a lot of work to do to adapt this to gforth. +;; Forth mode for Emacs + +;; Copyright (C) 1995,1996,1997,1998,2000 Free Software Foundation, Inc. -;; GNU Emacs is distributed in the hope that it will be useful, +;; This file is part of Gforth. + +;; GForth is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY. No author or distributor ;; accepts responsibility to anyone for the consequences of using it ;; or for whether it serves any particular purpose or works at all, @@ -15,12 +14,16 @@ ;; Everyone is granted permission to copy, modify and redistribute ;; GNU Emacs, but only under the conditions described in the ;; GNU Emacs General Public License. A copy of this license is -;; supposed to have been given to you along with GNU Emacs so you +;; supposed to have been given to you along with Gforth so you ;; can know your rights and responsibilities. It should be in a ;; file named COPYING. Among other things, the copyright notice ;; and this notice must be preserved on all copies. -;;; $Header: /nfs/unsafe/cvs-repository/src-master/gforth/gforth.el,v 1.15 1995/10/11 19:39:34 anton Exp $ +;; Changes by anton +;; This is a variant of forth.el that came with TILE. +;; I left most of this stuff untouched and made just a few changes for +;; the things I use (mainly indentation and syntax tables). +;; So there is still a lot of work to do to adapt this to gforth. ;;------------------------------------------------------------------- ;; A Forth indentation, documentation search and interaction library @@ -37,20 +40,30 @@ (defvar forth-positives - " : :noname code ;code does> begin do ?do +do -do u+do u-do while if ?dup-if ?dup-not-if else case struct [if] [else] " - "Contains all words which will cause the indent-level to be incremented + " : :noname m: :m code interpretation: ;code does> begin do ?do +do -do u+do u-do while if ?dup-if ?dup-0=-if else case of struct [if] [ifdef] [ifundef] [else] with public: private: class try recover " + "*Contains all words which will cause the indent-level to be incremented on the next line. OBS! All words in forth-positives must be surrounded by spaces.") (defvar forth-negatives - " ; end-code ;code does> until repeat while +loop loop -loop s+loop else then endif again endcase end-struct [then] [else] [endif]" - "Contains all words which will cause the indent-level to be decremented + " ; ;m end-code ;code does> until repeat while +loop loop -loop s+loop else then endif again endcase endof end-struct [then] [else] [endif] endwith end-class class; how: recover endtry " + "*Contains all words which will cause the indent-level to be decremented on the current line. OBS! All words in forth-negatives must be surrounded by spaces.") (defvar forth-zeroes - " : :noname code " - "Contains all words which causes the indent to go to zero") + " : :noname code interpretation: public: private: how: implements class class; " + "*Contains all words which causes the indent to go to zero") + +(setq forth-zero 0) + +(defvar forth-zup + " how: implements " + "Contains all words which causes zero indent level to change") + +(defvar forth-zdown + " class; how: class public: private: " + "Contains all words which causes zero indent level to change") (defvar forth-prefixes " postpone [compile] ['] [char] " @@ -67,10 +80,6 @@ OBS! All words in forth-negatives must b (if (not forth-mode-map) (setq forth-mode-map (make-sparse-keymap))) -(global-set-key "\e\C-m" 'forth-send-paragraph) -(global-set-key "\C-x\C-m" 'forth-split) -(global-set-key "\e " 'forth-reload) - ;(define-key forth-mode-map "\M-\C-x" 'compile) (define-key forth-mode-map "\C-x\\" 'comment-region) (define-key forth-mode-map "\C-x~" 'forth-remove-tracers) @@ -83,7 +92,17 @@ OBS! All words in forth-negatives must b (define-key forth-mode-map "\M-q" 'forth-fill-paragraph) (define-key forth-mode-map "\e." 'forth-find-tag) -(load "etags.el") +;setup for C-h C-i to work +(if (fboundp 'info-lookup-add-help) + (info-lookup-add-help + :topic 'symbol + :mode 'forth-mode + :regexp "[^ +]+" + :ignore-case t + :doc-spec '(("(gforth)Name Index" nil "`" "' ")))) + +(load "etags") (defun forth-find-tag (tagname &optional next-p regexp-p) (interactive (find-tag-interactive "Find tag: ")) @@ -151,7 +170,7 @@ OBS! All words in forth-negatives must b " Major mode for editing Forth code. Tab indents for Forth code. Comments are delimited with \\ and newline. Paragraphs are separated by blank lines -only. Delete converts tabs to spaces as it moves back. +only. \\{forth-mode-map} Forth-split Positions the current buffer on top and a forth-interaction window @@ -319,8 +338,12 @@ programmers who tend to fill code won't (regexp-quote (concat " " w1 " ")) forth-negatives) forth-indent-level 0))) + (if (string-match (regexp-quote (concat " " w1 " ")) forth-zdown) + (setq forth-zero 0)) (if (string-match (regexp-quote (concat " " w1 " ")) forth-zeroes) - (setq indent 0)) + (setq indent forth-zero)) + (if (string-match (regexp-quote (concat " " w1 " ")) forth-zup) + (setq forth-zero 4)) indent)) (defun forth-sum-line-indentation () @@ -378,7 +401,7 @@ the input stream (comments, arguments, e (defun forth-remove-tracers () "Remove tracers of the form `~~ '. Queries the user for each occurrence." (interactive) - (query-replace "~~ " "")) + (query-replace-regexp "\\(~~ \\| ~~$\\)" "" nil)) (defvar forth-program-name "gforth" "*Program invoked by the `run-forth' command.") @@ -408,6 +431,10 @@ part of the screen." (forth-split) (forth-set-runlight forth-runlight:input)) +(defun run-forth-if-not () + (if (not (forth-process-running-p)) + (run-forth forth-program-name))) + (defun reset-forth () "Reset the Forth process." (interactive) @@ -701,7 +728,7 @@ The region is sent terminated by a newli (interactive) (let ((process (get-process forth-program-name))) (if process (kill-process process t))) - (sleep-for-millisecs 100) + (sleep-for 0 100) (forth-mode)) @@ -909,18 +936,44 @@ The region is sent terminated by a newli (require 'outline) -;;(define-key outline-minor-mode-map 'f9 'show-entry) -;;(define-key outline-minor-mode-map 'f10 'hide-entry) +(defun f-outline-level () + (cond ((looking-at "\\`\\\\") + 0) + ((looking-at "\\\\ SEC") + 0) + ((looking-at "\\\\ \\\\ .*") + 0) + ((looking-at "\\\\ DEFS") + 1) + ((looking-at "\\/\\* ") + 1) + ((looking-at ": .*") + 1) + ((looking-at "\\\\G") + 2) + ((looking-at "[ \t]+\\\\") + 3)) +) (defun fold-f () (interactive) (add-hook 'outline-minor-mode-hook 'hide-body) ; outline mode header start, i.e. find word definitions - (setq outline-regexp "^\\(:\\)[ \t]+\\([^ \t]*\\)") +;;; (setq outline-regexp "^\\(:\\)[ \t]+\\([^ \t]*\\)") + (setq outline-regexp "\\`\\\\\\|:\\|\\\\ SEC\\|\\\\G\\|[ \t]+\\\\\\|\\\\ DEFS\\|\\/\\*\\|\\\\ \\\\ .*") + (setq outline-level 'f-outline-level) (outline-minor-mode) + (define-key outline-minor-mode-map '(shift up) 'hide-sublevels) + (define-key outline-minor-mode-map '(shift right) 'show-children) + (define-key outline-minor-mode-map '(shift left) 'hide-subtree) + (define-key outline-minor-mode-map '(shift down) 'show-subtree) + ) + +;;(define-key global-map '(shift up) 'fold-f) + ;;; end file folding ;;; func-menu is a package that scans your source file for function definitions @@ -933,6 +986,32 @@ The region is sent terminated by a newli (require 'func-menu) ;; (define-key global-map 'f8 'function-menu) (add-hook 'find-fible-hooks 'fume-add-menubar-entry) - (define-key global-map "\C-cg" 'fume-prompt-function-goto) - (define-key global-map '(shift button3) 'mouse-function-menu) - )) +; (define-key global-map "\C-cg" 'fume-prompt-function-goto) +; (define-key global-map '(shift button3) 'mouse-function-menu) +)) + +;;; Highlighting + +(if (not (file-exists-p "/usr/share/emacs/site-lisp/hl319.el")) + (require 'hilit19) + (require 'hl319)) + +(hilit-set-mode-patterns + '(forth-mode) + (append + '(("\\\\ \\(.*\\)$" nil comment)) ; comments + '(("\\\\[gG] \\(.*\\)$" nil comment)) ; comments + '(("(\\( [^)\n]* \\| \\)--\\( [^)\n]* \\| \\))" nil decl)) + '(("( " ")" comment)) + '(("\" [^\"\n]*\"" nil string)) + '(("\\(\\[IF]\\|\\[IFDEF]\\|\\[IFUNDEF]\\|\\[ELSE]\\|\\[THEN]\\|IF\\|ELSE\\|THEN\\|CASE\\|ENDCASE\\|OF\\|ENDOF\\|BEGIN\\|WHILE\\|REPEAT\\|UNTIL\\|AGAIN\\|DOES>\\|?DO\\|DO\\|\+LOOP\\|UNLOOP\\|LOOP\\|EXIT\\)" nil keyword)) + '(("\\(\\[if]\\|\\[ifdef]\\|\\[ifundef]\\|\\[else]\\|\\[then]\\|if\\|else\\|then\\|case\\|endcase\\|of\\|endof\\|begin\\|while\\|repeat\\|until\\|again\\|does>\\|?do\\|do\\|\+loop\\|unloop\\|loop\\|exit\\)" nil keyword)) + '((": *[^ \n]*" nil defun)) + '(("Defer *[^ \n]*" nil defun)) + '(("\\(Variable\\|Constant\\|Value\\|Create\\) *[^ \n]*" nil define)) + '(("\\(include\\|require\\) *[^ \n]*" nil include)) + '(("[\n ]\\(\\$[0-9A-Fa-f]+[\n ]\\|&[0-9]+[\n ]\\|[0-9]+[\n ]\\|%[01]+[\n ]\\|'[^ \n]+\\)+" nil formula)) + '((":noname" nil defun)))) + +;; end +