Menu

[424828]: / inc / ode / ode.bi  Maximize  Restore  History

Download this file

1570 lines (1458 with data), 91.0 kB

'' FreeBASIC binding for ode-0.13.1
''
'' based on the C header files:
''   **********************************************************************
''                                                                          *
''    Open Dynamics Engine, Copyright (C) 2001,2002 Russell L. Smith.       *
''    All rights reserved.  Email: russ@q12.org   Web: www.q12.org          *
''                                                                          *
''    This library is free software; you can redistribute it and/or         *
''    modify it under the terms of EITHER:                                  *
''      (1) The GNU Lesser General Public License as published by the Free  *
''          Software Foundation; either version 2.1 of the License, or (at  *
''          your option) any later version. The text of the GNU Lesser      *
''          General Public License is included with this library in the     *
''          file LICENSE.TXT.                                               *
''      (2) The BSD-style license that is included with this library in     *
''          the file LICENSE-BSD.TXT.                                       *
''                                                                          *
''    This library is distributed in the hope that it will be useful,       *
''    but WITHOUT ANY WARRANTY; without even the implied warranty of        *
''    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the files    *
''    LICENSE.TXT and LICENSE-BSD.TXT for more details.                     *
''                                                                          *
''   ***********************************************************************
''
'' translated to FreeBASIC by:
''   Copyright © 2015 FreeBASIC development team

#pragma once

#if defined(__FB_DOS__) or defined(__FB_UNIX__)
	#inclib "ode"
#elseif defined(__FB_WIN32__) and defined(dDOUBLE)
	#inclib "ode_double"
#else
	#inclib "ode_single"
#endif

#include once "crt/long.bi"
#include once "crt/stddef.bi"
#include once "crt/limits.bi"
#include once "crt/stdio.bi"
#include once "crt/stdlib.bi"
#include once "crt/stdarg.bi"
#include once "crt/math.bi"
#include once "crt/string.bi"
#include once "crt/time.bi"

'' The following symbols have been renamed:
''     procedure dDot => dDot_

extern "C"

#define _ODE_ODE_H_
#define _ODE_ODECONFIG_H_

#if defined(__FB_64BIT__) and (((not defined(__FB_ARM__)) and (defined(__FB_LINUX__) or defined(__FB_FREEBSD__) or defined(__FB_OPENBSD__) or defined(__FB_NETBSD__))) or defined(__FB_DARWIN__) or defined(__FB_CYGWIN__) or defined(__FB_WIN32__))
	const X86_64_SYSTEM = 1
#endif

type dint64 as longint
type duint64 as ulongint
type dint32 as long
type duint32 as ulong
type dint16 as short
type duint16 as ushort
type dint8 as byte
type duint8 as ubyte

#ifdef dDOUBLE
	const dInfinity = 1.0 / 0.0
	const dNaN = dInfinity - dInfinity
#else
	const dInfinity = csng(1.0 / 0.0)
	const dNaN = csng(dInfinity - dInfinity)
#endif

#define _ode_copysignf(x, y) copysignf(x, y)
#define _ode_copysign(x, y) copysign(x, y)
#define _ode_nextafterf(x, y) nextafterf(x, y)
#define _ode_nextafter(x, y) nextafter(x, y)
#define _ODE_COMPATIBILITY_H_
#define dQtoR(q, R) dRfromQ((R), (q))
#define dRtoQ(R, q) dQfromR((q), (R))
#define dWtoDQ(w, q, dq) dDQfromW((dq), (w), (q))
#define _ODE_COMMON_H_
#define _ODE_ERROR_H_

declare sub dSetErrorHandler(byval fn as sub(byval errnum as long, byval msg as const zstring ptr, byval ap as va_list))
declare sub dSetDebugHandler(byval fn as sub(byval errnum as long, byval msg as const zstring ptr, byval ap as va_list))
declare sub dSetMessageHandler(byval fn as sub(byval errnum as long, byval msg as const zstring ptr, byval ap as va_list))
declare function dGetErrorHandler() as sub(byval errnum as long, byval msg as const zstring ptr, byval ap as va_list)
declare function dGetDebugHandler() as sub(byval errnum as long, byval msg as const zstring ptr, byval ap as va_list)
declare function dGetMessageHandler() as sub(byval errnum as long, byval msg as const zstring ptr, byval ap as va_list)
declare sub dError(byval num as long, byval msg as const zstring ptr, ...)
declare sub dDebug(byval num as long, byval msg as const zstring ptr, ...)
declare sub dMessage(byval num as long, byval msg as const zstring ptr, ...)

#ifndef M_PI
	#define M_PI REAL(3.1415926535897932384626433832795029)
#endif
#ifndef M_PI_2
	#define M_PI_2 REAL(1.5707963267948966192313216916398)
#endif
#ifndef M_SQRT1_2
	#define M_SQRT1_2 REAL(0.7071067811865475244008443621048490)
#endif

#ifdef dDOUBLE
	type dReal as double
#else
	type dReal as single
#endif

type dTriIndex as duint32
#define dPAD(a) iif((a) > 1, (((a) - 1) or 3) + 1, (a))

#ifdef dDOUBLE
	#define REAL(x) (x)
	#define dRecip(x) (1.0 / (x))
	#define dSqrt(x) sqrt(x)
	#define dRecipSqrt(x) (1.0 / sqrt(x))
	#define dSin(x) sin(x)
	#define dCos(x) cos(x)
	#define dFabs(x) fabs(x)
	#define dAtan2(y, x) atan2((y), (x))
	#define dAcos(x) acos(x)
	#define dFMod(a, b) fmod((a), (b))
	#define dFloor(x) floor(x)
	#define dCeil(x) ceil(x)
	#define dCopySign(a, b) _ode_copysign(a, b)
	#define dNextAfter(x, y) _ode_nextafter(x, y)
#else
	#define REAL(x) x##f
	#define dRecip(x) (1.0f / (x))
	#define dSqrt(x) sqrtf(x)
	#define dRecipSqrt(x) (1.0f / sqrtf(x))
	#define dSin(x) sinf(x)
	#define dCos(x) cosf(x)
	#define dFabs(x) fabsf(x)
	#define dAtan2(y, x) atan2f(y, x)
	#define dAcos(x) acosf(x)
	#define dFMod(a, b) fmodf(a, b)
	#define dFloor(x) floorf(x)
	#define dCeil(x) ceilf(x)
	#define dCopySign(a, b) _ode_copysignf(a, b)
	#define dNextAfter(x, y) _ode_nextafterf(x, y)
#endif

#define dIsNan(x) _isnan(x)
type dWorldID as dxWorld ptr
type dSpaceID as dxSpace ptr
type dBodyID as dxBody ptr
type dGeomID as dxGeom ptr
type dJointID as dxJoint ptr
type dJointGroupID as dxJointGroup ptr
type dWorldStepThreadingManagerID as dxWorldProcessThreadingManager ptr

enum
	d_ERR_UNKNOWN = 0
	d_ERR_IASSERT
	d_ERR_UASSERT
	d_ERR_LCP
end enum

type dJointType as long
enum
	dJointTypeNone = 0
	dJointTypeBall
	dJointTypeHinge
	dJointTypeSlider
	dJointTypeContact
	dJointTypeUniversal
	dJointTypeHinge2
	dJointTypeFixed
	dJointTypeNull
	dJointTypeAMotor
	dJointTypeLMotor
	dJointTypePlane2D
	dJointTypePR
	dJointTypePU
	dJointTypePiston
	dJointTypeDBall
	dJointTypeDHinge
	dJointTypeTransmission
end enum

enum
	dParamLoStop = 0
	dParamHiStop
	dParamVel
	dParamLoVel
	dParamHiVel
	dParamFMax
	dParamFudgeFactor
	dParamBounce
	dParamCFM
	dParamStopERP
	dParamStopCFM
	dParamSuspensionERP
	dParamSuspensionCFM
	dParamERP
	dParamsInGroup
	dParamGroup1 = &h000
	dParamLoStop1 = &h000
	dParamHiStop1
	dParamVel1
	dParamLoVel1
	dParamHiVel1
	dParamFMax1
	dParamFudgeFactor1
	dParamBounce1
	dParamCFM1
	dParamStopERP1
	dParamStopCFM1
	dParamSuspensionERP1
	dParamSuspensionCFM1
	dParamERP1
	dParamGroup2 = &h100
	dParamLoStop2 = &h100
	dParamHiStop2
	dParamVel2
	dParamLoVel2
	dParamHiVel2
	dParamFMax2
	dParamFudgeFactor2
	dParamBounce2
	dParamCFM2
	dParamStopERP2
	dParamStopCFM2
	dParamSuspensionERP2
	dParamSuspensionCFM2
	dParamERP2
	dParamGroup3 = &h200
	dParamLoStop3 = &h200
	dParamHiStop3
	dParamVel3
	dParamLoVel3
	dParamHiVel3
	dParamFMax3
	dParamFudgeFactor3
	dParamBounce3
	dParamCFM3
	dParamStopERP3
	dParamStopCFM3
	dParamSuspensionERP3
	dParamSuspensionCFM3
	dParamERP3
	dParamGroup = &h100
end enum

enum
	dAMotorUser = 0
	dAMotorEuler = 1
end enum

enum
	dTransmissionParallelAxes = 0
	dTransmissionIntersectingAxes = 1
	dTransmissionChainDrive = 2
end enum

type dJointFeedback
	f1(0 to 3) as dReal
	t1(0 to 3) as dReal
	f2(0 to 3) as dReal
	t2(0 to 3) as dReal
end type

declare sub dGeomMoved(byval as dGeomID)
declare function dGeomGetBodyNext(byval as dGeomID) as dGeomID
declare function dGetConfiguration() as const zstring ptr
declare function dCheckConfiguration(byval token as const zstring ptr) as long
#define _ODE_ODEINIT_H_

type dInitODEFlags as long
enum
	dInitFlagManualThreadCleanup = &h00000001
end enum

declare sub dInitODE()
declare function dInitODE2(byval uiInitFlags as ulong) as long

type dAllocateODEDataFlags as long
enum
	dAllocateFlagBasicData = 0
	dAllocateFlagCollisionData = &h00000001
	dAllocateMaskAll = not 0
end enum

declare function dAllocateODEDataForThread(byval uiAllocateFlags as ulong) as long
declare sub dCleanupODEAllDataForThread()
declare sub dCloseODE()
#define _ODE_CONTACT_H_

enum
	dContactMu2 = &h001
	dContactAxisDep = &h001
	dContactFDir1 = &h002
	dContactBounce = &h004
	dContactSoftERP = &h008
	dContactSoftCFM = &h010
	dContactMotion1 = &h020
	dContactMotion2 = &h040
	dContactMotionN = &h080
	dContactSlip1 = &h100
	dContactSlip2 = &h200
	dContactRolling = &h400
	dContactApprox0 = &h0000
	dContactApprox1_1 = &h1000
	dContactApprox1_2 = &h2000
	dContactApprox1_N = &h4000
	dContactApprox1 = &h7000
end enum

type dSurfaceParameters
	mode as long
	mu as dReal
	mu2 as dReal
	rho as dReal
	rho2 as dReal
	rhoN as dReal
	bounce as dReal
	bounce_vel as dReal
	soft_erp as dReal
	soft_cfm as dReal
	motion1 as dReal
	motion2 as dReal
	motionN as dReal
	slip1 as dReal
	slip2 as dReal
end type

type dContactGeom
	pos(0 to 3) as dReal
	normal(0 to 3) as dReal
	depth as dReal
	g1 as dGeomID
	g2 as dGeomID
	side1 as long
	side2 as long
end type

type dContact
	surface as dSurfaceParameters
	geom as dContactGeom
	fdir1(0 to 3) as dReal
end type

