19fe1936ddf600b23a6804c18e0b68c7f3a93230
[uffi.git] / tests / getenv.lisp
1 ;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*-
2 ;;;; *************************************************************************
3 ;;;; FILE IDENTIFICATION
4 ;;;;
5 ;;;; Name:          getenv.lisp
6 ;;;; Purpose:       UFFI Example file to get environment variable
7 ;;;; Programmer:    Kevin M. Rosenberg
8 ;;;; Date Started:  Feb 2002
9 ;;;;
10 ;;;; $Id$
11 ;;;;
12 ;;;; This file, part of UFFI, is Copyright (c) 2002-2003 by Kevin M. Rosenberg
13 ;;;;
14 ;;;; *************************************************************************
15
16 (in-package #:uffi-tests)
17
18
19 (uffi:def-function ("getenv" c-getenv) 
20     ((name :cstring))
21   :returning :cstring)
22
23 (uffi:def-function ("setenv" c-setenv) 
24     ((name :cstring)
25      (value :cstring)
26      (overwrite :int))
27   :returning :int)
28
29 (uffi:def-function ("unsetenv" c-unsetenv)
30     ((name :cstring))
31   :returning :void)
32
33 (defun my-getenv (key)
34   "Returns an environment variable, or NIL if it does not exist"
35   (check-type key string)
36   (uffi:with-cstring (key-native key)
37     (uffi:convert-from-cstring (c-getenv key-native))))
38
39 (defun my-setenv (key name &optional (overwrite t))
40   "Returns an environment variable, or NIL if it does not exist"
41   (check-type key string)
42   (check-type name string)
43   (setq overwrite (if overwrite 1 0))
44   (uffi:with-cstrings ((key-native key)
45                        (name-native name))
46     (c-setenv key-native name-native (if overwrite 1 0))))
47
48 (defun my-unsetenv (key)
49   "Returns an environment variable, or NIL if it does not exist"
50   (check-type key string)
51   (uffi:with-cstrings ((key-native key))
52     (c-unsetenv key-native)))
53
54 (deftest getenv.1 (progn
55                     (my-unsetenv "__UFFI_FOO1__")
56                     (my-getenv "__UFFI_FOO1__"))
57   nil)
58 (deftest getenv.2 (progn
59                     (my-setenv "__UFFI_FOO1__" "UFFI-TEST")
60                     (my-getenv "__UFFI_FOO1__"))
61   "UFFI-TEST")
62
63
64