Enforce LANG=C for all shell-command-to-string calls
This commit is contained in:
		
							parent
							
								
									0a8a340260
								
							
						
					
					
						commit
						b2eff90711
					
				| @ -184,6 +184,11 @@ | |||||||
|   "Helper macro for applying face `PROPERTIES' to `STR'." |   "Helper macro for applying face `PROPERTIES' to `STR'." | ||||||
|   `(propertize ,str 'face (list ,@properties))) |   `(propertize ,str 'face (list ,@properties))) | ||||||
| 
 | 
 | ||||||
|  | (defun eshell-info-banner--shell-command-to-string (command) | ||||||
|  |   "Execute shell command COMMAND and return its output as a string. | ||||||
|  | Ensures the command is ran with LANG=C." | ||||||
|  |   (shell-command-to-string (format "LANG=C %s" command))) | ||||||
|  | 
 | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|                                         ;          Internal functions         ; |                                         ;          Internal functions         ; | ||||||
| @ -196,12 +201,12 @@ | |||||||
| 
 | 
 | ||||||
| If the executable `uptime' is not found, return nil." | If the executable `uptime' is not found, return nil." | ||||||
|   (when (executable-find "uptime") |   (when (executable-find "uptime") | ||||||
|     (let ((uptime-str (shell-command-to-string "uptime -p"))) |     (let ((uptime-str (eshell-info-banner--shell-command-to-string "uptime -p"))) | ||||||
|       (if (not (seq-some (lambda (keyword) |       (if (not (seq-some (lambda (keyword) | ||||||
|                            (string-match-p keyword uptime-str)) |                            (string-match-p keyword uptime-str)) | ||||||
|                          '("invalid" "illegal"))) |                          '("invalid" "illegal"))) | ||||||
|           (s-chop-prefix "up " (s-trim uptime-str)) |           (s-chop-prefix "up " (s-trim uptime-str)) | ||||||
|         (let ((uptime-str (shell-command-to-string "LANG=C uptime"))) |         (let ((uptime-str (eshell-info-banner--shell-command-to-string "uptime"))) | ||||||
|           (save-match-data |           (save-match-data | ||||||
|             (string-match "[^,]+up *\\([^,]+\\)," uptime-str) |             (string-match "[^,]+up *\\([^,]+\\)," uptime-str) | ||||||
|             (s-trim (substring-no-properties uptime-str |             (s-trim (substring-no-properties uptime-str | ||||||
| @ -290,7 +295,7 @@ chosen. Relies on the `duf' command." | |||||||
| Return detected partitions as a list of structs.  See | Return detected partitions as a list of structs.  See | ||||||
| `eshell-info-banner-partition-prefixes' to see how partitions are | `eshell-info-banner-partition-prefixes' to see how partitions are | ||||||
| chosen.  Relies on the `df' command." | chosen.  Relies on the `df' command." | ||||||
|   (let ((partitions (split-string (shell-command-to-string "LANG=C df -lH") (regexp-quote "\n") t))) |   (let ((partitions (split-string (eshell-info-banner--shell-command-to-string "df -lH") (regexp-quote "\n") t))) | ||||||
|     (-keep (lambda (partition) |     (-keep (lambda (partition) | ||||||
|              (let* ((partition  (split-string partition " " t)) |              (let* ((partition  (split-string partition " " t)) | ||||||
|                     (filesystem (nth 0 partition)) |                     (filesystem (nth 0 partition)) | ||||||
| @ -327,7 +332,7 @@ chosen." | |||||||
| Return detected partitions as a list of structs.  See | Return detected partitions as a list of structs.  See | ||||||
| `eshell-info-banner-partition-prefixes' to see how partitions are | `eshell-info-banner-partition-prefixes' to see how partitions are | ||||||
| chosen.  Relies on the `df' command." | chosen.  Relies on the `df' command." | ||||||
|   (let ((partitions (split-string (shell-command-to-string "LANG=C df -lH") (regexp-quote "\n") t))) |   (let ((partitions (split-string (eshell-info-banner--shell-command-to-string "df -lH") (regexp-quote "\n") t))) | ||||||
|     (-keep (lambda (partition) |     (-keep (lambda (partition) | ||||||
|              (let* ((partition  (split-string partition " " t)) |              (let* ((partition  (split-string partition " " t)) | ||||||
|                     (filesystem (nth 0 partition)) |                     (filesystem (nth 0 partition)) | ||||||
| @ -355,7 +360,7 @@ Return detected partitions as a list of structs." | |||||||
|   (if eshell-info-banner-use-duf |   (if eshell-info-banner-use-duf | ||||||
|       (eshell-info-banner--get-mounted-partitions/duf) |       (eshell-info-banner--get-mounted-partitions/duf) | ||||||
|     (pcase system-type |     (pcase system-type | ||||||
|        ((or 'gnu 'gnu/linux 'gnu/kfreebsd) |        ((or 'gnu 'gnu/linux 'gnu/kfreebsd 'berkeley-unix) | ||||||
|         (eshell-info-banner--get-mounted-partitions/gnu)) |         (eshell-info-banner--get-mounted-partitions/gnu)) | ||||||
|        ((or 'ms-dos 'windows-nt 'cygwin) |        ((or 'ms-dos 'windows-nt 'cygwin) | ||||||
|         (eshell-info-banner--get-mounted-partitions/windows)) |         (eshell-info-banner--get-mounted-partitions/windows)) | ||||||
| @ -405,7 +410,7 @@ For TEXT-PADDING and BAR-LENGTH, see the documentation of | |||||||
|             (list (s-chop-suffix ":" (nth 0 line))   ; name |             (list (s-chop-suffix ":" (nth 0 line))   ; name | ||||||
|                   (string-to-number (nth 1 line))    ; total |                   (string-to-number (nth 1 line))    ; total | ||||||
|                   (string-to-number (nth 2 line))))) ; used |                   (string-to-number (nth 2 line))))) ; used | ||||||
|         (split-string (shell-command-to-string "LANG=C free -b | tail -2") |         (split-string (eshell-info-banner--shell-command-to-string "free -b | tail -2") | ||||||
|                       "\n" |                       "\n" | ||||||
|                       t))) |                       t))) | ||||||
| 
 | 
 | ||||||
| @ -413,7 +418,12 @@ For TEXT-PADDING and BAR-LENGTH, see the documentation of | |||||||
|   "Get memory usage for UNIX systems. |   "Get memory usage for UNIX systems. | ||||||
| Compatible with Darwin and FreeBSD at least." | Compatible with Darwin and FreeBSD at least." | ||||||
|   (let* ((command-to-mem (lambda (command) |   (let* ((command-to-mem (lambda (command) | ||||||
|                            (string-to-number (s-trim (cadr (split-string (shell-command-to-string command) " " t))))))) |                            (string-to-number | ||||||
|  |                             (s-trim | ||||||
|  |                              (cadr | ||||||
|  |                               (split-string (eshell-info-banner--shell-command-to-string command) | ||||||
|  |                                             " " | ||||||
|  |                                             t))))))) | ||||||
|     `(("RAM" |     `(("RAM" | ||||||
|        ,(apply command-to-mem '("sysctl hw.physmem")) |        ,(apply command-to-mem '("sysctl hw.physmem")) | ||||||
|        ,(apply command-to-mem '("sysctl hw.usermem")))))) |        ,(apply command-to-mem '("sysctl hw.usermem")))))) | ||||||
| @ -422,7 +432,7 @@ Compatible with Darwin and FreeBSD at least." | |||||||
| 
 | 
 | ||||||
| (defun eshell-info-banner--get-memory/darwin () | (defun eshell-info-banner--get-memory/darwin () | ||||||
|   "Get memory usage for macOS." |   "Get memory usage for macOS." | ||||||
|   (let* ((mem (s-lines (shell-command-to-string "LANG=C vm_stat"))) |   (let* ((mem (s-lines (eshell-info-banner--shell-command-to-string "vm_stat"))) | ||||||
|          (mem (cl-remove-if-not (lambda (line) |          (mem (cl-remove-if-not (lambda (line) | ||||||
|                                   (string-match-p "^Pages \\(free\\|active\\|inactive\\|speculative\\|wired\\)" |                                   (string-match-p "^Pages \\(free\\|active\\|inactive\\|speculative\\|wired\\)" | ||||||
|                                                   line)) |                                                   line)) | ||||||
| @ -617,7 +627,7 @@ If RELEASE-FILE is nil, use '/etc/os-release'." | |||||||
| 
 | 
 | ||||||
| (defun eshell-info-banner--get-os-information-from-lsb-release () | (defun eshell-info-banner--get-os-information-from-lsb-release () | ||||||
|   "Read the operating system information from lsb_release." |   "Read the operating system information from lsb_release." | ||||||
|   (shell-command-to-string "lsb_release -d -s")) |   (eshell-info-banner--shell-command-to-string "lsb_release -d -s")) | ||||||
| 
 | 
 | ||||||
| (defun eshell-info-banner--get-os-information-from-registry () | (defun eshell-info-banner--get-os-information-from-registry () | ||||||
|   "Read the operating system information from the Windows registry." |   "Read the operating system information from the Windows registry." | ||||||
| @ -656,7 +666,7 @@ If RELEASE-FILE is nil, use '/etc/os-release'." | |||||||
|         ((file-exists-p (concat prefix "/etc/os-release")) |         ((file-exists-p (concat prefix "/etc/os-release")) | ||||||
|          (eshell-info-banner--get-os-information-from-release-file)) |          (eshell-info-banner--get-os-information-from-release-file)) | ||||||
|         ((executable-find "shepherd") |         ((executable-find "shepherd") | ||||||
|          (let ((distro (car (s-lines (shell-command-to-string "guix -V"))))) |          (let ((distro (car (s-lines (eshell-info-banner--shell-command-to-string "guix -V"))))) | ||||||
|            (save-match-data |            (save-match-data | ||||||
|              (string-match "\\([0-9\\.]+\\)" distro) |              (string-match "\\([0-9\\.]+\\)" distro) | ||||||
|              (concat "Guix System " |              (concat "Guix System " | ||||||
| @ -670,7 +680,7 @@ If RELEASE-FILE is nil, use '/etc/os-release'." | |||||||
|                      (buffer-string))))) |                      (buffer-string))))) | ||||||
|         (t "Unknown")) |         (t "Unknown")) | ||||||
|       . |       . | ||||||
|       ,(s-trim (shell-command-to-string "uname -rs"))))) |       ,(s-trim (eshell-info-banner--shell-command-to-string "uname -rs"))))) | ||||||
| 
 | 
 | ||||||
| (defmacro eshell-info-banner--get-macos-name (version) | (defmacro eshell-info-banner--get-macos-name (version) | ||||||
|   "Get the name of the current macOS or OSX system based on its VERSION." |   "Get the name of the current macOS or OSX system based on its VERSION." | ||||||
| @ -684,9 +694,9 @@ If RELEASE-FILE is nil, use '/etc/os-release'." | |||||||
| 
 | 
 | ||||||
| (defun eshell-info-banner--get-os-information/darwin () | (defun eshell-info-banner--get-os-information/darwin () | ||||||
|   "See `eshell-info-banner--get-os-information'." |   "See `eshell-info-banner--get-os-information'." | ||||||
|   `(,(eshell-info-banner--get-macos-name (s-trim (shell-command-to-string "sw_vers -productVersion"))) |   `(,(eshell-info-banner--get-macos-name (s-trim (eshell-info-banner--shell-command-to-string "sw_vers -productVersion"))) | ||||||
|     . |     . | ||||||
|     ,(s-trim (shell-command-to-string "uname -rs")))) |     ,(s-trim (eshell-info-banner--shell-command-to-string "uname -rs")))) | ||||||
| 
 | 
 | ||||||
| (defun eshell-info-banner--get-os-information () | (defun eshell-info-banner--get-os-information () | ||||||
|   "Get operating system identifying information. |   "Get operating system identifying information. | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user