DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - metrics - download
Index: T m

⟦e1fc6849a⟧ TextFile

    Length: 4886 (0x1316)
    Types: TextFile
    Names: »man.el«

Derivation

└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
    └─⟦this⟧ »EUUGD11/gnu-31mar87/emacs/lisp/man.el« 

TextFile

;; Read in and display parts of Unix manual.
;; Copyright (C) 1985, 1986 Free Software Foundation, Inc.

;; This file is part of GNU Emacs.

;; GNU Emacs is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY.  No author or distributor
;; accepts responsibility to anyone for the consequences of using it
;; or for whether it serves any particular purpose or works at all,
;; unless he says so in writing.  Refer to the GNU Emacs General Public
;; License for full details.

;; Everyone is granted permission to copy, modify and redistribute
;; GNU Emacs, but only under the conditions described in the
;; GNU Emacs General Public License.   A copy of this license is
;; supposed to have been given to you along with GNU Emacs so you
;; can know your rights and responsibilities.  It should be in a
;; file named COPYING.  Among other things, the copyright notice
;; and this notice must be preserved on all copies.

(defun manual-entry (topic &optional section)
  "Display the Unix manual entry for TOPIC."
  (interactive "sManual entry (topic): ")
  (if (and (null section)
	   (string-match "\\`[ \t]*\\([^( \t]+\\)[ \t]*(\\(.+\\))[ \t]*\\'" topic))
      (setq section (substring topic (match-beginning 2)
				     (match-end 2))
	    topic (substring topic (match-beginning 1)
				   (match-end 1))))
  (with-output-to-temp-buffer "*Manual Entry*"
    (buffer-flush-undo standard-output)
    (save-excursion
      (set-buffer standard-output)
      (message "Looking for formatted entry for %s%s..."
	       topic (if section (concat "(" section ")") ""))
      (let ((dirlist manual-formatted-dirlist)
	    (case-fold-search nil)
	    name)
	(if (and section (file-exists-p
			   (setq name (concat manual-formatted-dir-prefix
					      (substring section 0 1)
					      "/"
					      topic "." section))))
	    (insert-man-file name)
	  (while dirlist
	    (let* ((dir (car dirlist))
		   (name1 (concat dir "/"
				  topic "." (or section (substring dir -1))))
		   completions)
	      (if (file-exists-p name1)
		  (insert-man-file name1)
		(condition-case ()
		    (progn
		      (setq completions (file-name-all-completions
					 (concat topic "." (or section ""))
					 dir))
		      (while completions
			(insert-man-file (concat dir "/" (car completions)))
			(setq completions (cdr completions))))
		  (file-error nil)))
	      (goto-char (point-max)))
	    (setq dirlist (cdr dirlist)))))

      (if (= (buffer-size) 0)
	  (progn
	    (message "No formatted entry, invoking man %s%s..."
		     (if section (concat section " ") "") topic)
	    (if section
		(call-process manual-program nil t nil section topic)
	        (call-process manual-program nil t nil topic))
	    (if (< (buffer-size) 80)
		(progn
		  (goto-char (point-min))
		  (end-of-line)
		  (error (buffer-substring 1 (point)))))))

      (message "Cleaning manual entry for %s..." topic)

      ;; Nuke underlining and overstriking (only by the same letter)
      (goto-char (point-min))
      (while (search-forward "\b" nil t)
	(let* ((preceding (char-after (- (point) 2)))
	       (following (following-char)))
	  (cond ((= preceding following)
		 ;; x\bx
		 (delete-char -2))
		((= preceding ?\_)
		 ;; _\b
		 (delete-char -2))
		((= following ?\_)
		 ;; \b_
		 (delete-region (1- (point)) (1+ (point)))))))

      ;; Nuke headers: "MORE(1) UNIX Programmer's Manual MORE(1)"
      (goto-char (point-min))
      (while (re-search-forward "^ *\\([A-Za-z][-_A-Za-z0-9]*([0-9A-Z]+)\\).*\\1$" nil t)
	(replace-match ""))

      ;; Nuke footers: "Printed 12/3/85	27 April 1981	1"
      ;;    Sun appear to be on drugz:
      ;;     "Sun Release 3.0▶0e◀B▶0f◀  Last change: 1 February 1985     1"
      ;;    HP are even worse!
      ;;     "     Hewlett-Packard   -1- (printed 12/31/99)"  FMHWA12ID!!
      ;;    System V (well WICATs anyway):
      ;;     "Page 1			  (printed 7/24/85)"
      ;;    Who is administering PCP to these corporate bozos?
      (goto-char (point-min))
      (while (re-search-forward
	       (if (eq system-type 'hpux)
		   "^ *Hewlett-Packard.*(printed [0-9/]*)$"
		 (if (eq system-type 'usg-unix-v)
		     "^ *Page [0-9]*.*(printed [0-9/]*)$"
		   "^\\(Printed\\|Sun Release\\) [0-9].*[0-9]$"))
	       nil t)
	(replace-match ""))

      ;; Crunch blank lines
      (goto-char (point-min))
      (while (re-search-forward "\n\n\n\n*" nil t)
	(replace-match "\n\n"))

      ;; Nuke blanks lines at start.
      (goto-char (point-min))
      (skip-chars-forward "\n")
      (delete-region (point-min) (point))

      (set-buffer-modified-p nil)

      (message ""))))

(defun insert-man-file (name)
  ;; Insert manual file (unpacked as necessary) into buffer
  (if (equal (substring name -2) ".Z")
      (call-process "zcat" nil t nil name)
    (if (equal (substring name -2) ".z")
	(call-process "pcat" nil t nil name)
      (insert-file-contents name))))