X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=src%2Fbox3d.cpp;h=f9a688b7c848ea9f598b38660afdddecce04f7bd;hb=d78951bd91783c61b312451198beb31f70b0f8b2;hp=ee5c65bd312dbbe5b662b1695345a64909db61ef;hpb=37217d692d4ead81cfed829395a9a7a5caf9325c;p=guile-irrlicht.git diff --git a/src/box3d.cpp b/src/box3d.cpp index ee5c65b..f9a688b 100644 --- a/src/box3d.cpp +++ b/src/box3d.cpp @@ -22,38 +22,50 @@ #include #include #include "box3d.h" +#include "gsubr.h" #include "vector3d.h" -#include "wrapped.h" -extern "C" { - void - init_box3d (void) - { - init_box3d_type (); - scm_c_define_gsubr ("box3d-reset!", 2, 0, 0, (scm_t_subr)box3d_reset); - scm_c_define_gsubr ("make-box3d", 0, 0, 0, (scm_t_subr)make_box3d); - scm_c_export ("box3d-reset!", "make-box3d", NULL); - } +using namespace irr; - DEFINE_WRAPPED_TYPE (irr::core::aabbox3df*, "box3d", - init_box3d_type, box3d_p, - wrap_box3d, unwrap_box3d); - SCM - box3d_reset (SCM box3d, - SCM init_value) - { - irr::core::aabbox3df* aabbox = unwrap_box3d (box3d); - aabbox->reset (scm_to_vector3df (init_value)); - return SCM_UNSPECIFIED; - } +SCM +core_aabbox3d_addInternalPoint (SCM box3d, + SCM point) +{ + ((core::aabbox3df*)scm_to_pointer (box3d))->addInternalPoint (scm_to_vector3df (point)); + return SCM_UNSPECIFIED; +} - SCM - make_box3d () + +SCM +core_aabbox3d_make () +{ + core::aabbox3df* aabbox = new core::aabbox3df (); + return scm_from_pointer ((void*)aabbox, NULL); +} + + +SCM +core_aabbox3d_reset (SCM box3d, + SCM init_value) +{ + ((core::aabbox3df*)scm_to_pointer (box3d))->reset (scm_to_vector3df (init_value)); + return SCM_UNSPECIFIED; +} + + +extern "C" { + + void + init_box3d (void) { - irr::core::aabbox3df* aabbox = new irr::core::aabbox3df (); - return wrap_box3d (aabbox); + DEFINE_GSUBR ("core_aabbox3d_addInternalPoint", 2, 0, 0, + core_aabbox3d_addInternalPoint); + DEFINE_GSUBR ("core_aabbox3d_make", 0, 0, 0, + core_aabbox3d_make); + DEFINE_GSUBR ("core_aabbox3d_reset", 2, 0, 0, + core_aabbox3d_reset); } }