File: gethostname.lisp

package info (click to toggle)
cl-uffi 2.1.2-1.1
  • links: PTS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 1,028 kB
  • sloc: lisp: 3,854; xml: 2,990; makefile: 238; ansic: 169; sh: 35
file content (50 lines) | stat: -rw-r--r-- 1,762 bytes parent folder | download | duplicates (3)
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
;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*-
;;;; *************************************************************************
;;;; FILE IDENTIFICATION
;;;;
;;;; Name:          gethostname.lisp
;;;; Purpose:       UFFI Example file to get hostname of system
;;;; Programmer:    Kevin M. Rosenberg
;;;; Date Started:  Feb 2002
;;;;
;;;; This file, part of UFFI, is Copyright (c) 2002-2010 by Kevin M. Rosenberg
;;;;
;;;; *************************************************************************

(in-package #:uffi-tests)


;;; This example is inspired by the example on the CL-Cookbook web site

(eval-when (:compile-toplevel :load-toplevel :execute)
  (uffi:def-function ("gethostname" c-gethostname)
      ((name (* :unsigned-char))
       (len :int))
    :returning :int)

  (defun gethostname ()
    "Returns the hostname"
    (let* ((name (uffi:allocate-foreign-string 256))
           (result-code (c-gethostname name 256))
           (hostname (when (zerop result-code)
                       (uffi:convert-from-foreign-string name))))
      (uffi:free-foreign-object name)
      (unless (zerop result-code)
        (error "gethostname() failed."))
      hostname))

  (defun gethostname2 ()
    "Returns the hostname"
    (uffi:with-foreign-object (name '(:array :unsigned-char 256))
      (if (zerop (c-gethostname (uffi:char-array-to-pointer name) 256))
          (uffi:convert-from-foreign-string name)
          (error "gethostname() failed.")))))

(deftest :gethostname.1 (stringp (gethostname)) t)
(deftest :gethostname.2 (stringp (gethostname2)) t)
(deftest :gethostname.3 (plusp (length (gethostname))) t)
(deftest :gethostname.4 (plusp (length (gethostname2))) t)
(deftest :gethostname.5 (string= (gethostname) (gethostname2)) t)