Mercurial > hg > xemacs-beta
view lisp/ilisp/ilisp-hlw.el @ 185:3d6bfa290dbd r20-3b19
Import from CVS: tag r20-3b19
author | cvs |
---|---|
date | Mon, 13 Aug 2007 09:55:28 +0200 |
parents | b82b59fe008d |
children |
line wrap: on
line source
;;; -*- Mode: Emacs-Lisp -*- ;;; ilisp-hlw.el -- ;;; This file is part of ILISP. ;;; Version: 5.8 ;;; ;;; Copyright (C) 1990, 1991, 1992, 1993 Chris McConnell ;;; 1993, 1994 Ivan Vasquez ;;; 1994, 1995, 1996 Marco Antoniotti and Rick Busdiecker ;;; 1996 Marco Antoniotti and Rick Campbell ;;; ;;; Other authors' names for which this Copyright notice also holds ;;; may appear later in this file. ;;; ;;; Send mail to 'ilisp-request@naggum.no' to be included in the ;;; ILISP mailing list. 'ilisp@naggum.no' is the general ILISP ;;; mailing list were bugs and improvements are discussed. ;;; ;;; ILISP is freely redistributable under the terms found in the file ;;; COPYING. ;;; ;;; ILISP LispWorks Common Lisp dialect definition ;;; ;;; Independently written by: ;;; ;;; Jason Trenouth: jason@harlequin.co.uk ;;; Qiegang Long: qlong@cs.umass.edu ;;; ;;; and later merged together by Jason ;;; (defvar ilisp-lispworks-init-file "lispworks.lisp") ;; may use Qiegang's instead? "[-A-Z]+ [0-9]+ : \\([0-9]+\\) >" (defun lispworks-break-level (prompt) (let ((position nil)) (if (and prompt (setq position (string-match ": [0-9]+" prompt))) (string-to-int (substring prompt (+ 2 position))) 0))) (defun lispworks-check-prompt (old new) "Compare the break level printed at the beginning of the prompt." (<= (lispworks-break-level new) (lispworks-break-level old))) ;; Qiegang's prompt matcher "^\\([-A-Z]+ [0-9]+ >\\)\\|\\([-A-Z]+ [0-9]+ : [0-9]+ >\\) " ;; Qiegang's error matcher "\\(ILISP:[^\"]*\\)\\|\\(Error: [^\n]*\\)\\|\\(Break.[^\n]*\\)" (defdialect lispworks "LispWorks" clisp (ilisp-load-init 'lispworks ilisp-lispworks-init-file) (setq comint-fix-error ":a" ilisp-reset ":a" ;; LW doesn't have a multi-level abort yet comint-continue ":c" comint-interrupt-regexp "Break.\n.*") (setq comint-prompt-status (function (lambda (old line) (comint-prompt-status old line 'lispworks-check-prompt)))) ;; <cl> or package> at top-level ;; [0-9c] <cl> or package> in error ;; (setq comint-prompt-regexp "^\\(\\[[0-9]*c*\\] \\|\\)\\(<\\|\\)[^>]*> ") (setq comint-prompt-regexp "^[A-Z=][-a-z0-9A-Z:= ]*[$%#>]+ *") (setq ilisp-error-regexp "ILISP [0-9]* : [0-9]* > ") (setq ilisp-binary-command "system::*binary-file-type*") (setq ilisp-source-types (append ilisp-source-types '(("any")))) (setq ilisp-directory-command "(lw:current-pathname)") (setq ilisp-set-directory-command "(lw:change-directory \"%s\")") (setq ilisp-find-source-command "(ILISP:ilisp-source-files \"%s\" \"%s\" \"%s\")") (setq ilisp-init-binary-command "system::*binary-file-type*")) (if (not lispworks-program) (setq lispworks-program "lispworks")) (provide 'ilisp-lw)