changeset 15187:d46c1e8bdb0d

(convert-standard-filename): Test msdos-long-file-names. Return "." or ".." unchanged.
author Richard M. Stallman <rms@gnu.org>
date Wed, 08 May 1996 17:40:51 +0000
parents 242bddc25e5a
children aba0eb3e723d
files lisp/dos-fns.el
diffstat 1 files changed, 44 insertions(+), 45 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/dos-fns.el	Wed May 08 17:13:31 1996 +0000
+++ b/lisp/dos-fns.el	Wed May 08 17:40:51 1996 +0000
@@ -49,51 +49,50 @@
 This function's standard definition is trivial; it just returns the argument.
 However, on some systems, the function is redefined
 with a definition that really does change some file names."
-  (let* ((dir (file-name-directory filename))
-	 (string (copy-sequence (file-name-nondirectory filename)))
-	 (lastchar (aref string (1- (length string))))
-	 i firstdot)
-    ;; If the argument is empty, just return it.
-    (if (or (not (stringp filename))
-	    (string= filename "")
-	    (string= string ""))
-	filename
-      (progn
-	;; Change a leading period to a leading underscore.
-	(if (= (aref string 0) ?.)
-	    (aset string 0 ?_))
-	;; 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.
-	(if (> (or (string-match "\\." string)
-		   (length string))
-	       8)
-	    (setq string
-		  (concat (substring string 0 8)
-			  "."
-			  (substring string 8))))
-	(setq firstdot (or (string-match "\\." string) (1- (length string))))
-	;; Truncate to 3 chars after the first period.
-	(if (> (length string) (+ firstdot 4))
-	    (setq string (substring string 0 (+ firstdot 4))))
-	;; Change all periods except the first one into underscores.
-	(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.
-	(if (equal lastchar ?~)
-	    (aset string (1- (length string)) lastchar))
-	(concat dir string)))))
+  (if (or (msdos-long-file-names)
+	  (not (stringp filename))
+	  (member (file-name-nondirectory filename) '("" "." "..")))
+      filename
+    (let* ((dir (file-name-directory filename))
+	   (string (copy-sequence (file-name-nondirectory filename)))
+	   (lastchar (aref string (1- (length string))))
+	   i firstdot)
+      ;; If the argument is empty, just return it.
+      ;; Change a leading period to a leading underscore.
+      (if (= (aref string 0) ?.)
+	  (aset string 0 ?_))
+      ;; 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.
+      (if (> (or (string-match "\\." string)
+		 (length string))
+	     8)
+	  (setq string
+		(concat (substring string 0 8)
+			"."
+			(substring string 8))))
+      (setq firstdot (or (string-match "\\." string) (1- (length string))))
+      ;; Truncate to 3 chars after the first period.
+      (if (> (length string) (+ firstdot 4))
+	  (setq string (substring string 0 (+ firstdot 4))))
+      ;; Change all periods except the first one into underscores.
+      (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.
+      (if (equal lastchar ?~)
+	  (aset string (1- (length string)) lastchar))
+      (concat dir string))))
 
 (defvar file-name-buffer-file-type-alist
   '(