# HG changeset patch # User Chong Yidong # Date 1265523790 18000 # Node ID f2353518b99497aaceedec1ae392258f24d226f1 # Parent 3554839df1fc5824ab8184e2691603c509e99029 Fix to uid/gid format in eshell's ls (Bug#5528). * eshell/esh-util.el (eshell-file-attributes): New optional arg ID-FORMAT. Pass it to `file-attributes'. * eshell/em-ls.el (eshell-do-ls): Use it (Bug#5528). diff -r 3554839df1fc -r f2353518b994 lisp/ChangeLog --- a/lisp/ChangeLog Sat Feb 06 23:14:26 2010 -0500 +++ b/lisp/ChangeLog Sun Feb 07 01:23:10 2010 -0500 @@ -1,3 +1,10 @@ +2010-02-07 Chong Yidong + + * eshell/esh-util.el (eshell-file-attributes): New optional arg + ID-FORMAT. Pass it to `file-attributes'. + + * eshell/em-ls.el (eshell-do-ls): Use it (Bug#5528). + 2010-02-07 sj (tiny change) * faces.el (set-face-attribute): Allow calling diff -r 3554839df1fc -r f2353518b994 lisp/eshell/em-ls.el --- a/lisp/eshell/em-ls.el Sat Feb 06 23:14:26 2010 -0500 +++ b/lisp/eshell/em-ls.el Sun Feb 07 01:23:10 2010 -0500 @@ -393,13 +393,13 @@ (eshell-glob-regexp ignore-pattern)))) ;; list the files! (eshell-ls-entries - (mapcar (function - (lambda (arg) - (cons (if (and (eshell-under-windows-p) - (file-name-absolute-p arg)) - (expand-file-name arg) - arg) - (eshell-file-attributes arg)))) + (mapcar (lambda (arg) + (cons (if (and (eshell-under-windows-p) + (file-name-absolute-p arg)) + (expand-file-name arg) + arg) + (eshell-file-attributes + arg (if numeric-uid-gid 'integer 'string)))) args) t (expand-file-name default-directory))) (funcall flush-func))) @@ -710,7 +710,7 @@ (funcall insert-func need-return "\n")))))) (defun eshell-ls-entries (entries &optional separate root-dir) - "Output PATH's directory ENTRIES, formatted according to OPTIONS. + "Output PATH's directory ENTRIES. Each member of ENTRIES may either be a string or a cons cell, the car of which is the file name, and the cdr of which is the list of attributes. diff -r 3554839df1fc -r f2353518b994 lisp/eshell/esh-util.el --- a/lisp/eshell/esh-util.el Sat Feb 06 23:14:26 2010 -0500 +++ b/lisp/eshell/esh-util.el Sun Feb 07 01:23:10 2010 -0500 @@ -701,8 +701,11 @@ (forward-line))) entry)) -(defun eshell-file-attributes (file) - "Return the attributes of FILE, playing tricks if it's over ange-ftp." +(defun eshell-file-attributes (file &optional id-format) + "Return the attributes of FILE, playing tricks if it's over ange-ftp. +The optional argument ID-FORMAT specifies the preferred uid and +gid format. Valid values are 'string and 'integer, defaulting to +'integer. See `file-attributes'." (let* ((file (expand-file-name file)) entry) (if (string-equal (file-remote-p file 'method) "ftp") @@ -723,7 +726,7 @@ (setq entry (cdr fentry)) (setq entry nil))))) entry) - (file-attributes file)))) + (file-attributes file id-format)))) (defalias 'eshell-copy-tree 'copy-tree)