+ (unless (file-directory-p lisp-dir)
+ (make-directory lisp-dir t))
+ (unless (file-directory-p info-dir)
+ (make-directory info-dir))
+ (unless (file-directory-p pkginfo-dir)
+ (make-directory pkginfo-dir))
+
+ (setq files
+ (sort (delete "dgnuspath.el"
+ (delete "dgnuspath.elc"
+ (directory-files "." nil "\\.elc?$")))
+ 'string-lessp))
+ (mapcar
+ (lambda (file)
+ (unless (or (member file files)
+ (not (string-match "\\.elc?$" file)))
+ (setq file (expand-file-name file lisp-dir))
+ (message "Removing %s..." file)
+ (condition-case nil
+ (delete-file file)
+ (error nil))))
+ (directory-files lisp-dir nil nil nil t))
+ (mapcar
+ (lambda (file)
+ (message "Copying %s to %s..." file lisp-dir)
+ (copy-file file (expand-file-name file lisp-dir) t t))
+ files)
+
+ (mapcar
+ (lambda (file)
+ (message "Copying ../texi/%s to %s..." file info-dir)
+ (copy-file (expand-file-name file "../texi/")
+ (expand-file-name file info-dir)
+ t t))
+ (sort (directory-files "../texi/" nil dgnushack-info-file-regexp)
+ 'string-lessp))
+
+ (message "Copying ../%s to %s..." manifest pkginfo-dir)
+ (copy-file (expand-file-name manifest "../")
+ (expand-file-name manifest pkginfo-dir) t t)
+
+ (message "Done")))
+
+(defun dgnushack-texi-add-suffix-and-format ()
+ (dgnushack-texi-format t))
+
+(defun dgnushack-texi-format (&optional addsuffix)
+ (if (not noninteractive)
+ (error "batch-texinfo-format may only be used -batch."))
+ (require 'texinfmt)
+ (let ((auto-save-default nil)
+ (find-file-run-dired nil)
+ coding-system-for-write
+ output-coding-system)
+ (let ((error 0)
+ file
+ (files ()))
+ (while command-line-args-left
+ (setq file (expand-file-name (car command-line-args-left)))
+ (cond ((not (file-exists-p file))
+ (message ">> %s does not exist!" file)
+ (setq error 1
+ command-line-args-left (cdr command-line-args-left)))
+ ((file-directory-p file)
+ (setq command-line-args-left
+ (nconc (directory-files file)
+ (cdr command-line-args-left))))
+ (t
+ (setq files (cons file files)
+ command-line-args-left (cdr command-line-args-left)))))
+ (while files
+ (setq file (car files)
+ files (cdr files))
+ (condition-case err
+ (progn
+ (if buffer-file-name (kill-buffer (current-buffer)))
+ (find-file file)
+ (if (boundp 'MULE)
+ (setq output-coding-system (symbol-value
+ 'file-coding-system))
+ (setq coding-system-for-write buffer-file-coding-system))
+ (when (and addsuffix
+ (re-search-forward
+ "^@setfilename[\t ]+\\([^\t\n ]+\\)" nil t)
+ (not (string-match "\\.info$" (match-string 1))))
+ (insert ".info"))
+ (buffer-disable-undo (current-buffer))
+ ;; process @include before updating node
+ ;; This might produce some problem if we use @lowersection or
+ ;; such.
+ (let ((input-directory default-directory)
+ (texinfo-command-end))
+ (while (re-search-forward "^@include" nil t)
+ (setq texinfo-command-end (point))
+ (let ((filename (concat input-directory
+ (texinfo-parse-line-arg))))
+ (re-search-backward "^@include")
+ (delete-region (point) (save-excursion
+ (forward-line 1)
+ (point)))
+ (message "Reading included file: %s" filename)
+ (save-excursion
+ (save-restriction
+ (narrow-to-region
+ (point)
+ (+ (point)
+ (car (cdr (insert-file-contents filename)))))
+ (goto-char (point-min))
+ ;; Remove `@setfilename' line from included file,
+ ;; if any, so @setfilename command not duplicated.
+ (if (re-search-forward "^@setfilename"
+ (save-excursion
+ (forward-line 100)
+ (point))
+ t)
+ (progn
+ (beginning-of-line)
+ (delete-region (point) (save-excursion
+ (forward-line 1)
+ (point))))))))))
+ (texinfo-mode)
+ (texinfo-every-node-update)
+ (set-buffer-modified-p nil)
+ (message "texinfo formatting %s..." file)
+ (texinfo-format-buffer nil)
+ (if (buffer-modified-p)
+ (progn (message "Saving modified %s" (buffer-file-name))
+ (save-buffer))))
+ (error
+ (message ">> Error: %s" (prin1-to-string err))
+ (message ">> point at")
+ (let ((s (buffer-substring (point)
+ (min (+ (point) 100)
+ (point-max))))
+ (tem 0))
+ (while (setq tem (string-match "\n+" s tem))
+ (setq s (concat (substring s 0 (match-beginning 0))
+ "\n>> "
+ (substring s (match-end 0)))
+ tem (1+ tem)))
+ (message ">> %s" s))
+ (setq error 1))))
+ (kill-emacs error))))
+
+;; Mule-2.3@19.34 fails to make info from texi.
+(when (boundp 'MULE)
+ (put 'detailmenu 'texinfo-format 'texinfo-discard-line)
+ (put 'detailmenu 'texinfo-end 'texinfo-discard-command))
+
+;;; dgnushack.el ends here