Gnus development mailing list
 help / color / mirror / Atom feed
From: Kai Grossjohann <grossjohann@charly.cs.uni-dortmund.de>
Cc: ding@gnus.org
Subject: Re: Searching in all mails ...
Date: 13 Oct 1997 09:58:33 +0200	[thread overview]
Message-ID: <vafn2keumae.fsf@petty.ls6.uni-do> (raw)
In-Reply-To: Stefan Waldherr's message of 12 Oct 1997 19:45:33 -0400

>>>>> On 12 Oct 1997, Stefan Waldherr said:

  Stefan> It would be really nice to have a feature (possibly thru `G
  Stefan> w' in the group buffer?) that searches thru all mails.

I wish I had something that did the right thing.  But at least I have
something that sort of works for one group only.  Consider it to be an
intermediate solution till we get something better.

Usage: set gnus-glimpse-program and gnus-glimpse-options, type "G G"
in an nnml group.  Tell me about things that don't work as you expect.

kai
-- 
~/.signature: No such file or directory


;; gnus-glimpse.el -- search current group with glimpse
;; University of Dortmund, Information Retrieval Group, CS Dept.
;; RCS Status      : $Id$
;; Author          : Kai Grossjohann
;; Created On      : Tue May 20 19:08:10 1997
;; Last Modified By: 
;; Last Modified On: 
;; Update Count    : 0
;; Status          : Unknown, Use with caution!

(require 'gnus-sum)

(defvar gnus-glimpse-program
  "/app/sun4_55/unido-inf/glimpse/default/bin/glimpse"
  "Path to glimpse program to run.")

(defvar gnus-glimpse-options "-W -y -l"
  "Default options to pass to glimpse.")

(defvar gnus-glimpse-home-option-function nil
  "You can set this to a function which should return a glimpse option.
This can be used for per-group glimpse index files.  Just set this to
a function that returns -H <path.to.index>, for instance.
The function `gnus-glimpse-home-option-per-group' is provided as an
example.")

(defun gnus-glimpse-group-to-directory (group)
  "Return directory name for this group."
  (string-match "^nnml:\\(.*\\)$" group)
  (expand-file-name
   (concat nnml-directory
           (gnus-newsgroup-directory-form
            (substring group (match-beginning 1) (match-end 1))))))

(defun gnus-glimpse-group-option ()
  "Return the string used as the group option for glimpse."
  (let ((s (gnus-glimpse-group-to-directory gnus-newsgroup-name)))
    (string-match (expand-file-name "~/") s)
    (concat "-F '" (replace-match "" nil nil s 0)
            "/[0-9]'")))

(defun gnus-glimpse-home-option-per-group ()
  "Returns an option for Glimpse to search its index files in the
directory of the group.  Can be used as a value for
`gnus-glimpse-home-option-function'."
  (let ((s (gnus-glimpse-group-to-directory gnus-newsgroup-name)))
    (concat "-H '" s "'")))

(defun gnus-glimpse-home-option ()
  "If `gnus-glimpse-home-option-function' is set, call the function specified.
Otherwise, return an empty string."
  (if gnus-glimpse-home-option-function
      (apply gnus-glimpse-home-option-function nil)
    ""))

(defun gnus-summary-glimpse (glimpse-opt)
  (interactive "sGlimpse options: ")
  (let ((cmd (concat gnus-glimpse-program " "
             gnus-glimpse-options " "
             (gnus-glimpse-group-option) " "
             (gnus-glimpse-home-option) " "
             glimpse-opt))
        ;; gnus-newsgroup-name must be read in the summary buffer.  So
        ;; we do it here which is before switching to the glimpse
        ;; output buffer.
        (newsgroup-name gnus-newsgroup-name)
        (gnus-glimpse-articles nil)
        (num-articles nil)
        (cur-article 1))
    (save-excursion
      ;; Can't read gnus-newsgroup-name after the following line.
      (set-buffer (get-buffer-create " *glimpse output*"))
      (erase-buffer)
      (message "Running %s..." cmd) (sit-for 0)
      (shell-command cmd t)
      (message "Running %s...done" cmd) (sit-for 0)
      (goto-char (point-min))
      (while (re-search-forward
              (concat "^" (gnus-glimpse-group-to-directory newsgroup-name)
                      "/\\([0-9]*\\)$")
              nil t nil)
        (replace-match "\\1" nil nil))
      (sort-numeric-fields 1 (point-min) (point-max))
      (goto-char (point-min))
      (insert "(setq gnus-glimpse-articles '(\n")
      (goto-char (point-max))
      (insert "))")
      (eval-current-buffer)
      )
    (setq num-articles (length gnus-glimpse-articles))
    (message "Found %d articles." num-articles) (sit-for 0)
    (while gnus-glimpse-articles 
      (setq cur-article (1+ cur-article))
      (gnus-summary-goto-subject (pop gnus-glimpse-articles) t t))
    (sit-for 0)))

(define-key gnus-summary-goto-map "G" 'gnus-summary-glimpse)

(provide 'gnus-glimpse)

;; gnus-glimpse.el ends here
                           


      reply	other threads:[~1997-10-13  7:58 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
1997-10-12 23:45 Stefan Waldherr
1997-10-13  7:58 ` Kai Grossjohann [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=vafn2keumae.fsf@petty.ls6.uni-do \
    --to=grossjohann@charly.cs.uni-dortmund.de \
    --cc=ding@gnus.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).