File: getenv.lisp

package info (click to toggle)
cl-uffi 1.6.1-1
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 752 kB
  • ctags: 389
  • sloc: lisp: 3,515; xml: 2,978; makefile: 251; ansic: 169; sh: 82
file content (64 lines) | stat: -rw-r--r-- 1,876 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*-
;;;; *************************************************************************
;;;; FILE IDENTIFICATION
;;;;
;;;; Name:          getenv.lisp
;;;; Purpose:       UFFI Example file to get environment variable
;;;; Programmer:    Kevin M. Rosenberg
;;;; Date Started:  Feb 2002
;;;;
;;;; $Id$
;;;;
;;;; This file, part of UFFI, is Copyright (c) 2002-2005 by Kevin M. Rosenberg
;;;;
;;;; *************************************************************************

(in-package #:uffi-tests)


(uffi:def-function ("getenv" c-getenv)
    ((name :cstring))
  :returning :cstring)

(uffi:def-function ("setenv" c-setenv)
    ((name :cstring)
     (value :cstring)
     (overwrite :int))
  :returning :int)

(uffi:def-function ("unsetenv" c-unsetenv)
    ((name :cstring))
  :returning :void)

(defun my-getenv (key)
  "Returns an environment variable, or NIL if it does not exist"
  (check-type key string)
  (uffi:with-cstring (key-native key)
    (uffi:convert-from-cstring (c-getenv key-native))))

(defun my-setenv (key name &optional (overwrite t))
  "Returns an environment variable, or NIL if it does not exist"
  (check-type key string)
  (check-type name string)
  (setq overwrite (if overwrite 1 0))
  (uffi:with-cstrings ((key-native key)
                       (name-native name))
    (c-setenv key-native name-native (if overwrite 1 0))))

(defun my-unsetenv (key)
  "Returns an environment variable, or NIL if it does not exist"
  (check-type key string)
  (uffi:with-cstrings ((key-native key))
    (c-unsetenv key-native)))

(deftest :getenv.1 (progn
                    (my-unsetenv "__UFFI_FOO1__")
                    (my-getenv "__UFFI_FOO1__"))
  nil)
(deftest :getenv.2 (progn
                    (my-setenv "__UFFI_FOO1__" "UFFI-TEST")
                    (my-getenv "__UFFI_FOO1__"))
  "UFFI-TEST")