File: argout_runme.scm

package info (click to toggle)
renderdoc 1.27%2Bdfsg-1
  • links: PTS, VCS
  • area: non-free
  • in suites: sid
  • size: 107,796 kB
  • sloc: cpp: 763,519; ansic: 326,847; python: 26,946; xml: 23,189; java: 11,382; cs: 7,181; makefile: 6,707; yacc: 5,682; ruby: 4,648; perl: 3,461; sh: 2,381; php: 2,119; lisp: 1,835; javascript: 1,525; tcl: 1,068; ml: 747
file content (20 lines) | stat: -rw-r--r-- 778 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
;; tests support for native guile pointers
;; https://www.gnu.org/software/guile/manual/html_node/Void-Pointers-and-Byte-Access.html
(dynamic-call "scm_init_argout_module" (dynamic-link "./libargout"))

(define initial-value 42)
(define some-s32-data (s32vector initial-value))

;; if we're running guile 1.8, then bytevector->pointer won't exist and this
;; test is useless
(if (>= (string->number (major-version)) 2)
    (begin
      (use-modules (srfi srfi-4) (system foreign))

      (if (not (= (incp (bytevector->pointer some-s32-data)) initial-value))
          (error "Didn't read s32 data" initial-value some-s32-data))

      (if (not (= (s32vector-ref some-s32-data 0) (+ initial-value 1)))
          (error "Failed to increment s32 data" some-s32-data))))

(exit 0)