Mercurial > emacs
view vms/make-mms-derivative.el @ 61424:ad05d91d3598
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-243
Merge from gnus--rel--5.10
Patches applied:
* gnus--rel--5.10 (patch 59)
- Update from CVS
2005-04-06 Katsumi Yamaoka <yamaoka@jpl.org>
* lisp/calendar/time-date.el (time-to-seconds): Don't use the #xhhhh
syntax which Emacs 20 doesn't support.
(seconds-to-time, days-to-time, time-subtract, time-add): Ditto.
2005-04-06 Katsumi Yamaoka <yamaoka@jpl.org>
* lisp/gnus/mm-util.el (mm-coding-system-p): Don't return binary for the nil
argument in XEmacs.
* lisp/gnus/nnrss.el (nnrss-compatible-encoding-alist): New variable.
(nnrss-request-group): Decode group name first.
(nnrss-request-article): Make a text/plain article if mml-to-mime
failed.
(nnrss-get-encoding): Return a compatible encoding according to
nnrss-compatible-encoding-alist.
(nnrss-opml-export): Use dolist.
(nnrss-find-el): Use consp instead of listp.
(nnrss-order-hrefs): Use dolist.
2005-04-06 Arne J,Ax(Brgensen <arne@arnested.dk>
* lisp/gnus/nnrss.el (nnrss-verbose): Remove.
(nnrss-request-group): Use `nnheader-message' instead.
2005-04-06 Mark Plaksin <happy@usg.edu> (tiny change)
* lisp/gnus/nnrss.el (nnrss-verbose): New variable.
(nnrss-request-group): Make it say nnrss is requesting a group.
2005-04-06 Katsumi Yamaoka <yamaoka@jpl.org>
* lisp/gnus/gnus-agent.el (gnus-agent-group-path): Decode group name.
(gnus-agent-group-pathname): Ditto.
* lisp/gnus/gnus-cache.el (gnus-cache-file-name): Decode group name.
* lisp/gnus/gnus-group.el (gnus-group-line-format-alist): Use decoded group
name for only %g and %c.
(gnus-group-insert-group-line): Bind gnus-tmp-decoded-group
instead of gnus-tmp-group to decoded group name.
(gnus-group-make-group): Decode group name.
(gnus-group-delete-group): Ditto.
(gnus-group-make-rss-group): Exclude `/'s from group names;
register the group data after opening the nnrss group; unify
non-ASCII group names; encode group name.
(gnus-group-catchup-current): Decode group name.
(gnus-group-expire-articles-1): Ditto.
(gnus-group-set-current-level): Ditto.
(gnus-group-kill-group): Ditto.
* lisp/gnus/gnus-spec.el (gnus-update-format-specifications): Flush the
group format spec cache if it doesn't support decoded group names.
* lisp/gnus/mm-url.el (mm-url-predefined-programs): Add --silent arg to curl.
* lisp/gnus/nnrss.el: Require rfc2047 and mml.
(nnrss-file-coding-system): New variable.
(nnrss-format-string): Redefine it as an inline function.
(nnrss-decode-group-name): New function.
(nnrss-string-as-multibyte): Remove.
(nnrss-retrieve-headers): Decode group name; don't use
nnrss-format-string.
(nnrss-request-group): Decode group name.
(nnrss-request-article): Decode group name; allow a Message-ID as
well as an article number; don't use nnrss-format-string; encode a
Message-ID string which may contain non-ASCII characters; use
mml-to-mime to compose a MIME article; use search-forward instead
of re-search-forward.
(nnrss-request-expire-articles): Decode group name.
(nnrss-request-delete-group): Delete entries in nnrss-group-alist
as well; decode group name.
(nnrss-get-encoding): Fix regexp.
(nnrss-fetch): Clarify error message.
(nnrss-read-server-data): Use insert-file-contents instead of load;
bind file-name-coding-system; use multibyte buffer.
(nnrss-save-server-data): Insert newline; bind
coding-system-for-write to the value of nnrss-file-coding-system;
bind file-name-coding-system; add coding cookie.
(nnrss-read-group-data): Use insert-file-contents instead of load;
bind file-name-coding-system; use multibyte buffer.
(nnrss-save-group-data): Bind coding-system-for-write to the
value of nnrss-file-coding-system; bind file-name-coding-system.
(nnrss-decode-entities-string): Rename from n-d-e-unibyte-string;
make it work with non-ASCII text.
(nnrss-opml-export): Use mm-set-buffer-file-coding-system instead
of set-buffer-file-coding-system.
(nnrss-find-el): Check carefully whether there's a list of string
which old xml.el may return rather than a string; make it work
with old xml.el as well.
2005-04-06 Tsuyoshi AKIHO <akiho@kawachi.zaq.ne.jp>
* lisp/gnus/gnus-sum.el (gnus-summary-walk-group-buffer): Decode group name.
* lisp/gnus/nnrss.el (nnrss-get-encoding): New function.
(nnrss-fetch): Use unibyte buffer initially; bind
coding-system-for-read while performing mm-url-insert; remove ^Ms;
decode contents according to the encoding attribute.
(nnrss-save-group-data): Add coding cookie.
(nnrss-mime-encode-string): New function.
(nnrss-check-group): Use it to encode subject and author.
2005-04-06 Maciek Pasternacki <maciekp@japhy.fnord.org> (tiny change)
* lisp/gnus/nnrss.el (nnrss-fetch): Signal an error if w3-parse-buffer also
failed.
2005-04-06 Jesper Harder <harder@ifa.au.dk>
* lisp/gnus/mm-util.el (mm-subst-char-in-string): Support inplace.
* lisp/gnus/nnrss.el: Pedantic docstring and whitespace fixes (courtesy of
checkdoc.el).
(nnrss-request-article): Cleanup.
(nnrss-request-delete-group): Use nnrss-make-filename.
(nnrss-read-server-data): Use nnrss-make-filename; use load.
(nnrss-save-server-data): Use nnrss-make-filename; use gnus-prin1.
(nnrss-read-group-data): Fix off-by-one error. From Joakim Verona
<joakim@verona.se>; hash on description if link is missing; use
nnrss-make-filename; use load.
(nnrss-save-group-data): Use nnrss-make-filename; use gnus-prin1.
(nnrss-make-filename): New function.
(nnrss-close): New function.
(nnrss-check-group): Hash on description if link is missing.
(nnrss-get-namespace-prefix): Use string= to compare strings!
Reported by David D. Smith <davidsmith@acm.org>.
(nnrss-opml-export): Turn on sgml-mode.
2005-04-06 Mark A. Hershberger <mah@everybody.org>
* lisp/gnus/nnrss.el (nnrss-opml-import, nnrss-opml-export): New functions.
2005-04-06 Katsumi Yamaoka <yamaoka@jpl.org>
* man/gnus.texi (RSS): Addition.
author | Miles Bader <miles@gnu.org> |
---|---|
date | Sun, 10 Apr 2005 04:20:14 +0000 |
parents | 6c3c9561257e |
children | 23a17af379b1 13796b0653c7 |
line wrap: on
line source
;;; make-mms-derivative.el --- framework to do horrible things for VMS support ;; Copyright (C) 2005 Free Software Foundation, Inc. ;; Author: Thien-Thi Nguyen <ttn@gnu.org> ;; Keywords: maint build vms mms makefile levitte autoconf war-is-a-lose ;; This file is part of GNU Emacs. ;; GNU Emacs is free software; you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation; either version 2, or (at your option) ;; any later version. ;; GNU Emacs is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with GNU Emacs; see the file COPYING. If not, write to the ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, ;; Boston, MA 02111-1307, USA. ;;; Commentary: ;; Under VMS the standard make-like program is called MMS, which looks ;; for an input file in the default directory named DESCRIP.MMS and runs ;; the DCL command rules therein. As of 2005, the build process ;; requires a hand translation of the Makefile.in and Emacs-specific ;; methodology to DCL and TPU commands, so to alleviate this pain, we ;; provide `make-mms-derivative', which given a source FILENAME, inserts ;; the file contents in a new buffer and loads FILENAME-2mms. The lisp ;; code in the -2mms file can (do whatever -- it's emacs -- and), as ;; long as it arranges to write out the modified buffer after loading by ;; specifying, on a line of its own, the directive: ;; ;; :output RELATIVE-OUTPUT ;; ;; where RELATIVE-OUTPUT is a filename (a string) relative to FILENAME's ;; directory, typically something simple like "descrip.mms_in_in". Only ;; the first :output directive is recognized. ;; ;; The only other special directive at this time has the form: ;; ;; :gigo NAME ;; ;;blah blah blah ;; ;;(more text here) ;; ;; NAME is anything distinguishable w/ `eq' (number, symbol or keyword). ;; This associates NAME with the block of text starting immediately below ;; the :gigo directive and ending at the first line that does not begin ;; with two semicolons (which are stripped from each line in the block). ;; To insert this block of text, pass NAME to `make-mms-derivative-gigo'. ;; ;; Directives are scanned before normal evaluation, so their placement ;; in the file is not important. During loading, plain strings are ;; displayed in the echo area, prefixed with the current line number. ;; ;; Over the long run, the convenience functions provided (see source) ;; will be augmented by factoring maximally the -2mms files, squeezing ;; as much algorithm out of those nasty heuristics as possible. What ;; makes them nasty is not that they rely on the conventions of the ;; Emacs makefiles; that's no big deal. What makes them nasty is that ;; they rely on the conventions of separately maintained tools (namely ;; Autoconf for VMS and GNU Autoconf), and the separation of conventions ;; is how people drift apart, dragging their software behind ;; mercilessly. ;; ;; In general, codified thought w/o self-synchronization is doomed. ;; That a generation would eat its young (most discriminatingly, even) ;; is no reason GNU cannot build around such woe. ;;; Code: (defvar make-mms-derivative-data nil "Plist of data specific to `make-mms-derivative'.") (defun make-mms-derivative-data (key &optional newval) (if newval (setq make-mms-derivative-data (plist-put make-mms-derivative-data key newval)) (plist-get make-mms-derivative-data key))) (defun make-mms-derivative-gigo (name) "Insert the text associated with :gigo NAME." (insert (cdr (assq name (make-mms-derivative-data :gigo))))) (defun make-mms-derivative (filename) "Take FILENAME contents, load FILENAME-2mms, and write out the result. The output file is specified by the :output directive in FILENAME-2mms. See commentary of make-mms-derivative.el for full documentation." (interactive "fSource File: ") (let* ((todo (let ((fn (concat filename "-2mms"))) (unless (file-exists-p fn) (error "Could not find %s" fn)) (set-buffer (get-buffer-create " *make-mms-derivative todo*")) (insert-file-contents fn) (current-buffer))) (deriv (get-buffer-create (format "*mms-derivative: %s" (file-relative-name filename)))) output gigo form) (set-buffer todo) (re-search-forward "^:output") (setq output (expand-file-name (read (current-buffer)) (file-name-directory filename))) (goto-char (point-min)) (while (re-search-forward "^:gigo" (point-max) t) (let ((name (read (current-buffer))) (p (progn (forward-line 1) (point)))) (while (looking-at ";;") (delete-char 2) (forward-line 1)) (setq gigo (cons (cons name (buffer-substring p (point))) gigo)) (delete-region p (point)))) (message "Munging...") (switch-to-buffer deriv) (erase-buffer) (insert-file-contents filename) (set (make-local-variable 'make-mms-derivative-data) (list :gigo gigo)) (set-buffer todo) (goto-char (point-min)) (while (condition-case nil (setq form (read (current-buffer))) (end-of-file nil)) (if (stringp form) (message "%d: %s" (count-lines (point-min) (point)) form) (save-excursion (set-buffer deriv) (eval form)))) (set-buffer deriv) (message "Munging...done") (write-file output) (kill-buffer todo) (kill-buffer deriv))) (provide 'make-mms-derivative) ;;; arch-tag: a5b08625-3952-4053-be16-296220e27bb0 ;;; make-mms-derivative.el ends here