os: search in temporary buffer instead of string

Instead of filtering all lines for `PRETTY_LINE` and then replace the
line with only the quoted contents, `re-serach-forward` (or -backward)
provide a `match-*` interface. That way we can work solely inside the
buffer and return only the matching string part.
This commit is contained in:
Benjamin Kästner 2021-05-01 12:47:29 +02:00
parent f4734014ac
commit 9ccd234a3d

View File

@ -298,14 +298,11 @@ the warning face with a battery level of 25% or less."
If RELEASE-FILE is nil, use '/etc/os-release'."
(setq release-file (or release-file "/etc/os-release"))
(replace-regexp-in-string
".*\"\\(.+\\)\""
"\\1"
(car (-filter (lambda (line)
(s-contains? "PRETTY_NAME" line))
(s-lines (with-temp-buffer
(insert-file-contents release-file)
(buffer-string)))))))
(with-temp-buffer
(insert-file-contents release-file)
(goto-char (point-min))
(re-search-forward "PRETTY_NAME=\"\\(.*\\)\"")
(match-string 1)))
(defun eshell-info-banner--get-os-information-from-hostnamectl ()
"Read the operating system via hostnamectl."