summaryrefslogtreecommitdiff
path: root/lisp/dos-fns.el
diff options
context:
space:
mode:
authorEli Zaretskii <eliz@gnu.org>2001-09-16 17:59:35 +0000
committerEli Zaretskii <eliz@gnu.org>2001-09-16 17:59:35 +0000
commita007e4e39dbb01153acbaa837b050afab420f2f8 (patch)
treed99b473acd21718b46786e532219a798ee82cd0d /lisp/dos-fns.el
parenta6ce7e4cbba3a13b9ea54d163a2a6ff85937f7b8 (diff)
downloademacs-a007e4e39dbb01153acbaa837b050afab420f2f8.tar.gz
(convert-standard-filename): Replace invalid
characters only after converting dash/underscore to a period.
Diffstat (limited to 'lisp/dos-fns.el')
-rw-r--r--lisp/dos-fns.el28
1 files changed, 18 insertions, 10 deletions
diff --git a/lisp/dos-fns.el b/lisp/dos-fns.el
index 3751cc76d24..4b91cdf7a1b 100644
--- a/lisp/dos-fns.el
+++ b/lisp/dos-fns.el
@@ -74,18 +74,25 @@ with a definition that really does change some file names."
;; Change a leading period to a leading underscore.
(if (= (aref string 0) ?.)
(aset string 0 ?_))
+ ;; If the name is longer than 8 chars, and doesn't have a
+ ;; period, and we have a dash or underscore that isn't too
+ ;; close to the beginning, change that to a period. This
+ ;; is so we could salvage more characters of the original
+ ;; name by pushing them into the extension.
+ (if (and (not (string-match "\\." string))
+ (> (length string) 8)
+ ;; We don't gain anything if we put the period closer
+ ;; than 5 chars from the beginning (5 + 3 = 8).
+ (setq i (string-match "[-_]" string 5)))
+ (aset string i ?\.))
;; Get rid of invalid characters.
(while (setq i (string-match
"[^-a-zA-Z0-9_.%~^$!#&{}@`'()\200-\376]"
string))
(aset string i ?_))
- ;; If we don't have a period,
- ;; and we have a dash or underscore that isn't the first char,
- ;; change that to a period.
- (if (and (not (string-match "\\." string))
- (setq i (string-match "[-_]" string 1)))
- (aset string i ?\.))
;; If we don't have a period in the first 8 chars, insert one.
+ ;; This enables to have 3 more characters from the original
+ ;; name in the extension.
(if (> (or (string-match "\\." string) (length string))
8)
(setq string
@@ -98,13 +105,14 @@ with a definition that really does change some file names."
(if (> (length string) (+ firstdot 4))
(setq string (substring string 0 (+ firstdot 4))))
;; Change all periods except the first one into underscores.
+ ;; (DOS doesn't allow more than one period.)
(while (string-match "\\." string (1+ firstdot))
(setq i (string-match "\\." string (1+ firstdot)))
(aset string i ?_))
- ;; If the last character of the original filename was `~',
- ;; make sure the munged name ends with it also. This is so
- ;; a backup file retains its final `~'.
- (if (equal lastchar ?~)
+ ;; If the last character of the original filename was `~' or `#',
+ ;; make sure the munged name ends with it also. This is so that
+ ;; backup and auto-save files retain their telltale form.
+ (if (memq lastchar '(?~ ?#))
(aset string (1- (length string)) lastchar))))
(concat (if (and (stringp dir)
(memq (aref dir dlen-m-1) '(?/ ?\\)))