#define _ODE_MEMORY_H_
declare sub dSetAllocHandler(byval fn as function(byval size as uinteger) as any ptr)
declare sub dSetReallocHandler(byval fn as function(byval ptr as any ptr, byval oldsize as uinteger, byval newsize as uinteger) as any ptr)
declare sub dSetFreeHandler(byval fn as sub(byval ptr as any ptr, byval size as uinteger))
declare function dGetAllocHandler() as function(byval size as uinteger) as any ptr
declare function dGetReallocHandler() as function(byval ptr as any ptr, byval oldsize as uinteger, byval newsize as uinteger) as any ptr
declare function dGetFreeHandler() as sub(byval ptr as any ptr, byval size as uinteger)
declare function dAlloc(byval size as uinteger) as any ptr
declare function dRealloc(byval ptr as any ptr, byval oldsize as uinteger, byval newsize as uinteger) as any ptr
declare sub dFree(byval ptr as any ptr, byval size as uinteger)

#define _ODE_ODEMATH_H_
#define dACCESS33(A, i, j) (A)[(((i) * 4) + (j))]
#define dVALIDVEC3(v) (((dIsNan(v[0]) orelse dIsNan(v[1])) orelse dIsNan(v[2])) = 0)
#define dVALIDVEC4(v) ((((dIsNan(v[0]) orelse dIsNan(v[1])) orelse dIsNan(v[2])) orelse dIsNan(v[3])) = 0)
#define dVALIDMAT3(m) ((((((((((((dIsNan(m[0]) orelse dIsNan(m[1])) orelse dIsNan(m[2])) orelse dIsNan(m[3])) orelse dIsNan(m[4])) orelse dIsNan(m[5])) orelse dIsNan(m[6])) orelse dIsNan(m[7])) orelse dIsNan(m[8])) orelse dIsNan(m[9])) orelse dIsNan(m[10])) orelse dIsNan(m[11])) = 0)
#define dVALIDMAT4(m) ((((((((((((((((dIsNan(m[0]) orelse dIsNan(m[1])) orelse dIsNan(m[2])) orelse dIsNan(m[3])) orelse dIsNan(m[4])) orelse dIsNan(m[5])) orelse dIsNan(m[6])) orelse dIsNan(m[7])) orelse dIsNan(m[8])) orelse dIsNan(m[9])) orelse dIsNan(m[10])) orelse dIsNan(m[11])) orelse dIsNan(m[12])) orelse dIsNan(m[13])) orelse dIsNan(m[14])) orelse dIsNan(m[15])) = 0)

