Commit | Line | Data |
---|---|---|
8b2120f4 | 1 | ;;; yow.el --- quote random zippyisms |
6cf0d154 | 2 | |
1be14568 | 3 | ;; Copyright (C) 1993, 1994, 1995, 2000 Free Software Foundation, Inc. |
58142744 | 4 | |
6cf0d154 | 5 | ;; Maintainer: FSF |
f6dd89c6 | 6 | ;; Author: Richard Mlynarik |
6251ee24 | 7 | ;; Keywords: games |
76d7458e | 8 | |
a18d567f RS |
9 | ;; This file is part of GNU Emacs. |
10 | ||
11 | ;; GNU Emacs is free software; you can redistribute it and/or modify | |
12 | ;; it under the terms of the GNU General Public License as published by | |
e5167999 | 13 | ;; the Free Software Foundation; either version 2, or (at your option) |
a18d567f RS |
14 | ;; any later version. |
15 | ||
16 | ;; GNU Emacs is distributed in the hope that it will be useful, | |
17 | ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 | ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 | ;; GNU General Public License for more details. | |
20 | ||
21 | ;; You should have received a copy of the GNU General Public License | |
b578f267 EN |
22 | ;; along with GNU Emacs; see the file COPYING. If not, write to the |
23 | ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
24 | ;; Boston, MA 02111-1307, USA. | |
a18d567f | 25 | |
6cf0d154 ER |
26 | ;;; Commentary: |
27 | ||
eb8c3be9 | 28 | ;; Important pinheadery for GNU Emacs. |
ed73b256 | 29 | ;; |
269d869f | 30 | ;; See cookie1.el for implementation. Note --- the `n' argument of yow |
ed73b256 ER |
31 | ;; from the 18.xx implementation is no longer; we only support *random* |
32 | ;; random access now. | |
6cf0d154 ER |
33 | |
34 | ;;; Code: | |
35 | ||
269d869f | 36 | (require 'cookie1) |
ed73b256 | 37 | |
323f7c49 SE |
38 | (defgroup yow nil |
39 | "Quote random zippyisms." | |
40 | :prefix "yow-" | |
41 | :group 'games) | |
42 | ||
43 | (defcustom yow-file (concat data-directory "yow.lines") | |
44 | "File containing pertinent pinhead phrases." | |
45 | :type 'file | |
46 | :group 'yow) | |
a18d567f | 47 | |
6f579a69 NF |
48 | (defconst yow-load-message "Am I CONSING yet?...") |
49 | (defconst yow-after-load-message "I have SEEN the CONSING!!") | |
50 | ||
7229064d | 51 | ;;;###autoload |
b85b15f3 | 52 | (defun yow (&optional insert display) |
b6173cae | 53 | "Return or display a random Zippy quotation. With prefix arg, insert it." |
b85b15f3 | 54 | (interactive "P\np") |
6f579a69 | 55 | (let ((yow (cookie yow-file yow-load-message yow-after-load-message))) |
b6173cae RM |
56 | (cond (insert |
57 | (insert yow)) | |
b85b15f3 | 58 | ((not display) |
a18d567f | 59 | yow) |
a18d567f | 60 | (t |
1be14568 | 61 | (message "%s" yow))))) |
a18d567f | 62 | |
2694dfb9 RM |
63 | (defsubst read-zippyism (prompt &optional require-match) |
64 | "Read a Zippyism from the minibuffer with completion, prompting with PROMPT. | |
65 | If optional second arg is non-nil, require input to match a completion." | |
6f579a69 | 66 | (read-cookie prompt yow-file yow-load-message yow-after-load-message |
2694dfb9 | 67 | require-match)) |
b6173cae RM |
68 | |
69 | ;;;###autoload | |
70 | (defun insert-zippyism (&optional zippyism) | |
71 | "Prompt with completion for a known Zippy quotation, and insert it at point." | |
72 | (interactive (list (read-zippyism "Pinhead wisdom: " t))) | |
73 | (insert zippyism)) | |
6f579a69 NF |
74 | |
75 | ;;;###autoload | |
76 | (defun apropos-zippy (regexp) | |
77 | "Return a list of all Zippy quotes matching REGEXP. | |
78 | If called interactively, display a list of matches." | |
79 | (interactive "sApropos Zippy (regexp): ") | |
80 | ;; Make sure yows are loaded | |
81 | (cookie yow-file yow-load-message yow-after-load-message) | |
82 | (let* ((case-fold-search t) | |
83 | (cookie-table-symbol (intern yow-file cookie-cache)) | |
84 | (string-table (symbol-value cookie-table-symbol)) | |
85 | (matches nil) | |
86 | (len (length string-table)) | |
87 | (i 0)) | |
88 | (save-match-data | |
89 | (while (< i len) | |
90 | (and (string-match regexp (aref string-table i)) | |
91 | (setq matches (cons (aref string-table i) matches))) | |
92 | (setq i (1+ i)))) | |
93 | (and matches | |
94 | (setq matches (sort matches 'string-lessp))) | |
95 | (and (interactive-p) | |
96 | (cond ((null matches) | |
97 | (message "No matches found.")) | |
98 | (t | |
99 | (let ((l matches)) | |
100 | (with-output-to-temp-buffer "*Zippy Apropos*" | |
101 | (while l | |
102 | (princ (car l)) | |
103 | (setq l (cdr l)) | |
104 | (and l (princ "\n\n")))))))) | |
105 | matches)) | |
106 | ||
a18d567f | 107 | \f |
6f579a69 NF |
108 | ;; Yowza!! Feed zippy quotes to the doctor. Watch results. |
109 | ;; fun, fun, fun. Entertainment for hours... | |
110 | ;; | |
111 | ;; written by Kayvan Aghaiepour | |
a18d567f | 112 | |
7229064d | 113 | ;;;###autoload |
a18d567f RS |
114 | (defun psychoanalyze-pinhead () |
115 | "Zippy goes to the analyst." | |
116 | (interactive) | |
117 | (doctor) ; start the psychotherapy | |
a18d567f RS |
118 | (message "") |
119 | (switch-to-buffer "*doctor*") | |
120 | (sit-for 0) | |
121 | (while (not (input-pending-p)) | |
967732f6 | 122 | (insert (yow)) |
a18d567f RS |
123 | (sit-for 0) |
124 | (doctor-ret-or-read 1) | |
125 | (doctor-ret-or-read 1))) | |
126 | ||
49116ac0 JB |
127 | (provide 'yow) |
128 | ||
6b61353c | 129 | ;;; arch-tag: d13db89b-84f1-4141-a5ce-261d1733a65c |
76d7458e | 130 | ;;; yow.el ends here |