Mercurial > hg > xemacs-beta
diff lisp/oobr/clos-brows.el @ 0:376386a54a3c r19-14
Import from CVS: tag r19-14
author | cvs |
---|---|
date | Mon, 13 Aug 2007 08:45:50 +0200 |
parents | |
children | 4103f0995bd7 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/lisp/oobr/clos-brows.el Mon Aug 13 08:45:50 2007 +0200 @@ -0,0 +1,124 @@ +;;!emacs +;; +;; FILE: clos-brows.el +;; SUMMARY: Common Lisp/CLOS source code browser. +;; USAGE: GNU Emacs Lisp Library +;; KEYWORDS: lisp, oop, tools +;; +;; AUTHOR: Bob Weiner +;; ORG: Motorola Inc. +;; +;; ORIG-DATE: 29-Jul-90 +;; LAST-MOD: 20-Sep-95 at 14:21:17 by Bob Weiner +;; +;; Copyright (C) 1990-1995 Free Software Foundation, Inc. +;; See the file BR-COPY for license information. +;; +;; This file is part of the OO-Browser. +;; +;; DESCRIPTION: +;; +;; Use 'clos-browse' to invoke the CLOS OO-Browser. Prefix arg prompts for +;; name of Environment file. +;; +;; DESCRIP-END. + +;;; ************************************************************************ +;;; Other required Elisp libraries +;;; ************************************************************************ + +(mapcar 'require '(br-start br br-clos-ft)) + +;;; ************************************************************************ +;;; Public functions +;;; ************************************************************************ + +;;;###autoload +(defun clos-browse (&optional env-file no-ui) + "Invoke the CLOS OO-Browser. +This allows browsing through CLOS library and system class hierarchies. With +an optional non-nil prefix argument ENV-FILE, prompt for Environment file +to use. Alternatively, a string value of ENV-FILE is used as the +Environment file name. See also the file \"br-help\"." + (interactive "P") + (let ((same-lang (equal br-lang-prefix clos-lang-prefix)) + (load-succeeded t) + same-env) + (if same-lang + nil + ;; Save other language Environment in memory + (if br-lang-prefix (br-env-copy nil)) + (setq br-lang-prefix clos-lang-prefix + *br-save-wconfig* nil)) + (setq same-env (or (equal clos-env-file env-file) + (and (null env-file) + (or clos-lib-search-dirs clos-sys-search-dirs)))) + (cond + ;; Continue browsing an Environment + ((and same-env same-lang)) + ((and same-env (not same-lang)) + (clos-browse-setup) (br-env-copy t)) + ;; + ;; Create default Environment file specification if needed and none + ;; exists. + ;; + (t (or env-file (file-exists-p clos-env-file) + (br-env-create clos-env-file clos-lang-prefix)) + (or env-file (setq env-file clos-env-file)) + ;; + ;; Start browsing a new Environment. + ;; + (clos-browse-setup) + (setq load-succeeded (br-env-init env-file same-lang nil)) + (if load-succeeded + (setq *br-save-wconfig* nil + clos-env-file load-succeeded + clos-sys-search-dirs br-sys-search-dirs + clos-lib-search-dirs br-lib-search-dirs)))) + (cond (load-succeeded + (br-init) + (or no-ui (br-browse))) + (no-ui nil) + (t (message "(clos-browse): You must build the Environment to browse it."))))) + +;; Don't filter Environment classes when listed. +(fset 'clos-class-list-filter 'identity) + +(defun clos-class-definition-regexp (class) + "Return regexp to uniquely match the definition of CLASS name." + (concat clos-class-name-before (regexp-quote class) + clos-class-name-after)) + +;;; ************************************************************************ +;;; Internal functions +;;; ************************************************************************ + +(defun clos-browse-setup () + "Setup language-dependent functions for OO-Browser." + (br-setup-functions) + ;; Use this until an info function is implemented for the language. + (fmakunbound 'br-insert-class-info) + (fset 'br-store-class-info 'clos-store-class-info) + (fset 'br-lang-mode + (cond ((featurep 'clos-mode) 'clos-mode) + ((load "clos-mode" 'missing-ok 'nomessage) + (provide 'clos-mode)) + (t 'clos-browse-mode))) + (br-setup-constants) + ;; Setup to add default classes to system class table after building it. + ;; This must come after br-setup-constants call since it clears these + ;; hooks. + (if (fboundp 'add-hook) + (add-hook 'br-after-build-sys-hook 'clos-add-default-classes) + (setq br-after-build-sys-hook '(clos-add-default-classes)))) + +(defun clos-browse-mode () + "Select major mode for browsing the current buffer's file." + (interactive) + (if (and (stringp buffer-file-name) + (not (memq major-mode '(lisp-mode emacs-lisp-mode)))) + (cond ((string-match "\\.el$" buffer-file-name) + (emacs-lisp-mode)) + (t (lisp-mode))))) + +(provide 'clos-brows)