guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

07/20: installer: Add new utils.


From: guix-commits
Subject: 07/20: installer: Add new utils.
Date: Wed, 5 Dec 2018 01:28:54 -0500 (EST)

mothacehe pushed a commit to branch wip-newt-installer
in repository guix.

commit 87c1d1530a390a0190d33f49e2f9c67fe3dee735
Author: Mathieu Othacehe <address@hidden>
Date:   Wed Dec 5 14:24:04 2018 +0900

    installer: Add new utils.
    
    * gnu/installer/utils.scm (nearest-exact-integer): New exported procedure,
    (read-percentage): ditto,
    (run-shell-command): ditto.
---
 gnu/installer/utils.scm | 28 +++++++++++++++++++++++++++-
 1 file changed, 27 insertions(+), 1 deletion(-)

diff --git a/gnu/installer/utils.scm b/gnu/installer/utils.scm
index 5087683..e91f90a 100644
--- a/gnu/installer/utils.scm
+++ b/gnu/installer/utils.scm
@@ -17,10 +17,16 @@
 ;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.
 
 (define-module (gnu installer utils)
+  #:use-module (guix utils)
+  #:use-module (guix build utils)
   #:use-module (ice-9 rdelim)
+  #:use-module (ice-9 regex)
   #:use-module (ice-9 textual-ports)
   #:export (read-lines
-            read-all))
+            read-all
+            nearest-exact-integer
+            read-percentage
+            run-shell-command))
 
 (define* (read-lines #:optional (port (current-input-port)))
   "Read lines from PORT and return them as a list."
@@ -35,3 +41,23 @@
   "Return the content of the given FILE as a string."
   (call-with-input-file file
     get-string-all))
+
+(define (nearest-exact-integer x)
+  "Given a real number X, return the nearest exact integer, with ties going to
+the nearest exact even integer."
+  (inexact->exact (round x)))
+
+(define (read-percentage percentage)
+  "Read PERCENTAGE string and return the corresponding percentage as a
+number. If no percentage is found, return #f"
+  (let ((result (string-match "^([0-9]+)%$" percentage)))
+    (and result
+         (string->number (match:substring result 1)))))
+
+(define (run-shell-command command)
+  (call-with-temporary-output-file
+   (lambda (file port)
+     (format port "~a~%" command)
+     ;; (format port "exit~%")
+     (close port)
+     (invoke "bash" "--init-file" file))))



reply via email to

[Prev in Thread] Current Thread [Next in Thread]