(derived-mode-p): Moved here from derived.el.
authorRichard M. Stallman <rms@gnu.org>
Wed, 12 Dec 2001 09:26:43 +0000 (09:26 +0000)
committerRichard M. Stallman <rms@gnu.org>
Wed, 12 Dec 2001 09:26:43 +0000 (09:26 +0000)
lisp/subr.el

index 4232fd7..4029b7f 100644 (file)
@@ -1294,6 +1294,16 @@ Only affects hooks run in the current buffer."
      (let ((delay-mode-hooks t))
        ,@body)))
 
+;; PUBLIC: find if the current mode derives from another.
+
+(defun derived-mode-p (&rest modes)
+  "Non-nil if the current major mode is derived from one of MODES.
+Uses the `derived-mode-parent' property of the symbol to trace backwards."
+  (let ((parent major-mode))
+    (while (and (not (memq parent modes))
+               (setq parent (get parent 'derived-mode-parent))))
+    parent))
+
 (defmacro with-syntax-table (table &rest body)
   "Evaluate BODY with syntax table of current buffer set to a copy of TABLE.
 The syntax table of the current buffer is saved, BODY is evaluated, and the