X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=irrlicht.scm;h=1aea1521298d53b06bb912c29d7c5358b1a52de6;hb=6dd88690b25a4df65ee7568377e25a0e1bf3af2f;hp=d6d64ad7c9e8121f757978efbc481a0d113efb29;hpb=5a8e38d5ce29b53c5521e5ca71698d6c232ba897;p=guile-irrlicht.git diff --git a/irrlicht.scm b/irrlicht.scm index d6d64ad..1aea152 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,18 +19,115 @@ (define-module (irrlicht) - #:use-module (ice-9 match) - #:use-module ((irrlicht bindings) #:prefix ffi:) - #:use-module ((irrlicht bindings video) #:prefix ffi-video:) - #:export (create-device)) + #: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-file-archive! + add-image! + add-internal-point! + 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-cursor-control + 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-font! + set-frame-loop! + set-material! + set-material-flag! + set-material-texture! + set-max! + set-md2-animation! + set-override-color! + set-position! + set-resizable! + set-rotation! + set-scale! + set-transform! + set-visible! + set-window-caption! + yield-device)) -(define* (create-device #:optional (device-type 'software)) - (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)))) - (ffi:create-device driver))) +;; Merged methods have to be exported apart +(re-export draw-all + get-position)