X-Git-Url: https://git.jsancho.org/?p=guile-irrlicht.git;a=blobdiff_plain;f=irrlicht.scm;h=4682a7a4e2cfac4abaf1e405960231d4b10a2844;hp=46332419678ddef82136512c10d2aaff3a5ac0f8;hb=002163db179e6409ea5744f1b8194b9f758054d8;hpb=afe624d2b1339c6b76408ecbfd95d072d2a661ad diff --git a/irrlicht.scm b/irrlicht.scm index 4633241..4682a7a 100644 --- a/irrlicht.scm +++ b/irrlicht.scm @@ -1,5 +1,5 @@ ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine -;;; Copyright (C) 2019 Javier Sancho +;;; Copyright (C) 2020 Javier Sancho ;;; ;;; This file is part of guile-irrlicht. ;;; @@ -19,50 +19,123 @@ (define-module (irrlicht) - #:use-module (ice-9 match) - #:use-module (system foreign) - #:use-module ((irrlicht bindings) #:prefix ffi:) - #:use-module ((irrlicht bindings core) #:prefix ffi-core:) - #:use-module ((irrlicht bindings video) #:prefix ffi-video:) - #:export (create-device - get-video-driver - get-scene-manager - set-window-caption! - run? - drop!)) + #:use-module (oop goops) + #:use-module (irrlicht base) + #:use-module (irrlicht core) + #:use-module (irrlicht device) + #:use-module (irrlicht gui) + #:use-module (irrlicht io) + #:use-module (irrlicht irr) + #:use-module (irrlicht scene) + #:use-module (irrlicht video) + #:duplicates (merge-generics) + #:re-export (;; classes + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ;; methods + add-animated-mesh-scene-node! + add-animator! + add-button! + add-camera-scene-node! + add-camera-scene-node-fps! + add-cube-scene-node! + add-custom-scene-node! + add-editbox! + add-file-archive! + add-image! + add-internal-point! + add-listbox! + add-octree-scene-node! + add-scrollbar! + add-sphere-scene-node! + add-static-text! + begin-scene + create-device + create-fly-circle-animator + create-fly-straight-animator + create-rotation-animator + draw-vertex-primitive-list + drop! + end-scene + get-absolute-transformation + get-built-in-font + get-color + get-cursor-control + get-event-gui-caller + get-event-key + get-event-key-pressed + get-event-type + get-file-system + get-font + get-fps + get-gui-environment + get-mesh + get-name + get-root-scene-node + get-scene-manager + get-skin + get-texture + get-time + get-timer + get-video-driver + is-window-active? + make-box3d + make-event-receiver + make-material + make-vertex3d + reset-box3d! + run + set-animation-speed! + set-color! + set-event-receiver! + set-font! + set-frame-loop! + set-material! + set-material-flag! + set-material-texture! + set-max! + set-md2-animation! + set-override-color! + set-resizable! + set-rotation! + set-scale! + set-transform! + set-visible! + set-window-caption! + yield-device)) -(define* (create-device #:optional - (device-type 'software) - (window-size '(640 480)) - (bits 16) - (fullscreen #f) - (stencilbuffer #f) - (vsync #f)) - (let ((driver (match device-type - ('null ffi-video:EDT_NULL) - ('software ffi-video:EDT_SOFTWARE) - ('burnings ffi-video:EDT_BURNINGSVIDEO) - ('direct3d8 ffi-video:EDT_DIRECT3D8) - ('direct3d9 ffi-video:EDT_DIRECT3D9) - ('opengl ffi-video:EDT_OPENGL) - ('count ffi-video:EDT_COUNT))) - (wsize (make-c-struct ffi-core:dimension2d window-size))) - (ffi:create-device driver wsize bits - (if fullscreen 1 0) - (if stencilbuffer 1 0) - (if vsync 1 0)))) - -(define (get-video-driver device) - (ffi:get-video-driver device)) - -(define (get-scene-manager device) - (ffi:get-scene-manager device)) - -(define (set-window-caption! device text) - (ffi:set-window-caption device (string->pointer text))) - -(define (run? device) - (if (> (ffi:run device) 0) #t #f)) - -(define (drop! device) - (if (> (ffi:drop device) 0) #t #f)) +;; Merged methods have to be exported apart +(re-export draw-all + get-position + set-position!)