# HG changeset patch # User Eli Zaretskii # Date 976200693 0 # Node ID fe91911bd5837af763d7f90c0b2206d8cd170c57 # Parent 39f2e2837fac4ace2c363181342ca0cfe2f6226f (dired-insert-directory): If file-system-info is fboundp, call it instead of invoking dired-free-space-program. diff -r 39f2e2837fac -r fe91911bd583 lisp/dired.el --- a/lisp/dired.el Thu Dec 07 13:53:21 2000 +0000 +++ b/lisp/dired.el Thu Dec 07 14:51:33 2000 +0000 @@ -686,24 +686,30 @@ (goto-char (point-min)) (when (re-search-forward "total [0-9]+$" nil t) (insert " free ") - (let ((beg (point))) - (condition-case nil - (if (zerop (call-process dired-free-space-program nil t nil - dired-free-space-args - (expand-file-name dir-or-list))) - (progn - (goto-char beg) - (forward-line 1) - (skip-chars-forward "^ \t") - (forward-word 2) - (skip-chars-forward " \t") - (delete-region beg (point)) - (forward-word 1) - (delete-region (point) - (progn (forward-line 1) (point)))) - ;; The dired-free-space-program failed; delete its output - (delete-region (- beg 7) (point))) - (error (delete-region (- beg 7) (point))))))))) + ;; Non-Posix systems don't always have dired-free-space-program, + ;; but might have an equivalent system call. + (if (fboundp 'file-system-info) + (insert + (format "%.0f" + (/ (nth 2 (file-system-info dir-or-list)) 1024))) + (let ((beg (point))) + (condition-case nil + (if (zerop (call-process dired-free-space-program nil t nil + dired-free-space-args + (expand-file-name dir-or-list))) + (progn + (goto-char beg) + (forward-line 1) + (skip-chars-forward "^ \t") + (forward-word 2) + (skip-chars-forward " \t") + (delete-region beg (point)) + (forward-word 1) + (delete-region (point) + (progn (forward-line 1) (point)))) + ;; The dired-free-space-program failed; delete its output + (delete-region (- beg 7) (point))) + (error (delete-region (- beg 7) (point)))))))))) ;; Quote certain characters, unless ls quoted them for us. (if (not (string-match "b" dired-actual-switches)) (save-excursion