private sub dAddVectors3(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim res_0 as const dReal = a[0] + b[0]
	dim res_1 as const dReal = a[1] + b[1]
	dim res_2 as const dReal = a[2] + b[2]
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dSubtractVectors3(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim res_0 as const dReal = a[0] - b[0]
	dim res_1 as const dReal = a[1] - b[1]
	dim res_2 as const dReal = a[2] - b[2]
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dAddScaledVectors3(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr, byval a_scale as dReal, byval b_scale as dReal)
	dim res_0 as const dReal = (a_scale * a[0]) + (b_scale * b[0])
	dim res_1 as const dReal = (a_scale * a[1]) + (b_scale * b[1])
	dim res_2 as const dReal = (a_scale * a[2]) + (b_scale * b[2])
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dScaleVector3(byval res as dReal ptr, byval nScale as dReal)
	res[0] *= nScale
	res[1] *= nScale
	res[2] *= nScale
end sub

private sub dNegateVector3(byval res as dReal ptr)
	res[0] = -res[0]
	res[1] = -res[1]
	res[2] = -res[2]
end sub

private sub dCopyVector3(byval res as dReal ptr, byval a as const dReal ptr)
	dim res_0 as const dReal = a[0]
	dim res_1 as const dReal = a[1]
	dim res_2 as const dReal = a[2]
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dCopyScaledVector3(byval res as dReal ptr, byval a as const dReal ptr, byval nScale as dReal)
	dim res_0 as const dReal = a[0] * nScale
	dim res_1 as const dReal = a[1] * nScale
	dim res_2 as const dReal = a[2] * nScale
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dCopyNegatedVector3(byval res as dReal ptr, byval a as const dReal ptr)
	dim res_0 as const dReal = -a[0]
	dim res_1 as const dReal = -a[1]
	dim res_2 as const dReal = -a[2]
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dCopyVector4(byval res as dReal ptr, byval a as const dReal ptr)
	dim res_0 as const dReal = a[0]
	dim res_1 as const dReal = a[1]
	dim res_2 as const dReal = a[2]
	dim res_3 as const dReal = a[3]
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
	res[3] = res_3
end sub

private sub dCopyMatrix4x4(byval res as dReal ptr, byval a as const dReal ptr)
	dCopyVector4(res + 0, a + 0)
	dCopyVector4(res + 4, a + 4)
	dCopyVector4(res + 8, a + 8)
end sub

private sub dCopyMatrix4x3(byval res as dReal ptr, byval a as const dReal ptr)
	dCopyVector3(res + 0, a + 0)
	dCopyVector3(res + 4, a + 4)
	dCopyVector3(res + 8, a + 8)
end sub

private sub dGetMatrixColumn3(byval res as dReal ptr, byval a as const dReal ptr, byval n as ulong)
	dim res_0 as const dReal = a[(n + 0)]
	dim res_1 as const dReal = a[(n + 4)]
	dim res_2 as const dReal = a[(n + 8)]
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

#ifdef dDOUBLE
	private function dCalcVectorLength3(byval a as const dReal ptr) as dReal
		return sqrt(((a[0] * a[0]) + (a[1] * a[1])) + (a[2] * a[2]))
	end function
#else
	private function dCalcVectorLength3(byval a as const dReal ptr) as dReal
		return sqrtf(((a[0] * a[0]) + (a[1] * a[1])) + (a[2] * a[2]))
	end function
#endif

private function dCalcVectorLengthSquare3(byval a as const dReal ptr) as dReal
	return ((a[0] * a[0]) + (a[1] * a[1])) + (a[2] * a[2])
end function

private function dCalcPointDepth3(byval test_p as const dReal ptr, byval plane_p as const dReal ptr, byval plane_n as const dReal ptr) as dReal
	return (((plane_p[0] - test_p[0]) * plane_n[0]) + ((plane_p[1] - test_p[1]) * plane_n[1])) + ((plane_p[2] - test_p[2]) * plane_n[2])
end function

private function _dCalcVectorDot3(byval a as const dReal ptr, byval b as const dReal ptr, byval step_a as ulong, byval step_b as ulong) as dReal
	return ((a[0] * b[0]) + (a[step_a] * b[step_b])) + (a[(2 * step_a)] * b[(2 * step_b)])
end function

#define dCalcVectorDot3(a, b) cast(dReal, _dCalcVectorDot3((a), (b), 1, 1))
#define dCalcVectorDot3_13(a, b) cast(dReal, _dCalcVectorDot3((a), (b), 1, 3))
#define dCalcVectorDot3_31(a, b) cast(dReal, _dCalcVectorDot3((a), (b), 3, 1))
#define dCalcVectorDot3_33(a, b) cast(dReal, _dCalcVectorDot3((a), (b), 3, 3))
#define dCalcVectorDot3_14(a, b) cast(dReal, _dCalcVectorDot3((a), (b), 1, 4))
#define dCalcVectorDot3_41(a, b) cast(dReal, _dCalcVectorDot3((a), (b), 4, 1))
#define dCalcVectorDot3_44(a, b) cast(dReal, _dCalcVectorDot3((a), (b), 4, 4))

private sub _dCalcVectorCross3(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr, byval step_res as ulong, byval step_a as ulong, byval step_b as ulong)
	dim res_0 as const dReal = (a[step_a] * b[(2 * step_b)]) - (a[(2 * step_a)] * b[step_b])
	dim res_1 as const dReal = (a[(2 * step_a)] * b[0]) - (a[0] * b[(2 * step_b)])
	dim res_2 as const dReal = (a[0] * b[step_b]) - (a[step_a] * b[0])
	res[0] = res_0
	res[step_res] = res_1
	res[(2 * step_res)] = res_2
end sub

private sub dCalcVectorCross3(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 1, 1, 1)
end sub

private sub dCalcVectorCross3_114(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 1, 1, 4)
end sub

private sub dCalcVectorCross3_141(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 1, 4, 1)
end sub

private sub dCalcVectorCross3_144(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 1, 4, 4)
end sub

private sub dCalcVectorCross3_411(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 4, 1, 1)
end sub

private sub dCalcVectorCross3_414(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 4, 1, 4)
end sub

private sub dCalcVectorCross3_441(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 4, 4, 1)
end sub

private sub dCalcVectorCross3_444(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	_dCalcVectorCross3(res, a, b, 4, 4, 4)
end sub

private sub dAddVectorCross3(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dCalcVectorCross3(@tmp(0), a, b)
	dAddVectors3(res, res, @tmp(0))
end sub

private sub dSubtractVectorCross3(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dCalcVectorCross3(@tmp(0), a, b)
	dSubtractVectors3(res, res, @tmp(0))
end sub

private sub dSetCrossMatrixPlus(byval res as dReal ptr, byval a as const dReal ptr, byval skip as ulong)
	dim a_0 as const dReal = a[0]
	dim a_1 as const dReal = a[1]
	dim a_2 as const dReal = a[2]
	res[1] = -a_2
	res[2] = +a_1
	res[(skip + 0)] = +a_2
	res[(skip + 2)] = -a_0
	res[((2 * skip) + 0)] = -a_1
	res[((2 * skip) + 1)] = +a_0
end sub

private sub dSetCrossMatrixMinus(byval res as dReal ptr, byval a as const dReal ptr, byval skip as ulong)
	dim a_0 as const dReal = a[0]
	dim a_1 as const dReal = a[1]
	dim a_2 as const dReal = a[2]
	res[1] = +a_2
	res[2] = -a_1
	res[(skip + 0)] = -a_2
	res[(skip + 2)] = +a_0
	res[((2 * skip) + 0)] = +a_1
	res[((2 * skip) + 1)] = -a_0
end sub

private function dCalcPointsDistance3(byval a as const dReal ptr, byval b as const dReal ptr) as dReal
	dim res as dReal
	dim tmp(0 to 2) as dReal
	dSubtractVectors3(@tmp(0), a, b)
	res = dCalcVectorLength3(@tmp(0))
	return res
end function

private sub dMultiplyHelper0_331(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim res_0 as const dReal = dCalcVectorDot3(a, b)
	dim res_1 as const dReal = dCalcVectorDot3(a + 4, b)
	dim res_2 as const dReal = dCalcVectorDot3(a + 8, b)
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dMultiplyHelper1_331(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim res_0 as const dReal = dCalcVectorDot3_41(a, b)
	dim res_1 as const dReal = dCalcVectorDot3_41(a + 1, b)
	dim res_2 as const dReal = dCalcVectorDot3_41(a + 2, b)
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dMultiplyHelper0_133(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dMultiplyHelper1_331(res, b, a)
end sub

private sub dMultiplyHelper1_133(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim res_0 as const dReal = dCalcVectorDot3_44(a, b)
	dim res_1 as const dReal = dCalcVectorDot3_44(a + 1, b)
	dim res_2 as const dReal = dCalcVectorDot3_44(a + 2, b)
	res[0] = res_0
	res[1] = res_1
	res[2] = res_2
end sub

private sub dMultiply0_331(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dMultiplyHelper0_331(res, a, b)
end sub

private sub dMultiply1_331(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dMultiplyHelper1_331(res, a, b)
end sub

private sub dMultiply0_133(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dMultiplyHelper0_133(res, a, b)
end sub

private sub dMultiply0_333(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dMultiplyHelper0_133(res + 0, a + 0, b)
	dMultiplyHelper0_133(res + 4, a + 4, b)
	dMultiplyHelper0_133(res + 8, a + 8, b)
end sub

private sub dMultiply1_333(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dMultiplyHelper1_133(res + 0, b, a + 0)
	dMultiplyHelper1_133(res + 4, b, a + 1)
	dMultiplyHelper1_133(res + 8, b, a + 2)
end sub

private sub dMultiply2_333(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dMultiplyHelper0_331(res + 0, b, a + 0)
	dMultiplyHelper0_331(res + 4, b, a + 4)
	dMultiplyHelper0_331(res + 8, b, a + 8)
end sub

private sub dMultiplyAdd0_331(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dMultiplyHelper0_331(@tmp(0), a, b)
	dAddVectors3(res, res, @tmp(0))
end sub

private sub dMultiplyAdd1_331(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dMultiplyHelper1_331(@tmp(0), a, b)
	dAddVectors3(res, res, @tmp(0))
end sub

private sub dMultiplyAdd0_133(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dMultiplyHelper0_133(@tmp(0), a, b)
	dAddVectors3(res, res, @tmp(0))
end sub

private sub dMultiplyAdd0_333(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dMultiplyHelper0_133(@tmp(0), a + 0, b)
	dAddVectors3(res + 0, res + 0, @tmp(0))
	dMultiplyHelper0_133(@tmp(0), a + 4, b)
	dAddVectors3(res + 4, res + 4, @tmp(0))
	dMultiplyHelper0_133(@tmp(0), a + 8, b)
	dAddVectors3(res + 8, res + 8, @tmp(0))
end sub

private sub dMultiplyAdd1_333(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dMultiplyHelper1_133(@tmp(0), b, a + 0)
	dAddVectors3(res + 0, res + 0, @tmp(0))
	dMultiplyHelper1_133(@tmp(0), b, a + 1)
	dAddVectors3(res + 4, res + 4, @tmp(0))
	dMultiplyHelper1_133(@tmp(0), b, a + 2)
	dAddVectors3(res + 8, res + 8, @tmp(0))
end sub

private sub dMultiplyAdd2_333(byval res as dReal ptr, byval a as const dReal ptr, byval b as const dReal ptr)
	dim tmp(0 to 2) as dReal
	dMultiplyHelper0_331(@tmp(0), b, a + 0)
	dAddVectors3(res + 0, res + 0, @tmp(0))
	dMultiplyHelper0_331(@tmp(0), b, a + 4)
	dAddVectors3(res + 4, res + 4, @tmp(0))
	dMultiplyHelper0_331(@tmp(0), b, a + 8)
	dAddVectors3(res + 8, res + 8, @tmp(0))
end sub

private function dCalcMatrix3Det(byval mat as const dReal ptr) as dReal
	dim det as dReal
	det = ((mat[0] * ((mat[5] * mat[10]) - (mat[9] * mat[6]))) - (mat[1] * ((mat[4] * mat[10]) - (mat[8] * mat[6])))) + (mat[2] * ((mat[4] * mat[9]) - (mat[8] * mat[5])))
	return det
end function

#ifdef dDOUBLE
	private function dInvertMatrix3(byval dst as dReal ptr, byval ma as const dReal ptr) as dReal
		dim det as dReal
		dim detRecip as dReal
		det = dCalcMatrix3Det(ma)
		if det = 0 then
			return 0
		end if
		detRecip = 1.0 / det
		dst[0] = ((ma[5] * ma[10]) - (ma[6] * ma[9])) * detRecip
		dst[1] = ((ma[9] * ma[2]) - (ma[1] * ma[10])) * detRecip
		dst[2] = ((ma[1] * ma[6]) - (ma[5] * ma[2])) * detRecip
		dst[4] = ((ma[6] * ma[8]) - (ma[4] * ma[10])) * detRecip
		dst[5] = ((ma[0] * ma[10]) - (ma[8] * ma[2])) * detRecip
		dst[6] = ((ma[4] * ma[2]) - (ma[0] * ma[6])) * detRecip
		dst[8] = ((ma[4] * ma[9]) - (ma[8] * ma[5])) * detRecip
		dst[9] = ((ma[8] * ma[1]) - (ma[0] * ma[9])) * detRecip
		dst[10] = ((ma[0] * ma[5]) - (ma[1] * ma[4])) * detRecip
		return det
	end function
#else
	private function dInvertMatrix3(byval dst as dReal ptr, byval ma as const dReal ptr) as dReal
		dim det as dReal
		dim detRecip as dReal
		det = dCalcMatrix3Det(ma)
		if det = 0 then
			return 0
		end if
		detRecip = 1.0f / det
		dst[0] = ((ma[5] * ma[10]) - (ma[6] * ma[9])) * detRecip
		dst[1] = ((ma[9] * ma[2]) - (ma[1] * ma[10])) * detRecip
		dst[2] = ((ma[1] * ma[6]) - (ma[5] * ma[2])) * detRecip
		dst[4] = ((ma[6] * ma[8]) - (ma[4] * ma[10])) * detRecip
		dst[5] = ((ma[0] * ma[10]) - (ma[8] * ma[2])) * detRecip
		dst[6] = ((ma[4] * ma[2]) - (ma[0] * ma[6])) * detRecip
		dst[8] = ((ma[4] * ma[9]) - (ma[8] * ma[5])) * detRecip
		dst[9] = ((ma[8] * ma[1]) - (ma[0] * ma[9])) * detRecip
		dst[10] = ((ma[0] * ma[5]) - (ma[1] * ma[4])) * detRecip
		return det
	end function
#endif

#define _ODE_ODEMATH_LEGACY_H_
#macro dOP(a, op, b, c)
	scope
		(a)[0] = ((b)[0]) op ((c)[0])
		(a)[1] = ((b)[1]) op ((c)[1])
		(a)[2] = ((b)[2]) op ((c)[2])
	end scope
#endmacro
#macro dOPC(a, op, b, c)
	scope
		(a)[0] = ((b)[0]) op (c)
		(a)[1] = ((b)[1]) op (c)
		(a)[2] = ((b)[2]) op (c)
	end scope
#endmacro
#macro dOPE(a, op, b)
	scope
		(a)[0] op ((b)[0])
		(a)[1] op ((b)[1])
		(a)[2] op ((b)[2])
	end scope
#endmacro
#macro dOPEC(a, op, c)
	scope
		(a)[0] op (c)
		(a)[1] op (c)
		(a)[2] op (c)
	end scope
#endmacro
#macro dOPE2(a, op1, b, op2, c)
	scope
		(a)[0] op1 ((b)[0]) op2 ((c)[0])
		(a)[1] op1 ((b)[1]) op2 ((c)[1])
		(a)[2] op1 ((b)[2]) op2 ((c)[2])
	end scope
#endmacro
#define dLENGTHSQUARED(a) dCalcVectorLengthSquare3(a)
#define dLENGTH(a) dCalcVectorLength3(a)
#define dDISTANCE(a, b) dCalcPointsDistance3(a, b)
#define dDOT(a, b) dCalcVectorDot3(a, b)
#define dDOT13(a, b) dCalcVectorDot3_13(a, b)
#define dDOT31(a, b) dCalcVectorDot3_31(a, b)
#define dDOT33(a, b) dCalcVectorDot3_33(a, b)
#define dDOT14(a, b) dCalcVectorDot3_14(a, b)
#define dDOT41(a, b) dCalcVectorDot3_41(a, b)
#define dDOT44(a, b) dCalcVectorDot3_44(a, b)
#macro dCROSS(a, op, b, c)
	scope
		(a)[0] op ((b)[1]*(c)[2] - (b)[2]*(c)[1])
		(a)[1] op ((b)[2]*(c)[0] - (b)[0]*(c)[2])
		(a)[2] op ((b)[0]*(c)[1] - (b)[1]*(c)[0])
	end scope
#endmacro
#macro dCROSSpqr(a, op, b, c, p, q, r)
	scope
		(a)[  0] op ((b)[  q]*(c)[2*r] - (b)[2*q]*(c)[  r])
		(a)[  p] op ((b)[2*q]*(c)[  0] - (b)[  0]*(c)[2*r])
		(a)[2*p] op ((b)[  0]*(c)[  r] - (b)[  q]*(c)[  0])
	end scope
#endmacro
#define dCROSS114(a, op, b, c) dCROSSpqr(a, op, b, c, 1, 1, 4)
#define dCROSS141(a, op, b, c) dCROSSpqr(a, op, b, c, 1, 4, 1)
#define dCROSS144(a, op, b, c) dCROSSpqr(a, op, b, c, 1, 4, 4)
#define dCROSS411(a, op, b, c) dCROSSpqr(a, op, b, c, 4, 1, 1)
#define dCROSS414(a, op, b, c) dCROSSpqr(a, op, b, c, 4, 1, 4)
#define dCROSS441(a, op, b, c) dCROSSpqr(a, op, b, c, 4, 4, 1)
#define dCROSS444(a, op, b, c) dCROSSpqr(a, op, b, c, 4, 4, 4)
#macro dCROSSMAT(A, a_, skip, plus, minus)
	scope
		(A)[1] = minus (a_)[2]
		(A)[2] = plus (a_)[1]
		(A)[(skip)+0] = plus (a_)[2]
		(A)[(skip)+2] = minus (a_)[0]
		(A)[2*(skip)+0] = minus (a_)[1]
		(A)[2*(skip)+1] = plus (a_)[0]
	end scope
#endmacro

declare function dSafeNormalize3(byval a as dReal ptr) as long
declare function dSafeNormalize4(byval a as dReal ptr) as long
declare sub dNormalize3(byval a as dReal ptr)
declare sub dNormalize4(byval a as dReal ptr)
declare sub dPlaneSpace(byval n as const dReal ptr, byval p as dReal ptr, byval q as dReal ptr)
declare sub dOrthogonalizeR(byval m as dReal ptr)
#define _ODE_MATRIX_H_
declare sub dSetZero(byval a as dReal ptr, byval n as long)
declare sub dSetValue(byval a as dReal ptr, byval n as long, byval value as dReal)
declare function dDot_ alias "dDot"(byval a as const dReal ptr, byval b as const dReal ptr, byval n as long) as dReal
declare sub dMultiply0(byval A as dReal ptr, byval B as const dReal ptr, byval C as const dReal ptr, byval p as long, byval q as long, byval r as long)
declare sub dMultiply1(byval A as dReal ptr, byval B as const dReal ptr, byval C as const dReal ptr, byval p as long, byval q as long, byval r as long)
declare sub dMultiply2(byval A as dReal ptr, byval B as const dReal ptr, byval C as const dReal ptr, byval p as long, byval q as long, byval r as long)
declare function dFactorCholesky(byval A as dReal ptr, byval n as long) as long
declare sub dSolveCholesky(byval L as const dReal ptr, byval b as dReal ptr, byval n as long)
declare function dInvertPDMatrix(byval A as const dReal ptr, byval Ainv as dReal ptr, byval n as long) as long
declare function dIsPositiveDefinite(byval A as const dReal ptr, byval n as long) as long
declare sub dFactorLDLT(byval A as dReal ptr, byval d as dReal ptr, byval n as long, byval nskip as long)
declare sub dSolveL1(byval L as const dReal ptr, byval b as dReal ptr, byval n as long, byval nskip as long)
declare sub dSolveL1T(byval L as const dReal ptr, byval b as dReal ptr, byval n as long, byval nskip as long)
declare sub dVectorScale(byval a as dReal ptr, byval d as const dReal ptr, byval n as long)
declare sub dSolveLDLT(byval L as const dReal ptr, byval d as const dReal ptr, byval b as dReal ptr, byval n as long, byval nskip as long)
declare sub dLDLTAddTL(byval L as dReal ptr, byval d as dReal ptr, byval a as const dReal ptr, byval n as long, byval nskip as long)
declare sub dLDLTRemove(byval A as dReal ptr ptr, byval p as const long ptr, byval L as dReal ptr, byval d as dReal ptr, byval n1 as long, byval n2 as long, byval r as long, byval nskip as long)
declare sub dRemoveRowCol(byval A as dReal ptr, byval n as long, byval nskip as long, byval r as long)
#define _ODE_TIMER_H_

type dStopwatch
	time as double
	cc(0 to 1) as culong
end type

declare sub dStopwatchReset(byval as dStopwatch ptr)
declare sub dStopwatchStart(byval as dStopwatch ptr)
declare sub dStopwatchStop(byval as dStopwatch ptr)
declare function dStopwatchTime(byval as dStopwatch ptr) as double
declare sub dTimerStart(byval description as const zstring ptr)
declare sub dTimerNow(byval description as const zstring ptr)
declare sub dTimerEnd()
declare sub dTimerReport(byval fout as FILE ptr, byval average as long)
declare function dTimerTicksPerSecond() as double
declare function dTimerResolution() as double
#define _ODE_ROTATION_H_
declare sub dRSetIdentity(byval R as dReal ptr)
declare sub dRFromAxisAndAngle(byval R as dReal ptr, byval ax as dReal, byval ay as dReal, byval az as dReal, byval angle as dReal)
declare sub dRFromEulerAngles(byval R as dReal ptr, byval phi as dReal, byval theta as dReal, byval psi as dReal)
declare sub dRFrom2Axes(byval R as dReal ptr, byval ax as dReal, byval ay as dReal, byval az as dReal, byval bx as dReal, byval by as dReal, byval bz as dReal)
declare sub dRFromZAxis(byval R as dReal ptr, byval ax as dReal, byval ay as dReal, byval az as dReal)
declare sub dQSetIdentity(byval q as dReal ptr)
declare sub dQFromAxisAndAngle(byval q as dReal ptr, byval ax as dReal, byval ay as dReal, byval az as dReal, byval angle as dReal)
declare sub dQMultiply0(byval qa as dReal ptr, byval qb as const dReal ptr, byval qc as const dReal ptr)
declare sub dQMultiply1(byval qa as dReal ptr, byval qb as const dReal ptr, byval qc as const dReal ptr)
declare sub dQMultiply2(byval qa as dReal ptr, byval qb as const dReal ptr, byval qc as const dReal ptr)
declare sub dQMultiply3(byval qa as dReal ptr, byval qb as const dReal ptr, byval qc as const dReal ptr)
declare sub dRfromQ(byval R as dReal ptr, byval q as const dReal ptr)
declare sub dQfromR(byval q as dReal ptr, byval R as const dReal ptr)
declare sub dDQfromW(byval dq as dReal ptr, byval w as const dReal ptr, byval q as const dReal ptr)
#define _ODE_MASS_H_
type dMass as dMass_
declare function dMassCheck(byval m as const dMass ptr) as long
declare sub dMassSetZero(byval as dMass ptr)
declare sub dMassSetParameters(byval as dMass ptr, byval themass as dReal, byval cgx as dReal, byval cgy as dReal, byval cgz as dReal, byval I11 as dReal, byval I22 as dReal, byval I33 as dReal, byval I12 as dReal, byval I13 as dReal, byval I23 as dReal)
declare sub dMassSetSphere(byval as dMass ptr, byval density as dReal, byval radius as dReal)
declare sub dMassSetSphereTotal(byval as dMass ptr, byval total_mass as dReal, byval radius as dReal)
declare sub dMassSetCapsule(byval as dMass ptr, byval density as dReal, byval direction as long, byval radius as dReal, byval length as dReal)
declare sub dMassSetCapsuleTotal(byval as dMass ptr, byval total_mass as dReal, byval direction as long, byval radius as dReal, byval length as dReal)
declare sub dMassSetCylinder(byval as dMass ptr, byval density as dReal, byval direction as long, byval radius as dReal, byval length as dReal)
declare sub dMassSetCylinderTotal(byval as dMass ptr, byval total_mass as dReal, byval direction as long, byval radius as dReal, byval length as dReal)
declare sub dMassSetBox(byval as dMass ptr, byval density as dReal, byval lx as dReal, byval ly as dReal, byval lz as dReal)
declare sub dMassSetBoxTotal(byval as dMass ptr, byval total_mass as dReal, byval lx as dReal, byval ly as dReal, byval lz as dReal)
declare sub dMassSetTrimesh(byval as dMass ptr, byval density as dReal, byval g as dGeomID)
declare sub dMassSetTrimeshTotal(byval m as dMass ptr, byval total_mass as dReal, byval g as dGeomID)
declare sub dMassAdjust(byval as dMass ptr, byval newmass as dReal)
declare sub dMassTranslate(byval as dMass ptr, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dMassRotate(byval as dMass ptr, byval R as const dReal ptr)
declare sub dMassAdd(byval a as dMass ptr, byval b as const dMass ptr)
declare sub dMassSetCappedCylinder(byval a as dMass ptr, byval b as dReal, byval c as long, byval d as dReal, byval e as dReal)
declare sub dMassSetCappedCylinderTotal(byval a as dMass ptr, byval b as dReal, byval c as long, byval d as dReal, byval e as dReal)

type dMass_
	mass as dReal
	c(0 to 3) as dReal
	I(0 to (4 * 3) - 1) as dReal
end type

#define _ODE_MISC_H_
declare function dTestRand() as long
declare function dRand() as culong
declare function dRandGetSeed() as culong
declare sub dRandSetSeed(byval s as culong)
declare function dRandInt(byval n as long) as long
declare function dRandReal() as dReal
declare sub dPrintMatrix(byval A as const dReal ptr, byval n as long, byval m as long, byval fmt as const zstring ptr, byval f as FILE ptr)
declare sub dMakeRandomVector(byval A as dReal ptr, byval n as long, byval range as dReal)
declare sub dMakeRandomMatrix(byval A as dReal ptr, byval n as long, byval m as long, byval range as dReal)
declare sub dClearUpperTriangle(byval A as dReal ptr, byval n as long)
declare function dMaxDifference(byval A as const dReal ptr, byval B as const dReal ptr, byval n as long, byval m as long) as dReal
declare function dMaxDifferenceLowerTriangle(byval A as const dReal ptr, byval B as const dReal ptr, byval n as long) as dReal
#define _ODE_OBJECTS_H_
#define _ODE_THREADING_H_

type dThreadingImplementationID as dxThreadingImplementation ptr
type dmutexindex_t as ulong
type dMutexGroupID as dxMutexGroup ptr
type dCallReleaseeID as dxCallReleasee ptr
type dCallWaitID as dxCallWait ptr
type ddependencycount_t as uinteger
type ddependencychange_t as integer
type dcallindex_t as uinteger

type dxThreadedWaitTime
	wait_sec as time_t
	wait_nsec as culong
end type

type dThreadedWaitTime as dxThreadedWaitTime

type dxThreadingFunctionsInfo
	struct_size as ulong
	alloc_mutex_group as function(byval impl as dThreadingImplementationID, byval Mutex_count as dmutexindex_t, byval Mutex_names_ptr as const zstring const ptr ptr) as dMutexGroupID
	free_mutex_group as sub(byval impl as dThreadingImplementationID, byval mutex_group as dMutexGroupID)
	lock_group_mutex as sub(byval impl as dThreadingImplementationID, byval mutex_group as dMutexGroupID, byval mutex_index as dmutexindex_t)
	unlock_group_mutex as sub(byval impl as dThreadingImplementationID, byval mutex_group as dMutexGroupID, byval mutex_index as dmutexindex_t)
	alloc_call_wait as function(byval impl as dThreadingImplementationID) as dCallWaitID
	reset_call_wait as sub(byval impl as dThreadingImplementationID, byval call_wait as dCallWaitID)
	free_call_wait as sub(byval impl as dThreadingImplementationID, byval call_wait as dCallWaitID)
	post_call as sub(byval impl as dThreadingImplementationID, byval out_summary_fault as long ptr, byval out_post_releasee as dCallReleaseeID ptr, byval dependencies_count as ddependencycount_t, byval dependent_releasee as dCallReleaseeID, byval call_wait as dCallWaitID, byval call_func as function(byval call_context as any ptr, byval instance_index as dcallindex_t, byval this_releasee as dCallReleaseeID) as long, byval call_context as any ptr, byval instance_index as dcallindex_t, byval call_name as const zstring ptr)
	alter_call_dependencies_count as sub(byval impl as dThreadingImplementationID, byval target_releasee as dCallReleaseeID, byval dependencies_count_change as ddependencychange_t)
	wait_call as sub(byval impl as dThreadingImplementationID, byval out_wait_status as long ptr, byval call_wait as dCallWaitID, byval timeout_time_ptr as const dThreadedWaitTime ptr, byval wait_name as const zstring ptr)
	retrieve_thread_count as function(byval impl as dThreadingImplementationID) as ulong
	preallocate_resources_for_calls as function(byval impl as dThreadingImplementationID, byval max_simultaneous_calls_estimate as ddependencycount_t) as long
end type

type dThreadingFunctionsInfo as dxThreadingFunctionsInfo
declare function dWorldCreate() as dWorldID
declare sub dWorldDestroy(byval world as dWorldID)
declare sub dWorldSetData(byval world as dWorldID, byval data as any ptr)
declare function dWorldGetData(byval world as dWorldID) as any ptr
declare sub dWorldSetGravity(byval as dWorldID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dWorldGetGravity(byval as dWorldID, byval gravity as dReal ptr)
declare sub dWorldSetERP(byval as dWorldID, byval erp as dReal)
declare function dWorldGetERP(byval as dWorldID) as dReal
declare sub dWorldSetCFM(byval as dWorldID, byval cfm as dReal)
declare function dWorldGetCFM(byval as dWorldID) as dReal
const dWORLDSTEP_THREADCOUNT_UNLIMITED = 0u
declare sub dWorldSetStepIslandsProcessingMaxThreadCount(byval w as dWorldID, byval count as ulong)
declare function dWorldGetStepIslandsProcessingMaxThreadCount(byval w as dWorldID) as ulong
declare function dWorldUseSharedWorkingMemory(byval w as dWorldID, byval from_world as dWorldID) as long
declare sub dWorldCleanupWorkingMemory(byval w as dWorldID)
const dWORLDSTEP_RESERVEFACTOR_DEFAULT = 1.2f
const dWORLDSTEP_RESERVESIZE_DEFAULT = 65536u

type dWorldStepReserveInfo
	struct_size as ulong
	reserve_factor as single
	reserve_minimum as ulong
end type

declare function dWorldSetStepMemoryReservationPolicy(byval w as dWorldID, byval policyinfo as const dWorldStepReserveInfo ptr) as long

type dWorldStepMemoryFunctionsInfo
	struct_size as ulong
	alloc_block as function(byval block_size as uinteger) as any ptr
	shrink_block as function(byval block_pointer as any ptr, byval block_current_size as uinteger, byval block_smaller_size as uinteger) as any ptr
	free_block as sub(byval block_pointer as any ptr, byval block_current_size as uinteger)
end type

declare function dWorldSetStepMemoryManager(byval w as dWorldID, byval memfuncs as const dWorldStepMemoryFunctionsInfo ptr) as long
declare sub dWorldSetStepThreadingImplementation(byval w as dWorldID, byval functions_info as const dThreadingFunctionsInfo ptr, byval threading_impl as dThreadingImplementationID)
declare function dWorldStep(byval w as dWorldID, byval stepsize as dReal) as long
declare function dWorldQuickStep(byval w as dWorldID, byval stepsize as dReal) as long
declare sub dWorldImpulseToForce(byval as dWorldID, byval stepsize as dReal, byval ix as dReal, byval iy as dReal, byval iz as dReal, byval force as dReal ptr)
declare sub dWorldSetQuickStepNumIterations(byval as dWorldID, byval num as long)
declare function dWorldGetQuickStepNumIterations(byval as dWorldID) as long
declare sub dWorldSetQuickStepW(byval as dWorldID, byval over_relaxation as dReal)
declare function dWorldGetQuickStepW(byval as dWorldID) as dReal
declare sub dWorldSetContactMaxCorrectingVel(byval as dWorldID, byval vel as dReal)
declare function dWorldGetContactMaxCorrectingVel(byval as dWorldID) as dReal
declare sub dWorldSetContactSurfaceLayer(byval as dWorldID, byval depth as dReal)
declare function dWorldGetContactSurfaceLayer(byval as dWorldID) as dReal
declare function dWorldGetAutoDisableLinearThreshold(byval as dWorldID) as dReal
declare sub dWorldSetAutoDisableLinearThreshold(byval as dWorldID, byval linear_threshold as dReal)
declare function dWorldGetAutoDisableAngularThreshold(byval as dWorldID) as dReal
declare sub dWorldSetAutoDisableAngularThreshold(byval as dWorldID, byval angular_threshold as dReal)
declare function dWorldGetAutoDisableLinearAverageThreshold(byval as dWorldID) as dReal
declare sub dWorldSetAutoDisableLinearAverageThreshold(byval as dWorldID, byval linear_average_threshold as dReal)
declare function dWorldGetAutoDisableAngularAverageThreshold(byval as dWorldID) as dReal
declare sub dWorldSetAutoDisableAngularAverageThreshold(byval as dWorldID, byval angular_average_threshold as dReal)
declare function dWorldGetAutoDisableAverageSamplesCount(byval as dWorldID) as long
declare sub dWorldSetAutoDisableAverageSamplesCount(byval as dWorldID, byval average_samples_count as ulong)
declare function dWorldGetAutoDisableSteps(byval as dWorldID) as long
declare sub dWorldSetAutoDisableSteps(byval as dWorldID, byval steps as long)
declare function dWorldGetAutoDisableTime(byval as dWorldID) as dReal
declare sub dWorldSetAutoDisableTime(byval as dWorldID, byval time as dReal)
declare function dWorldGetAutoDisableFlag(byval as dWorldID) as long
declare sub dWorldSetAutoDisableFlag(byval as dWorldID, byval do_auto_disable as long)
declare function dWorldGetLinearDampingThreshold(byval w as dWorldID) as dReal
declare sub dWorldSetLinearDampingThreshold(byval w as dWorldID, byval threshold as dReal)
declare function dWorldGetAngularDampingThreshold(byval w as dWorldID) as dReal
declare sub dWorldSetAngularDampingThreshold(byval w as dWorldID, byval threshold as dReal)
declare function dWorldGetLinearDamping(byval w as dWorldID) as dReal
declare sub dWorldSetLinearDamping(byval w as dWorldID, byval scale as dReal)
declare function dWorldGetAngularDamping(byval w as dWorldID) as dReal
declare sub dWorldSetAngularDamping(byval w as dWorldID, byval scale as dReal)
declare sub dWorldSetDamping(byval w as dWorldID, byval linear_scale as dReal, byval angular_scale as dReal)
declare function dWorldGetMaxAngularSpeed(byval w as dWorldID) as dReal
declare sub dWorldSetMaxAngularSpeed(byval w as dWorldID, byval max_speed as dReal)
declare function dBodyGetAutoDisableLinearThreshold(byval as dBodyID) as dReal
declare sub dBodySetAutoDisableLinearThreshold(byval as dBodyID, byval linear_average_threshold as dReal)
declare function dBodyGetAutoDisableAngularThreshold(byval as dBodyID) as dReal
declare sub dBodySetAutoDisableAngularThreshold(byval as dBodyID, byval angular_average_threshold as dReal)
declare function dBodyGetAutoDisableAverageSamplesCount(byval as dBodyID) as long
declare sub dBodySetAutoDisableAverageSamplesCount(byval as dBodyID, byval average_samples_count as ulong)
declare function dBodyGetAutoDisableSteps(byval as dBodyID) as long
declare sub dBodySetAutoDisableSteps(byval as dBodyID, byval steps as long)
declare function dBodyGetAutoDisableTime(byval as dBodyID) as dReal
declare sub dBodySetAutoDisableTime(byval as dBodyID, byval time as dReal)
declare function dBodyGetAutoDisableFlag(byval as dBodyID) as long
declare sub dBodySetAutoDisableFlag(byval as dBodyID, byval do_auto_disable as long)
declare sub dBodySetAutoDisableDefaults(byval as dBodyID)
declare function dBodyGetWorld(byval as dBodyID) as dWorldID
declare function dBodyCreate(byval as dWorldID) as dBodyID
declare sub dBodyDestroy(byval as dBodyID)
declare sub dBodySetData(byval as dBodyID, byval data as any ptr)
declare function dBodyGetData(byval as dBodyID) as any ptr
declare sub dBodySetPosition(byval as dBodyID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dBodySetRotation(byval as dBodyID, byval R as const dReal ptr)
declare sub dBodySetQuaternion(byval as dBodyID, byval q as const dReal ptr)
declare sub dBodySetLinearVel(byval as dBodyID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dBodySetAngularVel(byval as dBodyID, byval x as dReal, byval y as dReal, byval z as dReal)
declare function dBodyGetPosition(byval as dBodyID) as const dReal ptr
declare sub dBodyCopyPosition(byval body as dBodyID, byval pos as dReal ptr)
declare function dBodyGetRotation(byval as dBodyID) as const dReal ptr
declare sub dBodyCopyRotation(byval as dBodyID, byval R as dReal ptr)
declare function dBodyGetQuaternion(byval as dBodyID) as const dReal ptr
declare sub dBodyCopyQuaternion(byval body as dBodyID, byval quat as dReal ptr)
declare function dBodyGetLinearVel(byval as dBodyID) as const dReal ptr
declare function dBodyGetAngularVel(byval as dBodyID) as const dReal ptr
declare sub dBodySetMass(byval as dBodyID, byval mass as const dMass ptr)
declare sub dBodyGetMass(byval as dBodyID, byval mass as dMass ptr)
declare sub dBodyAddForce(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal)
declare sub dBodyAddTorque(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal)
declare sub dBodyAddRelForce(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal)
declare sub dBodyAddRelTorque(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal)
declare sub dBodyAddForceAtPos(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal, byval px as dReal, byval py as dReal, byval pz as dReal)
declare sub dBodyAddForceAtRelPos(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal, byval px as dReal, byval py as dReal, byval pz as dReal)
declare sub dBodyAddRelForceAtPos(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal, byval px as dReal, byval py as dReal, byval pz as dReal)
declare sub dBodyAddRelForceAtRelPos(byval as dBodyID, byval fx as dReal, byval fy as dReal, byval fz as dReal, byval px as dReal, byval py as dReal, byval pz as dReal)
declare function dBodyGetForce(byval as dBodyID) as const dReal ptr
declare function dBodyGetTorque(byval as dBodyID) as const dReal ptr
declare sub dBodySetForce(byval b as dBodyID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dBodySetTorque(byval b as dBodyID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dBodyGetRelPointPos(byval as dBodyID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dBodyGetRelPointVel(byval as dBodyID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dBodyGetPointVel(byval as dBodyID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dBodyGetPosRelPoint(byval as dBodyID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dBodyVectorToWorld(byval as dBodyID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dBodyVectorFromWorld(byval as dBodyID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dBodySetFiniteRotationMode(byval as dBodyID, byval mode as long)
declare sub dBodySetFiniteRotationAxis(byval as dBodyID, byval x as dReal, byval y as dReal, byval z as dReal)
declare function dBodyGetFiniteRotationMode(byval as dBodyID) as long
declare sub dBodyGetFiniteRotationAxis(byval as dBodyID, byval result as dReal ptr)
declare function dBodyGetNumJoints(byval b as dBodyID) as long
declare function dBodyGetJoint(byval as dBodyID, byval index as long) as dJointID
declare sub dBodySetDynamic(byval as dBodyID)
declare sub dBodySetKinematic(byval as dBodyID)
declare function dBodyIsKinematic(byval as dBodyID) as long
declare sub dBodyEnable(byval as dBodyID)
declare sub dBodyDisable(byval as dBodyID)
declare function dBodyIsEnabled(byval as dBodyID) as long
declare sub dBodySetGravityMode(byval b as dBodyID, byval mode as long)
declare function dBodyGetGravityMode(byval b as dBodyID) as long
declare sub dBodySetMovedCallback(byval b as dBodyID, byval callback as sub(byval as dBodyID))
declare function dBodyGetFirstGeom(byval b as dBodyID) as dGeomID
declare function dBodyGetNextGeom(byval g as dGeomID) as dGeomID
declare sub dBodySetDampingDefaults(byval b as dBodyID)
declare function dBodyGetLinearDamping(byval b as dBodyID) as dReal
declare sub dBodySetLinearDamping(byval b as dBodyID, byval scale as dReal)
declare function dBodyGetAngularDamping(byval b as dBodyID) as dReal
declare sub dBodySetAngularDamping(byval b as dBodyID, byval scale as dReal)
declare sub dBodySetDamping(byval b as dBodyID, byval linear_scale as dReal, byval angular_scale as dReal)
declare function dBodyGetLinearDampingThreshold(byval b as dBodyID) as dReal
declare sub dBodySetLinearDampingThreshold(byval b as dBodyID, byval threshold as dReal)
declare function dBodyGetAngularDampingThreshold(byval b as dBodyID) as dReal
declare sub dBodySetAngularDampingThreshold(byval b as dBodyID, byval threshold as dReal)
declare function dBodyGetMaxAngularSpeed(byval b as dBodyID) as dReal
declare sub dBodySetMaxAngularSpeed(byval b as dBodyID, byval max_speed as dReal)
declare function dBodyGetGyroscopicMode(byval b as dBodyID) as long
declare sub dBodySetGyroscopicMode(byval b as dBodyID, byval enabled as long)
declare function dJointCreateBall(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateHinge(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateSlider(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateContact(byval as dWorldID, byval as dJointGroupID, byval as const dContact ptr) as dJointID
declare function dJointCreateHinge2(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateUniversal(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreatePR(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreatePU(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreatePiston(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateFixed(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateNull(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateAMotor(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateLMotor(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreatePlane2D(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateDBall(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateDHinge(byval as dWorldID, byval as dJointGroupID) as dJointID
declare function dJointCreateTransmission(byval as dWorldID, byval as dJointGroupID) as dJointID
declare sub dJointDestroy(byval as dJointID)
declare function dJointGroupCreate(byval max_size as long) as dJointGroupID
declare sub dJointGroupDestroy(byval as dJointGroupID)
declare sub dJointGroupEmpty(byval as dJointGroupID)
declare function dJointGetNumBodies(byval as dJointID) as long
declare sub dJointAttach(byval as dJointID, byval body1 as dBodyID, byval body2 as dBodyID)
declare sub dJointEnable(byval as dJointID)
declare sub dJointDisable(byval as dJointID)
declare function dJointIsEnabled(byval as dJointID) as long
declare sub dJointSetData(byval as dJointID, byval data as any ptr)
declare function dJointGetData(byval as dJointID) as any ptr
declare function dJointGetType(byval as dJointID) as dJointType
declare function dJointGetBody(byval as dJointID, byval index as long) as dBodyID
declare sub dJointSetFeedback(byval as dJointID, byval as dJointFeedback ptr)
declare function dJointGetFeedback(byval as dJointID) as dJointFeedback ptr
declare sub dJointSetBallAnchor(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetBallAnchor2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetBallParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointSetHingeAnchor(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetHingeAnchorDelta(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval ax as dReal, byval ay as dReal, byval az as dReal)
declare sub dJointSetHingeAxis(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetHingeAxisOffset(byval j as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval angle as dReal)
declare sub dJointSetHingeParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointAddHingeTorque(byval joint as dJointID, byval torque as dReal)
declare sub dJointSetSliderAxis(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetSliderAxisDelta(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval ax as dReal, byval ay as dReal, byval az as dReal)
declare sub dJointSetSliderParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointAddSliderForce(byval joint as dJointID, byval force as dReal)
declare sub dJointSetHinge2Anchor(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetHinge2Axis1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetHinge2Axis2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetHinge2Param(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointAddHinge2Torques(byval joint as dJointID, byval torque1 as dReal, byval torque2 as dReal)
declare sub dJointSetUniversalAnchor(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetUniversalAxis1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetUniversalAxis1Offset(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval offset1 as dReal, byval offset2 as dReal)
declare sub dJointSetUniversalAxis2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetUniversalAxis2Offset(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval offset1 as dReal, byval offset2 as dReal)
declare sub dJointSetUniversalParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointAddUniversalTorques(byval joint as dJointID, byval torque1 as dReal, byval torque2 as dReal)
declare sub dJointSetPRAnchor(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPRAxis1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPRAxis2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPRParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointAddPRTorque(byval j as dJointID, byval torque as dReal)
declare sub dJointSetPUAnchor(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPUAnchorDelta(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval dx as dReal, byval dy as dReal, byval dz as dReal)
declare sub dJointSetPUAnchorOffset(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval dx as dReal, byval dy as dReal, byval dz as dReal)
declare sub dJointSetPUAxis1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPUAxis2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPUAxis3(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPUAxisP(byval id as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPUParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointAddPUTorque(byval j as dJointID, byval torque as dReal)
declare sub dJointSetPistonAnchor(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPistonAnchorOffset(byval j as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval dx as dReal, byval dy as dReal, byval dz as dReal)
declare sub dJointSetPistonAxis(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetPistonAxisDelta(byval j as dJointID, byval x as dReal, byval y as dReal, byval z as dReal, byval ax as dReal, byval ay as dReal, byval az as dReal)
declare sub dJointSetPistonParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointAddPistonForce(byval joint as dJointID, byval force as dReal)
declare sub dJointSetFixed(byval as dJointID)
declare sub dJointSetFixedParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointSetAMotorNumAxes(byval as dJointID, byval num as long)
declare sub dJointSetAMotorAxis(byval as dJointID, byval anum as long, byval rel as long, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetAMotorAngle(byval as dJointID, byval anum as long, byval angle as dReal)
declare sub dJointSetAMotorParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointSetAMotorMode(byval as dJointID, byval mode as long)
declare sub dJointAddAMotorTorques(byval as dJointID, byval torque1 as dReal, byval torque2 as dReal, byval torque3 as dReal)
declare sub dJointSetLMotorNumAxes(byval as dJointID, byval num as long)
declare sub dJointSetLMotorAxis(byval as dJointID, byval anum as long, byval rel as long, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetLMotorParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointSetPlane2DXParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointSetPlane2DYParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointSetPlane2DAngleParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare sub dJointGetBallAnchor(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetBallAnchor2(byval as dJointID, byval result as dReal ptr)
declare function dJointGetBallParam(byval as dJointID, byval parameter as long) as dReal
declare sub dJointGetHingeAnchor(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetHingeAnchor2(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetHingeAxis(byval as dJointID, byval result as dReal ptr)
declare function dJointGetHingeParam(byval as dJointID, byval parameter as long) as dReal
declare function dJointGetHingeAngle(byval as dJointID) as dReal
declare function dJointGetHingeAngleRate(byval as dJointID) as dReal
declare function dJointGetSliderPosition(byval as dJointID) as dReal
declare function dJointGetSliderPositionRate(byval as dJointID) as dReal
declare sub dJointGetSliderAxis(byval as dJointID, byval result as dReal ptr)
declare function dJointGetSliderParam(byval as dJointID, byval parameter as long) as dReal
declare sub dJointGetHinge2Anchor(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetHinge2Anchor2(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetHinge2Axis1(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetHinge2Axis2(byval as dJointID, byval result as dReal ptr)
declare function dJointGetHinge2Param(byval as dJointID, byval parameter as long) as dReal
declare function dJointGetHinge2Angle1(byval as dJointID) as dReal
declare function dJointGetHinge2Angle2(byval as dJointID) as dReal
declare function dJointGetHinge2Angle1Rate(byval as dJointID) as dReal
declare function dJointGetHinge2Angle2Rate(byval as dJointID) as dReal
declare sub dJointGetUniversalAnchor(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetUniversalAnchor2(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetUniversalAxis1(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetUniversalAxis2(byval as dJointID, byval result as dReal ptr)
declare function dJointGetUniversalParam(byval as dJointID, byval parameter as long) as dReal
declare sub dJointGetUniversalAngles(byval as dJointID, byval angle1 as dReal ptr, byval angle2 as dReal ptr)
declare function dJointGetUniversalAngle1(byval as dJointID) as dReal
declare function dJointGetUniversalAngle2(byval as dJointID) as dReal
declare function dJointGetUniversalAngle1Rate(byval as dJointID) as dReal
declare function dJointGetUniversalAngle2Rate(byval as dJointID) as dReal
declare sub dJointGetPRAnchor(byval as dJointID, byval result as dReal ptr)
declare function dJointGetPRPosition(byval as dJointID) as dReal
declare function dJointGetPRPositionRate(byval as dJointID) as dReal
declare function dJointGetPRAngle(byval as dJointID) as dReal
declare function dJointGetPRAngleRate(byval as dJointID) as dReal
declare sub dJointGetPRAxis1(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetPRAxis2(byval as dJointID, byval result as dReal ptr)
declare function dJointGetPRParam(byval as dJointID, byval parameter as long) as dReal
declare sub dJointGetPUAnchor(byval as dJointID, byval result as dReal ptr)
declare function dJointGetPUPosition(byval as dJointID) as dReal
declare function dJointGetPUPositionRate(byval as dJointID) as dReal
declare sub dJointGetPUAxis1(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetPUAxis2(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetPUAxis3(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetPUAxisP(byval id as dJointID, byval result as dReal ptr)
declare sub dJointGetPUAngles(byval as dJointID, byval angle1 as dReal ptr, byval angle2 as dReal ptr)
declare function dJointGetPUAngle1(byval as dJointID) as dReal
declare function dJointGetPUAngle1Rate(byval as dJointID) as dReal
declare function dJointGetPUAngle2(byval as dJointID) as dReal
declare function dJointGetPUAngle2Rate(byval as dJointID) as dReal
declare function dJointGetPUParam(byval as dJointID, byval parameter as long) as dReal
declare function dJointGetPistonPosition(byval as dJointID) as dReal
declare function dJointGetPistonPositionRate(byval as dJointID) as dReal
declare function dJointGetPistonAngle(byval as dJointID) as dReal
declare function dJointGetPistonAngleRate(byval as dJointID) as dReal
declare sub dJointGetPistonAnchor(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetPistonAnchor2(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetPistonAxis(byval as dJointID, byval result as dReal ptr)
declare function dJointGetPistonParam(byval as dJointID, byval parameter as long) as dReal
declare function dJointGetAMotorNumAxes(byval as dJointID) as long
declare sub dJointGetAMotorAxis(byval as dJointID, byval anum as long, byval result as dReal ptr)
declare function dJointGetAMotorAxisRel(byval as dJointID, byval anum as long) as long
declare function dJointGetAMotorAngle(byval as dJointID, byval anum as long) as dReal
declare function dJointGetAMotorAngleRate(byval as dJointID, byval anum as long) as dReal
declare function dJointGetAMotorParam(byval as dJointID, byval parameter as long) as dReal
declare function dJointGetAMotorMode(byval as dJointID) as long
declare function dJointGetLMotorNumAxes(byval as dJointID) as long
declare sub dJointGetLMotorAxis(byval as dJointID, byval anum as long, byval result as dReal ptr)
declare function dJointGetLMotorParam(byval as dJointID, byval parameter as long) as dReal
declare function dJointGetFixedParam(byval as dJointID, byval parameter as long) as dReal
declare sub dJointGetTransmissionContactPoint1(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetTransmissionContactPoint2(byval as dJointID, byval result as dReal ptr)
declare sub dJointSetTransmissionAxis1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetTransmissionAxis1(byval as dJointID, byval result as dReal ptr)
declare sub dJointSetTransmissionAxis2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetTransmissionAxis2(byval as dJointID, byval result as dReal ptr)
declare sub dJointSetTransmissionAnchor1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetTransmissionAnchor1(byval as dJointID, byval result as dReal ptr)
declare sub dJointSetTransmissionAnchor2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetTransmissionAnchor2(byval as dJointID, byval result as dReal ptr)
declare sub dJointSetTransmissionParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare function dJointGetTransmissionParam(byval as dJointID, byval parameter as long) as dReal
declare sub dJointSetTransmissionMode(byval j as dJointID, byval mode as long)
declare function dJointGetTransmissionMode(byval j as dJointID) as long
declare sub dJointSetTransmissionRatio(byval j as dJointID, byval ratio as dReal)
declare function dJointGetTransmissionRatio(byval j as dJointID) as dReal
declare sub dJointSetTransmissionAxis(byval j as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetTransmissionAxis(byval j as dJointID, byval result as dReal ptr)
declare function dJointGetTransmissionAngle1(byval j as dJointID) as dReal
declare function dJointGetTransmissionAngle2(byval j as dJointID) as dReal
declare function dJointGetTransmissionRadius1(byval j as dJointID) as dReal
declare function dJointGetTransmissionRadius2(byval j as dJointID) as dReal
declare sub dJointSetTransmissionRadius1(byval j as dJointID, byval radius as dReal)
declare sub dJointSetTransmissionRadius2(byval j as dJointID, byval radius as dReal)
declare function dJointGetTransmissionBacklash(byval j as dJointID) as dReal
declare sub dJointSetTransmissionBacklash(byval j as dJointID, byval backlash as dReal)
declare sub dJointSetDBallAnchor1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetDBallAnchor2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetDBallAnchor1(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetDBallAnchor2(byval as dJointID, byval result as dReal ptr)
declare function dJointGetDBallDistance(byval as dJointID) as dReal
declare sub dJointSetDBallParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare function dJointGetDBallParam(byval as dJointID, byval parameter as long) as dReal
declare sub dJointSetDHingeAxis(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetDHingeAxis(byval as dJointID, byval result as dReal ptr)
declare sub dJointSetDHingeAnchor1(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointSetDHingeAnchor2(byval as dJointID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dJointGetDHingeAnchor1(byval as dJointID, byval result as dReal ptr)
declare sub dJointGetDHingeAnchor2(byval as dJointID, byval result as dReal ptr)
declare function dJointGetDHingeDistance(byval as dJointID) as dReal
declare sub dJointSetDHingeParam(byval as dJointID, byval parameter as long, byval value as dReal)
declare function dJointGetDHingeParam(byval as dJointID, byval parameter as long) as dReal
declare function dConnectingJoint(byval as dBodyID, byval as dBodyID) as dJointID
declare function dConnectingJointList(byval as dBodyID, byval as dBodyID, byval as dJointID ptr) as long
declare function dAreConnected(byval as dBodyID, byval as dBodyID) as long
declare function dAreConnectedExcluding(byval body1 as dBodyID, byval body2 as dBodyID, byval joint_type as long) as long
#define _ODE_COLLISION_SPACE_H_
declare function dSimpleSpaceCreate(byval space as dSpaceID) as dSpaceID
declare function dHashSpaceCreate(byval space as dSpaceID) as dSpaceID
declare function dQuadTreeSpaceCreate(byval space as dSpaceID, byval Center as const dReal ptr, byval Extents as const dReal ptr, byval Depth as long) as dSpaceID

const dSAP_AXES_XYZ = (0 or (1 shl 2)) or (2 shl 4)
const dSAP_AXES_XZY = (0 or (2 shl 2)) or (1 shl 4)
const dSAP_AXES_YXZ = (1 or (0 shl 2)) or (2 shl 4)
const dSAP_AXES_YZX = (1 or (2 shl 2)) or (0 shl 4)
const dSAP_AXES_ZXY = (2 or (0 shl 2)) or (1 shl 4)
const dSAP_AXES_ZYX = (2 or (1 shl 2)) or (0 shl 4)

declare function dSweepAndPruneSpaceCreate(byval space as dSpaceID, byval axisorder as long) as dSpaceID
declare sub dSpaceDestroy(byval as dSpaceID)
declare sub dHashSpaceSetLevels(byval space as dSpaceID, byval minlevel as long, byval maxlevel as long)
declare sub dHashSpaceGetLevels(byval space as dSpaceID, byval minlevel as long ptr, byval maxlevel as long ptr)
declare sub dSpaceSetCleanup(byval space as dSpaceID, byval mode as long)
declare function dSpaceGetCleanup(byval space as dSpaceID) as long
declare sub dSpaceSetSublevel(byval space as dSpaceID, byval sublevel as long)
declare function dSpaceGetSublevel(byval space as dSpaceID) as long
declare sub dSpaceSetManualCleanup(byval space as dSpaceID, byval mode as long)
declare function dSpaceGetManualCleanup(byval space as dSpaceID) as long
declare sub dSpaceAdd(byval as dSpaceID, byval as dGeomID)
declare sub dSpaceRemove(byval as dSpaceID, byval as dGeomID)
declare function dSpaceQuery(byval as dSpaceID, byval as dGeomID) as long
declare sub dSpaceClean(byval as dSpaceID)
declare function dSpaceGetNumGeoms(byval as dSpaceID) as long
declare function dSpaceGetGeom(byval as dSpaceID, byval i as long) as dGeomID
declare function dSpaceGetClass(byval space as dSpaceID) as long
#define _ODE_COLLISION_H_
declare sub dGeomDestroy(byval geom as dGeomID)
declare sub dGeomSetData(byval geom as dGeomID, byval data as any ptr)
declare function dGeomGetData(byval geom as dGeomID) as any ptr
declare sub dGeomSetBody(byval geom as dGeomID, byval body as dBodyID)
declare function dGeomGetBody(byval geom as dGeomID) as dBodyID
declare sub dGeomSetPosition(byval geom as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dGeomSetRotation(byval geom as dGeomID, byval R as const dReal ptr)
declare sub dGeomSetQuaternion(byval geom as dGeomID, byval Q as const dReal ptr)
declare function dGeomGetPosition(byval geom as dGeomID) as const dReal ptr
declare sub dGeomCopyPosition(byval geom as dGeomID, byval pos as dReal ptr)
declare function dGeomGetRotation(byval geom as dGeomID) as const dReal ptr
declare sub dGeomCopyRotation(byval geom as dGeomID, byval R as dReal ptr)
declare sub dGeomGetQuaternion(byval geom as dGeomID, byval result as dReal ptr)
declare sub dGeomGetAABB(byval geom as dGeomID, byval aabb as dReal ptr)
declare function dGeomIsSpace(byval geom as dGeomID) as long
declare function dGeomGetSpace(byval as dGeomID) as dSpaceID
declare function dGeomGetClass(byval geom as dGeomID) as long
declare sub dGeomSetCategoryBits(byval geom as dGeomID, byval bits as culong)
declare sub dGeomSetCollideBits(byval geom as dGeomID, byval bits as culong)
declare function dGeomGetCategoryBits(byval as dGeomID) as culong
declare function dGeomGetCollideBits(byval as dGeomID) as culong
declare sub dGeomEnable(byval geom as dGeomID)
declare sub dGeomDisable(byval geom as dGeomID)
declare function dGeomIsEnabled(byval geom as dGeomID) as long

enum
	dGeomCommonControlClass = 0
	dGeomColliderControlClass = 1
end enum

enum
	dGeomCommonAnyControlCode = 0
	dGeomColliderSetMergeSphereContactsControlCode = 1
	dGeomColliderGetMergeSphereContactsControlCode = 2
end enum

enum
	dGeomColliderMergeContactsValue__Default = 0
	dGeomColliderMergeContactsValue_None = 1
	dGeomColliderMergeContactsValue_Normals = 2
	dGeomColliderMergeContactsValue_Full = 3
end enum

declare function dGeomLowLevelControl(byval geom as dGeomID, byval controlClass as long, byval controlCode as long, byval dataValue as any ptr, byval dataSize as long ptr) as long
declare sub dGeomGetRelPointPos(byval geom as dGeomID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dGeomGetPosRelPoint(byval geom as dGeomID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dGeomVectorToWorld(byval geom as dGeomID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dGeomVectorFromWorld(byval geom as dGeomID, byval px as dReal, byval py as dReal, byval pz as dReal, byval result as dReal ptr)
declare sub dGeomSetOffsetPosition(byval geom as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dGeomSetOffsetRotation(byval geom as dGeomID, byval R as const dReal ptr)
declare sub dGeomSetOffsetQuaternion(byval geom as dGeomID, byval Q as const dReal ptr)
declare sub dGeomSetOffsetWorldPosition(byval geom as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal)
declare sub dGeomSetOffsetWorldRotation(byval geom as dGeomID, byval R as const dReal ptr)
declare sub dGeomSetOffsetWorldQuaternion(byval geom as dGeomID, byval as const dReal ptr)
declare sub dGeomClearOffset(byval geom as dGeomID)
declare function dGeomIsOffset(byval geom as dGeomID) as long
declare function dGeomGetOffsetPosition(byval geom as dGeomID) as const dReal ptr
declare sub dGeomCopyOffsetPosition(byval geom as dGeomID, byval pos as dReal ptr)
declare function dGeomGetOffsetRotation(byval geom as dGeomID) as const dReal ptr
declare sub dGeomCopyOffsetRotation(byval geom as dGeomID, byval R as dReal ptr)
declare sub dGeomGetOffsetQuaternion(byval geom as dGeomID, byval result as dReal ptr)
const CONTACTS_UNIMPORTANT = &h80000000
declare function dCollide(byval o1 as dGeomID, byval o2 as dGeomID, byval flags as long, byval contact as dContactGeom ptr, byval skip as long) as long
declare sub dSpaceCollide(byval space as dSpaceID, byval data as any ptr, byval callback as sub(byval data as any ptr, byval o1 as dGeomID, byval o2 as dGeomID))
declare sub dSpaceCollide2(byval space1 as dGeomID, byval space2 as dGeomID, byval data as any ptr, byval callback as sub(byval data as any ptr, byval o1 as dGeomID, byval o2 as dGeomID))

enum
	dMaxUserClasses = 4
end enum

enum
	dSphereClass = 0
	dBoxClass
	dCapsuleClass
	dCylinderClass
	dPlaneClass
	dRayClass
	dConvexClass
	dGeomTransformClass
	dTriMeshClass
	dHeightfieldClass
	dFirstSpaceClass
	dSimpleSpaceClass = dFirstSpaceClass
	dHashSpaceClass
	dSweepAndPruneSpaceClass
	dQuadTreeSpaceClass
	dLastSpaceClass = dQuadTreeSpaceClass
	dFirstUserClass
	dLastUserClass = (dFirstUserClass + dMaxUserClasses) - 1
	dGeomNumClasses
end enum

declare function dCreateSphere(byval space as dSpaceID, byval radius as dReal) as dGeomID
declare sub dGeomSphereSetRadius(byval sphere as dGeomID, byval radius as dReal)
declare function dGeomSphereGetRadius(byval sphere as dGeomID) as dReal
declare function dGeomSpherePointDepth(byval sphere as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal) as dReal
declare function dCreateConvex(byval space as dSpaceID, byval _planes as dReal ptr, byval _planecount as ulong, byval _points as dReal ptr, byval _pointcount as ulong, byval _polygons as ulong ptr) as dGeomID
declare sub dGeomSetConvex(byval g as dGeomID, byval _planes as dReal ptr, byval _count as ulong, byval _points as dReal ptr, byval _pointcount as ulong, byval _polygons as ulong ptr)
declare function dCreateBox(byval space as dSpaceID, byval lx as dReal, byval ly as dReal, byval lz as dReal) as dGeomID
declare sub dGeomBoxSetLengths(byval box as dGeomID, byval lx as dReal, byval ly as dReal, byval lz as dReal)
declare sub dGeomBoxGetLengths(byval box as dGeomID, byval result as dReal ptr)
declare function dGeomBoxPointDepth(byval box as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal) as dReal
declare function dCreatePlane(byval space as dSpaceID, byval a as dReal, byval b as dReal, byval c as dReal, byval d as dReal) as dGeomID
declare sub dGeomPlaneSetParams(byval plane as dGeomID, byval a as dReal, byval b as dReal, byval c as dReal, byval d as dReal)
declare sub dGeomPlaneGetParams(byval plane as dGeomID, byval result as dReal ptr)
declare function dGeomPlanePointDepth(byval plane as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal) as dReal
declare function dCreateCapsule(byval space as dSpaceID, byval radius as dReal, byval length as dReal) as dGeomID
declare sub dGeomCapsuleSetParams(byval ccylinder as dGeomID, byval radius as dReal, byval length as dReal)
declare sub dGeomCapsuleGetParams(byval ccylinder as dGeomID, byval radius as dReal ptr, byval length as dReal ptr)
declare function dGeomCapsulePointDepth(byval ccylinder as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal) as dReal
declare function dCreateCCylinder alias "dCreateCapsule"(byval space as dSpaceID, byval radius as dReal, byval length as dReal) as dGeomID
declare sub dGeomCCylinderSetParams alias "dGeomCapsuleSetParams"(byval ccylinder as dGeomID, byval radius as dReal, byval length as dReal)
declare sub dGeomCCylinderGetParams alias "dGeomCapsuleGetParams"(byval ccylinder as dGeomID, byval radius as dReal ptr, byval length as dReal ptr)
declare function dGeomCCylinderPointDepth alias "dGeomCapsulePointDepth"(byval ccylinder as dGeomID, byval x as dReal, byval y as dReal, byval z as dReal) as dReal
const dCCylinderClass = dCapsuleClass
declare function dCreateCylinder(byval space as dSpaceID, byval radius as dReal, byval length as dReal) as dGeomID
declare sub dGeomCylinderSetParams(byval cylinder as dGeomID, byval radius as dReal, byval length as dReal)
declare sub dGeomCylinderGetParams(byval cylinder as dGeomID, byval radius as dReal ptr, byval length as dReal ptr)
declare function dCreateRay(byval space as dSpaceID, byval length as dReal) as dGeomID
declare sub dGeomRaySetLength(byval ray as dGeomID, byval length as dReal)
declare function dGeomRayGetLength(byval ray as dGeomID) as dReal
declare sub dGeomRaySet(byval ray as dGeomID, byval px as dReal, byval py as dReal, byval pz as dReal, byval dx as dReal, byval dy as dReal, byval dz as dReal)
declare sub dGeomRayGet(byval ray as dGeomID, byval start as dReal ptr, byval dir as dReal ptr)
declare sub dGeomRaySetParams(byval g as dGeomID, byval FirstContact as long, byval BackfaceCull as long)
declare sub dGeomRayGetParams(byval g as dGeomID, byval FirstContact as long ptr, byval BackfaceCull as long ptr)
declare sub dGeomRaySetFirstContact(byval g as dGeomID, byval firstContact as long)
declare function dGeomRayGetFirstContact(byval g as dGeomID) as long
declare sub dGeomRaySetBackfaceCull(byval g as dGeomID, byval backfaceCull as long)
declare function dGeomRayGetBackfaceCull(byval g as dGeomID) as long
declare sub dGeomRaySetClosestHit(byval g as dGeomID, byval closestHit as long)
declare function dGeomRayGetClosestHit(byval g as dGeomID) as long
#define _ODE_COLLISION_TRIMESH_H_
type dTriMeshDataID as dxTriMeshData ptr
declare function dGeomTriMeshDataCreate() as dTriMeshDataID
declare sub dGeomTriMeshDataDestroy(byval g as dTriMeshDataID)

enum
	TRIMESH_FACE_NORMALS
end enum

declare sub dGeomTriMeshDataSet(byval g as dTriMeshDataID, byval data_id as long, byval in_data as any ptr)
declare function dGeomTriMeshDataGet(byval g as dTriMeshDataID, byval data_id as long) as any ptr
declare sub dGeomTriMeshSetLastTransform(byval g as dGeomID, byval last_trans as dReal ptr)
declare function dGeomTriMeshGetLastTransform(byval g as dGeomID) as dReal ptr
declare sub dGeomTriMeshDataBuildSingle(byval g as dTriMeshDataID, byval Vertices as const any ptr, byval VertexStride as long, byval VertexCount as long, byval Indices as const any ptr, byval IndexCount as long, byval TriStride as long)
declare sub dGeomTriMeshDataBuildSingle1(byval g as dTriMeshDataID, byval Vertices as const any ptr, byval VertexStride as long, byval VertexCount as long, byval Indices as const any ptr, byval IndexCount as long, byval TriStride as long, byval Normals as const any ptr)
declare sub dGeomTriMeshDataBuildDouble(byval g as dTriMeshDataID, byval Vertices as const any ptr, byval VertexStride as long, byval VertexCount as long, byval Indices as const any ptr, byval IndexCount as long, byval TriStride as long)
declare sub dGeomTriMeshDataBuildDouble1(byval g as dTriMeshDataID, byval Vertices as const any ptr, byval VertexStride as long, byval VertexCount as long, byval Indices as const any ptr, byval IndexCount as long, byval TriStride as long, byval Normals as const any ptr)
declare sub dGeomTriMeshDataBuildSimple(byval g as dTriMeshDataID, byval Vertices as const dReal ptr, byval VertexCount as long, byval Indices as const dTriIndex ptr, byval IndexCount as long)
declare sub dGeomTriMeshDataBuildSimple1(byval g as dTriMeshDataID, byval Vertices as const dReal ptr, byval VertexCount as long, byval Indices as const dTriIndex ptr, byval IndexCount as long, byval Normals as const long ptr)
declare sub dGeomTriMeshDataPreprocess(byval g as dTriMeshDataID)
declare sub dGeomTriMeshDataGetBuffer(byval g as dTriMeshDataID, byval buf as ubyte ptr ptr, byval bufLen as long ptr)
declare sub dGeomTriMeshDataSetBuffer(byval g as dTriMeshDataID, byval buf as ubyte ptr)
declare sub dGeomTriMeshSetCallback(byval g as dGeomID, byval Callback as function(byval TriMesh as dGeomID, byval RefObject as dGeomID, byval TriangleIndex as long) as long)
declare function dGeomTriMeshGetCallback(byval g as dGeomID) as function(byval TriMesh as dGeomID, byval RefObject as dGeomID, byval TriangleIndex as long) as long
declare sub dGeomTriMeshSetArrayCallback(byval g as dGeomID, byval ArrayCallback as sub(byval TriMesh as dGeomID, byval RefObject as dGeomID, byval TriIndices as const long ptr, byval TriCount as long))
declare function dGeomTriMeshGetArrayCallback(byval g as dGeomID) as sub(byval TriMesh as dGeomID, byval RefObject as dGeomID, byval TriIndices as const long ptr, byval TriCount as long)
declare sub dGeomTriMeshSetRayCallback(byval g as dGeomID, byval Callback as function(byval TriMesh as dGeomID, byval Ray as dGeomID, byval TriangleIndex as long, byval u as dReal, byval v as dReal) as long)
declare function dGeomTriMeshGetRayCallback(byval g as dGeomID) as function(byval TriMesh as dGeomID, byval Ray as dGeomID, byval TriangleIndex as long, byval u as dReal, byval v as dReal) as long
declare sub dGeomTriMeshSetTriMergeCallback(byval g as dGeomID, byval Callback as function(byval TriMesh as dGeomID, byval FirstTriangleIndex as long, byval SecondTriangleIndex as long) as long)
declare function dGeomTriMeshGetTriMergeCallback(byval g as dGeomID) as function(byval TriMesh as dGeomID, byval FirstTriangleIndex as long, byval SecondTriangleIndex as long) as long
declare function dCreateTriMesh(byval space as dSpaceID, byval Data as dTriMeshDataID, byval Callback as function(byval TriMesh as dGeomID, byval RefObject as dGeomID, byval TriangleIndex as long) as long, byval ArrayCallback as sub(byval TriMesh as dGeomID, byval RefObject as dGeomID, byval TriIndices as const long ptr, byval TriCount as long), byval RayCallback as function(byval TriMesh as dGeomID, byval Ray as dGeomID, byval TriangleIndex as long, byval u as dReal, byval v as dReal) as long) as dGeomID
declare sub dGeomTriMeshSetData(byval g as dGeomID, byval Data as dTriMeshDataID)
declare function dGeomTriMeshGetData(byval g as dGeomID) as dTriMeshDataID
declare sub dGeomTriMeshEnableTC(byval g as dGeomID, byval geomClass as long, byval enable as long)
declare function dGeomTriMeshIsTCEnabled(byval g as dGeomID, byval geomClass as long) as long
declare sub dGeomTriMeshClearTCCache(byval g as dGeomID)
declare function dGeomTriMeshGetTriMeshDataID(byval g as dGeomID) as dTriMeshDataID
declare sub dGeomTriMeshGetTriangle(byval g as dGeomID, byval Index as long, byval v0 as dReal ptr, byval v1 as dReal ptr, byval v2 as dReal ptr)
declare sub dGeomTriMeshGetPoint(byval g as dGeomID, byval Index as long, byval u as dReal, byval v as dReal, byval Out as dReal ptr)
declare function dGeomTriMeshGetTriangleCount(byval g as dGeomID) as long
declare sub dGeomTriMeshDataUpdate(byval g as dTriMeshDataID)
declare function dCreateGeomTransform(byval space as dSpaceID) as dGeomID
declare sub dGeomTransformSetGeom(byval g as dGeomID, byval obj as dGeomID)
declare function dGeomTransformGetGeom(byval g as dGeomID) as dGeomID
declare sub dGeomTransformSetCleanup(byval g as dGeomID, byval mode as long)
declare function dGeomTransformGetCleanup(byval g as dGeomID) as long
declare sub dGeomTransformSetInfo(byval g as dGeomID, byval mode as long)
declare function dGeomTransformGetInfo(byval g as dGeomID) as long
type dHeightfieldDataID as dxHeightfieldData ptr
declare function dCreateHeightfield(byval space as dSpaceID, byval data as dHeightfieldDataID, byval bPlaceable as long) as dGeomID
declare function dGeomHeightfieldDataCreate() as dHeightfieldDataID
declare sub dGeomHeightfieldDataDestroy(byval d as dHeightfieldDataID)
declare sub dGeomHeightfieldDataBuildCallback(byval d as dHeightfieldDataID, byval pUserData as any ptr, byval pCallback as function(byval p_user_data as any ptr, byval x as long, byval z as long) as dReal, byval width as dReal, byval depth as dReal, byval widthSamples as long, byval depthSamples as long, byval scale as dReal, byval offset as dReal, byval thickness as dReal, byval bWrap as long)
declare sub dGeomHeightfieldDataBuildByte(byval d as dHeightfieldDataID, byval pHeightData as const ubyte ptr, byval bCopyHeightData as long, byval width as dReal, byval depth as dReal, byval widthSamples as long, byval depthSamples as long, byval scale as dReal, byval offset as dReal, byval thickness as dReal, byval bWrap as long)
declare sub dGeomHeightfieldDataBuildShort(byval d as dHeightfieldDataID, byval pHeightData as const short ptr, byval bCopyHeightData as long, byval width as dReal, byval depth as dReal, byval widthSamples as long, byval depthSamples as long, byval scale as dReal, byval offset as dReal, byval thickness as dReal, byval bWrap as long)
declare sub dGeomHeightfieldDataBuildSingle(byval d as dHeightfieldDataID, byval pHeightData as const single ptr, byval bCopyHeightData as long, byval width as dReal, byval depth as dReal, byval widthSamples as long, byval depthSamples as long, byval scale as dReal, byval offset as dReal, byval thickness as dReal, byval bWrap as long)
declare sub dGeomHeightfieldDataBuildDouble(byval d as dHeightfieldDataID, byval pHeightData as const double ptr, byval bCopyHeightData as long, byval width as dReal, byval depth as dReal, byval widthSamples as long, byval depthSamples as long, byval scale as dReal, byval offset as dReal, byval thickness as dReal, byval bWrap as long)
declare sub dGeomHeightfieldDataSetBounds(byval d as dHeightfieldDataID, byval minHeight as dReal, byval maxHeight as dReal)
declare sub dGeomHeightfieldSetHeightfieldData(byval g as dGeomID, byval d as dHeightfieldDataID)
declare function dGeomHeightfieldGetHeightfieldData(byval g as dGeomID) as dHeightfieldDataID
declare sub dClosestLineSegmentPoints(byval a1 as const dReal ptr, byval a2 as const dReal ptr, byval b1 as const dReal ptr, byval b2 as const dReal ptr, byval cp1 as dReal ptr, byval cp2 as dReal ptr)
declare function dBoxTouchesBox(byval _p1 as const dReal ptr, byval R1 as const dReal ptr, byval side1 as const dReal ptr, byval _p2 as const dReal ptr, byval R2 as const dReal ptr, byval side2 as const dReal ptr) as long
declare function dBoxBox(byval p1 as const dReal ptr, byval R1 as const dReal ptr, byval side1 as const dReal ptr, byval p2 as const dReal ptr, byval R2 as const dReal ptr, byval side2 as const dReal ptr, byval normal as dReal ptr, byval depth as dReal ptr, byval return_code as long ptr, byval flags as long, byval contact as dContactGeom ptr, byval skip as long) as long
declare sub dInfiniteAABB(byval geom as dGeomID, byval aabb as dReal ptr)

type dGeomClass
	bytes as long
	collider as function(byval num as long) as function(byval o1 as dGeomID, byval o2 as dGeomID, byval flags as long, byval contact as dContactGeom ptr, byval skip as long) as long
	aabb as sub(byval as dGeomID, byval aabb as dReal ptr)
	aabb_test as function(byval o1 as dGeomID, byval o2 as dGeomID, byval aabb as dReal ptr) as long
	dtor as sub(byval o as dGeomID)
end type

declare function dCreateGeomClass(byval classptr as const dGeomClass ptr) as long
declare function dGeomGetClassData(byval as dGeomID) as any ptr
declare function dCreateGeom(byval classnum as long) as dGeomID
declare sub dSetColliderOverride(byval i as long, byval j as long, byval fn as function(byval o1 as dGeomID, byval o2 as dGeomID, byval flags as long, byval contact as dContactGeom ptr, byval skip as long) as long)
#define _ODE_THREADING_IMPL_H_
type dThreadingThreadPoolID as dxThreadingThreadPool ptr
declare function dThreadingAllocateMultiThreadedImplementation() as dThreadingImplementationID
declare function dThreadingImplementationGetFunctions(byval impl as dThreadingImplementationID) as const dThreadingFunctionsInfo ptr
declare sub dThreadingImplementationShutdownProcessing(byval impl as dThreadingImplementationID)
declare sub dThreadingImplementationCleanupForRestart(byval impl as dThreadingImplementationID)
declare sub dThreadingFreeImplementation(byval impl as dThreadingImplementationID)
declare sub dExternalThreadingServeMultiThreadedImplementation(byval impl as dThreadingImplementationID, byval readiness_callback as sub(byval callback_context as any ptr), byval callback_context as any ptr)
declare function dThreadingAllocateThreadPool(byval thread_count as ulong, byval stack_size as uinteger, byval ode_data_allocate_flags as ulong, byval reserved as any ptr) as dThreadingThreadPoolID
declare sub dThreadingThreadPoolServeMultiThreadedImplementation(byval pool as dThreadingThreadPoolID, byval impl as dThreadingImplementationID)
declare sub dThreadingThreadPoolWaitIdleState(byval pool as dThreadingThreadPoolID)
declare sub dThreadingFreeThreadPool(byval pool as dThreadingThreadPoolID)
#define _ODE_EXPORT_DIF_
declare sub dWorldExportDIF(byval w as dWorldID, byval file as FILE ptr, byval world_name as const zstring ptr)
#define _ODE_VERSION_H_
#define dODE_VERSION "0.13.1"

end extern
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.