X-Git-Url: https://code.delx.au/gnu-emacs/blobdiff_plain/2846c6e3607995ce250435e5998ea6a08f60dd89..f2cdb04ac04fb8f9f92bce11df6e4a020720208b:/lisp/dos-fns.el diff --git a/lisp/dos-fns.el b/lisp/dos-fns.el index cf37cc26d6..c1c2517bc2 100644 --- a/lisp/dos-fns.el +++ b/lisp/dos-fns.el @@ -1,7 +1,7 @@ ;;; dos-fns.el --- MS-Dos specific functions -;; Copyright (C) 1991, 1993, 1995, 1996, 2001, 2002, 2003, 2004, -;; 2005, 2006, 2007, 2008 Free Software Foundation, Inc. +;; Copyright (C) 1991, 1993, 1995, 1996, 2001, 2002, 2003, 2004, 2005, +;; 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. ;; Maintainer: Morten Welinder ;; Keywords: internal @@ -186,18 +186,52 @@ shell requires it (see `w32-shell-dos-semantics')." (dos-8+3-filename dir)) string)))))) +;; This is for the sake of standard file names elsewhere in Emacs that +;; are defined as constant strings or via defconst, and whose +;; conversion via `convert-standard-filename' does not give good +;; enough results. +(defun dosified-file-name (file-name) + "Return a variant of FILE-NAME that is valid on MS-DOS filesystems. + +This function is for those rare cases where `convert-standard-filename' +does not do a job that is good enough, e.g. if you need to preserve the +file-name extension. It recognizes only certain specific file names +that are used in Emacs Lisp sources; any other file name will be +returned unaltered." + (cond + ;; See files.el:dir-locals-file. + ((string= file-name ".dir-locals.el") + "_dir-locals.el") + (t + file-name))) + ;; See dos-vars.el for defcustom. (defvar msdos-shells) -;;; Override setting chosen at startup. +;; Override settings chosen at startup. (defun set-default-process-coding-system () (setq default-process-coding-system - (if default-enable-multibyte-characters + (if (default-value 'enable-multibyte-characters) '(undecided-dos . undecided-dos) '(raw-text-dos . raw-text-dos)))) (add-hook 'before-init-hook 'set-default-process-coding-system) +;; File names defined in preloaded packages can be incorrect or +;; invalid if long file names were available during dumping, but not +;; at runtime, or vice versa, and if the default file name begins with +;; a period. Their defcustom's need to be reevaluated at startup. To +;; see if the list of defcustom's below is up to date, run the command +;; "M-x apropos-value RET ~/\. RET". +(defun dos-reevaluate-defcustoms () + ;; This is not needed in Emacs 23.2 and later, as trash-directory is + ;; initialized as nil. But something like this might become + ;; necessary in the future, so I'm keeping it here as a reminder. + ;(custom-reevaluate-setting 'trash-directory) + ) + +(add-hook 'before-init-hook 'dos-reevaluate-defcustoms) + (defvar register-name-alist '((ax . 0) (bx . 1) (cx . 2) (dx . 3) (si . 4) (di . 5) (cflag . 6) (flags . 7)