Mercurial > emacs
view vms/make-mms-derivative.el @ 58997:f7098e12436d
*** empty log message ***
author | Kim F. Storm <storm@cua.dk> |
---|---|
date | Thu, 16 Dec 2004 15:26:39 +0000 |
parents | d6dc58f9beaa |
children | e5d5ea6a58f1 |
line wrap: on
line source
;;; make-mms-derivative.el --- framework to do horrible things for VMS support ;; Copyright (C) 2003 Free Software Foundation, Inc. ;; Author: Thien-Thi Nguyen <ttn@gnu.org> ;; Keywords: maint build vms mms makefile levitte autoconf war-is-a-lose ;; Favorite-TV-Game-Show: L'Eredità ;; 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 OpenVMS 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 2003, the build ;; process requires a hand translation of the Makefile.in and related ;; Emacs-specific methodology to DCL and TPU commands, so to alleviate ;; this pain, we provide `make-mms-derivative', which given a source ;; FILENAME (under `make-mms-derivative-root-dir'), inserts the file ;; contents in a new buffer and loads FILENAME-2mms. The elisp in the ;; -2mms file can (do whatever -- it's emacs -- and) arrange to write ;; out the modified buffer after FILENAME-2mms loading by using: ;; ;; (make-mms-derivative-data 'write-under-root RELATIVE-FILENAME) ;; ;; where RELATIVE-FILENAME is something like "src/descrip.mms_in_in". ;; Over the long run, the convenience procedures 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 1.11 under OpenVMS and the rest of GNU), 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-root-dir "AXPA:[TTN.EMACS.EMACS212_3]" "Source tree root directory.") (defvar make-mms-derivative-data nil "Alist of data specific to `make-mms-derivative'.") (defun make-mms-derivative-data (key &optional newval) (if newval (setq make-mms-derivative-data (cons (cons key newval) make-mms-derivative-data)) (cdr (assq key make-mms-derivative-data)))) (defun make-mms-derivative-write-under-root (rel-filename) (write-file (expand-file-name rel-filename make-mms-derivative-root-dir))) (defmacro make-mms-derivative-progn (msg &rest body) `(progn (message "(%s) %s" (point) ,msg) ,@body)) (put 'make-mms-derivative-progn 'lisp-indent-function 1) (defun make-mms-derivative-load-edits-file (name) (make-mms-derivative-data 'edits-filename name) (let (raw-data (cur (current-buffer)) (wbuf (get-buffer-create "*make-mms-derivative-load-edits-file work"))) (set-buffer wbuf) (insert-file-contents name) (keep-lines "^;;;[0-9]+;;") (goto-char (point-max)) (while (re-search-backward "^;;;\\([0-9]+\\);;\\(.*\\)$" (point-min) t) (let* ((i (string-to-number (match-string 1))) (line (match-string 2)) (look (assq i raw-data))) (if look (setcdr look (cons line (cdr look))) (setq raw-data (cons (list i line) raw-data))))) (kill-buffer wbuf) (set-buffer cur) (mapcar '(lambda (ent) (setcdr ent (mapconcat '(lambda (line) (concat line "\n")) (cdr ent) ""))) raw-data) (make-mms-derivative-data 'raw-data raw-data)) (load name)) (defun make-mms-derivative-insert-raw-data (n) (insert (cdr (assq n (make-mms-derivative-data 'raw-data))))) (defun make-mms-derivative (file) (interactive "fSource File: ") (let ((root (expand-file-name make-mms-derivative-root-dir)) (file (expand-file-name file))) (when (file-name-absolute-p (file-relative-name file root)) (error "Not under root (%s)" root)) (let ((edits-filename (concat file "-2mms"))) (unless (file-exists-p edits-filename) (error "Could not find %s" edits-filename)) (let ((buf (get-buffer-create (format "*mms-derivative: %s" (file-relative-name file root))))) (message "Munging ...") (switch-to-buffer buf) (erase-buffer) (make-variable-buffer-local 'make-mms-derivative-data) (insert-file file) (make-mms-derivative-load-edits-file edits-filename) (let ((out (make-mms-derivative-data 'write-under-root))) (when out (make-mms-derivative-write-under-root out)) (kill-buffer buf) (unless out (message "Munging ... done"))))))) (provide 'make-mms-derivative) ;;; arch-tag: a5b08625-3952-4053-be16-296220e27bb0 ;;; make-mms-derivative.el ends here