From: Noah Friedman Date: Tue, 19 Dec 1995 22:33:55 +0000 (+0000) Subject: (apropos-zippy): New command. X-Git-Tag: emacs-19.34~2107 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=6f579a691abe231458ccc00f4f3f514758d2c621;p=emacs.git (apropos-zippy): New command. (yow-load-message, yow-after-load-message): New constants. (yow, read-zippyism): Use them. Now KEN and BARBIE are PERMANENTLY ADDICTED to MIND-ALTERING DRUGS.. --- diff --git a/lisp/play/yow.el b/lisp/play/yow.el index cbaef0a2680..33600a42c37 100644 --- a/lisp/play/yow.el +++ b/lisp/play/yow.el @@ -1,6 +1,6 @@ ;;; yow.el --- quote random zippyisms -;; Copyright (C) 1993, 1994 Free Software Foundation, Inc. +;; Copyright (C) 1993, 1994, 1995 Free Software Foundation, Inc. ;; Maintainer: FSF ;; Author: Richard Mlynarik @@ -37,12 +37,14 @@ (defvar yow-file (concat data-directory "yow.lines") "File containing pertinent pinhead phrases.") +(defconst yow-load-message "Am I CONSING yet?...") +(defconst yow-after-load-message "I have SEEN the CONSING!!") + ;;;###autoload (defun yow (&optional insert) "Return or display a random Zippy quotation. With prefix arg, insert it." (interactive "P") - (let ((yow (cookie yow-file - "Am I CONSING yet?..." "I have SEEN the CONSING!!"))) + (let ((yow (cookie yow-file yow-load-message yow-after-load-message))) (cond (insert (insert yow)) ((not (interactive-p)) @@ -61,8 +63,7 @@ (defsubst read-zippyism (prompt &optional require-match) "Read a Zippyism from the minibuffer with completion, prompting with PROMPT. If optional second arg is non-nil, require input to match a completion." - (read-cookie prompt yow-file - "Am I CONSING yet?..." "I have SEEN the CONSING!!" + (read-cookie prompt yow-file yow-load-message yow-after-load-message require-match)) ;;;###autoload @@ -70,11 +71,44 @@ If optional second arg is non-nil, require input to match a completion." "Prompt with completion for a known Zippy quotation, and insert it at point." (interactive (list (read-zippyism "Pinhead wisdom: " t))) (insert zippyism)) + +;;;###autoload +(defun apropos-zippy (regexp) + "Return a list of all Zippy quotes matching REGEXP. +If called interactively, display a list of matches." + (interactive "sApropos Zippy (regexp): ") + ;; Make sure yows are loaded + (cookie yow-file yow-load-message yow-after-load-message) + (let* ((case-fold-search t) + (cookie-table-symbol (intern yow-file cookie-cache)) + (string-table (symbol-value cookie-table-symbol)) + (matches nil) + (len (length string-table)) + (i 0)) + (save-match-data + (while (< i len) + (and (string-match regexp (aref string-table i)) + (setq matches (cons (aref string-table i) matches))) + (setq i (1+ i)))) + (and matches + (setq matches (sort matches 'string-lessp))) + (and (interactive-p) + (cond ((null matches) + (message "No matches found.")) + (t + (let ((l matches)) + (with-output-to-temp-buffer "*Zippy Apropos*" + (while l + (princ (car l)) + (setq l (cdr l)) + (and l (princ "\n\n")))))))) + matches)) + -; Yowza!! Feed zippy quotes to the doctor. Watch results. -; fun, fun, fun. Entertainment for hours... -; -; written by Kayvan Aghaiepour +;; Yowza!! Feed zippy quotes to the doctor. Watch results. +;; fun, fun, fun. Entertainment for hours... +;; +;; written by Kayvan Aghaiepour ;;;###autoload (defun psychoanalyze-pinhead ()