X-Git-Url: http://cgit.sxemacs.org/?p=gnus;a=blobdiff_plain;f=lisp%2Fdgnushack.el;h=b1203e38a55b67132a9943e9dbf90cdd254c6b07;hp=ee14ff28b12c2d260de2bd78fa771cb2413749e9;hb=HEAD;hpb=dd2c57ddd13e84e2909950f05092fbc76515a57c diff --git a/lisp/dgnushack.el b/lisp/dgnushack.el index ee14ff28b..b1203e38a 100644 --- a/lisp/dgnushack.el +++ b/lisp/dgnushack.el @@ -1,5 +1,5 @@ ;;; dgnushack.el --- a hack to set the load path for byte-compiling -;; Copyright (C) 1994-2011 Free Software Foundation, Inc. +;; Copyright (C) 1994-2016 Free Software Foundation, Inc. ;; Author: Lars Magne Ingebrigtsen ;; Version: 4.19 @@ -18,9 +18,7 @@ ;; 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. +;; along with GNU Emacs. If not, see . ;;; Commentary: @@ -28,6 +26,11 @@ (defvar dgnushack-default-load-path (copy-sequence load-path)) +(when (featurep 'xemacs) + (defmacro declare-function (fn file &optional arglist fileonly) + (unless (fboundp fn) (autoload fn file)) + nil)) + (defalias 'facep 'ignore) (require 'cl) @@ -47,15 +50,9 @@ (if (my-getenv "lispdir") (push (my-getenv "lispdir") load-path)) -(push (or (my-getenv "URLDIR") (expand-file-name "../../url/lisp/" loaddir)) - load-path) - -(push (or (my-getenv "W3DIR") (expand-file-name "../../w3/lisp/" loaddir)) - load-path) - ;(push "/usr/share/emacs/site-lisp" load-path) -;; If we are building w3 in a different directory than the source +;; If we are building Gnus in a different directory than the source ;; directory, we must read *.el from source directory and write *.elc ;; into the building directory. For that, we define this function ;; before loading bytecomp. Bytecomp doesn't overwrite this function. @@ -129,6 +126,8 @@ (defalias 'efs-re-read-dir 'ignore) (defalias 'ange-ftp-re-read-dir 'ignore) (defalias 'define-mail-user-agent 'ignore) +(defalias 'debbugs-gnu-summary-mode 'ignore) +(defvar debbugs-gnu-bug-number nil) (eval-and-compile (unless (featurep 'xemacs) @@ -141,12 +140,23 @@ (eval-and-compile (when (featurep 'xemacs) + (defvar window-point-insertion-type nil) (unless (fboundp 'defadvice) (autoload 'defadvice "advice" nil nil 'macro)) (unless (boundp 'help-echo-owns-message) (defvar help-echo-owns-message)) + (unless (boundp 'gnus-registry-enabled) + (defvar gnus-registry-enabled nil)) + (unless (boundp 'mail-dont-reply-to-names) + (defvar mail-dont-reply-to-names nil)) (unless (fboundp 'url-retrieve-synchronously) (defalias 'url-retrieve-synchronously 'url-retrieve)) + (unless (fboundp 'url-queue-retrieve) + (defun url-queue-retrieve (url callback &optional cbargs silent + inhibit-cookies) + (url-retrieve url callback cbargs))) + (unless (boundp 'w3-configuration-directory) + (setq w3-configuration-directory "~/.w3/")) (autoload 'Info-directory "info" nil t) (autoload 'Info-index "info" nil t) (autoload 'Info-index-next "info" nil t) @@ -169,6 +179,7 @@ (autoload 'customize-set-variable "cus-edit" nil t) (autoload 'customize-variable "cus-edit" nil t) (autoload 'debug "debug" nil t) + (autoload 'sha1 "sha1") (if (featurep 'mule) (unless (locate-library "mule-ccl") (autoload 'define-ccl-program "ccl" nil nil 'macro)) @@ -188,7 +199,6 @@ (autoload 'mail-fetch-field "mail-utils") (autoload 'make-annotation "annotations") (autoload 'make-display-table "disp-table") - (autoload 'pgg-snarf-keys-region "pgg" nil t) (autoload 'pp "pp") (autoload 'ps-despool "ps-print" nil t) (autoload 'ps-spool-buffer "ps-print" nil t) @@ -220,21 +230,21 @@ (autoload 'toggle-truncate-lines "view-less" nil t) (autoload 'trace-function-background "trace" nil t) (autoload 'unmorse-region "morse" nil t) - (autoload 'w3-do-setup "w3") - (autoload 'w3-prepare-buffer "w3-display") - (autoload 'w3-region "w3-display" nil t) (defalias 'frame-char-height 'frame-height) (defalias 'frame-char-width 'frame-width) (defalias 'frame-parameter 'frame-property) - (defalias 'make-overlay 'ignore) - (defalias 'overlay-end 'ignore) - (defalias 'overlay-get 'ignore) - (defalias 'overlay-put 'ignore) - (defalias 'overlay-start 'ignore) - (defalias 'overlays-in 'ignore) (defalias 'replace-dehighlight 'ignore) (defalias 'replace-highlight 'ignore) - (defalias 'w3-coding-system-for-mime-charset 'ignore))) + (defalias 'gnutls-available-p 'ignore) + (defvar timer-list nil) + (defvar scroll-margin 0) + (dolist (fn '(copy-overlay + delete-overlay make-overlay move-overlay next-overlay-change + overlay-buffer overlay-end overlay-get overlay-lists + overlay-properties overlay-put overlay-recenter overlay-start + overlayp overlays-at overlays-in previous-overlay-change + remove-overlays)) + (autoload fn "overlay")))) (defun dgnushack-emacs-compile-defcustom-p () "Return non-nil if Emacs byte compiles `defcustom' forms. @@ -262,9 +272,17 @@ in `defcustom' forms." (when (and (eq last (third form)) (consp last) (eq 'mapcar (car last)) - (equal (nth 1 form) ''nconc)) + (member (nth 1 form) '('nconc #'nconc))) (setq form (cons 'mapcan (cdr last))))))) +(if (featurep 'emacs) + (defun dgnushack-compile-file (file) + "Byte-compile FILE after reporting that it's being compiled." + (message "Compiling %s..." (file-name-nondirectory file)) + ;; The Emacs 25 version of it doesn't say much. + (byte-compile-file file)) + (defalias 'dgnushack-compile-file 'byte-compile-file)) + (defun dgnushack-compile-verbosely () "Call dgnushack-compile with warnings ENABLED. If you are compiling patches to gnus, you should consider modifying make.bat to call @@ -295,12 +313,6 @@ This means that every warning will be reported as an error." (setq files (delete file files))) (when (featurep 'base64) (setq files (delete "base64.el" files))) - (condition-case code - (require 'w3-parse) - (error - (message "No w3: %s %s" (cadr code) (or (locate-library "w3-parse") "")) - (dolist (file '("webmail.el" "nnwfm.el")) - (setq files (delete file files))))) (condition-case code ;; Under XEmacs 21.4 this loads easy-mmode.elc that provides ;; the Emacs functions `propertize' and `replace-regexp-in-string'. @@ -322,9 +334,37 @@ This means that every warning will be reported as an error." ;; lpath.el binds it. (not (eq (symbol-function 'libxml-parse-html-region) 'ignore))) - (dolist (file '("color.el" "shr-color.el" "shr.el")) + (dolist (file '("color.el")) (setq files (delete file files)))) - + (unless (locate-library "epg") + (setq files (delete "plstore.el" files))) + ;; Temporary code until we fix pcase and defmethod stuff. + (when (or (featurep 'xemacs) + (or (< emacs-major-version 24) + (< emacs-minor-version 3))) + (setq files (delete "gnus-icalendar.el" files)) + ;; Temporary during development. + (setq files (delete "gnus-cloud.el" files))) + ;; Prefer XEmacs mail-lib pkg if installed + (when (and (featurep 'xemacs) + (locate-library "mail-lib/_pkg")) + (dolist (file + '("rfc2104.el" "netrc.el" "pop3.el" "starttls.el" "tls.el")) + (setq files (delete file files)))) + ;; Prefer XEmacs ecrypto pkg if installed + (when (and (featurep 'xemacs) + (locate-library "ecrypto/_pkg")) + (dolist (file '("md4.el" "sha1.el" "hex-util.el")) + (setq files (delete file files)))) + ;; Prefer XEmacs net-utils pkg if installed + (when (and (featurep 'xemacs) + (locate-library "net-utils/_pkg")) + (dolist (file '("dig.el" "dns.el" "dns-mode.el")) + (setq files (delete file files)))) + ;; Prefer XEmacs text-modes pkg if installed + (when (and (featurep 'xemacs) + (locate-library "text-modes/_pkg")) + (setq files (delete "format-spec.el" files))) (dolist (file files) (setq file (expand-file-name file srcdir)) (when (and (file-exists-p @@ -340,10 +380,10 @@ This means that every warning will be reported as an error." (if error-on-warn (let ((byte-compile-error-on-warn t)) (unless (ignore-errors - (byte-compile-file file)) + (dgnushack-compile-file file)) (setq compilesuccess nil))) (ignore-errors - (byte-compile-file file))))) + (dgnushack-compile-file file))))) compilesuccess)) (defun dgnushack-recompile () @@ -539,4 +579,47 @@ or remove them using `make remove-installed-shadows'.\n\n")))))))) (error (princ "failed\n"))))) (setq path (cdr path)))))) +(unless (fboundp 'with-demoted-errors) + (defmacro with-demoted-errors (&rest body) + "Run BODY and demote any errors to simple messages. +If `debug-on-error' is non-nil, run BODY without catching its errors. +This is to be used around code which is not expected to signal an error +but which should be robust in the unexpected case that an error is signaled." + (declare (debug t) (indent 0)) + (let ((err (make-symbol "err"))) + `(condition-case ,err + (progn ,@body) + (error (message "Error: %S" ,err) nil))))) + +;; `define-obsolete-function-alias' and `define-obsolete-variable-alias' +;; take only two arguments in XEmacs: +;; (define-obsolete-function-alias OLDFUN NEWFUN) +;; (define-obsolete-variable-alias OLDVAR NEWVAR) +(condition-case nil + (define-obsolete-function-alias + 'dgnushack-obsolete-name 'dgnushack-current-name "0") + (wrong-number-of-arguments + (defadvice define-obsolete-function-alias (around ignore-rest-args + (oldfun newfun &rest args) + activate) + "Ignore arguments other than the 1st and the 2nd ones." + ad-do-it) + (put 'define-obsolete-function-alias 'byte-optimizer + (lambda (form) + (setcdr (nthcdr 2 form) nil) + form)))) +(condition-case nil + (define-obsolete-variable-alias + 'dgnushack-obsolete-name 'dgnushack-current-name "0") + (wrong-number-of-arguments + (defadvice define-obsolete-variable-alias (around ignore-rest-args + (oldvar newvar &rest args) + activate) + "Ignore arguments other than the 1st and the 2nd ones." + ad-do-it) + (put 'define-obsolete-variable-alias 'byte-optimizer + (lambda (form) + (setcdr (nthcdr 2 form) nil) + form)))) + ;;; dgnushack.el ends here