Mercurial > emacs
view vms/make-mms-derivative.el @ 85972:51aa47312c4b
* ediff-init.el (ediff-xemacs-p, ediff-emacs-p): Remove.
(ediff-has-face-support-p, ediff-BAD-INFO, ediff-check-version)
(ediff-current-diff-A, ediff-current-diff-B)
(ediff-current-diff-C, ediff-fine-diff-C, ediff-fine-diff-A)
(ediff-fine-diff-B, ediff-fine-diff-Ancestor, ediff-even-diff-A)
(ediff-even-diff-B, ediff-even-diff-C, ediff-even-diff-Ancestor)
(ediff-odd-diff-A, ediff-odd-diff-B, ediff-odd-diff-C)
(ediff-odd-diff-Ancestor, ediff-reset-mouse):
* ediff-wind.el (ediff-narrow-control-frame-leftward-shift)
(ediff-setup-windows-plain-merge)
(ediff-setup-windows-plain-compare, ediff-setup-control-frame)
(ediff-refresh-control-frame, ediff-get-visible-buffer-window):
* ediff-util.el (ediff-setup-keymap, )
(ediff-toggle-wide-display, ediff-toggle-multiframe)
(ediff-toggle-use-toolbar, ediff-really-quit)
(ediff-good-frame-under-mouse)
(ediff-highlight-diff-in-one-buffer)
(ediff-remove-flags-from-buffer, ediff-place-flags-in-buffer1)
(ediff-make-bullet-proof-overlay):
* ediff-mult.el (ediff-setup-meta-map, ediff-emacs-p)
(ediff-set-meta-overlay):
* ediff-help.el (ediff-help-region-map, ediff-set-help-overlays):
* ediff.el (ediff-documentation): Replace ediff-xemacs-p and
ediff-emacs-p with their former definitions.
* emulation/viper-init.el (viper-xemacs-p, viper-emacs-p): Remove.
(viper-has-face-support-p, viper-inactivate-input-method)
(viper-activate-input-method)
(viper-use-replace-region-delimiters, viper-restore-cursor-type):
* emulation/viper-mous.el (viper-multiclick-timeout)
(viper-surrounding-word, viper-mouse-click-insert-word)
(viper-mouse-click-search-word, viper-parse-mouse-key):
* emulation/viper-macs.el (viper-char-array-to-macro):
* emulation/viper.el (viper-go-away, viper-set-hooks)
(viper-non-hook-settings):
* emulation/viper-util.el (viper-get-saved-cursor-color-in-replace-mode)
(viper-get-saved-cursor-color-in-insert-mode)
(viper-get-saved-cursor-color-in-emacs-mode)
(viper-check-version, viper-get-visible-buffer-window)
(viper-file-checked-in-p, viper-set-replace-overlay)
(viper-set-replace-overlay-glyphs, viper-set-minibuffer-overlay)
(viper-check-minibuffer-overlay, viper-read-key-sequence)
(viper-key-to-emacs-key): Replace viper-xemacs-p and viper-emacs-p
with their former definitions.
(viper-eventify-list-xemacs): Only do work for XEmacs.
(viper-set-unread-command-events): Only do work for Emacs.
(viper-overlay-p, viper-make-overlay, viper-overlay-live-p)
(viper-move-overlay, viper-overlay-start, viper-overlay-end)
(viper-overlay-get, viper-overlay-put, viper-read-event)
(viper-characterp, viper-int-to-char, viper-get-face)
(viper-color-defined-p, viper-iconify): New defaliases replacing
the old fsets.
* progmodes/fortran.el (comment-region-function)
(uncomment-region-function): Pacify byte compiler.
* vc.el (vc-diff-internal): Remove code for an old version of
gnus.
author | Dan Nicolaescu <dann@ics.uci.edu> |
---|---|
date | Fri, 09 Nov 2007 05:20:57 +0000 |
parents | 063b5c926e98 |
children | a670de1f8013 f55f9811f5d7 |
line wrap: on
line source
;;; make-mms-derivative.el --- framework to do horrible things for VMS support ;; Copyright (C) 2003, 2004, 2005, 2006, 2007 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 3, 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., 51 Franklin Street, Fifth Floor, ;; Boston, MA 02110-1301, 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