ilisp / ilisp-sbcl.el

Full commit
;;; -*- Mode: Emacs-Lisp -*-

;;; ilisp-sbcl.el --

;;; This file is part of ILISP.
;;; Version: 5.10.1
;;; Copyright (C) 1990, 1991, 1992, 1993 Chris McConnell
;;;               1993, 1994 Ivan Vasquez
;;;               1994, 1995, 1996 Marco Antoniotti and Rick Busdiecker
;;;               1996, 1997, 1998, 1999 Marco Antoniotti and Rick Campbell
;;;               2000 Matthias Hölzl
;;; Other authors' names for which this Copyright notice also holds
;;; may appear later in this file.
;;; Send mail to '' to be included in the
;;; ILISP mailing list. '' is the general ILISP
;;; mailing list were bugs and improvements are discussed.
;;; ILISP is freely redistributable under the terms found in the file

;;; ILISP SB Common Lisp dialect definition
;;;%%%SB Common Lisp

(defvar sblisp-source-directory-regexp 
  "*Regexp to match sblisp source code directory.")

(defvar sblisp-local-source-directory
  "*Where the sblisp sources really are.")

(defvar ilisp-sblisp-init-file "sblisp")

(defun sblisp-source-directory-fixup-function ()
  (if sblisp-local-source-directory
      (replace-match sblisp-local-source-directory)))

(defun sblisp-check-prompt (old new)
  "Compare the break level printed at the beginning of the prompt."
  (let* ((was-in-break (and old (string-match "]+" old)))
 	 (old-level (if was-in-break
 			(- (match-end 0) (match-beginning 0))
 	 (is-in-break (string-match "]+" new))
 	 (new-level (if is-in-break
 			(- (match-end 0) (match-beginning 0))
    (<= new-level old-level)))

(defdialect sblisp "SB Common LISP"
  (ilisp-load-init 'sb ilisp-sblisp-init-file)
  (if sblisp-local-source-directory
      (setq ilisp-source-directory-fixup-alist
	     (cons sblisp-source-directory-regexp
    (message "sblisp-local-source-directory not set."))
  (setq comint-prompt-regexp "^\\([0-9]+\\]+\\|\\*\\) "
	ilisp-trace-command "(ILISP:sblisp-trace \"%s\" \"%s\" \"%s\")"
	(function (lambda (old line)
		    (comint-prompt-status old line 'sblisp-check-prompt)))

	ilisp-error-regexp "\\(ILISP:[^\"]*\\)\\|\\(Error [^\n]*\n\n\\)"
	;; The above regexp has been suggested by
	;; (Larry Hunter)

	ilisp-arglist-command "(ILISP:ilisp-arglist \"%s\" \"%s\")"

	ilisp-find-source-command "(ILISP:source-file \"%s\" \"%s\" \"%s\")"

	comint-fix-error ":pop"

	comint-continue ":go"

	ilisp-reset ":q"

	comint-interrupt-regexp "Interrupted at"

	;; Note:
	;; 19990806 Marco Antoniotti
	;; As Martin Atzmueller has pointed out, these hardcoded
	;; constraints are very nasty.
	;; However, before hacking the code right here, I'd like to
	;; see an all-out solution to the binary file extension problem.

	ilisp-binary-extension "x86f"
	ilisp-init-binary-extension "x86f"
	ilisp-binary-command "\"x86f\""

  ;; ILD Support

  (setq ild-abort-string ":abort"
	ild-continue-string ":go"
	ild-next-string ":down"
	ild-next-string-arg nil		;needs work
	ild-previous-string ":up"
	ild-previous-string-arg nil	;needs work
	ild-top-string ":bottom"
	ild-bottom-string ":top"
	ild-backtrace-string ":backtrace"
	ild-locals-string ":l"
	ild-local-string-arg "(debug:arg %s)"
	ild-return-string nil		; needs work (debug:debug-return x)
	ild-retry-string nil		; needs work
	ild-trap-on-exit-string nil	; needs work

(unless sblisp-program (setq sblisp-program "sbcl"))

;;; end of file -- ilisp-sbcl.el --