67 lines
2.3 KiB
Scheme
67 lines
2.3 KiB
Scheme
;;; Gash -- Guile As SHell
|
|
;;; Copyright © 2018 R.E.W. van Beusekom <rutger.van.beusekom@gmail.com>
|
|
;;; Copyright © 2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
|
;;;
|
|
;;; This file is part of Gash.
|
|
;;;
|
|
;;; Gash is free software; you can redistribute it and/or modify it
|
|
;;; under the terms of the GNU General Public License as published by
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
;;; your option) any later version.
|
|
;;;
|
|
;;; Gash is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
;;; WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
;;; FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
;;; details.
|
|
;;;
|
|
;;; You should have received a copy of the GNU General Public License
|
|
;;; along with Gash. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
(define-module (gash environment)
|
|
#:use-module (srfi srfi-1)
|
|
#:use-module (srfi srfi-26)
|
|
|
|
#:use-module (gash io)
|
|
|
|
#:export (
|
|
%global-variables
|
|
assignment
|
|
set-shell-opt!
|
|
shell-opt?
|
|
variable
|
|
))
|
|
|
|
;; FIXME: export/env vs set
|
|
(define %global-variables
|
|
(map identity ;; FIXME: make mutable
|
|
`(,(cons "SHELLOPTS" "")
|
|
,(cons "PIPESTATUS" "([0]=\"0\"")
|
|
,(cons "?" "0")
|
|
,@(map (lambda (key-value)
|
|
(let* ((key-value (string-split key-value #\=))
|
|
(key (car key-value))
|
|
(value (cadr key-value)))
|
|
(cons key value)))
|
|
(environ)))))
|
|
|
|
(define (assignment name value)
|
|
(set! %global-variables
|
|
(assoc-set! %global-variables name value))
|
|
#t)
|
|
|
|
(define (variable name)
|
|
(let ((name (if (string-prefix? "$" name) (string-drop name 1) name)))
|
|
(or (assoc-ref %global-variables name) "")))
|
|
|
|
(define (set-shell-opt! name set?)
|
|
(let* ((shell-opts (variable "SHELLOPTS"))
|
|
(options (if (string-null? shell-opts) '()
|
|
(string-split shell-opts #\:)))
|
|
(new-options (if set? (delete-duplicates (sort (cons name options) string<))
|
|
(filter (negate (cut equal? <> name)) options)))
|
|
(new-shell-opts (string-join new-options ":")))
|
|
(assignment "SHELLOPTS" new-shell-opts)))
|
|
|
|
(define (shell-opt? name)
|
|
(member name (string-split (assoc-ref %global-variables "SHELLOPTS") #\:)))
|